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/ViewDiaLog.vue |   63 +++++++++++++++++++++++++++++++
 1 files changed, 62 insertions(+), 1 deletions(-)

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>

--
Gitblit v1.9.3