Files
sgxt_web/src/views/backOfficeSystem/IntelligentControl/myControl/components/addBkdx.vue

592 lines
20 KiB
Vue
Raw Normal View History

2025-07-08 20:10:24 +08:00
<template>
<div class="dialog" v-if="dialogForm">
<div class="head_box">
<span class="title">布控对象</span>
<div>
2025-07-10 17:59:39 +08:00
<el-button size="small" type="primary" v-if="!disabled" :loading="loading" @click="submit">保存</el-button>
<el-button size="small" @click="close">关闭</el-button>
2025-07-08 20:10:24 +08:00
</div>
</div>
2025-08-16 16:54:03 +08:00
<div class="flex">
<div :class="dataOrge.gzlid?'ww80':'ww100'">
<div class="form_cnt">
<el-form :model="listQuery" :rules="rules" :disabled="disabled" ref="elform" inline :label-width="100"
label-position="left">
<div class="smallTitle">布控信息</div>
<!-- <el-form-item prop="bkBt" label="布控标题">
2025-08-06 14:25:36 +08:00
<MOSTY.Other v-model="listQuery.bkBt" placeholder="请输入布控标题" clearable />
2025-08-16 16:54:03 +08:00
</el-form-item> -->
<el-form-item prop="bkDx" label="布控对象">
<MOSTY.Select v-model="listQuery.bkDx" @change="shangeDx" :dictEnum="props.dic.D_GS_BK_DX"
placeholder="请选择布控对象" clearable />
</el-form-item>
<div class="ww100 mt10 mb10">
<el-button type="primary" @click="handleAddPeo" v-if="!disabled">
<el-icon style="vertical-align: middle">
<CirclePlus />
</el-icon>
<span style="vertical-align: middle">新增</span>
</el-button>
</div>
<div class="relative ww100">
<MyTable :tableData="listQuery.bkdxList" :tableColumn="tableDate.tableColumn"
:tableHeight="tableDate.tableHeight" :key="tableDate.keyCount" :tableConfiger="tableDate.tableConfiger"
:controlsWidth="tableDate.controlsWidth">
<template #fjZp="{ row }">
<el-image :src="row.fjZp"></el-image>
</template>
<template #yjdj="{ row }">
<DictTag :tag="false" :value="row.yjdj" :options="props.dic.D_GS_ZDR_YJDJ" />
</template>
<template #yjbq="{ row }">
<DictTag :tag="false" :value="row.yjbq" :options="props.dic.BD_BK_CLYJBQ" />
</template>
<template #ryXb="{ row }">
<DictTag :tag="false" :value="row.ryXb" :options="props.dic.D_BZ_XB" />
</template>
<template #bqList="{ row }">
<span v-if="row.bqList">
<span v-for="(it, idx) in row.bqList" :key="idx"> {{ it.bqMc }}</span>
</span>
</template>
<!-- 操作 -->
<template #controls="{ row }">
<el-link type="primary">查看档案</el-link>
<el-link type="danger" @click="deleteRow(row)">删除</el-link>
</template>
</MyTable>
</div>
2025-08-06 14:25:36 +08:00
2025-08-16 16:54:03 +08:00
<div class="smallTitle">布控范围</div>
<div class="ww100 relative mb10"
style="height: 250px;border: 1px solid #dcdfe6;border-radius: 4px;overflow: hidden;">
<div class="absolute mapSearch flex">
<MOSTY.Select v-model="listQuery.bkqyList" filterable multiple :dictEnum="bkqyArr" style="width:350px"
placeholder="请选择布控范围" clearable />
</div>
<GdMap></GdMap>
</div>
<!-- <el-form-item prop="bkBt" label="布控要素" style="width: 100%;">
2025-08-06 14:25:36 +08:00
<div class="flex align-center">
<el-button @click="listQuery.bkYz = it.dm" :type="listQuery.bkYz == it.dm ? 'primary' : ''"
v-for="it in props.dic.D_GS_BK_BKYS" :key="it">{{ it.zdmc }}</el-button>
</div>
2025-08-16 16:54:03 +08:00
</el-form-item> -->
<div style="width: 100%;" class="mt25">
<el-form-item prop="bkSjKs" label="布控开始时间" label-width="120px">
<MOSTY.Date v-model="listQuery.bkSjKs" type="datetime" format="YYYY-MM-DD HH:mm:ss"
placeholder="请选择布控开始时间" clearable />
</el-form-item>
<el-form-item prop="bkSjJs" label="布控结束时间" label-width="120px">
<MOSTY.Date v-model="listQuery.bkSjJs" type="datetime" format="YYYY-MM-DD HH:mm:ss"
placeholder="请选择布控结束时间" clearable />
</el-form-item>
2025-07-08 20:10:24 +08:00
</div>
2025-08-16 16:54:03 +08:00
<div style="width: 100%;" class="mt25">
<el-form-item prop="czYq" label="处置要求">
<MOSTY.Select v-model="listQuery.czYq" :dictEnum="props.dic.D_GS_BK_CZYQ" placeholder="请选择处置要求"
clearable />
</el-form-item>
<el-form-item prop="bkDj" label="布控等级">
<MOSTY.Select v-model="listQuery.bkDj" :dictEnum="props.dic.D_GS_BK_DJ" placeholder="请选择布控级别"
clearable />
</el-form-item>
</div>
<div style="width: 100%;" class="mt10">
<el-form-item prop="bkSy" label="布控事由" style="width: 100%;">
<MOSTY.Other v-model="listQuery.bkSy" placeholder="请输入布控事由" type="textarea" style="width: 100%;"
clearable />
</el-form-item>
</div>
<div style="width: 100%;" class="mt10">
<el-form-item prop="bkfj" label="上传附件" style="width: 100%;">
<div>
<MOSTY.Upload :showBtn="true" :limit="10" :isImg="false" :isAll="true" v-model="listQuery.bkfj" />
<div>支持pngjpgpdf文件上传</div>
</div>
</el-form-item>
</div>
</el-form>
2025-08-06 14:25:36 +08:00
</div>
2025-08-16 16:54:03 +08:00
</div>
<div class="ww20" v-if="dataOrge.gzlid">
<!-- <div class="smallTitle">审批信息</div>
2025-08-06 14:25:36 +08:00
<div class="ww100">
2025-08-16 16:54:03 +08:00
<el-steps :active="listQuery.wccz" space="500" finish-status="success" direction="vertical" status=''>
<el-step :title="item.eventType == '0' ? '发起申请' : item.eventType == '1' ? '审批结束' : item.nodeName"
v-for="(item, index) in workflow" :key="index">
2025-08-06 14:25:36 +08:00
<template #description>
2025-08-16 16:54:03 +08:00
<div class="ww100 mt10 mb20 nodeBox" v-if="item.eventType == '0'||item.eventType == '1'">
<div class="nodeorgNameTg">{{ item.log.userData.orgname }}</div>
<div class="flex just-between nameTag">
<div>{{ item.log.userName }}</div>
<div class="fontColor">{{ item.eventType == '0' ? '发起' : '结束' }}</div>
</div>
<div>{{ item.log.xtLrsj }}</div>
2025-07-08 20:10:24 +08:00
</div>
2025-08-16 16:54:03 +08:00
<div v-else class="ww100 mt10 mb20 nodeBox">
<div :class="item.taskStatus=='2'?'nodeorgNameTg':'nodeorgNameDd'">{{ item.orgNameData.orgname }}</div>
<div v-for="(items, indexs) in item.log" :key="indexs">
<div class="flex just-between nameTag" >
<div>{{ items.userName }}</div>
<div :class="item.taskStatus=='2'?'fontColor':'fontColorDd'">审批中</div>
</div>
<div>{{ items.xtLrsj }}</div>
</div>
2025-07-08 20:10:24 +08:00
</div>
2025-08-06 14:25:36 +08:00
</template>
</el-step>
2025-08-16 16:54:03 +08:00
2025-08-06 14:25:36 +08:00
</el-steps>
2025-08-16 16:54:03 +08:00
</div> -->
<ApprovalEcho ref="approvalEcho"/>
</div>
2025-07-08 20:10:24 +08:00
</div>
2025-08-16 16:54:03 +08:00
2025-07-08 20:10:24 +08:00
</div>
<!-- 选择布控人员 -->
2025-08-06 14:25:36 +08:00
<BkryDialod :modelValue="chooseVisible_RY" @update:modelValue="chooseVisible_RY = $event" @choosed="choosed"
@choosedAdd="choosedAdd" :roleIds="roleIds" />
<!-- 选择车辆布控 -->
<BkclDialod :modelValue="chooseVisible_CL" @update:modelValue="chooseVisible_CL = $event" @choosed="choosed"
@choosedAdd="choosedAdd" :roleIds="roleIds" />
2025-07-10 17:59:39 +08:00
<!-- 选择布控群体 -->
2025-08-06 14:25:36 +08:00
<BkqtDialod :modelValue="chooseVisible_QT" @update:modelValue="chooseVisible_QT = $event" @choosed="choosed"
:roleIds="roleIds" />
2025-08-16 16:54:03 +08:00
<BksfzDialod :modelValue="chooseVisible_SFZ" @update:modelValue="chooseVisible_SFZ = $event" @choosed="choosed"
:roleIds="roleIds" :bkDx="listQuery.bkDx" @choosedAdd="choosedAdd" />
2025-07-08 20:10:24 +08:00
</template>
<script setup>
2025-07-10 17:59:39 +08:00
import { getItem } from "@/utils/storage";
2025-07-10 20:53:34 +08:00
import BkryDialod from '@/components/ChooseList/ChooseZdr/index.vue';
import BkqtDialod from '@/components/ChooseList/ChooseQt/index.vue';
2025-08-06 14:25:36 +08:00
import BkclDialod from '@/components/ChooseList/ChooseCl/index.vue';
2025-08-16 16:54:03 +08:00
import BksfzDialod from './dolog/sfzLog.vue';
2025-07-08 20:10:24 +08:00
import GdMap from "@/components/GdMap/index.vue";
import * as MOSTY from "@/components/MyComponents/index";
import MyTable from "@/components/aboutTable/MyTable.vue";
2025-08-06 14:25:36 +08:00
import { qcckGet, qcckPost } from "@/api/qcckApi.js";
2025-08-16 16:54:03 +08:00
import { tableColumnList,Zd } from '@/views/backOfficeSystem/ApprovalInformation/tableRow.js'
import { ref, defineExpose, reactive, defineEmits, getCurrentInstance, nextTick, watch } from "vue";
import { queryProcessNode, queryProcessNodeLog, queryProcess } from '@/api/spl'
import ApprovalEcho from "@/components/flowPath/ApprovalEcho.vue";
2025-07-08 20:10:24 +08:00
const emit = defineEmits(["change"]);
const props = defineProps({
dic: Object
});
2025-07-10 17:59:39 +08:00
const elform = ref()
2025-07-08 20:10:24 +08:00
const roleIds = ref([]); //角色ID
2025-07-10 17:59:39 +08:00
const chooseVisible_RY = ref(false); //选择布控人员弹窗
const chooseVisible_QT = ref(false); //选择布控群体弹窗
2025-08-06 14:25:36 +08:00
const chooseVisible_CL = ref(false)
2025-07-10 12:09:51 +08:00
const bkqyArr = ref([]); //布控区域
2025-07-08 20:10:24 +08:00
const { proxy } = getCurrentInstance();
const dialogForm = ref(false); //弹窗
2025-07-10 10:53:48 +08:00
const loading = ref(false)
2025-07-10 18:27:50 +08:00
const addPerson = ref([]) //单独新增的数据
2025-07-08 20:10:24 +08:00
const listQuery = ref({
2025-08-06 14:25:36 +08:00
bkYz: '01',
bkdxList: [],
2025-07-08 20:10:24 +08:00
}); //表单数据
2025-07-10 17:59:39 +08:00
const rules = reactive({
2025-08-06 14:25:36 +08:00
bkBt: [{ required: true, message: "请输入布控标题", trigger: "blur" }],
bkDx: [{ required: true, message: "请选择布控对象", trigger: "change" }],
bkSjKs: [{ required: true, message: "请选择布控开始时间", trigger: "change" }],
bkSjJs: [{ required: true, message: "请选择布控结束时间", trigger: "change" }],
czJsdwdm: [{ required: true, message: "请选择处置接收单位", trigger: "change" }],
bkshrSsbmdm: [{ required: true, message: "请选择审核部门", trigger: "change" }],
bksprSsbmdm: [{ required: true, message: "请选择审批部门", trigger: "change" }],
2025-07-10 17:59:39 +08:00
})
2025-08-06 14:25:36 +08:00
let tableDate = reactive({
2025-07-08 20:10:24 +08:00
keyCount: 0,
tableConfiger: {
rowHieght: 61,
showSelectType: "null",
loading: false
},
total: 0,
pageConfiger: {
pageSize: 20,
pageCurrent: 1
}, //分页
controlsWidth: 200, //操作栏宽度
tableColumn: [
2025-08-06 14:25:36 +08:00
{ label: "照片", prop: "fjZp", showSolt: true },
2025-07-10 10:53:48 +08:00
{ label: "姓名", prop: "ryXm" },
2025-08-06 14:25:36 +08:00
{ label: "性别", prop: "ryXb", showSolt: true },
2025-07-10 10:53:48 +08:00
{ label: "身份证号", prop: "rySfzh" },
{ label: "户籍地", prop: "ryHjd" },
{ label: "现居住地址", prop: "ryXjd" },
{ label: "手机号", prop: "rySjhm" },
{ label: "虚拟身份", prop: "qtXnsf" },
{ label: "车牌号", prop: "clCph" },
2025-08-16 16:54:03 +08:00
{ label: "车辆识别代码", prop: "clCjh" },
2025-07-10 10:53:48 +08:00
{ label: "特征描述", prop: "qtTzms" },
2025-08-16 16:54:03 +08:00
{ label: "标签", prop: "bqList", showSolt: true, showOverflowTooltip: true }
2025-07-08 20:10:24 +08:00
]
});
2025-07-15 20:19:13 +08:00
const title = ref('')
2025-07-10 17:59:39 +08:00
const disabled = ref(false)
2025-07-08 20:10:24 +08:00
// 初始化数据
2025-08-06 14:25:36 +08:00
const init = (type, row) => {
listQuery.value.bkfj = [];
if (type == 'add') {
tableDate.tableConfiger.haveControls = true;
disabled.value = false;
listQuery.value.bkfqrXm = getItem("USERNAME");
2025-08-27 17:26:29 +08:00
console.log(getItem("USERNAME"));
2025-08-06 14:25:36 +08:00
listQuery.value.bkfqrSfzh = getItem("idEntityCard");
2025-08-27 17:26:29 +08:00
console.log( getItem("USERID"));
console.log( getItem("idEntityCard"));
2025-08-06 14:25:36 +08:00
listQuery.value.bkfqrSsbmmc = getItem("deptId")[0].deptName;;
listQuery.value.bkfqrSsbmdm = getItem("deptId")[0].deptCode;;
}
title.value = type == 'add' ? '新增' : type == 'detail' ? '详情' : '编辑';
disabled.value = type == 'detail' ? true : false;
dialogForm.value = true;
if (row) tableDate.tableConfiger.haveControls = false;
2025-08-16 16:54:03 +08:00
Zd({D_GS_BK_DJ:props.dic.D_GS_BK_DJ,BD_BK_CLYJBQ:props.dic.BD_BK_CLYJBQ})
2025-08-06 14:25:36 +08:00
get_bkqy_list(row)
2025-07-08 20:10:24 +08:00
};
2025-07-10 17:59:39 +08:00
2025-07-10 12:09:51 +08:00
// 获取布控区域
2025-08-06 14:25:36 +08:00
const get_bkqy_list = (row) => {
qcckGet({}, '/mosty-gsxt/tbGsxtBkQy/selectList').then(res => {
let arr = res || [];
bkqyArr.value = arr.map(item => {
return { ...item, label: item.qymc, value: item.id }
2025-07-10 12:09:51 +08:00
})
2025-08-06 14:25:36 +08:00
if (row) getDataById(row.id);
})
2025-07-10 12:09:51 +08:00
}
2025-08-16 16:54:03 +08:00
const dataOrge=ref({})
const approvalEcho = ref()
watch(() => approvalEcho.value, (val) => {
if (val) {
approvalEcho.value.getWorkflow(dataOrge.value.gzlid)
}
},{deep:true})
2025-07-08 20:10:24 +08:00
2025-07-10 17:59:39 +08:00
// 根据id获取详情
2025-08-06 14:25:36 +08:00
const getDataById = (id) => {
qcckGet({}, '/mosty-gsxt/tbGsxtBk/selectVoById/' + id).then(res => {
res.bkfj = res.ossList || [];
res.bkqyList = res.qyList ? res.qyList.map(v => v.id) : [];
listQuery.value = res || {}
2025-08-16 16:54:03 +08:00
dataOrge.value=res
tableDate.tableColumn = tableColumnList[res.bkDx ? res.bkDx : '01']
2025-08-06 14:25:36 +08:00
})
2025-07-10 17:59:39 +08:00
}
2025-08-16 16:54:03 +08:00
watch(() => approvalEcho.value, (val) => {
if (val) {
console.log(approvalEcho.value);
approvalEcho.value.getWorkflow(dataOrge.value.gzlid)
}
},{deep:true})
2025-07-10 17:59:39 +08:00
2025-08-06 14:25:36 +08:00
const shangeDx = () => {
2025-08-16 16:54:03 +08:00
tableDate.tableColumn = tableColumnList[listQuery.value.bkDx]
2025-08-06 14:25:36 +08:00
listQuery.value.bkDxxx = '';
listQuery.value.bkdxList = [];
roleIds.value = [];
addPerson.value = []
2025-07-10 18:27:50 +08:00
}
// 删除数据
const deleteRow = (row) => {
2025-08-06 14:25:36 +08:00
roleIds.value = roleIds.value.filter(id => id != row.id);
addPerson.value = addPerson.value.filter(it => it.id != row.id);
listQuery.value.bkdxList = listQuery.value.bkdxList.filter(it => it.id != row.id);
2025-07-10 18:27:50 +08:00
}
// 单独新增的数据
2025-08-06 14:25:36 +08:00
const choosedAdd = (item) => {
let obj = {}
2025-08-16 16:54:03 +08:00
if (listQuery.value.bkDx !== '02') {
obj = { id: item.id, fjZp: item.fjZp, ryXm: item.ryXm, ryXb: item.ryXb, rySfzh: item.rySfzh, ryHjd: item.hjdXz, ryXjd: item.xzdXz, rySjhm: item.ryLxdh, qtXnsf: item.qtXnsf, clCjh: item.clCjh, clCph: item.clCph, qtTzms: item.qtTzms, bqList: item.bqList }
2025-08-06 14:25:36 +08:00
} else {
2025-08-16 16:54:03 +08:00
obj = {
2025-08-06 14:25:36 +08:00
clCph: item.hphm, clCjh: item.clCjh, clSyr: item.clSyr, clSyrsfzh: item.clSyrsfzh,
2025-08-16 16:54:03 +08:00
clYs: item.clYs, gxSsbmmc: item.gxSsbmmc, bqList: item.bqList
}
}
switch (listQuery.value.bkDx) {
default:
obj = { ...item }
break;
2025-08-06 14:25:36 +08:00
}
addPerson.value.push(obj);//缓存的数据
if (!listQuery.value.bkdxList) listQuery.value.bkdxList = [];
listQuery.value.bkdxList.unshift(obj);
2025-08-16 16:54:03 +08:00
console.log(listQuery.value.bkdxList);
2025-07-10 17:59:39 +08:00
}
2025-07-10 18:27:50 +08:00
2025-07-08 20:10:24 +08:00
// 选择重点人
const choosed = (val) => {
2025-08-16 16:54:03 +08:00
tableDate.tableColumn = tableColumnList[listQuery.value.bkDx]
2025-08-06 14:25:36 +08:00
if (listQuery.value.bkDx == '01') {// 人员
roleIds.value = val.map(it => it.id);
let arr = val.map(item => {
let bqArr = item.bqList || [];
let bqs = bqArr.map(v => {
return { bqZl: v.bqZl, bqId: v.bqId, bqLx: v.bqLx, bqLb: v.bqLb, bqMc: v.bqMc, bqDm: v.bqDm }
})
2025-08-16 16:54:03 +08:00
return {
id: item.id, fjZp: item.fjZp, ryXm: item.ryXm, ryXb: item.ryXb,
rySfzh: item.rySfzh, ryHjd: item.hjdXz, ryXjd: item.xzdXz,
rySjhm: item.ryLxdh, qtXnsf: item.qtXnsf, clCjh: item.clCjh,
clCph: item.clCph, qtTzms: item.qtTzms, bqList: bqs, yjdj: item.zdrYjdj,ssbmdm:item.zrSsbmdm
}
2025-08-06 14:25:36 +08:00
})
listQuery.value.bkdxList = [...addPerson.value, ...arr];
} else if (listQuery.value.bkDx == '03') {
2025-08-16 16:54:03 +08:00
roleIds.value = val.map(it => it.id);
2025-08-06 14:25:36 +08:00
let arr = val.map(item => {
2025-08-16 16:54:03 +08:00
2025-08-06 14:25:36 +08:00
return {
clCph: item.hphm, clCjh: item.clCjh, clSyr: item.clSyr, clSyrsfzh: item.clSyrsfzh,
2025-08-16 16:54:03 +08:00
clYs: item.clYs, gxSsbmmc: item.gxSsbmmc,yjbq: item.yjbq, yjdj: item.yjdj,ssbmdm:item.zrSsbmdm
2025-08-06 14:25:36 +08:00
}
})
listQuery.value.bkdxList = [...addPerson.value, ...arr];
}
else {// 群体
listQuery.value.bkDxxx = (val.map(it => it.id)).join(',');
let peolist = []
val.forEach(item => {
if (item.zdryList) peolist = peolist.concat(item.zdryList)
})
let brrPeo = peolist.map(item => {
let bqArr = item.bqList || [];
let bqs = bqArr.map(v => {
return { bqZl: v.bqZl, bqId: v.bqId, bqLx: v.bqLx, bqLb: v.bqLb, bqMc: v.bqMc, bqDm: v.bqDm }
})
return {
id: item.id, fjZp: item.fjZp, ryXm: item.ryXm, ryXb: item.ryXb,
rySfzh: item.rySfzh, ryHjd: item.hjdXz, ryXjd: item.xzdXz,
rySjhm: item.ryLxdh, qtXnsf: item.qtXnsf, clCjh: item.clCjh,
2025-08-16 16:54:03 +08:00
clCph: item.clCph, qtTzms: item.qtTzms, bqList: bqs,
yjdj: item.zdrYjdj,ssbmdm:item.zrSsbmdm
2025-08-06 14:25:36 +08:00
}
})
listQuery.value.bkdxList = brrPeo;
}
2025-07-10 17:59:39 +08:00
};
2025-07-10 19:07:56 +08:00
2025-07-10 17:59:39 +08:00
// 选择人员
2025-08-06 14:25:36 +08:00
const handleAddPeo = () => {
if (!listQuery.value.bkDx) return proxy.$message({ type: "warning", message: '请选择布控对象' });
switch (listQuery.value.bkDx) {
case '01':
chooseVisible_RY.value = true
break;
2025-08-16 16:54:03 +08:00
case '04':
case '05':
case '06':
case '07':
case '08':
case '09':
case '10':
chooseVisible_SFZ.value = true
2025-08-06 14:25:36 +08:00
break;
case '03':
chooseVisible_CL.value = true
break;
2025-08-16 16:54:03 +08:00
case '02':
chooseVisible_QT.value = true
break;
2025-08-06 14:25:36 +08:00
}
2025-07-10 17:59:39 +08:00
}
2025-07-08 20:10:24 +08:00
2025-07-15 20:46:37 +08:00
2025-07-10 17:59:39 +08:00
// 提交
const submit = () => {
2025-07-15 20:19:13 +08:00
elform.value.validate((validate) => {
2025-08-06 14:25:36 +08:00
if (!validate) return;
let params = { ...listQuery.value };
params.bkfj = params.bkfj ? params.bkfj.join(',') : '';
2025-07-10 17:59:39 +08:00
params.bkdxList = params.bkdxList ? params.bkdxList : [];
2025-08-06 14:25:36 +08:00
params.bkdxList.forEach(item => { item.fjZp = item.fjZp ? item.fjZp.join(',') : '' })
2025-07-10 17:59:39 +08:00
loading.value = true;
2025-07-15 20:19:13 +08:00
let url = title.value == '新增' ? "/mosty-gsxt/tbGsxtBk/save" : "/mosty-gsxt/tbGsxtBk/update";
qcckPost(params, url).then((res) => {
2025-08-06 14:25:36 +08:00
proxy.$message({ type: "success", message: "布控成功" });
emit("change");
loading.value = false;
close();
}).catch(() => {
loading.value = false;
});
2025-07-10 17:59:39 +08:00
});
};
2025-07-08 20:10:24 +08:00
// 关闭
const close = () => {
listQuery.value = {};
dialogForm.value = false;
loading.value = false;
2025-07-10 19:07:56 +08:00
addPerson.value = [];
roleIds.value = []
2025-08-16 16:54:03 +08:00
dataOrge.value={}
};
// 选择身份证
const chooseVisible_SFZ = ref(false)
// 获取布控信息的工作流
const workflow = ref()
const getWorkflow = async (id) => {
const promes = {
processId: id
}
const proNode = await queryProcessNode(promes)
const proNodeLog = await queryProcessNodeLog(promes)
const process = await queryProcess(promes)
workflow.value = proNode.rows.map(item => {
const log = proNodeLog.rows.filter(items => item.nodeId == items.nodeId)
if (item.eventType == '0') {
return {
...item,
log: {
userData: item.userData ? JSON.parse(item.userData) : JSON.parse(process.rows[0].processData).orgNameData,
userName: process.rows[0].userName,
xtLrsj: process.rows[0].xtLrsj,
processStatus: process.rows[0].processStatus,
}
}
} else {
return {
...item,
orgNameData: JSON.parse(log[0].userData),
log: log
}
}
})
2025-07-08 20:10:24 +08:00
};
defineExpose({ init });
</script>
<style lang="scss" scoped>
@import "~@/assets/css/layout.scss";
@import "~@/assets/css/element-plus.scss";
2025-08-06 14:25:36 +08:00
.smallTitle {
width: 100%;
font-size: 15px;
line-height: 50px;
font-weight: 550;
color: #606266;
2025-07-08 20:10:24 +08:00
}
2025-08-06 14:25:36 +08:00
.mapSearch {
left: 10px;
top: 10px;
z-index: 100;
2025-07-08 20:10:24 +08:00
}
2025-08-06 14:25:36 +08:00
.dialog {
::v-deep .el-form-item--default {
margin: 0 1% 0 0 !important;
padding-bottom: 0 !important;
}
2025-07-08 20:10:24 +08:00
}
2025-08-06 14:25:36 +08:00
::v-deep .avatar-uploader {
display: flex;
2025-07-08 20:10:24 +08:00
}
2025-08-06 14:25:36 +08:00
::v-deep .el-upload--picture-card i {
width: 156px;
2025-07-08 20:10:24 +08:00
}
2025-08-06 14:25:36 +08:00
.depBox {
border: 1px solid #e9e9e9;
width: 305px;
padding: 0 0 0 4px;
border-radius: 4px;
::v-deep .el-input__inner {
border: none;
}
::v-deep .el-cascader .el-input.is-focus .el-input__inner {
border-color: transparent !important;
}
::v-deep .el-input__inner:focus {
box-shadow: none;
}
::v-deep .el-input.is-disabled .el-input__inner {
border-color: transparent !important;
}
2025-07-10 12:09:51 +08:00
}
2025-08-16 16:54:03 +08:00
/* 使用深度选择器覆盖子组件样式 */
::v-deep .el-step.is-vertical .el-step__title {
color: #000000 !important;
border-color: #000000 !important;
}
::v-deep .el-step__description{
padding: 0 !important;
}
::v-deep .el-step__description.is-wait {
color: #000000 !important;
border-color: #000000 !important;
}
.el-step__title.is-wait {
color: #000000 !important;
border-color: #000000 !important;
}
::v-deep .el-step__head.is-wait {
color: #000000 !important;
border-color: #000000 !important;
}
::v-deep .el-step__line {
background-color: #000000 !important;
}
.nodeBox {
width: 80%;
text-align: center;
line-height: 30px;
border-radius: 10px;
overflow: hidden;
background-color: aliceblue;
.nodeorgNameTg {
background-color: #1abe20;
}
.nameTag {
line-height: 30px;
padding: 0 10px;
}
.nodeorgNameDd {
background-color: #18a2dd;
}
.fontColor {
color: #1abe20;
} .fontColorDd {
color: #18a2dd;
}
}
2025-07-08 20:10:24 +08:00
</style>