<template>
|
<!-- <div class="header">媒体文件</div>-->
|
<!--搜索栏-->
|
<div class="search-panel-wrapper">
|
<div class="search-part">
|
<a-range-picker :size="searchPanelOptions.size" :format="searchPanelOptions.dateFormat"
|
:valueFormat="searchPanelOptions.valueFormat" v-model:value="timeRangeArr.data"
|
@change="dateChange" style="width: 300px"/>
|
</div>
|
|
<div class="search-part">
|
<a-select v-model:value="subFileTypeArr" allowClear @change="subFileTypeChange" :options="subFileTypeOptions"
|
:maxTagCount="searchPanelOptions.maxTagCount" mode="multiple"
|
:size="searchPanelOptions.size" placeholder="所有类型" style="width: 300px">
|
</a-select>
|
</div>
|
|
<div class="search-part">
|
<a-select v-model:value="payloadArr" allowClear @change="payloadChange" :options="payloadOptions"
|
:maxTagCount="searchPanelOptions.maxTagCount" mode="multiple"
|
:size="searchPanelOptions.size" placeholder="所有负载" style="width: 300px">
|
</a-select>
|
</div>
|
|
<div class="search-part">
|
<a-input-search :size="searchPanelOptions.size" v-model:value="searchQuery.name" @change="inputChange"
|
placeholder="按文件名称搜索" style="width: 300px"/>
|
</div>
|
|
</div>
|
|
<a-spin :spinning="loading" :delay="1000" tip="downloading" size="large">
|
<div class="media-panel-wrapper">
|
<a-table class="media-table" :columns="columns" :data-source="mediaData.data" row-key="fingerprint"
|
:pagination="paginationProp" :scroll="{ x: '100%', y: 600 }" @change="refreshData">
|
<template v-for="col in ['name', 'path']" #[col]="{ text }" :key="col">
|
<a-tooltip :title="text">
|
<a v-if="col === 'name'">{{ text }}</a>
|
<span v-else>{{ text }}</span>
|
</a-tooltip>
|
</template>
|
<template #original="{ text }">
|
{{ text }}
|
</template>
|
<template #action="{ record }">
|
<a-tooltip title="download">
|
<a class="fz18" @click="downloadMedia(record)">
|
<DownloadOutlined/>
|
</a>
|
</a-tooltip>
|
</template>
|
</a-table>
|
</div>
|
</a-spin>
|
</template>
|
|
<script setup lang="ts">
|
import { ref } from '@vue/reactivity'
|
import { TableState } from 'ant-design-vue/lib/table/interface'
|
import { onMounted, reactive } from 'vue'
|
import { IPage } from '../api/http/type'
|
import { ELocalStorageKey } from '../types/enums'
|
import { downloadFile } from '../utils/common'
|
import { downloadMediaFile, getMediaFiles, MediaQueryParam } from '/@/api/media'
|
import { DownloadOutlined } from '@ant-design/icons-vue'
|
import { message, Pagination } from 'ant-design-vue'
|
import { TaskStatus, TaskStatusMap } from '/@/types/task'
|
|
const workspaceId = localStorage.getItem(ELocalStorageKey.WorkspaceId)!
|
const loading = ref(false)
|
|
// 搜索栏配置项
|
const searchPanelOptions = reactive({
|
size: 'large',
|
maxTagCount: 2,
|
dateFormat: 'YYYY-MM-DD',
|
valueFormat: 'YYYY-MM-DD'
|
})
|
|
const subFileTypeOptions = [
|
{ value: 0, label: '普通图片' },
|
{ value: 1, label: '全景图' },
|
]
|
|
const payloadOptions = []
|
|
const timeRangeArr = reactive({
|
data: [] as string[]
|
})
|
const searchQuery = reactive<MediaQueryParam>({})
|
const subFileTypeArr = reactive([])
|
const payloadArr = reactive([])
|
|
const columns = [
|
{
|
title: '文件名称',
|
dataIndex: 'file_name',
|
ellipsis: true,
|
slots: { customRender: 'name' }
|
},
|
// {
|
// title: '文件路径',
|
// dataIndex: 'file_path',
|
// ellipsis: true,
|
// slots: { customRender: 'path' }
|
// },
|
{
|
title: '拍摄负载',
|
dataIndex: 'payload'
|
},
|
{
|
title: '大小',
|
dataIndex: 'size',
|
},
|
// {
|
// title: '拍摄负载',
|
// dataIndex: 'drone'
|
// },
|
// {
|
// title: 'Original',
|
// dataIndex: 'is_original',
|
// slots: { customRender: 'original' }
|
// },
|
{
|
title: '创建时间',
|
dataIndex: 'create_time'
|
},
|
{
|
title: '操作',
|
slots: { customRender: 'action' }
|
}
|
]
|
const body: IPage = {
|
page: 1,
|
total: 0,
|
page_size: 50
|
}
|
const paginationProp = reactive({
|
pageSizeOptions: ['20', '50', '100'],
|
showQuickJumper: true,
|
showSizeChanger: true,
|
pageSize: 50,
|
current: 1,
|
total: 0
|
})
|
|
type Pagination = TableState['pagination']
|
|
interface MediaFile {
|
fingerprint: string,
|
drone: string,
|
payload: string,
|
is_original: string,
|
file_name: string,
|
file_path: string,
|
create_time: string,
|
file_id: string,
|
}
|
|
const mediaData = reactive({
|
data: [] as MediaFile[]
|
})
|
|
onMounted(() => {
|
getFiles()
|
})
|
|
function dateChange (value: any) {
|
searchQuery.startTime = value[0]
|
searchQuery.endTime = value[1]
|
getFiles()
|
}
|
|
function subFileTypeChange (value: any) {
|
searchQuery.subFileType = value.join(',')
|
getFiles()
|
}
|
|
function payloadChange (value: any) {
|
searchQuery.payload = value.join(',')
|
getFiles()
|
}
|
|
function inputChange (searchValue: string) {
|
getFiles()
|
}
|
|
function getFiles () {
|
getMediaFiles(workspaceId, body, searchQuery).then(res => {
|
mediaData.data = res.data.list
|
paginationProp.total = res.data.pagination.total
|
paginationProp.current = res.data.pagination.page
|
console.info(mediaData.data[0])
|
})
|
}
|
|
function refreshData (page: Pagination) {
|
body.page = page?.current!
|
body.page_size = page?.pageSize!
|
getFiles()
|
}
|
|
function downloadMedia (media: MediaFile) {
|
loading.value = true
|
downloadMediaFile(workspaceId, media.file_id).then(res => {
|
if (!res) {
|
return
|
}
|
const data = new Blob([res])
|
downloadFile(data, media.file_name)
|
}).finally(() => {
|
loading.value = false
|
})
|
}
|
|
</script>
|
|
<style lang="scss" scoped>
|
.media-panel-wrapper {
|
width: 100%;
|
padding: 16px;
|
|
.media-table {
|
background: #fff;
|
margin-top: 10px;
|
}
|
|
.action-area {
|
color: $primary;
|
cursor: pointer;
|
}
|
}
|
|
.header {
|
width: 100%;
|
height: 60px;
|
background: #fff;
|
padding: 16px;
|
font-size: 20px;
|
font-weight: bold;
|
text-align: start;
|
color: #000;
|
}
|
|
.search-panel-wrapper {
|
height: 85px;
|
background: #ffffff;
|
padding: 0 20px;
|
display: flex;
|
align-items: center;
|
|
.search-part {
|
margin-right: 10px;
|
}
|
|
}
|
</style>
|