吉安感知网项目-前端
罗广辉
6 days ago 070408218b8e07cf4865bea737e3f39620e8cece
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>