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.
354 lines
12 KiB
354 lines
12 KiB
<template> |
|
<!-- 政务 --> |
|
<div class="c-auto"> |
|
<el-table class="c-table" |
|
:data="form" |
|
:max-height="height" |
|
:cell-style="{background:'#fff'}" |
|
:span-method="span" |
|
border> |
|
<el-table-column prop="name" |
|
label="指标" |
|
min-width="100" |
|
align="center"> |
|
</el-table-column> |
|
<el-table-column label="规则" |
|
min-width="350" |
|
align="center"> |
|
<template #default="{ row }"> |
|
<!-- 大病报销 || 贫困户 --> |
|
<div v-if="row.stRecordId == 161 || row.stRecordId == 164" |
|
class="flex items-center"> |
|
<span v-if="row.recordChildren" |
|
class="whitespace-nowrap">{{ row?.recordChildren[row.span ? 1 : 0]?.name }}</span> |
|
<div class="w-[90px] "> |
|
<el-select class="mx-2" |
|
v-model="row.symbol"> |
|
<el-option v-for="item in symbols" |
|
:key="item" |
|
:label="item.name" |
|
:value="item.name" /> |
|
</el-select> |
|
</div> |
|
<el-input class="w-[80px]" |
|
v-model="row.num"></el-input> |
|
<span class="ml-2 whitespace-nowrap">万元</span> |
|
</div> |
|
<!-- 大龄未婚 --> |
|
<div v-else-if="row.stRecordId == 167" |
|
class="flex items-center"> |
|
<template v-if="row.span"> |
|
<span class="whitespace-nowrap">且近一年</span> |
|
<div class="w-[90px] "> |
|
<el-select class="mx-2" |
|
v-model="row.had"> |
|
<el-option value="有" /> |
|
<el-option value="无" /> |
|
</el-select> |
|
</div> |
|
<span class="ml-2 whitespace-nowrap">缴纳过社保或公积金</span> |
|
</template> |
|
<template v-else> |
|
<span class="whitespace-nowrap">未婚,且年龄</span> |
|
<div class="w-[90px] "> |
|
<el-select class="mx-2" |
|
v-model="row.symbol"> |
|
<el-option v-for="item in symbols" |
|
:key="item" |
|
:label="item.name" |
|
:value="item.name" /> |
|
</el-select> |
|
</div> |
|
<el-input class="w-[80px]" |
|
v-model="row.num"></el-input> |
|
<span class="ml-2 whitespace-nowrap">,</span> |
|
<el-select class="w-[80px] ml-2" |
|
v-model="row.had"> |
|
<el-option value="有" /> |
|
<el-option value="无" /> |
|
</el-select> |
|
<span class="ml-2 whitespace-nowrap">固定资产</span> |
|
</template> |
|
</div> |
|
<span v-else>{{ '命中' + row.name }}</span> |
|
</template> |
|
</el-table-column> |
|
<el-table-column label="本人命中进黑名单" |
|
min-width="120" |
|
align="center"> |
|
<template #default="{ row }"> |
|
<el-checkbox v-model="row.personalHitBlacklist" |
|
@change="e => checkRow(e, row)"></el-checkbox> |
|
</template> |
|
</el-table-column> |
|
<el-table-column label="配偶命中拒入" |
|
min-width="120" |
|
align="center"> |
|
<template #default="{ row }"> |
|
<el-checkbox v-model="row.mateHitRejected" |
|
@change="e => checkRow(e, row)"></el-checkbox> |
|
</template> |
|
</el-table-column> |
|
<el-table-column label="父母/子女命中拒入" |
|
min-width="120" |
|
align="center"> |
|
<template #default="{ row }"> |
|
<el-checkbox v-model="row.parentsHitRejected" |
|
@change="e => checkRow(e, row)"></el-checkbox> |
|
</template> |
|
</el-table-column> |
|
<el-table-column label="其他家庭成员命中拒入" |
|
min-width="120" |
|
align="center"> |
|
<template #default="{ row }"> |
|
<el-checkbox v-model="row.otherFamilyMembersHitRejected" |
|
@change="e => checkRow(e, row)"></el-checkbox> |
|
</template> |
|
</el-table-column> |
|
<el-table-column label="企业大股东命中拒入" |
|
min-width="120" |
|
align="center"> |
|
<template #default="{ row }"> |
|
<el-checkbox v-model="row.corporateMajorityHitRejected" |
|
@change="e => checkRow(e, row)"></el-checkbox> |
|
</template> |
|
</el-table-column> |
|
<el-table-column label="本人及亲属企业命中准入" |
|
min-width="120" |
|
align="center"> |
|
<template #default="{ row }"> |
|
<el-checkbox v-model="row.hitAccess" |
|
@change="checkNone(row)"></el-checkbox> |
|
</template> |
|
</el-table-column> |
|
</el-table> |
|
</div> |
|
<div class="flex justify-end"> |
|
<div class="submit" |
|
@click="submit">确认完成配置</div> |
|
</div> |
|
</template> |
|
|
|
<script setup lang="ts"> |
|
import { ref, computed, watch, onMounted } from 'vue'; |
|
import { ElMessage } from 'element-plus'; |
|
import { accessStrategyGovernmentBlacklistFind, accessStrategyGovernmentBlacklistSave } from '@/api/model'; |
|
import { getProcessInformationBasedOnRoles, addOperation } from '@/api/judgment'; |
|
import type { TableColumnCtx } from 'element-plus'; |
|
import { useRouter, useRoute } from 'vue-router'; |
|
import { handleId, getIds } from '@/utils/common'; |
|
import Cookies from 'js-cookie'; |
|
|
|
const router = useRouter(); |
|
const route = useRoute(); |
|
const projectId = +Cookies.get('sand-projectId'); |
|
const levelId = +Cookies.get('sand-level'); |
|
const form = ref<Record<string, any>[]>([]); |
|
const info = ref<Record<string, any>[]>([]); |
|
const height = window.innerHeight - 230; |
|
const symbols: Array<Record<string, any>> = [ |
|
{ |
|
name: '>=', |
|
}, |
|
{ |
|
name: '<', |
|
}, |
|
{ |
|
name: '>', |
|
}, |
|
{ |
|
name: '==', |
|
}, |
|
{ |
|
name: '<=', |
|
}, |
|
]; |
|
// 配置项 |
|
const getConfig = async () => { |
|
const { process } = await getProcessInformationBasedOnRoles(150); |
|
const result = []; |
|
process.map((e) => { |
|
const cur = info.value.find((n) => n.stRecordId === e.id); |
|
let num = cur?.ruleOne.match(/\d+/g); |
|
let symbol = cur?.ruleOne.match(/[<>=]+/g); |
|
let had = cur?.ruleOne.match(/[有无]+/g); |
|
let temp = { |
|
checkpointId: levelId, |
|
projectId, |
|
name: e.name, |
|
recordChildren: e.recordChildren, |
|
isRule: isRule(e.id) ? 1 : 0, |
|
corporateMajorityHitRejected: !!cur?.corporateMajorityHitRejected, |
|
hitAccess: !!cur?.hitAccess, |
|
mateHitRejected: !!cur?.mateHitRejected, |
|
otherFamilyMembersHitRejected: !!cur?.otherFamilyMembersHitRejected, |
|
parentsHitRejected: !!cur?.parentsHitRejected, |
|
personalHitBlacklist: !!cur?.personalHitBlacklist, |
|
symbol: isRule(e.id) && symbol?.length ? symbol[0] : '>=', |
|
had: e.id === 167 && had?.length ? had[0] : '', |
|
num: isRule(e.id) && num?.length ? num[0] : '', |
|
ruleOne: '', |
|
ruleTwo: '', |
|
subjectId: e.subjectId, |
|
stRecordId: e.id, |
|
}; |
|
result.push(temp); |
|
if (isRule(e.id)) { |
|
temp = JSON.parse(JSON.stringify(temp)); |
|
temp.span = 1; |
|
|
|
num = cur?.ruleTwo?.match(/\d+/g); |
|
if (num?.length) temp.num = num[0]; |
|
symbol = cur?.ruleTwo?.match(/[<>=]+/g); |
|
if (symbol?.length) temp.symbol = symbol[0]; |
|
if (e.id === 167) temp.had = cur?.ruleTwo; |
|
result.push(temp); |
|
} |
|
}); |
|
form.value = result; |
|
}; |
|
// 详情 |
|
const getDetail = async () => { |
|
try { |
|
const { data } = await accessStrategyGovernmentBlacklistFind(levelId, projectId); |
|
info.value = data; |
|
getConfig(); |
|
} finally { |
|
} |
|
}; |
|
|
|
watch( |
|
() => route.query, |
|
() => { |
|
route.query.id === '150' && getDetail(); |
|
}, |
|
{ |
|
immediate: true, |
|
}, |
|
); |
|
|
|
// 判断是否是3个有输入框的指标 |
|
const isRule = (rule: number): boolean => { |
|
return rule === 161 || rule === 164 || rule === 167; |
|
}; |
|
interface SpanMethodProps { |
|
row: Record<string, any>; |
|
column: TableColumnCtx<Record<string, any>>; |
|
rowIndex: number; |
|
columnIndex: number; |
|
} |
|
// 表格合并 |
|
const span = ({ row, column, rowIndex, columnIndex }: SpanMethodProps) => { |
|
if (columnIndex === 0 || columnIndex === 2 || columnIndex === 3 || columnIndex === 4 || columnIndex === 5 || columnIndex === 6 || columnIndex === 7) { |
|
if (rowIndex === 4 || rowIndex === 6 || rowIndex === 8) { |
|
return { |
|
rowspan: 2, |
|
colspan: 1, |
|
}; |
|
} else if (rowIndex === 5 || rowIndex === 7 || rowIndex === 9) { |
|
return { |
|
rowspan: 0, |
|
colspan: 0, |
|
}; |
|
} |
|
} |
|
}; |
|
const checkRow = (e: boolean, row: Record<string, any>) => { |
|
if (e) row.hitAccess = false; |
|
}; |
|
const checkNone = (row: Record<string, any>) => { |
|
if (row.hitAccess) { |
|
row.corporateMajorityHitRejected = false; |
|
row.mateHitRejected = false; |
|
row.otherFamilyMembersHitRejected = false; |
|
row.parentsHitRejected = false; |
|
row.personalHitBlacklist = false; |
|
} |
|
}; |
|
// 提交 |
|
const submit = async () => { |
|
let param = JSON.parse(JSON.stringify(form.value)); |
|
param.map((e, i) => { |
|
if (info.value.length) e.id = info.value.find((n) => n.stRecordId === e.stRecordId)?.id; |
|
e.corporateMajorityHitRejected = +e.corporateMajorityHitRejected; |
|
e.hitAccess = +e.hitAccess; |
|
e.mateHitRejected = +e.mateHitRejected; |
|
e.otherFamilyMembersHitRejected = +e.otherFamilyMembersHitRejected; |
|
e.parentsHitRejected = +e.parentsHitRejected; |
|
e.personalHitBlacklist = +e.personalHitBlacklist; |
|
if (e.stRecordId == 161 || e.stRecordId == 164) { |
|
if (e.span) { |
|
// 这里是合并表格,详情那里多加了一行,这里数据要放到一行去 |
|
param[i - 1].ruleTwo = e.symbol + e.num; |
|
} else { |
|
e.ruleOne = e.symbol + e.num; |
|
} |
|
} else if (e.stRecordId == 167) { |
|
if (e.span) { |
|
// 这里是合并表格,详情那里多加了一行,这里数据要放到一行去 |
|
param[i - 1].ruleTwo = e.had; |
|
} else { |
|
e.ruleOne = e.symbol + e.num + ',' + e.had; |
|
} |
|
} |
|
}); |
|
param = param.filter((e) => !e.span); |
|
const recordParam = JSON.parse(JSON.stringify(param)); |
|
param.map((e) => { |
|
delete e.recordChildren; |
|
delete e.had; |
|
delete e.name; |
|
delete e.symbol; |
|
delete e.num; |
|
}); |
|
await accessStrategyGovernmentBlacklistSave({ governmentBlacklistList: param }); |
|
addRecord(recordParam); |
|
getDetail(); |
|
ElMessage.success('提交成功!'); |
|
}; |
|
// 新增判分记录 |
|
const addRecord = async (data: Record<string, any>) => { |
|
const preIds = `1,${Cookies.get('sand-level')},42,67,147,150`; // 1,关卡id,角色(这个页面是风控经理策略) |
|
const rule = []; |
|
|
|
data.map((e, i) => { |
|
const temp = []; |
|
e.personalHitBlacklist && temp.push(300); |
|
e.mateHitRejected && temp.push(301); |
|
e.parentsHitRejected && temp.push(302); |
|
e.otherFamilyMembersHitRejected && temp.push(303); |
|
e.corporateMajorityHitRejected && temp.push(304); |
|
e.hitAccess && temp.push(757); |
|
if (isRule(e.stRecordId)) { |
|
const len = e?.recordChildren?.length - 1; |
|
e?.recordChildren.map((n, j) => { |
|
if (j !== len) { |
|
if (n.id === 169 && e.had) { |
|
rule.push(handleId(n.id, n.subjectId, e.had === '有' ? 387 : 388, preIds + ',' + e.stRecordId + ',' + n.id, 1)); |
|
} else if (n.id === 168) { |
|
rule.push(handleId(n.id, n.subjectId, e.symbol + e.num, preIds + ',' + e.stRecordId + ',' + n.id, 5)); |
|
} else if (n.id === 170 && e.had) { |
|
rule.push(handleId(n.id, n.subjectId, e.had === '有' ? 389 : 390, preIds + ',' + e.stRecordId + ',' + n.id, 1)); |
|
} else { |
|
rule.push(handleId(n.id, n.subjectId, j ? (n.id === 168 ? e.symbol + e.num : e.ruleTwo) : e.ruleOne, preIds + ',' + e.stRecordId + ',' + n.id, 5)); |
|
} |
|
} else if (temp.length) { |
|
rule.push(handleId(n.id, e.subjectId, temp.join(), preIds + ',' + e.stRecordId + ',' + n.id, 1)); |
|
} |
|
}); |
|
} else { |
|
rule.push(handleId(e.stRecordId, e.subjectId, temp.join(), preIds + ',' + e.stRecordId, 1)); |
|
} |
|
}); |
|
|
|
await addOperation({ |
|
...getIds(), |
|
parentId: preIds, |
|
lcJudgmentRuleReq: rule, |
|
}); |
|
}; |
|
</script> |
|
|
|
<style lang="scss" scoped> |
|
@import url(../../../styles/form.scss); |
|
</style>
|
|
|