<template>
|
<el-dialog class="gd-dialog" :close-on-click-modal="false" v-model="visible" title="查看" @closed="visible = false" width="1000px" destroy-on-close>
|
<div class="gd-table-container" v-loading="loading">
|
<div class="gd-table-content gd-table-content-bg">
|
<el-table class="gd-table" :data="list">
|
<el-table-column label="线索缩略图" width="120">
|
<template v-slot="{ row }">
|
<el-image
|
v-if="row.resultUrl"
|
:src="row.resultUrl"
|
:preview-src-list="[row.resultUrl]"
|
fit="cover"
|
style="width: 80px; height: 60px"
|
preview-teleported
|
/>
|
<span v-else>-</span>
|
</template>
|
</el-table-column>
|
<el-table-column prop="resultCode" show-overflow-tooltip label="线索编号" />
|
<el-table-column prop="shootTime" show-overflow-tooltip label="拍摄时间" />
|
<el-table-column label="线索位置" show-overflow-tooltip>
|
<template v-slot="{ row }">
|
{{ formatLocation(row) }}
|
</template>
|
</el-table-column>
|
<el-table-column prop="distributeStatus" show-overflow-tooltip label="线索状态">
|
<template v-slot="{ row }">
|
{{ getDistributeStatusLabel(row.distributeStatus) }}
|
</template>
|
</el-table-column>
|
<el-table-column prop="distributeDeptName" show-overflow-tooltip label="分发部门" />
|
<el-table-column prop="distributeUserName" show-overflow-tooltip label="分发人员" />
|
<el-table-column label="操作" class-name="operation-btns" width="140">
|
<template v-slot="{ row }">
|
<el-link @click="openDistributeDialog(row)" :disabled="row.distributeStatus === 1">
|
转为事件并分发
|
</el-link>
|
</template>
|
</el-table-column>
|
</el-table>
|
</div>
|
</div>
|
|
<template #footer>
|
<el-button color="#F2F3F5" @click="visible = false">关闭</el-button>
|
</template>
|
|
<DistributeDiaLog
|
ref="distributeDialogRef"
|
v-if="distributeDialogVisible"
|
v-model="distributeDialogVisible"
|
@success="getList"
|
/>
|
</el-dialog>
|
</template>
|
|
<script setup>
|
import { ref } from 'vue'
|
import { gdTaskResultListApi } from './achievementApi'
|
import DistributeDiaLog from './DistributeDiaLog.vue'
|
|
const visible = defineModel()
|
const loading = ref(false)
|
const list = ref([])
|
const currentRow = ref(null) // 当前行数据
|
const distributeDialogRef = ref(null)
|
const distributeDialogVisible = ref(false)
|
|
// 分发状态选项
|
const distributeStatusOptions = [
|
{ label: '未分发', value: 0 },
|
{ label: '已分发', value: 1 },
|
{ label: '已驳回', value: 2 },
|
]
|
|
// 获取分发状态标签
|
function getDistributeStatusLabel(value) {
|
const item = distributeStatusOptions.find(item => item.value === value)
|
return item ? item.label : value
|
}
|
|
// 格式化位置信息
|
function formatLocation(row) {
|
if (row.longitude && row.latitude) {
|
return `${row.longitude}, ${row.latitude}`
|
}
|
return row.areaCode || '-'
|
}
|
|
// 获取成果列表
|
async function getList() {
|
if (!currentRow.value?.id) return
|
loading.value = true
|
try {
|
const res = await gdTaskResultListApi({ patrolTaskId: currentRow.value.id })
|
list.value = res?.data?.data ?? []
|
} finally {
|
loading.value = false
|
}
|
}
|
|
// 打开分发弹框
|
function openDistributeDialog(row) {
|
distributeDialogVisible.value = true
|
nextTick(() => {
|
distributeDialogRef.value?.open({
|
row,
|
workOrderId: currentRow.value.workOrderId,
|
})
|
})
|
}
|
|
// 打开弹框
|
async function open({ row } = {}) {
|
currentRow.value = row
|
await getList()
|
}
|
|
defineExpose({ open })
|
</script>
|
|
<style lang="scss" scoped></style>
|