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