diff --git a/src/api/model.ts b/src/api/model.ts index 4129c70..98c889e 100644 --- a/src/api/model.ts +++ b/src/api/model.ts @@ -40,3 +40,25 @@ export const findCredit = async (id: number): Promise => (await axios.post( export const listCredit = async (data: Record): Promise => (await axios.post(`/product/creditScoringStrategy/list?checkpointId=${data.checkpointId}&projectId=${data.projectId}&pageNum=${data.pageNum}&pageSize=${data.pageSize}`)).data; export const saveCredit = async (data: Record): Promise => (await axios.post(`/product/creditScoringStrategy/saveOrUpdate`, data)).data; + +export const detailRick = async (data: Record): Promise => + (await axios.post(`/product/riskDegreeStrategy/details?checkpointId=${data.checkpointId}&projectId=${data.projectId}&type=${data.type}`)).data; +export const saveRick = async (data: Record): Promise => (await axios.post(`/product/riskDegreeStrategy/saveOrUpdate`, data)).data; + +export const detailInterestRateBusiness = async (data: Record): Promise => + (await axios.post(`/product/interestRateModel/businessInterestRateDetails?checkpointId=${data.checkpointId}&projectId=${data.projectId}`)).data; +export const saveInterestRateBusiness = async (data: Record): Promise => + (await axios.post(`/product/interestRateModel/businessInterestRateSaveOrUpdate`, data)).data; +export const detailInterestRatePerson = async (data: Record): Promise => + (await axios.post(`/product/interestRateModel/personalInterestRateDetails?checkpointId=${data.checkpointId}&projectId=${data.projectId}`)).data; +export const saveInterestRatePerson = async (data: Record): Promise => + (await axios.post(`/product/interestRateModel/personalInterestRateSaveOrUpdate`, data)).data; + +export const businessQuotaModelDetails = async (data: Record): Promise => + (await axios.post(`/product/quotaModel/businessQuotaModelDetails?checkpointId=${data.checkpointId}&projectId=${data.projectId}`)).data; +export const businessQuotaModelSaveOrUpdate = async (data: Record): Promise => + (await axios.post(`/product/quotaModel/businessQuotaModelSaveOrUpdate`, data)).data; +export const personalCreditModelDetails = async (data: Record): Promise => + (await axios.post(`/product/quotaModel/personalCreditModelDetails?checkpointId=${data.checkpointId}&projectId=${data.projectId}`)).data; +export const personalCreditModelSaveOrUpdate = async (data: Record): Promise => + (await axios.post(`/product/quotaModel/personalCreditModelSaveOrUpdate`, data)).data; diff --git a/src/views/product/insurance/Add.vue b/src/views/product/insurance/Add.vue index b9ecbba..6f2f07e 100644 --- a/src/views/product/insurance/Add.vue +++ b/src/views/product/insurance/Add.vue @@ -197,7 +197,7 @@ const submit = async () => { e.check && e.sumInsured && param.insuranceCoverageConfigList.push({ - insuredLiabilityId: e.subjectId, + insuredLiabilityId: e.id, sumInsured: +e.sumInsured, }); }); @@ -214,15 +214,27 @@ const submit = async () => { const addRecord = async (data: Record) => { const preIds = `1,${Cookies.get('sand-level')},275,${data.insuranceType === 310 ? 276 : 277}`; // 1,关卡id,角色(这个页面是保险产品经理新增产品),个人/企业(44/45) const rule: Array> = [handleId(278, 118, data.insuranceName, preIds + ',278', 3), handleId(279, 119, data.insuranceType, preIds + ',279', 1)]; - data.minimumAge && rule.push(handleId(680, 219, data.minimumAge, preIds + '678,680', 3)); - data.maximumAge && rule.push(handleId(679, 218, data.maximumAge, preIds + '678,679', 3)); + data.minimumAge && rule.push(handleId(680, 219, data.minimumAge, preIds + ',678,680', 3)); + data.maximumAge && rule.push(handleId(679, 218, data.maximumAge, preIds + ',678,679', 3)); // 保险额度 config.value[form.insuranceType === 310 ? 0 : 1]?.recordChildren[2]?.recordChildren?.map((e) => { - e.check && e.sumInsured && rule.push(handleId(e.id, e.subjectId, e.sumInsured, preIds + ',280,' + e.id, 3)); + rule.push(handleId(766, 140, e.check ? 345 : 346, `${preIds},280,${e.id},766`, 1)); + e.check && e.sumInsured && rule.push(handleId(767, 234, e.sumInsured, `${preIds},280,${e.id},767`, 3)); }); data.premiumAmount && rule.push(handleId(296, 134, data.premiumAmount, preIds + ',296', 3)); data.formOfPayment && rule.push(handleId(297, 135, data.formOfPayment, preIds + ',297', 1)); - data.insuranceDeadline && rule.push(handleId(298, 136, data.insuranceDeadline, preIds + ',298', 3)); + + form.insuranceDeadline && rule.push(handleId(770, 136, form.insuranceDeadline, preIds + ',298,770', 3)); + form.insuranceDeadlineUnit && + rule.push( + handleId( + 771, + 235, + config.value[form.insuranceType === 310 ? 0 : 1]?.recordChildren[5]?.recordChildren[1]?.subject?.itemList?.find((e) => e.options === form.insuranceDeadlineUnit)?.itemId, + preIds + ',298,771', + 1, + ), + ); data.applicationMaterial && rule.push(handleId(299, 137, data.applicationMaterial, preIds + ',299', 1)); data.exemptionFromLiability && rule.push(handleId(301, 139, data.exemptionFromLiability, preIds + ',301', 1)); diff --git a/src/views/product/strategy/Credit.vue b/src/views/product/strategy/Credit.vue index 2129bbe..ee2335f 100644 --- a/src/views/product/strategy/Credit.vue +++ b/src/views/product/strategy/Credit.vue @@ -16,7 +16,106 @@
评分表
- + + + + + + + + + + + + + + + @@ -68,7 +167,6 @@ import { getProcessInformationBasedOnRoles, addOperation } from '@/api/judgment' import { useRouter, useRoute } from 'vue-router'; import type { TableColumnCtx } from 'element-plus'; import { handleId } from '@/utils/common'; -// import Info from './Info.vue'; import Cookies from 'js-cookie'; const emit = defineEmits(['getList']); @@ -80,6 +178,7 @@ const projectId = +Cookies.get('sand-projectId'); const levelId = +Cookies.get('sand-level'); let loading: boolean = true; const list = ref[]>([]); +const list1 = ref[]>([]); const detail = ref>({}); const scoringObjects = ref>([ { @@ -91,23 +190,24 @@ const scoringObjects = ref>([ name: '企业', }, ]); -const form = reactive({ +const form = reactive({ checkpointId: levelId, projectId, description: '', scoreCardName: '', - scoringObject: 0, + scoringObject: 1, id: computed(() => route.query.creditId || ''), }); // 配置项 const getConfig = async () => { const { process } = await getProcessInformationBasedOnRoles(148); + // 个人 const result = []; process[0]?.recordChildren.slice(3).forEach((e, j) => { e?.recordChildren.forEach((n, i) => { if (i) { - const cur = detail.value[j]; + const cur = !form.scoringObject && detail.value[j]; result.push({ answerId1: e.id, answerId2: n.id, @@ -127,6 +227,52 @@ const getConfig = async () => { }); }); list.value = result; + + // 企业 + const result1 = []; + process[1]?.recordChildren.slice(3).forEach((e, j) => { + result1.push({ + id: e.id, + name: e.name, + isChoose: false, + top: 1, + }); + e?.recordChildren.forEach((n, i) => { + if (i) { + let temp = { + answerId1: e.id, + answerId2: n.id, + subjectId: n.subjectId, + id: '', + dimensionId: '', + strategyId: '', + name: e.name, + sub: n.name, + index: n?.recordChildren[1]?.name, + remark: n.remark, + isChoose: false, + score: '', + span: i === 1 ? 1 : 0, + middle: 1, // 第二层的标识 + parent: i === 1 ? '' : j, + recordChildren: n?.recordChildren, + }; + result1.push(temp); + if (e.id === 589 || e.id === 594) { + n?.recordChildren.forEach((m, o) => { + if (o > 1) { + temp = JSON.parse(JSON.stringify(temp)); + temp.index = m.name; + delete temp.middle; + result1.push(temp); + } + }); + } + } + }); + }); + list1.value = result1; + console.log('🚀 ~ file: Credit.vue:202 ~ getConfig ~ result1:', result1); loading.close(); }; // 详情 @@ -154,7 +300,7 @@ const getDetail = async () => { form.description = ''; form.projectId = projectId; form.scoreCardName = ''; - form.scoringObject = 0; + form.scoringObject = 1; } }; watch( @@ -166,13 +312,49 @@ watch( immediate: true, }, ); +const isSelect = (rule: number): boolean => { + return rule === 589 || rule === 594; +}; interface SpanMethodProps { row: Record; column: TableColumnCtx>; rowIndex: number; columnIndex: number; } + +const rowMerge1 = [1, 4, 7, 10, 40, 43, 46]; +const rowMerge2 = [2, 3, 5, 6, 8, 9, 11, 12, 41, 42, 44, 45, 47, 48]; +const rowMerge3 = [0, 13, 18, 26, 33, 39, 49]; // 表格合并 +const span1 = ({ row, column, rowIndex, columnIndex }: SpanMethodProps) => { + if (rowMerge3.includes(rowIndex)) { + if (!columnIndex) { + return { + rowspan: 1, + colspan: 5, + }; + } else { + return { + rowspan: 0, + colspan: 0, + }; + } + } + + if (!columnIndex || columnIndex === 1 || columnIndex === 2) { + if (rowMerge1.includes(rowIndex)) { + return { + rowspan: 3, + colspan: 1, + }; + } else if (rowMerge2.includes(rowIndex)) { + return { + rowspan: 0, + colspan: 0, + }; + } + } +}; const span = ({ row, column, rowIndex, columnIndex }: SpanMethodProps) => { if (!columnIndex || columnIndex === 1) { if (!rowIndex || rowIndex === 31) { @@ -209,35 +391,29 @@ const submit = async () => { loading = ElLoading.service(); const param = []; list.value.forEach((e) => { + const child = { + id: e.id, + dimensionId: e.dimensionId, + recordName: e.sub, + score: e.score, + }; if (e.span) { param.push({ dimensionId: e.dimensionId, strategyId: e.strategyId, recordName: e.name, isChoose: +e.isChoose, - dimensionIndexList: [ - { - id: e.id, - dimensionId: e.dimensionId, - recordName: e.sub, - score: e.score, - }, - ], + dimensionIndexList: [child], }); } else { - param[e.parent].dimensionIndexList.push({ - id: e.id, - dimensionId: e.dimensionId, - recordName: e.sub, - score: e.score, - }); + param[e.parent].dimensionIndexList.push(child); } }); await saveCredit({ ...form, dimensionOfTheRatingTableList: param, }); - addRecord(); + // addRecord(); ElMessage.success('提交成功!'); emit('getList', 1); @@ -248,52 +424,22 @@ const addRecord = async () => { const isEnterprise = form.scoringObject; const preIds = `1,${Cookies.get('sand-level')},42,148,${form.scoringObject ? 513 : 512}`; // 1,关卡id,角色(这个页面是风控经理),个人/企业(512/513) const lcRule: Array> = [handleId(514, 190, form.scoreCardName, preIds + ',514', 3), handleId(515, 191, form.scoringObject ? 392 : 391, preIds + ',515', 1)]; + form.description && lcRule.push(handleId(516, 192, '94,' + form.description, preIds + ',516', 3)); // 企业 if (isEnterprise) { - lcRule.push( - handleId(120, 44, data.accountMaterials, preIds + ',112,120', 1), - handleId(121, 45, 162, preIds + ',112,121', 1), - handleId(122, 46, data.loanApplicationMethod, preIds + ',113,122', 1), - handleId(123, 47, data.borrowerMaterial, preIds + ',113,123', 1), - handleId(124, 48, data.collateral, preIds + ',113,124', 1), - handleId(125, 49, data.businessMaterials, preIds + ',113,125', 1), - handleId(126, 50, data.supplementaryMaterials, preIds + ',113,126', 1), - - handleId(127, 51, data.runBatchObject, preIds + ',114,127', 1), - handleId(128, 52, data.accessStrategy, preIds + ',114,128', 1), - ); - data.personalCreditScoringStrategiesCheck && lcRule.push(handleId(129, 53, '240,' + data.personalCreditScoringStrategies, preIds + ',114,129', 1)); - data.corporateCreditScoringStrategiesCheck && lcRule.push(handleId(129, 53, '241,' + data.corporateCreditScoringStrategies, preIds + ',114,129', 1)); - - lcRule.push(handleId(130, 54, data.riskDegreeStrategy, preIds + ',114,130', 1)); - data.interestRatePricingModelCheck && lcRule.push(handleId(131, 55, '247,' + data.interestRatePricingModel, preIds + ',114,131', 1)); - data.individualInterestRateModel && lcRule.push(handleId(131, 55, data.individualInterestRateModel, preIds + ',114,131', 1)); - - lcRule.push( - handleId(132, 56, data.dueDiligenceMode, preIds + ',115,132', 1), - handleId(133, 57, data.dueDiligenceContent, preIds + ',115,133', 1), - handleId(134, 58, data.reviewContent, preIds + ',116,134', 1), - handleId(135, 59, data.reviewSignature, preIds + ',116,135', 1), - handleId(136, 60, data.reviewApproveContent, preIds + ',117,136', 1), - handleId(137, 61, data.approvalSignature, preIds + ',117,137', 1), - handleId(138, 62, data.contractMaterials, preIds + ',118,138', 1), - ); - data.loanContract && lcRule.push(handleId(139, 63, data.loanContract, preIds + ',118,139', 1)); - data.mortgageContract && lcRule.push(handleId(139, 63, data.mortgageContract, preIds + ',118,139', 1)); - data.pledgeContract && lcRule.push(handleId(139, 63, data.pledgeContract, preIds + ',118,139', 1)); - data.guaranteeContract && lcRule.push(handleId(139, 63, data.guaranteeContract, preIds + ',118,139', 1)); - lcRule.push(handleId(140, 64, data.selectionStrategy, preIds + ',119,140', 1)); - } else { - form.description && lcRule.push(handleId(516, 192, '94,' + form.description, preIds + ',516', 3)); - list.value.forEach((e) => { - if (e.span) { - // e.isChoose && lcRule.push(handleId(e.answerId2, '', '', preIds + ',' + e.answerId1 + ',' + e.answerId2, '')) - e.isChoose && lcRule.push(handleId(518, '', '', preIds + ',' + e.answerId1 + ',518', '')); - } else { - lcRule.push(handleId(e.answerId2, e.subjectId, e?.itemList?.find((n) => n.options == e.score)?.itemId || '', preIds + ',' + e.answerId1 + ',' + e.answerId2, 1)); + // 选择了才需要给 + if (e.isChoose) { + e.middle ? lcRule.push(handleId(518, '', '', `${preIds},${e.answerId1},${e.answerId2},518`, '')) : lcRule.push(handleId(518, '', '', `${preIds},${e.answerId1},518`, '')); } + lcRule.push(handleId(e.answerId2, e.subjectId, e?.itemList?.find((n) => n.options == e.score)?.itemId || '', `${preIds},${e.answerId1},${e.answerId2}`, 1)); + }); + } else { + // 个人 + list.value.forEach((e) => { + e.span && e.isChoose && lcRule.push(handleId(518, '', '', preIds + ',' + e.answerId1 + ',518', '')); + lcRule.push(handleId(e.answerId2, e.subjectId, e?.itemList?.find((n) => n.options == e.score)?.itemId || '', preIds + ',' + e.answerId1 + ',' + e.answerId2, 1)); }); } diff --git a/src/views/report/Index.vue b/src/views/report/Index.vue index 321ce61..ed67492 100644 --- a/src/views/report/Index.vue +++ b/src/views/report/Index.vue @@ -232,6 +232,18 @@ const userScores = ref[]>([]); // 处理实验数据 const handleList = (list: Record[]) => { + list.map((e) => { + e.assessmentPoint = ''; + e.referenceAnswer = ''; + e.answer = ''; + e?.lcRuleRecords?.map((n, i) => { + e.assessmentPoint += `${i + 1}.${n.name}`; + // e.referenceAnswer += `${i + 1}.${n.ruleAnswer}`; + e.referenceAnswer += `${i + 1}.${n.ruleAnswer}`; + e.answer += `${i + 1}.${n.userAnswer || '未填写'}`; + }); + }); + console.log('🚀 ~ file: Index.vue:235 ~ handleList ~ list:', list); expData.value = list; }; // 查询详情 @@ -248,19 +260,35 @@ const getData = async () => { data: JSON.stringify(res.userScores), }); } else { - handleList(res.userScores.find((e) => e.lcRuleRecords) ? res.userScores : JSON.parse(data)); + handleList(res.userScores); } }; // 导出 const exportPage = async () => { const param = JSON.parse(JSON.stringify(form.value)); + const list = JSON.parse(JSON.stringify(expData.value)); + list.forEach((e, i) => { + e.id = i + 1; + if (e.referenceAnswer && typeof e.referenceAnswer === 'string') + e.referenceAnswer = e.referenceAnswer + .replace(/<[^>]+>/g, '') + .replace(/( |&|%s)/g, '') + .replace(/>/g, '>') + .replace(/]+>/g, ''); + e.answer = e.answer.replace(/( |&|%s)/g, ''); + e.answer = e.answer.replace(/>/g, '>'); + e.answer = e.answer.replace(/]+>/g, ''); } param.purpose = param.purpose.replace(/<[^>]+>/g, ''); const res = await exportBankExperimentReport({ ...param, - experimentalData: expData.value, + experimentalData: list, }); downloadFileDirect(`实验报告.docx`, new Blob([res])); };