| | |
| | | <template> |
| | | <!-- <div class="header">计划库</div>--> |
| | | <!--搜索栏--> |
| | | <a-config-provider :locale="zhCN"> |
| | | |
| | | <div class="search-panel-wrapper"> |
| | | <div class="search-part"> |
| | |
| | | </template> |
| | | </a-table> |
| | | </div> |
| | | </a-config-provider> |
| | | |
| | | </template> |
| | | |
| | | <script setup lang="ts"> |
| | | import {reactive, ref} from '@vue/reactivity' |
| | | import {message} from 'ant-design-vue' |
| | | import {TableState} from 'ant-design-vue/lib/table/interface' |
| | | import {computed, onMounted} from 'vue' |
| | | import {IPage} from '/@/api/http/type' |
| | | import zhCN from 'ant-design-vue/es/locale/zh_CN' |
| | | import { reactive, ref } from '@vue/reactivity' |
| | | import { message } from 'ant-design-vue' |
| | | import { TableState } from 'ant-design-vue/lib/table/interface' |
| | | import { computed, onMounted } from 'vue' |
| | | import { IPage } from '/@/api/http/type' |
| | | import 'moment/dist/locale/zh-cn' |
| | | import { |
| | | deleteTask, |
| | |
| | | uploadMediaFileNow, |
| | | TaskQueryParam |
| | | } from '/@/api/wayline' |
| | | import {useMyStore} from '/@/store' |
| | | import {ELocalStorageKey} from '/@/types/enums' |
| | | import {useFormatTask} from './use-format-task' |
| | | import { useMyStore } from '/@/store' |
| | | import { ELocalStorageKey } from '/@/types/enums' |
| | | import { useFormatTask } from './use-format-task' |
| | | import { |
| | | TaskTypeOptions, |
| | | TaskStatus, |
| | |
| | | MediaStatusProgressInfo, |
| | | TaskMediaHighestPriorityProgressInfo |
| | | } from '/@/types/task' |
| | | import {useTaskWsEvent} from './use-task-ws-event' |
| | | import {getErrorMessage} from '/@/utils/error-code/index' |
| | | import {commonColor} from '/@/utils/color' |
| | | import {ExclamationCircleOutlined, UploadOutlined} from '@ant-design/icons-vue' |
| | | import { useTaskWsEvent } from './use-task-ws-event' |
| | | import { getErrorMessage } from '/@/utils/error-code/index' |
| | | import { commonColor } from '/@/utils/color' |
| | | import { ExclamationCircleOutlined, UploadOutlined } from '@ant-design/icons-vue' |
| | | |
| | | const store = useMyStore() |
| | | const workspaceId = localStorage.getItem(ELocalStorageKey.WorkspaceId)! |
| | |
| | | const dockSns = computed(() => store.state.common.dockSns) |
| | | // 监听设备选择 |
| | | watch( |
| | | () => dockSns.value, |
| | | (newVal) => { |
| | | searchQuery.dockSn = newVal |
| | | getPlans() |
| | | } |
| | | () => dockSns.value, |
| | | (newVal) => { |
| | | searchQuery.dockSn = newVal |
| | | getPlans() |
| | | } |
| | | ) |
| | | |
| | | // 搜索栏配置项 |
| | |
| | | title: '计划|实际时间', |
| | | dataIndex: 'duration', |
| | | width: 200, |
| | | slots: {customRender: 'duration'}, |
| | | slots: { customRender: 'duration' }, |
| | | }, |
| | | { |
| | | title: '执行状态', |
| | | key: 'status', |
| | | width: 150, |
| | | slots: {customRender: 'status'} |
| | | slots: { customRender: 'status' } |
| | | }, |
| | | { |
| | | title: '计划名称', |
| | |
| | | title: '航线飞行中失联', |
| | | dataIndex: 'out_of_control_action', |
| | | width: 140, |
| | | slots: {customRender: 'lostAction'}, |
| | | slots: { customRender: 'lostAction' }, |
| | | }, |
| | | { |
| | | title: '操作', |
| | | width: 120, |
| | | slots: {customRender: 'action'} |
| | | slots: { customRender: 'action' } |
| | | } |
| | | ] |
| | | type Pagination = TableState['pagination'] |
| | |
| | | data: [] as Task[] |
| | | }) |
| | | |
| | | const {formatTaskType, formatTaskTime, formatLostAction, formatTaskStatus, formatMediaTaskStatus} = useFormatTask() |
| | | const { formatTaskType, formatTaskTime, formatLostAction, formatTaskStatus, formatMediaTaskStatus } = useFormatTask() |
| | | |
| | | // 设备任务执行进度更新 |
| | | function onTaskProgressWs(data: TaskProgressInfo) { |
| | | const {bid, output} = data |
| | | function onTaskProgressWs (data: TaskProgressInfo) { |
| | | const { bid, output } = data |
| | | if (output) { |
| | | const {status, progress} = output || {} |
| | | const { status, progress } = output || {} |
| | | const taskItem = plansData.data.find(task => task.job_id === bid) |
| | | if (!taskItem) return |
| | | if (status) { |
| | |
| | | } |
| | | |
| | | // 媒体上传进度更新 |
| | | function onTaskMediaProgressWs(data: MediaStatusProgressInfo) { |
| | | const {media_count: mediaCount, uploaded_count: uploadedCount, job_id: jobId} = data |
| | | function onTaskMediaProgressWs (data: MediaStatusProgressInfo) { |
| | | const { media_count: mediaCount, uploaded_count: uploadedCount, job_id: jobId } = data |
| | | if (isNaN(mediaCount) || isNaN(uploadedCount) || !jobId) { |
| | | return |
| | | } |
| | |
| | | taskItem.uploaded_count = uploadedCount |
| | | } |
| | | |
| | | function onoTaskMediaHighestPriorityWS(data: TaskMediaHighestPriorityProgressInfo) { |
| | | const {pre_job_id: preJobId, job_id: jobId} = data |
| | | function onoTaskMediaHighestPriorityWS (data: TaskMediaHighestPriorityProgressInfo) { |
| | | const { pre_job_id: preJobId, job_id: jobId } = data |
| | | const preTaskItem = plansData.data.find(task => task.job_id === preJobId) |
| | | const taskItem = plansData.data.find(task => task.job_id === jobId) |
| | | if (preTaskItem) { |
| | |
| | | } |
| | | } |
| | | |
| | | function getCodeMessage(code: number) { |
| | | function getCodeMessage (code: number) { |
| | | return getErrorMessage(code) + `(code: ${code})` |
| | | } |
| | | |
| | |
| | | getPlans() |
| | | }) |
| | | |
| | | function dateChange(value: any) { |
| | | function dateChange (value: any) { |
| | | searchQuery.startTime = value[0] |
| | | searchQuery.endTime = value[1] |
| | | getPlans() |
| | | } |
| | | |
| | | function inputChange(searchValue: string) { |
| | | function inputChange (searchValue: string) { |
| | | getPlans() |
| | | } |
| | | |
| | | function selectChange(value: any) { |
| | | function selectChange (value: any) { |
| | | getPlans() |
| | | } |
| | | |
| | | function selectMultipleChange(value: any) { |
| | | function selectMultipleChange (value: any) { |
| | | searchQuery.status = value.join(',') |
| | | getPlans() |
| | | } |
| | | |
| | | function getPlans() { |
| | | function getPlans () { |
| | | console.log('计划查询请求参数', searchQuery) |
| | | tableLoading.value = true |
| | | getWaylineJobs(workspaceId, body, searchQuery).then(res => { |
| | |
| | | }) |
| | | } |
| | | |
| | | function refreshData(page: Pagination) { |
| | | function refreshData (page: Pagination) { |
| | | body.page = page?.current! |
| | | body.page_size = page?.pageSize! |
| | | getPlans() |
| | | } |
| | | |
| | | // 删除任务 |
| | | async function onDeleteTask(jobId: string) { |
| | | const {code} = await deleteTask(workspaceId, { |
| | | async function onDeleteTask (jobId: string) { |
| | | const { code } = await deleteTask(workspaceId, { |
| | | job_id: jobId |
| | | }) |
| | | if (code === 0) { |
| | |
| | | } |
| | | |
| | | // 挂起任务 |
| | | async function onSuspendTask(jobId: string) { |
| | | const {code} = await updateTaskStatus(workspaceId, { |
| | | async function onSuspendTask (jobId: string) { |
| | | const { code } = await updateTaskStatus(workspaceId, { |
| | | job_id: jobId, |
| | | status: UpdateTaskStatus.Suspend |
| | | }) |
| | |
| | | } |
| | | |
| | | // 解除挂起任务 |
| | | async function onResumeTask(jobId: string) { |
| | | const {code} = await updateTaskStatus(workspaceId, { |
| | | async function onResumeTask (jobId: string) { |
| | | const { code } = await updateTaskStatus(workspaceId, { |
| | | job_id: jobId, |
| | | status: UpdateTaskStatus.Resume |
| | | }) |
| | |
| | | } |
| | | |
| | | // 立即上传媒体 |
| | | async function onUploadMediaFileNow(jobId: string) { |
| | | const {code} = await uploadMediaFileNow(workspaceId, jobId) |
| | | async function onUploadMediaFileNow (jobId: string) { |
| | | const { code } = await uploadMediaFileNow(workspaceId, jobId) |
| | | if (code === 0) { |
| | | message.success('Upload Media File successfully') |
| | | getPlans() |