数字督察一体化平台-前端
You can not select more than 25 topics Topics must start with a letter or number, can include dashes ('-') and can be up to 35 characters long.
 
 
 
 

1485 lines
58 KiB

<template>
<div class="container">
<header>
<transition name="fade-slide">
<el-form
v-show="!expanded"
class="simple-form"
>
<el-row class="search-flex-row">
<el-col>
<el-form-item label="问题录入时间" style="width: 450px">
<date-time-range-picker-ext
v-model="query.crtTime"
/>
</el-form-item>
</el-col>
<el-col>
<el-input
placeholder="事情简要描述"
v-model="query.thingDesc"
clearable
style="width: 400px"
/>
</el-col>
<el-col>
<el-tree-select
:data="dictProblemSources"
:props="{ value: 'id' }"
node-key="id"
v-model="query.problemSourcesCode"
clearable
filterable
multiple
collapse-tags
style="width: 200px"
placeholder="问题来源"
/>
</el-col>
<el-col>
<el-select
style="width: 200px"
placeholder="专项督察"
clearable
v-model="query.specialSupervision"
>
<el-option
v-for="item in dict.specialSupervision"
:key="item.id"
:label="item.dictLabel"
:value="item.dictValue"
/>
</el-select>
</el-col>
<el-col>
<div style="width: 200px">
<depart-tree-select
v-model="query.handleDepartId"
placeholder="办理单位"
/>
</div>
</el-col>
<el-col>
<div class="flex gap-4" style="height: 32px">
<el-select
v-model="query.responderKey"
style="width: 120px"
@change="delete query.responderValue"
>
<el-option value="name" label="姓名" />
<el-option value="phone" label="电话" />
</el-select>
<el-input
placeholder="投诉反映人"
v-model="query.responderValue"
clearable
style="width: 325px"
/>
</div>
</el-col>
<el-col>
<el-select
style="width: 193px"
placeholder="办理状态"
clearable
v-model="query.processingStatus"
multiple
collapse-tags
>
<el-option
v-for="item in dict.processingStatus"
:key="item.id"
:label="item.dictLabel"
:value="item.dictValue"
/>
</el-select>
</el-col>
<el-col >
<problem-type-select
style="width: 193px"
placeholder="问题类型"
v-model="query.threeLevelCode"
@change="(node) =>handleChangeProblem(node, problem)"
/>
</el-col>
<el-col>
<el-select
style="width: 200px"
placeholder="申请延期"
clearable
v-model="query.extensionFlag"
>
<el-option label="已申请" :value="true" />
<el-option label="未申请" :value="false" />
</el-select>
</el-col>
<el-col>
<el-select
style="width: 200px"
placeholder="核查结论"
clearable
v-model="query.checkStatusCode"
multiple
collapse-tags
>
<el-option
v-for="item in dict.checkStatus"
:key="item.id"
:label="item.dictLabel"
:value="item.dictValue"
/>
</el-select>
</el-col>
<el-col>
<div style="width: 200px">
<el-select
placeholder="处理结果"
v-model="query.handleResultCode"
multiple
@change="(val) => handleChangeResultCode(item, val) "
clearable
>
<el-option
v-for="dictItem in dict.handleResult"
:key="dictItem.dictCode"
:value="dictItem.dictValue"
:label="dictItem.dictLabel"
/>
</el-select>
</div>
</el-col>
</el-row>
</el-form>
</transition>
<transition name="fade-slide">
<div v-show="expanded" class="form-collapse-wrapper">
<el-form
:label-width="120"
class="full-form"
>
<el-row>
<el-col :span="6">
<el-form-item label="问题发现时间">
<date-time-range-picker-ext
v-model="query.discoveryTime"
/>
</el-form-item>
</el-col>
<el-col :span="6">
<el-form-item label="问题发生时间">
<date-time-range-picker-ext
v-model="query.happenTime"
/>
</el-form-item>
</el-col>
<el-col :span="6">
<el-form-item label="问题录入时间">
<date-time-range-picker-ext
v-model="query.crtTime"
/>
</el-form-item>
</el-col>
<!-- <el-col :span="6">-->
<!-- <el-form-item label="报告时间" style="width: 360px; margin-bottom: 0;">-->
<!-- <el-date-picker-->
<!-- v-model="query.reportDateRange"-->
<!-- type="daterange"-->
<!-- unlink-panels-->
<!-- range-separator="至"-->
<!-- start-placeholder="开始日期"-->
<!-- end-placeholder="结束日期"-->
<!-- value-format="YYYY-MM-DD"-->
<!-- format="YYYY-MM-DD"-->
<!-- style="width: 100%;"-->
<!-- />-->
<!-- </el-form-item>-->
<!-- </el-col>-->
</el-row>
<div class="form-row flex">
<label class="text-center">问题信息</label>
<div class="flex wrap query-box">
<el-input
placeholder="问题编号 / 样本源头编号"
v-model="query.originId"
clearable
style="width: 200px"
/>
<el-input
placeholder="涉及案件 / 警情编号"
v-model="query.caseNumber"
clearable
style="width: 200px"
/>
<el-input
placeholder="事情简要描述"
v-model="query.thingDesc"
clearable
style="width: 220px"
/>
<el-select
style="width: 146px"
placeholder="业务类别"
clearable
v-model="query.businessTypeCode"
>
<el-option
v-for="item in dict.businessType"
:key="item.id"
:label="item.dictLabel"
:value="item.dictValue"
/>
</el-select>
<el-tree-select
:data="dictProblemSources"
:props="{ value: 'id' }"
node-key="id"
v-model="query.problemSourcesCode"
clearable
filterable
multiple
collapse-tags
style="width: 140px"
placeholder="问题来源"
/>
<el-select
style="width: 146px"
placeholder="专项督察"
clearable
v-model="query.specialSupervision"
>
<el-option
v-for="item in dict.specialSupervision"
:key="item.id"
:label="item.dictLabel"
:value="item.dictValue"
/>
</el-select>
<el-input
placeholder="通报期数"
style="width: 146px"
v-model="query.reportNumber"
clearable
/>
<problem-type-select
multiple
style="width: 150px"
placeholder="问题类型"
v-model="query.threeLevelCode"
@change="(node) =>handleChangeProblem(node, problem)"
/>
</div>
</div>
<div class="form-row flex">
<label class="text-center">核查情况</label>
<div class="flex wrap query-box">
<div style="width: 200px">
<depart-tree-select
v-model="query.involveDepartId"
placeholder="涉及单位"
/>
</div>
<div style="width: 200px">
<depart-tree-select
v-model="query.handleDepartId"
placeholder="办理单位"
/>
</div>
<el-select
style="width: 160px"
placeholder="核查结论"
clearable
v-model="query.checkStatusCode"
multiple
collapse-tags
>
<el-option
v-for="item in dict.checkStatus"
:key="item.id"
:label="item.dictLabel"
:value="item.dictValue"
/>
</el-select>
<el-select
style="width: 120px"
placeholder="是否整改"
clearable
v-model="query.isRectifyCode"
>
<el-option
v-for="item in dict.isRectify"
:key="item.id"
:label="item.dictLabel"
:value="item.dictValue"
/>
</el-select>
<div class="flex gap-4">
<el-select
v-model="query.blameKey"
style="width: 90px"
@change="delete query.blameValue"
>
<el-option value="name" label="姓名" />
<el-option value="empNo" label="警号" />
<el-option value="idCode" label="身份证" />
</el-select>
<el-input
placeholder="涉及人员"
v-model="query.blameValue"
clearable
style="width: 150px"
/>
</div>
<div style="width: 120px">
<el-select
placeholder="处理结果"
v-model="query.handleResultCode"
multiple
@change="(val) => handleChangeResultCode(item, val) "
clearable
>
<el-option
v-for="dictItem in dict.handleResult"
:key="dictItem.dictCode"
:value="dictItem.dictValue"
:label="dictItem.dictLabel"
/>
</el-select>
</div>
<div style="width: 145px">
<el-select
placeholder="审批超时"
clearable
collapse-tags
collapse-tags-tooltip
multiple
v-model="query.approvalTimeoutStatus"
>
<el-option label="市局审批超时" value="city_timeout" />
<el-option label="市局审批未超时" value="city_normal" />
<el-option label="分局审批超时" value="branch_timeout" />
<el-option label="分局审批未超时" value="branch_normal" />
</el-select>
</div>
</div>
</div>
<div class="form-row flex">
<label class="text-center">其他选项</label>
<div class="flex wrap query-box">
<el-select
style="width: 200px"
placeholder="流程阶段"
clearable
v-model="query.flowKey"
>
<el-option
v-for="item in flowNodes"
:key="item.flowKey"
:label="item.flowName"
:value="item.flowKey"
/>
</el-select>
<el-select
style="width: 200px"
placeholder="审批阶段"
clearable
v-model="query.approvalFlow"
>
<el-option
v-for="item in dict.approvalFlow"
:key="item.id"
:label="item.dictLabel"
:value="item.dictValue"
/>
</el-select>
<el-select
style="width: 160px"
placeholder="办理状态"
clearable
v-model="query.processingStatus"
multiple
collapse-tags
>
<el-option
v-for="item in dict.processingStatus"
:key="item.id"
:label="item.dictLabel"
:value="item.dictValue"
/>
</el-select>
<el-select
style="width: 120px"
placeholder="是否超时"
clearable
v-model="query.timeoutFlag"
>
<el-option label="未超时" :value="false" />
<el-option label="已超时" :value="true" />
</el-select>
<div class="flex gap-4" style="height: 32px">
<el-select
v-model="query.responderKey"
style="width: 90px"
@change="delete query.responderValue"
>
<el-option value="name" label="姓名" />
<el-option value="phone" label="电话" />
</el-select>
<el-input
placeholder="投诉反映人"
v-model="query.responderValue"
clearable
style="width: 150px"
/>
</div>
<el-select
style="width: 120px"
placeholder="申请延期"
clearable
v-model="query.extensionFlag"
>
<el-option label="已申请" :value="true" />
<el-option label="未申请" :value="false" />
</el-select>
<el-select
style="width: 146px"
placeholder="下发单位的层级"
clearable
v-model="query.crtDepartLevel"
>
<el-option label="市局下发" :value="0" />
<el-option label="二级机构下发" :value="2" />
</el-select>
<depart-tree-select
style="width: 146px"
v-model="query.issuingDepartId"
placeholder="下发单位"
/>
</div>
</div>
</el-form>
</div>
</transition>
<div class="toggle-area">
<el-button
type="primary"
link
@click="expanded = !expanded"
>
{{ expanded ? '收起' : '展开查看更多搜索' }}
<el-icon class="ml-4">
<ArrowUp v-if="expanded" />
<ArrowDown v-else />
</el-icon>
</el-button>
</div>
<div class="flex between mt-20 mb-26">
<div class="flex gap-4">
<el-button type="primary" @click="handleExport"
>数据导出</el-button
>
<el-button type="primary" @click="handleReportGenerate"
v-if="userStore.user?.userName === 'oumyye'"
>报告生成</el-button
>
</div>
<div>
<el-switch
v-model="remainingTimeFlag"
inline-prompt
active-text="显示流程限时"
inactive-text="隐藏流程限时"
:active-value="true"
:inactive-value="false"
class="mr-20"
/>
<el-button type="primary" @click="getList">
<template #icon
><icon name="el-icon-Search"
/></template>
查询</el-button
>
<el-button @click="reset">重置</el-button>
</div>
</div>
</header>
<main>
<div class="table-container" v-loading="loading">
<el-table
:data="list"
@sort-change="handleTableSort"
ref="tableRef"
>
<el-table-column type="expand">
<template #default="{ row }">
<div class="row mt-10">
<div class="col col-6">
<label>样本源头编号</label>
<span>{{ row.originId }}</span>
</div>
<div class="col col-6">
<label>问题发现时间</label>
<span>{{ row.discoveryTime }}</span>
</div>
<div class="col col-6">
<label>问题发生时间</label>
<span>{{ row.happenTime || "/" }}</span>
</div>
</div>
<div class="row mt-10">
<div class="col col-6">
<label>问题来源</label>
<span>{{ row.problemSources }}</span>
</div>
<div class="col col-6">
<label>业务类别</label>
<span>{{ row.businessTypeName }}</span>
</div>
<div class="col col-12">
<label>涉嫌问题</label>
<span>{{
getInvolveProblem(
row.involveProblem,
dict.suspectProblem
) || "/"
}}</span>
</div>
</div>
<div class="row mt-10">
<div class="col col-6" v-if="row.responderName">
<label>投诉反映人</label>
<span>{{ row.responderName }}</span>
</div>
<div class="col col-6" v-if="row.contactPhone">
<label>联系电话</label>
<span>{{ row.contactPhone }}</span>
</div>
</div>
<div class="row mt-10">
<div class="col col-6">
<label>涉及警种</label>
<span>{{ row.policeTypeName }}</span>
</div>
<div class="col col-6">
<label>涉及单位</label>
<span>{{
row.involveDepartName || "/"
}}</span>
</div>
</div>
<div class="row mt-10">
<div class="col col-24">
<label>事情简要描述</label>
<span>{{ row.thingDesc }}</span>
</div>
</div>
</template>
</el-table-column>
<el-table-column
label="问题录入时间"
prop="crtTime"
width="150"
sortable="custom"
/>
<el-table-column
label="问题发现时间"
prop="discoveryTime"
width="150"
sortable="custom"
/>
<el-table-column
label="问题来源"
prop="problemSources"
width="110"
show-overflow-tooltip
/>
<el-table-column
label="业务类别"
prop="businessTypeName"
width="110"
/>
<el-table-column
label="问题内容"
prop="thingDesc"
show-overflow-tooltip
/>
<el-table-column label="办理单位" show-overflow-tooltip>
<template #default="{ row }">
<span
>{{ row.handleSecondDepartName
}}{{ row.handleThreeDepartName }}</span
>
</template>
</el-table-column>
<el-table-column
label="核查结论"
prop="checkStatusName"
width="100"
align="center"
/>
<el-table-column
label="流程限时"
width="150"
align="center"
v-if="remainingTimeFlag"
>
<template #default="{ row }">
<countdown
:time="row.remainingDuration"
v-if="
row.remainingDuration &&
row.processingStatus !==
ProcessingStatus.COMPLETED
"
/>
<el-tag
v-else-if="row.handleTimeout"
type="danger"
effect="dark"
>办结超时
{{ formatTimeText(row.handleTimeout) }}</el-tag
>
</template>
</el-table-column>
<el-table-column label="办理状态" width="110">
<template #default="{ row }">
<el-tag
:type="
row.processingStatus ===
ProcessingStatus.COMPLETED
? 'success'
: 'primary'
"
v-if="row.processingStatus"
>{{
getDictLable(
dict.processingStatus,
row.processingStatus
)
}}</el-tag
>
</template>
</el-table-column>
<el-table-column
label="当前处理对象"
prop="currentProcessingObject"
show-overflow-tooltip
>
<template #default="{ row }">
<span
v-if="
row.processingStatus ===
ProcessingStatus.COMPLETED
"
>无</span
>
<span v-else>{{
row.currentProcessingObject
}}</span>
</template>
</el-table-column>
<el-table-column
label="下发单位"
prop="issuingDepartName"
width="100"
align="center"
show-overflow-tooltip
/>
<!-- <el-table-column-->
<!-- label="二级审批时长"-->
<!-- width="120"-->
<!-- align="center"-->
<!-- >-->
<!-- <template #default="{ row }">-->
<!-- <span>{{ formatTimeText(row.secondApprovalTime) }}</span>-->
<!-- </template>-->
<!-- </el-table-column>-->
<!-- <el-table-column-->
<!-- label="市局审批时长"-->
<!-- width="120"-->
<!-- align="center"-->
<!-- >-->
<!-- <template #default="{ row }">-->
<!-- <span>{{ formatTimeText(row.firstApproveTime) }}</span>-->
<!-- </template>-->
<!-- </el-table-column>-->
<el-table-column label="操作" width="160">
<template #default="{ row }">
<div class="flex v-center">
<el-button
type="primary"
link
@click="handleAction(row)"
>详情</el-button
>
<el-dropdown
trigger="click"
placement="bottom-start"
class="ml-10"
>
<el-button type="primary" link
>更多操作</el-button
>
<template #dropdown>
<el-dropdown-menu>
<el-dropdown-item>
<el-button
type="primary"
text
@click="handleEdit(row)"
v-perms="['negative:edit']"
>编辑</el-button
>
</el-dropdown-item>
<el-dropdown-item>
<el-button
type="danger"
text
@click="handleDel(row)"
v-perms="['negative:del']"
>删除</el-button
>
</el-dropdown-item>
<el-dropdown-item>
<el-button
type="primary"
text
@click="
handleTransferTodo(row)
"
v-perms="[
'negative:transferTodo',
]"
v-if="
row.processingStatus ===
ProcessingStatus.COMPLETED
"
>转待办</el-button
>
</el-dropdown-item>
<el-dropdown-item>
<el-button
type="primary"
text
v-if="
row.processingStatus ===
ProcessingStatus.COMPLETED
"
@click="
handleSpotCheck(row)
"
v-perms="['negative:spotCheck']"
>抽查</el-button
>
</el-dropdown-item>
</el-dropdown-menu>
</template>
</el-dropdown>
</div>
</template>
</el-table-column>
</el-table>
</div>
<div class="flex end mt-8">
<el-pagination
@size-change="getList"
@current-change="getList"
:page-sizes="[10, 20, 50, 100]"
v-model:page-size="query.size"
v-model:current-page="query.current"
layout="total, sizes, prev, pager, next"
:total="total"
>
</el-pagination>
</div>
</main>
</div>
<negative-dialog
v-model="show"
:id="activeNegativeId"
@close="show = false"
ref="negativeDialogRef"
/>
<el-dialog v-model="editShow" title="问题编辑" width="900px">
<el-form label-width="148" :model="formData" ref="formRef">
<div style="margin-bottom: 80px">
<el-row>
<el-col :span="12">
<el-form-item
label="问题来源"
prop="problemSourcesCode"
:rules="{
required: true,
message: '请选择问题来源',
trigger: ['blur'],
}"
>
<dict-select
name="problemSources"
v-model="formData.problemSourcesCode"
@change="
(nodeData) =>
(formData.problemSources =
nodeData.label)
"
/>
</el-form-item>
</el-col>
<el-col :span="12">
<el-form-item
label="业务类别"
prop="businessTypeCode"
:rules="{
required: true,
message: '请选择业务类别',
trigger: ['blur'],
}"
>
<el-select
v-model="formData.businessTypeCode"
@change="
(val) =>
(formData.businessTypeName =
dict.businessType.filter(
(item) => item.dictValue === val
)[0].dictLabel)
"
>
<el-option
v-for="item in dict.businessType"
:key="item.id"
:label="item.dictLabel"
:value="item.dictValue"
/>
</el-select>
</el-form-item>
</el-col>
</el-row>
<el-row>
<el-col
:span="12"
v-if="
formData.problemSourcesCode === ProblemSources.ZXDC
"
>
<el-form-item
label="专项督察"
prop="specialSupervision"
:rules="{
required: true,
message: '请选择专项督察',
trigger: ['blur'],
}"
>
<el-select
v-model="formData.specialSupervision"
clearable
>
<el-option
v-for="item in dict.specialSupervision"
:key="item.id"
:label="item.dictLabel"
:value="item.dictValue"
/>
</el-select>
</el-form-item>
</el-col>
<el-col
:span="12"
v-if="
formData.problemSourcesCode ===
ProblemSources.ZXDC ||
formData.problemSourcesCode === ProblemSources.XCDC
"
>
<el-form-item
label="通报期数"
prop="reportNumber"
:rules="{
required: true,
message: '请选择通报期数',
trigger: ['blur'],
}"
>
<!-- <el-input-->
<!-- placeholder="请输入"-->
<!-- v-model="formData.reportNumber"-->
<!-- />-->
<el-select v-model="reportData"
filterable
remote
reserve-keyword
placeholder="请选择通报期数"
:remote-method="getReportListDataFun"
:loading="reportLoading"
>
<el-option
v-for="(item,id) in reportList"
:key="id"
:label="item.reportName"
:value="item.id"
/>
</el-select>
</el-form-item>
</el-col>
</el-row>
<el-row>
<el-col :span="12">
<el-form-item
label="涉及案件/警情编号"
prop="caseNumber"
>
<el-input
v-model="formData.caseNumber"
placeholder="请输入"
/>
</el-form-item>
</el-col>
<el-col :span="12">
<el-form-item
label="涉嫌问题"
prop="involveProblem"
:rules="{
required: true,
message: '请选择涉嫌问题',
trigger: ['blur'],
}"
>
<el-select
v-model="formData.involveProblem"
multiple
clearable
>
<el-option
v-for="item in dict.suspectProblem"
:key="item.id"
:label="item.dictLabel"
:value="item.dictValue"
/>
</el-select>
</el-form-item>
</el-col>
<el-col :span="12">
<el-form-item
label="问题涉及单位"
prop="involveDepartId"
:rules="{
required: true,
message: '请选择问题涉及单位',
trigger: ['blur'],
}"
>
<depart-tree-select
v-model="formData.involveDepartId"
:check-strictly="true"
@node-click="
(row) =>
(formData.involveDepartName =
row.shortName)
"
/>
</el-form-item>
</el-col>
<el-col :span="12">
<el-form-item-ext
label="涉及警种"
content="囊括了市局除分县市局以外的所有业务警种,便于后期统计分析业务条线的问题。"
prop="policeType"
>
<el-select
v-model="formData.policeType"
@change="
(val) =>
(formData.policeTypeName =
dict.policeType.filter(
(item) => item.dictValue === val
)[0].dictLabel)
"
clearable
>
<el-option
v-for="item in dict.policeType"
:key="item.id"
:label="item.dictLabel"
:value="item.dictValue"
/>
</el-select>
</el-form-item-ext>
</el-col>
</el-row>
<el-row
v-if="
ProblemSources_XFTS.includes(
formData.problemSourcesCode
)
"
>
<el-col :span="12">
<el-form-item label="投诉反映人" prop="responderName">
<el-input
placeholder="请输入"
v-model="formData.responderName"
/>
</el-form-item>
</el-col>
<el-col :span="12">
<el-form-item label="联系电话" prop="contactPhone">
<el-input
v-model="formData.contactPhone"
placeholder="请输入"
/>
</el-form-item>
</el-col>
</el-row>
<el-row>
<el-col :span="12">
<el-form-item
label="问题发现时间"
prop="discoveryTime"
:rules="{
required: true,
message: '请选择问题发现时间',
trigger: ['blur'],
}"
>
<el-date-picker
v-model="formData.discoveryTime"
type="datetime"
placeholder="请选择"
value-format="YYYY-MM-DD HH:mm"
time-format="HH:mm"
style="width: 100%"
/>
</el-form-item>
</el-col>
<el-col :span="12">
<el-form-item label="问题发生时间" prop="happenTime">
<el-date-picker
v-model="formData.happenTime"
type="datetime"
placeholder="请选择"
value-format="YYYY-MM-DD HH:mm"
time-format="HH:mm"
style="width: 100%"
/>
</el-form-item>
</el-col>
</el-row>
<el-form-item label="督察报告附件" v-if="reportFiles?.length > 0">
<file-list v-model:files="reportFiles" :removeEnable="false" />
</el-form-item>
<el-form-item
label="事情简要描述"
prop="thingDesc"
:rules="{
required: true,
message: '请输入事情简要描述',
trigger: ['blur'],
}"
>
<el-input
type="textarea"
placeholder="请输入"
v-model="formData.thingDesc"
:autosize="{ minRows: 4 }"
/>
</el-form-item>
</div>
</el-form>
<footer class="flex end">
<el-button @click="editShow = false" size="large">取消</el-button>
<el-button type="primary" @click="handleSumbit" size="large"
>确定</el-button
>
</footer>
</el-dialog>
</template>
<script setup>
import moment from "moment";
import { ElLoading } from "element-plus";
import {
listNegative,
negativeExport,
delNegative,
updateNegative,
transferTodo, createReportTask,
} from "@/api/work/negative";
import { getDictLable, formatTimeText, getInvolveProblem ,getYearTime} from "@/utils/util";
import feedback from "@/utils/feedback";
import { ProcessingStatus } from "@/enums/flowEnums";
import { ProblemSources_XFTS, ProblemSources } from "@/enums/dictEnums";
import useCatchStore from "@/stores/modules/catch";
import {computed, watch} from "vue";
import {getListData} from "@/api/superviseReport/superviseReport";
import {ArrowDown, ArrowUp} from "@element-plus/icons-vue";
import useUserStore from "@/stores/modules/user.ts";
const userStore = useUserStore();
const catchStore = useCatchStore();
const dict = catchStore.getDicts([
"businessType",
"inspectCase",
"checkStatus",
"isRectify",
"suspectProblem",
"policeType",
"specialSupervision",
"approvalFlow",
"handleResult"
]);
const flowNodes = catchStore.getFlowNodes();
const dictProblemSources = catchStore.getDictProblemSources();
const queryCrumbs = ref([]);
const query = ref({
current: 1,
size: 10,
responderKey: "name",
blameKey: "name",
});
const list = ref([]);
const total = ref(0);
const loading = ref(true);
function getList() {
loading.value = true;
listNegative(query.value).then((data) => {
list.value = data.records;
total.value = data.total;
loading.value = false;
});
}
function handleTableSort(orderObj) {
if (orderObj.order) {
query.value.order = orderObj.order;
query.value.orderProp = orderObj.prop;
} else {
query.value.order = "";
query.value.orderProp = "";
}
getList();
}
const tableRef = ref();
function reset() {
query.value = {
current: 1,
size: 10,
responderKey: "name",
blameKey: "name",
};
tableRef.value.clearSort();
getList();
// 重置路由
router.push("/query");
}
const route = useRoute();
watch(
() => route.query.toString(),
() => {
updateQuery();
getList();
}
);
async function updateQuery() {
if (route.query.processingStatus) {
query.value.processingStatus = [route.query.processingStatus];
}
if (route.query.crtTime === "today") {
query.value.crtTime = [
moment().startOf("day").format("YYYY-MM-DD HH:mm:ss"),
moment().endOf("day").format("YYYY-MM-DD HH:mm:ss"),
];
}
//大屏(12337)跳转
if(route.query.open && route.query.open === '12337'){
query.value.crtTime =getYearTime()
query.value.problemSourcesCode = ['24']
await nextTick()
}
//大屏(局长信箱)跳转
if(route.query.open && route.query.open === 'Mailbox'){
query.value.crtTime =getYearTime()
query.value.problemSourcesCode = ['23']
await nextTick()
}
if (route.query.extensionFlag === "true") {
query.value.extensionFlag = true;
query.value.processingStatus = ['signing', 'processing', 'approval'];
}
}
onMounted(() => {
updateQuery();
getList();
});
const show = ref(false);
const activeNegativeId = ref("");
function handleAction(row) {
show.value = true;
activeNegativeId.value = row.id;
}
const router = useRouter();
async function handleExport() {
await feedback.confirm("请确定导出当前页面所有数据");
const loading = ElLoading.service({
lock: true,
text: "导出中...",
background: "rgba(0, 0, 0, 0.5)",
});
await negativeExport(query.value);
loading.close();
await feedback.confirm("导出任务已生成,请到“导出记录”页面查看");
router.push("/negative/export");
}
async function handleReportGenerate() {
const crtTime = query.value.crtTime;
if (!crtTime) {
feedback.msgError("请选择对应录入时间");
return;
}
// 校验时间跨度不能超过一年
if (crtTime.length === 2) {
const startDate = new Date(crtTime[0]);
const endDate = new Date(crtTime[1]);
const timeDiff = endDate - startDate;
const yearDiff = timeDiff / (1000 * 60 * 60 * 24 * 365);
if (yearDiff > 1) {
feedback.msgError("所选时间跨度不能超过一年");
return;
}
}
const loading = ElLoading.service({
lock: true,
text: "报告任务生成中...",
background: "rgba(0, 0, 0, 0.5)",
});
await createReportTask(query.value);
loading.close();
await feedback.confirm("报告任务已生成,请到导出记录页面查看");
router.push("/negative/export");
}
async function handleDel(row) {
await feedback.confirm(`确定删除该数据?`);
await delNegative(row.id);
feedback.msgSuccess("操作成功");
getList();
}
const editShow = ref(false);
const formData = ref({});
const formRef = ref(null);
function handleEdit(row) {
console.log(row);
editShow.value = true;
formData.value = { ...row };
if (row.involveProblem) {
formData.value.involveProblem =
formData.value.involveProblem.split(",");
} else {
formData.value.involveProblem = [];
}
}
async function handleSumbit() {
await formRef.value.validate();
await updateNegative(formData.value);
editShow.value = false;
feedback.msgSuccess("操作成功");
getList();
}
async function handleTransferTodo(row) {
await feedback.confirm(`确定将该数据转为待办?`);
await transferTodo(row.id);
feedback.msgSuccess("已成功转为待办,请到我的待办查看");
getList();
}
const negativeDialogRef = ref();
function handleSpotCheck(row) {
activeNegativeId.value = row.id;
show.value = true;
negativeDialogRef.value.spotCheck();
}
const remainingTimeFlag = ref(true);
const reportData = ref(null)
watch(()=>reportData.value,(val)=>{
if(val){
formData.value.reportNumber = reportList.value.find(s=>s.id == val).reportName;
formData.value.reportId = val;
}
},{deep:true,immediate:true})
const reportQuery = ref({
current: 1,
size: 100,
type: 1
})
const reportList = ref([]);
const reportLoading = ref(false);
const getReportListDataFun =async (val=null)=>{
reportLoading.value=true;
try{
if(val){
reportQuery.value.reportName = val;
}else{
reportQuery.value.reportName =null;
}
const res = await getListData(reportQuery.value);
reportList.value=res.records;
console.log('reportList.value',reportList.value)
reportLoading.value=false;
}catch (e){
reportLoading.value=false;
}
}
const reportFiles = computed(()=> {
if( formData.value.reportNumber){
let data= reportList.value.find(s=>s.id === formData.value.reportId);
data = data?data:reportList.value.find(s=>s.reportNumber === formData.value.reportNumber);
console.log('data',data)
return data?.files;
}else{
return []
}
})
const expanded = ref(false)
function handleChangeResultCode(item) {
if (item.handleResultCode && item.handleResultCode.length > 0) {
item.handleResultName = dict.handleResult
.filter((obj) => item.handleResultCode.includes(obj.dictValue))
.map((obj) => obj.dictLabel)
.join("、");
} else {
item.handleResultName = "";
}
}
function handleChangeProblem(node, problem) {
if (node.level === 3) {
problem.threeLevelContent = node.label;
problem.oneLevelCode = node.parent.parent.key;
problem.oneLevelContent = node.parent.parent.label;
problem.twoLevelCode = node.parent.key;
problem.twoLevelContent = node.parent.label;
}
}
</script>
<style lang="scss" scoped>
:deep() {
.el-dropdown-menu__item {
padding: 0;
.el-button {
width: 100%;
}
}
}
/* 外层容器 */
.form-collapse-wrapper {
overflow: hidden;
}
/* 进入 / 离开 */
.collapse-fade-enter-active,
.collapse-fade-leave-active {
transition:
max-height 0.45s cubic-bezier(0.4, 0, 0.2, 1),
opacity 0.3s ease,
transform 0.3s ease;
}
/* 初始状态 */
.collapse-fade-enter-from,
.collapse-fade-leave-to {
max-height: 0;
opacity: 0;
transform: translateY(-6px);
}
/* 展开完成状态 */
.collapse-fade-enter-to,
.collapse-fade-leave-from {
max-height: 1200px; /* 大于表单最大高度 */
opacity: 1;
transform: translateY(0);
}
.toggle-area {
display: flex;
justify-content: center;
height: 32px;
margin: 8px 0 12px;
}
.collapse-fade-enter-active {
transition-delay: 0s, 0.1s, 0.1s;
}
.compact-row {
row-gap: 8px; /* 原来大概是 20px */
}
.search-flex-row {
display: flex;
flex-wrap: wrap; /* 排不下自动换行 */
gap: 12px 16px; /* 行间距 / 列间距 */
align-items: center; /* 垂直对齐 */
}
.search-flex-row {
display: flex;
flex-wrap: wrap;
gap: 12px 16px;
align-items: center;
}
.search-flex-row .el-col {
flex: none;
}
.search-flex-row .el-form-item {
display: flex;
align-items: center;
margin-bottom: 0;
}
.search-flex-row .el-form-item__label {
padding-right: 8px;
line-height: 32px;
white-space: nowrap;
}
</style>