parent
f256826bc3
commit
5ea8d51d06
3 changed files with 400 additions and 4 deletions
@ -0,0 +1,398 @@ |
|||||||
|
<template> |
||||||
|
<!-- 企业 --> |
||||||
|
<el-table class="c-table" |
||||||
|
:data="form" |
||||||
|
:max-height="height" |
||||||
|
border> |
||||||
|
<el-table-column prop="name" |
||||||
|
label="指标" |
||||||
|
min-width="180" |
||||||
|
align="center"> |
||||||
|
</el-table-column> |
||||||
|
<el-table-column label="规则" |
||||||
|
min-width="250"> |
||||||
|
<template #default="{ row,$index }"> |
||||||
|
<div class="flex items-center"> |
||||||
|
<template v-if="!$index"> |
||||||
|
<span class="whitespace-nowrap">跨行业经营,行业门类数</span> |
||||||
|
<div class="w-[90px] mx-2"> |
||||||
|
<el-select v-model="row.symbol"> |
||||||
|
<el-option v-for="item in symbols" |
||||||
|
:key="item" |
||||||
|
:label="item" |
||||||
|
:value="item" /> |
||||||
|
</el-select> |
||||||
|
</div> |
||||||
|
<div class="w-[90px] "> |
||||||
|
<el-select v-model="row.num"> |
||||||
|
<el-option v-for="item in nums" |
||||||
|
:key="item" |
||||||
|
:label="item" |
||||||
|
:value="item" /> |
||||||
|
</el-select> |
||||||
|
</div> |
||||||
|
<span class="whitespace-nowrap ml-2">。</span> |
||||||
|
</template> |
||||||
|
<template v-else-if="$index === 1"> |
||||||
|
<span class="whitespace-nowrap">名下企业</span> |
||||||
|
<div class="w-[90px] mx-2"> |
||||||
|
<el-select v-model="row.had"> |
||||||
|
<el-option v-for="item in have" |
||||||
|
:key="item" |
||||||
|
:label="item" |
||||||
|
:value="item" /> |
||||||
|
</el-select> |
||||||
|
</div> |
||||||
|
<span class="whitespace-nowrap ml-2">房产查封。</span> |
||||||
|
</template> |
||||||
|
<template v-else-if="$index === 2"> |
||||||
|
<span class="whitespace-nowrap">名下企业</span> |
||||||
|
<div class="w-[90px] mx-2"> |
||||||
|
<el-select v-model="row.had"> |
||||||
|
<el-option v-for="item in have" |
||||||
|
:key="item" |
||||||
|
:label="item" |
||||||
|
:value="item" /> |
||||||
|
</el-select> |
||||||
|
</div> |
||||||
|
<span class="whitespace-nowrap ml-2">股权冻结。</span> |
||||||
|
</template> |
||||||
|
<template v-else-if="$index === 3"> |
||||||
|
<span class="whitespace-nowrap">行内企业</span> |
||||||
|
<div class="w-[90px] mx-2"> |
||||||
|
<el-select v-model="row.had"> |
||||||
|
<el-option v-for="item in have" |
||||||
|
:key="item" |
||||||
|
:label="item" |
||||||
|
:value="item" /> |
||||||
|
</el-select> |
||||||
|
</div> |
||||||
|
<span class="whitespace-nowrap ml-2">不良贷款客户。</span> |
||||||
|
</template> |
||||||
|
<template v-else-if="$index === 4"> |
||||||
|
<el-checkbox-group v-model="row.check"> |
||||||
|
<el-checkbox v-for="item in row?.subject?.itemList" |
||||||
|
:key="item" |
||||||
|
:label="item.options" /> |
||||||
|
</el-checkbox-group> |
||||||
|
</template> |
||||||
|
<template v-else-if="$index === 5"> |
||||||
|
<div class="w-[90px]"> |
||||||
|
<el-select v-model="row.had" |
||||||
|
clearable> |
||||||
|
<el-option value="不是" /> |
||||||
|
<el-option value="是" /> |
||||||
|
</el-select> |
||||||
|
</div> |
||||||
|
<span class="whitespace-nowrap ml-2">被列为非正常户或注销户。</span> |
||||||
|
</template> |
||||||
|
<template v-else-if="$index === 6"> |
||||||
|
<div class="w-[90px]"> |
||||||
|
<el-select v-model="row.had" |
||||||
|
clearable> |
||||||
|
<el-option value="不是" /> |
||||||
|
<el-option value="是" /> |
||||||
|
</el-select> |
||||||
|
</div> |
||||||
|
<span class="whitespace-nowrap ml-2">非正常户或注销户。</span> |
||||||
|
</template> |
||||||
|
<template v-else-if="$index === 7"> |
||||||
|
<span class="whitespace-nowrap">经营年限</span> |
||||||
|
<div class="w-[90px] ml-2"> |
||||||
|
<el-select v-model="row.symbol"> |
||||||
|
<el-option v-for="item in symbols" |
||||||
|
:key="item" |
||||||
|
:label="item" |
||||||
|
:value="item" /> |
||||||
|
</el-select> |
||||||
|
</div> |
||||||
|
<div class="w-[90px] mx-2"> |
||||||
|
<el-select v-model="row.num"> |
||||||
|
<el-option v-for="item in nums" |
||||||
|
:key="item" |
||||||
|
:label="item" |
||||||
|
:value="item" /> |
||||||
|
</el-select> |
||||||
|
</div> |
||||||
|
<div class="w-[90px] "> |
||||||
|
<el-select v-model="row.unit"> |
||||||
|
<el-option v-for="item in units" |
||||||
|
:key="item" |
||||||
|
:label="item" |
||||||
|
:value="item" /> |
||||||
|
</el-select> |
||||||
|
</div> |
||||||
|
<span class="whitespace-nowrap ml-2">。</span> |
||||||
|
</template> |
||||||
|
<template v-else-if="$index === 8"> |
||||||
|
<span class="whitespace-nowrap mr-2">企业性质涉及</span> |
||||||
|
<el-checkbox-group v-model="row.check"> |
||||||
|
<el-checkbox v-for="item in row?.subject?.itemList" |
||||||
|
:key="item" |
||||||
|
:label="item.options" /> |
||||||
|
</el-checkbox-group> |
||||||
|
</template> |
||||||
|
<template v-else-if="$index === 9"> |
||||||
|
<div class="w-[90px]"> |
||||||
|
<el-select v-model="row.symbol"> |
||||||
|
<el-option v-for="item in symbols" |
||||||
|
:key="item" |
||||||
|
:label="item" |
||||||
|
:value="item" /> |
||||||
|
</el-select> |
||||||
|
</div> |
||||||
|
<div class="w-[90px] mx-2"> |
||||||
|
<el-select v-model="row.num"> |
||||||
|
<el-option v-for="item in nums" |
||||||
|
:key="item" |
||||||
|
:label="item" |
||||||
|
:value="item" /> |
||||||
|
</el-select> |
||||||
|
</div> |
||||||
|
<div class="w-[90px]"> |
||||||
|
<el-select v-model="row.unit"> |
||||||
|
<el-option v-for="item in units" |
||||||
|
:key="item" |
||||||
|
:label="item" |
||||||
|
:value="item" /> |
||||||
|
</el-select> |
||||||
|
</div> |
||||||
|
<span class="whitespace-nowrap ml-2">注册资本减少。</span> |
||||||
|
</template> |
||||||
|
<template v-else-if="$index === 10"> |
||||||
|
<div class="w-[90px]"> |
||||||
|
<el-select v-model="row.symbol"> |
||||||
|
<el-option v-for="item in symbols" |
||||||
|
:key="item" |
||||||
|
:label="item" |
||||||
|
:value="item" /> |
||||||
|
</el-select> |
||||||
|
</div> |
||||||
|
<div class="w-[90px] mx-2"> |
||||||
|
<el-select v-model="row.num"> |
||||||
|
<el-option v-for="item in nums" |
||||||
|
:key="item" |
||||||
|
:label="item" |
||||||
|
:value="item" /> |
||||||
|
</el-select> |
||||||
|
</div> |
||||||
|
<div class="w-[90px]"> |
||||||
|
<el-select v-model="row.unit"> |
||||||
|
<el-option v-for="item in units" |
||||||
|
:key="item" |
||||||
|
:label="item" |
||||||
|
:value="item" /> |
||||||
|
</el-select> |
||||||
|
</div> |
||||||
|
<span class="whitespace-nowrap ml-2">内法定代表人变更。</span> |
||||||
|
</template> |
||||||
|
<template v-else-if="$index === 11"> |
||||||
|
<div class="w-[90px]"> |
||||||
|
<el-select v-model="row.symbol"> |
||||||
|
<el-option v-for="item in symbols" |
||||||
|
:key="item" |
||||||
|
:label="item" |
||||||
|
:value="item" /> |
||||||
|
</el-select> |
||||||
|
</div> |
||||||
|
<div class="w-[90px] mx-2"> |
||||||
|
<el-select v-model="row.num"> |
||||||
|
<el-option v-for="item in nums" |
||||||
|
:key="item" |
||||||
|
:label="item" |
||||||
|
:value="item" /> |
||||||
|
</el-select> |
||||||
|
</div> |
||||||
|
<div class="w-[90px]"> |
||||||
|
<el-select v-model="row.unit"> |
||||||
|
<el-option v-for="item in units" |
||||||
|
:key="item" |
||||||
|
:label="item" |
||||||
|
:value="item" /> |
||||||
|
</el-select> |
||||||
|
</div> |
||||||
|
<span class="whitespace-nowrap ml-2">内大股东(股权占比>=50%)变更。</span> |
||||||
|
</template> |
||||||
|
<template v-else-if="$index === 12"> |
||||||
|
命中禁入行业名单中企业拒绝规则 |
||||||
|
</template> |
||||||
|
<template v-else-if="$index === 13"> |
||||||
|
<span class="whitespace-nowrap">申请人在该企业的股权占比</span> |
||||||
|
<div class="w-[90px] mx-2"> |
||||||
|
<el-select v-model="row.symbol"> |
||||||
|
<el-option v-for="item in symbols" |
||||||
|
:key="item" |
||||||
|
:label="item" |
||||||
|
:value="item" /> |
||||||
|
</el-select> |
||||||
|
</div> |
||||||
|
<div class="w-[90px] "> |
||||||
|
<el-select v-model="row.num"> |
||||||
|
<el-option v-for="item in nums" |
||||||
|
:key="item" |
||||||
|
:label="item" |
||||||
|
:value="item" /> |
||||||
|
</el-select> |
||||||
|
</div> |
||||||
|
<span class="whitespace-nowrap ml-2">%。</span> |
||||||
|
</template> |
||||||
|
<template v-else-if="$index === 14"> |
||||||
|
<div class="w-[90px] mx-2"> |
||||||
|
<el-select v-model="row.had" |
||||||
|
clearable> |
||||||
|
<el-option value="不在" /> |
||||||
|
<el-option value="在" /> |
||||||
|
</el-select> |
||||||
|
</div> |
||||||
|
<span class="whitespace-nowrap ml-2">工商局或农专经营异常目录。</span> |
||||||
|
</template> |
||||||
|
</div> |
||||||
|
</template> |
||||||
|
</el-table-column> |
||||||
|
</el-table> |
||||||
|
|
||||||
|
<div class="flex justify-end"> |
||||||
|
<div class="submit" |
||||||
|
@click="submit">确认完成配置</div> |
||||||
|
</div> |
||||||
|
</template> |
||||||
|
|
||||||
|
<script setup lang="ts"> |
||||||
|
import { ref, watch } from 'vue'; |
||||||
|
import { ElMessage } from 'element-plus'; |
||||||
|
import { accessStrategyEnterpriseBlacklistFind, accessStrategyEnterpriseBlacklistSave } from '@/api/model'; |
||||||
|
import { getProcessInformationBasedOnRoles, addOperation } from '@/api/judgment'; |
||||||
|
import type { TableColumnCtx } from 'element-plus'; |
||||||
|
import { useRouter, useRoute } from 'vue-router'; |
||||||
|
import { handleId, getNum, getSymbol, getChinese } 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 - 270; |
||||||
|
const symbols: Array<string> = ['>=', '<', '>', '==', '<=']; |
||||||
|
const nums: Array<number> = [1, 3, 5, 6, 16, 33, 40]; |
||||||
|
const units: Array<string> = ['年', '月', '天']; |
||||||
|
const have: Array<string> = ['无', '有']; |
||||||
|
// 配置项 |
||||||
|
const getConfig = async () => { |
||||||
|
const { process } = await getProcessInformationBasedOnRoles(154); |
||||||
|
const result = []; |
||||||
|
process.map((e, i) => { |
||||||
|
const cur = info.value.find((n) => n.stRecordId === e.id); |
||||||
|
let num = getNum(cur?.rule); |
||||||
|
let symbol = getSymbol(cur?.rule); |
||||||
|
let had = getChinese(cur?.rule); |
||||||
|
let temp = { |
||||||
|
name: e.name, |
||||||
|
subject: e.subject, |
||||||
|
stRecordId: e.id, |
||||||
|
symbol: symbol || '>=', |
||||||
|
unit: had || '年', |
||||||
|
num: num || 1, |
||||||
|
had: (((i > 0 && i < 4) || i === 5 || i === 6 || i === 14) && cur?.rule) || '', |
||||||
|
check: (i === 4 || i === 8) && cur ? cur?.rule.split(',') : [], |
||||||
|
}; |
||||||
|
|
||||||
|
result.push(temp); |
||||||
|
}); |
||||||
|
form.value = result; |
||||||
|
}; |
||||||
|
// 详情 |
||||||
|
const getDetail = async () => { |
||||||
|
try { |
||||||
|
const { data } = await accessStrategyEnterpriseBlacklistFind(levelId, projectId); |
||||||
|
info.value = data; |
||||||
|
getConfig(); |
||||||
|
} finally { |
||||||
|
} |
||||||
|
}; |
||||||
|
|
||||||
|
watch( |
||||||
|
() => route.query, |
||||||
|
() => { |
||||||
|
getDetail(); |
||||||
|
}, |
||||||
|
{ |
||||||
|
immediate: true, |
||||||
|
}, |
||||||
|
); |
||||||
|
|
||||||
|
// 提交 |
||||||
|
const submit = async () => { |
||||||
|
let param = []; |
||||||
|
form.value.map((e, i) => { |
||||||
|
const temp = { |
||||||
|
id: info.value.find((n) => n.stRecordId === e.stRecordId)?.id ?? '', |
||||||
|
stRecordId: e.stRecordId, |
||||||
|
checkpointId: levelId, |
||||||
|
projectId, |
||||||
|
}; |
||||||
|
let rule; |
||||||
|
if (!i || i === 13) { |
||||||
|
rule = e.symbol + e.num; |
||||||
|
} else if ((i > 0 && i < 4) || i === 5 || i === 6 || i === 14) { |
||||||
|
rule = e.had; |
||||||
|
} else if (i === 4 || i === 8) { |
||||||
|
rule = e.check.join(); |
||||||
|
} else if (i === 7 || i === 9 || i === 10 || i === 11) { |
||||||
|
rule = e.symbol + e.num + e.unit; |
||||||
|
} |
||||||
|
temp.rule = rule; |
||||||
|
param.push(temp); |
||||||
|
}); |
||||||
|
await accessStrategyEnterpriseBlacklistSave({ enterpriseBlacklistList: param }); |
||||||
|
// addRecord(param); |
||||||
|
getDetail(); |
||||||
|
ElMessage.success('提交成功!'); |
||||||
|
}; |
||||||
|
// 新增判分记录 |
||||||
|
const addRecord = async (data: Record<string, any>) => { |
||||||
|
const preIds = `1,${Cookies.get('sand-level')},42,67,147,154`; // 1,关卡id,角色(这个页面是风控经理策略) |
||||||
|
const rule = <Record<string, any>[]>[ |
||||||
|
handleId(324, 150, data[0].ruleOne, preIds + ',318,324', 5), |
||||||
|
handleId(325, 151, data[0].ruleTwo, preIds + ',318,325', 5), |
||||||
|
handleId(326, 152, data[0].ruleThree, preIds + ',318,326', 5), |
||||||
|
handleId(327, 153, data[0].ruleFour, preIds + ',318,327', 5), |
||||||
|
|
||||||
|
handleId(353, 154, data[1].ruleOne, preIds + ',320,353', 5), |
||||||
|
]; |
||||||
|
form.value[14].had && rule.push(handleId(354, 155, form.value[14].had === '有商品房' ? 353 : 354, preIds + ',320,354', 1)); |
||||||
|
rule.push( |
||||||
|
handleId(355, 156, form.value[15].num + form.value[15].symbol, preIds + ',320,355', 5), |
||||||
|
handleId(356, 157, form.value[15].symbol1 + form.value[15].num1, preIds + ',320,356', 5), |
||||||
|
); |
||||||
|
form.value[15].had && rule.push(handleId(357, 155, form.value[15].had === '有商品房' ? 353 : 354, preIds + ',320,357', 1)); |
||||||
|
data[2].ruleOne && rule.push(handleId(342, 158, data[2].ruleOne === '拒绝' ? 355 : 356, preIds + ',322,342', 1)); |
||||||
|
rule.push( |
||||||
|
handleId(344, 159, data[2].ruleTwo, preIds + ',322,344', 5), |
||||||
|
handleId(345, 160, data[2].ruleThree, preIds + ',322,345', 5), |
||||||
|
handleId(346, 161, data[2].ruleFour, preIds + ',322,346', 5), |
||||||
|
handleId(347, 162, data[2].ruleFive, preIds + ',322,347', 5), |
||||||
|
handleId(348, 163, data[2].ruleSix, preIds + ',322,348', 5), |
||||||
|
handleId(349, 164, data[2].ruleSeven, preIds + ',322,349', 5), |
||||||
|
handleId(350, 165, data[2].ruleEight, preIds + ',322,350', 5), |
||||||
|
handleId(351, 166, data[2].ruleNine, preIds + ',322,351', 5), |
||||||
|
); |
||||||
|
|
||||||
|
await addOperation({ |
||||||
|
checkpointId: levelId, |
||||||
|
parentId: preIds, |
||||||
|
lcJudgmentRuleReq: rule, |
||||||
|
projectId, |
||||||
|
}); |
||||||
|
}; |
||||||
|
</script> |
||||||
|
|
||||||
|
<style lang="scss" scoped> |
||||||
|
@import url(../../../styles/form.scss); |
||||||
|
.c-table { |
||||||
|
:deep(.el-input__inner) { |
||||||
|
@apply px-2; |
||||||
|
} |
||||||
|
} |
||||||
|
</style> |
Loading…
Reference in new issue