From 070408218b8e07cf4865bea737e3f39620e8cece Mon Sep 17 00:00:00 2001
From: 罗广辉 <guanghui.luo@foxmail.com>
Date: Tue, 23 Jun 2026 11:23:39 +0800
Subject: [PATCH] feat: 视频预览,事件名称
---
applications/task-work-order/src/views/orderView/orderManage/clueEvents/DistributeDiaLog.vue | 8 ++++
applications/task-work-order/src/views/orderView/orderManage/clueEvents/ViewDiaLog.vue | 63 +++++++++++++++++++++++++++++++
applications/task-work-order/src/views/orderView/orderManage/inspectionRequest/ViewDiaLog.vue | 8 ++-
3 files changed, 75 insertions(+), 4 deletions(-)
diff --git a/applications/task-work-order/src/views/orderView/orderManage/clueEvents/DistributeDiaLog.vue b/applications/task-work-order/src/views/orderView/orderManage/clueEvents/DistributeDiaLog.vue
index e4b392e..6ee6ffc 100644
--- a/applications/task-work-order/src/views/orderView/orderManage/clueEvents/DistributeDiaLog.vue
+++ b/applications/task-work-order/src/views/orderView/orderManage/clueEvents/DistributeDiaLog.vue
@@ -11,6 +11,11 @@
<el-form class="gd-dialog-form" ref="formRef" :model="formData" :rules="rules" label-width="100px">
<el-row>
<el-col :span="24">
+ <el-form-item label="事件名称" prop="eventName">
+ <el-input class="gd-input" v-model="formData.eventName" placeholder="请输入" clearable />
+ </el-form-item>
+ </el-col>
+ <el-col :span="24">
<el-form-item label="处置部门" prop="disposeDept">
<el-tree-select
class="gd-select"
@@ -58,6 +63,7 @@
// 初始化表单数据
const initForm = () => ({
+ eventName: '', // 事件名称
disposeDept: '', // 处置部门
disposeUser: '', // 工单处置人
})
@@ -76,6 +82,7 @@
// 校验规则
const rules = {
+ eventName: fieldRules(true, 50),
disposeDept: fieldRules(true),
disposeUser: fieldRules(true),
}
@@ -109,6 +116,7 @@
areaCode: currentRow.value.areaCode || '',
disposeDept: formData.value.disposeDept,
disposeUser: formData.value.disposeUser,
+ eventName: formData.value.eventName,
latitude: currentRow.value.latitude || 0,
longitude: currentRow.value.longitude || 0,
resultId: currentRow.value.id,
diff --git a/applications/task-work-order/src/views/orderView/orderManage/clueEvents/ViewDiaLog.vue b/applications/task-work-order/src/views/orderView/orderManage/clueEvents/ViewDiaLog.vue
index 54f3a64..4f34518 100644
--- a/applications/task-work-order/src/views/orderView/orderManage/clueEvents/ViewDiaLog.vue
+++ b/applications/task-work-order/src/views/orderView/orderManage/clueEvents/ViewDiaLog.vue
@@ -12,6 +12,11 @@
style="width: 80px; height: 80px"
preview-teleported
/>
+ <div class="video-btn" v-if="row.attachmentType === 3" @click="videoClick(row)">
+ <el-icon :size="30" color="#fff">
+ <VideoPlay />
+ </el-icon>
+ </div>
</template>
</el-table-column>
<el-table-column prop="resultCode" show-overflow-tooltip label="线索编号" />
@@ -54,6 +59,13 @@
@success="getList"
/>
</el-dialog>
+
+ <VideoPlayDialog
+ ref="videoPlayDialogRef"
+ v-if="VideoShow"
+ v-model="VideoShow"
+ :playUrl="currentVideo.resultUrl"
+ />
</template>
<script setup>
@@ -61,6 +73,8 @@
import { gdTaskResultListApi } from './achievementApi'
import DistributeDiaLog from './DistributeDiaLog.vue'
import { getAiImg } from '@ztzf/utils'
+import { VideoPlay } from '@element-plus/icons-vue'
+import VideoPlayDialog from '@/components/VideoPlayDialog.vue'
const store = useStore()
const requester = computed(() => store.state.user.userInfo?.role_id === '2014158512610869250')
@@ -75,6 +89,8 @@
const currentRow = ref(null) // 当前行数据
const distributeDialogRef = ref(null)
const distributeDialogVisible = ref(false)
+const VideoShow = ref(false)
+const currentVideo = ref({})
// 分发状态选项
const distributeStatusOptions = [
@@ -103,7 +119,7 @@
if (!currentRow.value?.id) return
loading.value = true
try {
- const res = await gdTaskResultListApi({ patrolTaskId: currentRow.value.id,attachmentType: '1,2' })
+ const res = await gdTaskResultListApi({ patrolTaskId: currentRow.value.id})
list.value = await Promise.all(
(res?.data?.data ?? []).map(async item => {
if (item.attachmentType !== 2) return item
@@ -127,6 +143,12 @@
})
}
+// 点击视频
+function videoClick(row) {
+ currentVideo.value = row
+ VideoShow.value = true
+}
+
// 打开弹框
async function open({ row } = {}) {
currentRow.value = row
@@ -141,4 +163,43 @@
color: #c0c4cc;
cursor: not-allowed;
}
+
+.video-btn {
+ width: 80px;
+ height: 80px;
+ position: relative;
+ overflow: hidden;
+ border-radius: 4px;
+ background: linear-gradient(135deg, rgba(76, 52, 255, 0.14), rgba(76, 52, 255, 0) 48%),
+ linear-gradient(180deg, #f4f5ff 0%, #e9ecff 100%);
+ box-shadow: inset 0 0 0 1px rgba(255, 255, 255, 0.7);
+ display: flex;
+ align-items: center;
+ justify-content: center;
+ cursor: pointer;
+
+ &::before {
+ content: '';
+ position: absolute;
+ inset: 0;
+ background-image: linear-gradient(
+ 90deg,
+ rgba(76, 52, 255, 0.05) 0,
+ rgba(76, 52, 255, 0.05) 1px,
+ transparent 1px,
+ transparent 12px
+ );
+ opacity: 0.42;
+ }
+
+ .el-icon {
+ position: relative;
+ z-index: 1;
+ width: 42px;
+ height: 42px;
+ border-radius: 50%;
+ background: rgba(76, 52, 255, 0.72);
+ box-shadow: 0 4px 12px rgba(76, 52, 255, 0.2);
+ }
+}
</style>
diff --git a/applications/task-work-order/src/views/orderView/orderManage/inspectionRequest/ViewDiaLog.vue b/applications/task-work-order/src/views/orderView/orderManage/inspectionRequest/ViewDiaLog.vue
index 14fed00..32f497b 100644
--- a/applications/task-work-order/src/views/orderView/orderManage/inspectionRequest/ViewDiaLog.vue
+++ b/applications/task-work-order/src/views/orderView/orderManage/inspectionRequest/ViewDiaLog.vue
@@ -83,7 +83,9 @@
</div>
<div class="imgBox">
<div
- v-for="item in taskResultList.filter(item1 => item1.resultUrl && [1, 2, 3].includes(item1.attachmentType))"
+ v-for="item in taskResultList.filter(
+ item1 => item1.resultUrl && [1, 2, 3].includes(item1.attachmentType)
+ )"
>
<el-image
v-if="item.attachmentType === 1 || item.attachmentType === 2"
@@ -300,7 +302,7 @@
import CommonCesiumMap from '@/components/map-container/common-cesium-map.vue'
import { gdTaskResultListApi } from '@/views/orderView/orderManage/clueEvents/achievementApi'
import RefuseOrderDialog1 from '@/views/orderView/orderManage/inspectionRequest/RefuseOrderDialog1.vue'
-import { Check } from '@element-plus/icons-vue'
+import { Check, VideoPlay } from '@element-plus/icons-vue'
import { queryAirById, airlineListApi, algorithmGroupedApi } from '@/api/zkxt'
import * as Cesium from 'cesium'
import { useStore } from 'vuex'
@@ -515,7 +517,7 @@
taskResultList.value = await Promise.all(
(res?.data?.data ?? []).map(async item => {
if (item.attachmentType !== 2) return item
- const aiImg = await getAiImg(item.resultUrl,item.geojson)
+ const aiImg = await getAiImg(item.resultUrl, item.geojson)
return { ...item, aiImg }
})
)
--
Gitblit v1.9.3