From 34d048b470fa0299e5b81c76ba9ae8e28ddc65df Mon Sep 17 00:00:00 2001
From: 罗广辉 <guanghui.luo@foxmail.com>
Date: Tue, 23 Jun 2026 16:48:35 +0800
Subject: [PATCH] feat: app模块
---
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