|
|
|
|
@ -67,33 +67,23 @@
|
|
|
|
|
</el-form-item> |
|
|
|
|
</el-col> |
|
|
|
|
<el-col :span="6"> |
|
|
|
|
<el-form-item label="办理状态"> |
|
|
|
|
<el-form-item label="办理情况"> |
|
|
|
|
<el-select |
|
|
|
|
v-model="query.status" |
|
|
|
|
clearable |
|
|
|
|
placeholder="办理状态" |
|
|
|
|
v-model="query.xxx" |
|
|
|
|
:disabled="true" |
|
|
|
|
> |
|
|
|
|
<el-option value="0" label="未办理"/> |
|
|
|
|
<el-option value="1" label="已办理"/> |
|
|
|
|
<el-option value="-1" label="全部"/> |
|
|
|
|
<el-option value="0" label="自办"/> |
|
|
|
|
<el-option value="1" label="下发"/> |
|
|
|
|
</el-select> |
|
|
|
|
</el-form-item> |
|
|
|
|
</el-col> |
|
|
|
|
<el-col :span="6"> |
|
|
|
|
<el-form-item label="标签"> |
|
|
|
|
<el-select |
|
|
|
|
placeholder="全部" |
|
|
|
|
clearable |
|
|
|
|
v-model="query.tags" |
|
|
|
|
multiple |
|
|
|
|
collapse-tags |
|
|
|
|
> |
|
|
|
|
<el-option |
|
|
|
|
v-for="item in dict.sfssTags" |
|
|
|
|
:key="item.id" |
|
|
|
|
:value="item.dictValue" |
|
|
|
|
:label="item.dictLabel" |
|
|
|
|
/> |
|
|
|
|
</el-select> |
|
|
|
|
<el-form-item label="办结时间"> |
|
|
|
|
<date-time-range-picker-ext |
|
|
|
|
v-model="query.xxxxTime" |
|
|
|
|
:disabled="true" |
|
|
|
|
/> |
|
|
|
|
</el-form-item> |
|
|
|
|
</el-col> |
|
|
|
|
</el-row> |
|
|
|
|
@ -120,10 +110,20 @@
|
|
|
|
|
</el-form-item> |
|
|
|
|
</el-col> |
|
|
|
|
<el-col :span="6"> |
|
|
|
|
<el-form-item label="核查结论" > |
|
|
|
|
<el-select v-model="query.checkStatusList" clearable multiple |
|
|
|
|
style="width: 280px"> |
|
|
|
|
<el-option v-for="item in dict.checkStatus" :value="item.dictValue" :label="item.dictLabel"></el-option> |
|
|
|
|
<el-form-item label="标签"> |
|
|
|
|
<el-select |
|
|
|
|
placeholder="全部" |
|
|
|
|
clearable |
|
|
|
|
v-model="query.tags" |
|
|
|
|
multiple |
|
|
|
|
collapse-tags |
|
|
|
|
> |
|
|
|
|
<el-option |
|
|
|
|
v-for="item in dict.sfssTags" |
|
|
|
|
:key="item.id" |
|
|
|
|
:value="item.dictValue" |
|
|
|
|
:label="item.dictLabel" |
|
|
|
|
/> |
|
|
|
|
</el-select> |
|
|
|
|
</el-form-item> |
|
|
|
|
</el-col> |
|
|
|
|
@ -144,9 +144,73 @@
|
|
|
|
|
</el-form-item> |
|
|
|
|
</el-col> |
|
|
|
|
</el-row> |
|
|
|
|
<!-- <el-row>--> |
|
|
|
|
<!-- <el-col :span="6">--> |
|
|
|
|
<!-- <el-form-item label="核查结论">--> |
|
|
|
|
<!-- <el-select--> |
|
|
|
|
<!-- v-model="query.xxx"--> |
|
|
|
|
<!-- :disabled="true"--> |
|
|
|
|
<!-- >--> |
|
|
|
|
<!-- <el-option value="-1" label="全部"/>--> |
|
|
|
|
<!-- <el-option value="0" label="否"/>--> |
|
|
|
|
<!-- <el-option value="1" label="是"/>--> |
|
|
|
|
<!-- </el-select>--> |
|
|
|
|
<!-- </el-form-item>--> |
|
|
|
|
<!-- </el-col>--> |
|
|
|
|
<!-- <el-col :span="6">--> |
|
|
|
|
<!-- <el-form-item label="涉及对象">--> |
|
|
|
|
<!-- <el-select--> |
|
|
|
|
<!-- v-model="query.xxx"--> |
|
|
|
|
<!-- :disabled="true"--> |
|
|
|
|
<!-- >--> |
|
|
|
|
<!-- <el-option value="-1" label="全部"/>--> |
|
|
|
|
<!-- <el-option value="0" label="否"/>--> |
|
|
|
|
<!-- <el-option value="1" label="是"/>--> |
|
|
|
|
<!-- </el-select>--> |
|
|
|
|
<!-- </el-form-item>--> |
|
|
|
|
<!-- </el-col>--> |
|
|
|
|
<!-- <el-col :span="6">--> |
|
|
|
|
<!-- <el-form-item label="问题核查情况">--> |
|
|
|
|
<!-- <el-input--> |
|
|
|
|
<!-- placeholder="请输入问题核查情况"--> |
|
|
|
|
<!-- v-model="query.xxx"--> |
|
|
|
|
<!-- clearable--> |
|
|
|
|
<!-- :disabled="true"--> |
|
|
|
|
<!-- style="width: 200px"--> |
|
|
|
|
<!-- />--> |
|
|
|
|
<!-- </el-form-item>--> |
|
|
|
|
<!-- </el-col>--> |
|
|
|
|
<!-- <el-col :span="6">--> |
|
|
|
|
<!-- <el-form-item label="涉及人员姓名">--> |
|
|
|
|
<!-- <el-input--> |
|
|
|
|
<!-- placeholder="请输入涉及人员姓名"--> |
|
|
|
|
<!-- v-model="query.xxx"--> |
|
|
|
|
<!-- clearable--> |
|
|
|
|
<!-- :disabled="true"--> |
|
|
|
|
<!-- style="width: 200px"--> |
|
|
|
|
<!-- />--> |
|
|
|
|
<!-- </el-form-item>--> |
|
|
|
|
<!-- </el-col>--> |
|
|
|
|
<!-- </el-row>--> |
|
|
|
|
<!-- <el-row>--> |
|
|
|
|
<!-- <el-col :span="6">--> |
|
|
|
|
<!-- <el-form-item label="涉及人员姓名">--> |
|
|
|
|
<!-- <el-input--> |
|
|
|
|
<!-- placeholder="请输入涉及人员姓名"--> |
|
|
|
|
<!-- v-model="query.xxx"--> |
|
|
|
|
<!-- clearable--> |
|
|
|
|
<!-- :disabled="true"--> |
|
|
|
|
<!-- style="width: 200px"--> |
|
|
|
|
<!-- />--> |
|
|
|
|
<!-- </el-form-item>--> |
|
|
|
|
<!-- </el-col>--> |
|
|
|
|
<!-- </el-row>--> |
|
|
|
|
</el-form> |
|
|
|
|
<div class="mb-25 flex between"> |
|
|
|
|
<div> |
|
|
|
|
<!-- <el-button type="primary" @click="show = true"--> |
|
|
|
|
<!-- >数据导入--> |
|
|
|
|
<!-- </el-button>--> |
|
|
|
|
<el-button type="primary" @click="add()">添加</el-button> |
|
|
|
|
<el-button type="primary" @click="handleExport">数据导出</el-button> |
|
|
|
|
</div> |
|
|
|
|
@ -162,7 +226,7 @@
|
|
|
|
|
</div> |
|
|
|
|
</header> |
|
|
|
|
<div class="table-container" v-loading="loading"> |
|
|
|
|
<el-table :data="list" @click="onHeaderDblClick"> |
|
|
|
|
<el-table :data="list"> |
|
|
|
|
<el-table-column type="expand" v-if="false"> |
|
|
|
|
<template #default="{ row }"> |
|
|
|
|
<div class="row mt-10"> |
|
|
|
|
@ -246,11 +310,6 @@
|
|
|
|
|
<el-table-column label="办理情况" width="100" prop="xxx" v-if="false"/> |
|
|
|
|
<el-table-column label="业务类别" width="100" prop="businessTypeName"/> |
|
|
|
|
<el-table-column label="业务类别Code" width="100" prop="businessTypeCode" v-if="false"/> |
|
|
|
|
<el-table-column label="核查结论" width="140" prop="checkStatus" show-overflow-tooltip> |
|
|
|
|
<template #default="{ row }"> |
|
|
|
|
{{ getDictLabel(dict.checkStatus, row.checkStatus) }} |
|
|
|
|
</template> |
|
|
|
|
</el-table-column> |
|
|
|
|
<el-table-column label="状态" prop="status" width="100"> |
|
|
|
|
<template #default="{ row }"> |
|
|
|
|
<span :style="row.status === '0' ? 'color: red' : ''"> |
|
|
|
|
@ -335,9 +394,6 @@
|
|
|
|
|
<el-button @click="negativeVerifySfssDailog = false">取消</el-button> |
|
|
|
|
<el-button type="primary" @click="handleSubmit" :loading="submitLoading" :disabled="submitLoading">提交 |
|
|
|
|
</el-button> |
|
|
|
|
<el-button type="primary" @click="handleSaveInvolve" :loading="saveLoading"> |
|
|
|
|
临时保存 |
|
|
|
|
</el-button> |
|
|
|
|
</div> |
|
|
|
|
</template> |
|
|
|
|
|
|
|
|
|
@ -360,7 +416,7 @@ import useCatchStore from "@/stores/modules/catch";
|
|
|
|
|
import { |
|
|
|
|
addComplaintCollection, addComplaintCollectionBlame, |
|
|
|
|
delComplaintCollection, exportData, |
|
|
|
|
getComplaintCollectionPage, handlerData, saveInvolveJson, |
|
|
|
|
getComplaintCollectionPage, handlerData, |
|
|
|
|
updateComplaintCollection |
|
|
|
|
} from "@/api/data/complaintCollection.ts"; |
|
|
|
|
import Complaint_detail from "@/components/data/complaint_detail.vue"; |
|
|
|
|
@ -760,29 +816,10 @@ const sleep = (ms) => new Promise((resolve) => setTimeout(resolve, ms));
|
|
|
|
|
const handleAction = async (row) => { |
|
|
|
|
submitLoading.value = true |
|
|
|
|
try { |
|
|
|
|
// 1️⃣ 基础信息 |
|
|
|
|
// 先设置基础信息 |
|
|
|
|
negativeSfss.value.currentRow = JSON.parse(JSON.stringify(row)) |
|
|
|
|
|
|
|
|
|
// 2️⃣ 后端回显数据 |
|
|
|
|
const res = await handlerData({ id: row.id }) |
|
|
|
|
const data = res?.data ?? res ?? {} |
|
|
|
|
|
|
|
|
|
// 3️⃣ 解析 involveJson |
|
|
|
|
let involveObj = {} |
|
|
|
|
if (data.involveJson) { |
|
|
|
|
try { |
|
|
|
|
involveObj = JSON.parse(data.involveJson) |
|
|
|
|
} catch (e) { |
|
|
|
|
console.error("involveJson 解析失败", e) |
|
|
|
|
} |
|
|
|
|
} |
|
|
|
|
|
|
|
|
|
// 4️⃣ 合并到 negative(🔥关键) |
|
|
|
|
Object.assign(negativeSfss.value, { |
|
|
|
|
...data, |
|
|
|
|
...involveObj, // ⭐ blames / blameLeaders / handlePolices |
|
|
|
|
}) |
|
|
|
|
|
|
|
|
|
const res = await handlerData({id: row.id}) |
|
|
|
|
Object.assign(negativeSfss.value, res?.data ?? res) |
|
|
|
|
negativeVerifySfssDailog.value = true |
|
|
|
|
} catch (e) { |
|
|
|
|
console.error("加载办理数据失败", e) |
|
|
|
|
@ -812,54 +849,6 @@ const handleSubmit = async () => {
|
|
|
|
|
submitLoading.value = false |
|
|
|
|
} |
|
|
|
|
} |
|
|
|
|
// 办理保存 |
|
|
|
|
const saveLoading = ref(false) |
|
|
|
|
const handleSaveInvolve = async () => { |
|
|
|
|
if (saveLoading.value) return |
|
|
|
|
saveLoading.value = true |
|
|
|
|
try { |
|
|
|
|
// ✅ 关键:让 el-input / el-select / 自定义组件把最后一次变更刷进 model |
|
|
|
|
await nextTick() |
|
|
|
|
|
|
|
|
|
// ✅ 再取一次最新数据 |
|
|
|
|
const formData = negativeVerifySfssRef.value.getData() |
|
|
|
|
|
|
|
|
|
// ✅ 关键:深拷贝 + 去代理,避免 Proxy/引用带来的“看起来旧值” |
|
|
|
|
const plain = JSON.parse(JSON.stringify(toRaw(formData))) |
|
|
|
|
|
|
|
|
|
const payload = { |
|
|
|
|
blames: plain.blames || [], |
|
|
|
|
blameLeaders: plain.blameLeaders || [], |
|
|
|
|
files: plain.files || [], |
|
|
|
|
} |
|
|
|
|
|
|
|
|
|
await saveInvolveJson({ |
|
|
|
|
complaintId: plain.complaintId, |
|
|
|
|
|
|
|
|
|
// 表字段 |
|
|
|
|
checkStatusCode: plain.checkStatusCode, |
|
|
|
|
checkStatusName: plain.checkStatusName, |
|
|
|
|
checkStatusDesc: plain.checkStatusDesc, |
|
|
|
|
accountabilityTarget: plain.accountabilityTarget, |
|
|
|
|
involveDepartId: plain.involveDepartId, |
|
|
|
|
involveDepartName: plain.involveDepartName, |
|
|
|
|
completionStatus: plain.completionStatus, |
|
|
|
|
publicRecognition: plain.publicRecognition, |
|
|
|
|
caseNumber: plain.caseNumber, |
|
|
|
|
|
|
|
|
|
// JSON |
|
|
|
|
involveJson: JSON.stringify(payload), |
|
|
|
|
}) |
|
|
|
|
feedback.msgSuccess("操作成功") |
|
|
|
|
negativeVerifySfssDailog.value = false |
|
|
|
|
getList() |
|
|
|
|
} catch (e) { |
|
|
|
|
console.error(e) |
|
|
|
|
feedback.notifyError("操作失败") |
|
|
|
|
} finally { |
|
|
|
|
saveLoading.value = false |
|
|
|
|
} |
|
|
|
|
} |
|
|
|
|
|
|
|
|
|
|
|
|
|
|
const negativeSfss = ref({ |
|
|
|
|
@ -873,18 +862,6 @@ const negativeSfss = ref({
|
|
|
|
|
handlePolices: [{}], |
|
|
|
|
}); |
|
|
|
|
provide('negative', negativeSfss) |
|
|
|
|
watch(negativeVerifySfssDailog, (open) => { |
|
|
|
|
if (!open) { |
|
|
|
|
negativeSfss.value = { |
|
|
|
|
currentRow: {}, |
|
|
|
|
blames: [], |
|
|
|
|
blameLeaders: [], |
|
|
|
|
handlePolices: [{}], |
|
|
|
|
files: [], |
|
|
|
|
} |
|
|
|
|
} |
|
|
|
|
}) |
|
|
|
|
|
|
|
|
|
// endregion |
|
|
|
|
|
|
|
|
|
|
|
|
|
|
@ -897,15 +874,6 @@ const handleWatchDetail = async (row) => {
|
|
|
|
|
} |
|
|
|
|
// endregion |
|
|
|
|
|
|
|
|
|
// region 自己排查相关 |
|
|
|
|
const onHeaderDblClick = () => { |
|
|
|
|
const rows = JSON.parse(JSON.stringify(toRaw(list.value || []))) |
|
|
|
|
console.groupCollapsed(`[DEBUG] list 全量(${rows.length}条)`) |
|
|
|
|
console.log('raw:', rows) |
|
|
|
|
console.groupEnd() |
|
|
|
|
} |
|
|
|
|
// endregion |
|
|
|
|
|
|
|
|
|
// region 导出相关 |
|
|
|
|
const handleExport = async () => { |
|
|
|
|
let body = { |
|
|
|
|
@ -913,10 +881,14 @@ const handleExport = async () => {
|
|
|
|
|
} |
|
|
|
|
await exportData(body); |
|
|
|
|
} |
|
|
|
|
// endregion |
|
|
|
|
</script> |
|
|
|
|
|
|
|
|
|
|
|
|
|
|
<style> |
|
|
|
|
.widthClass { |
|
|
|
|
min-width: 50% !important; |
|
|
|
|
} |
|
|
|
|
</style> |
|
|
|
|
|
|
|
|
|
<style lang="scss" scoped> |
|
|
|
|
.el-form-item .el-form-item { |
|
|
|
|
|