diff --git a/src/api/aftersales/aftersalesWorkOrder.js b/src/api/aftersales/aftersalesWorkOrder.js index 7a29a6d4..ab015a4d 100644 --- a/src/api/aftersales/aftersalesWorkOrder.js +++ b/src/api/aftersales/aftersalesWorkOrder.js @@ -436,4 +436,12 @@ export const $_updateProcessingParty = (data) => { method: 'put', data }) +} + +export const $_settlementUpdate = (data) => { + return request({ + url: '/api/logpm-aftersales/aftersalesWorkOrder/update', + method: 'post', + data + }) } \ No newline at end of file diff --git a/src/option/aftersales/vueTvemp.js b/src/option/aftersales/vueTvemp.js index 5a6feca7..c9080314 100644 --- a/src/option/aftersales/vueTvemp.js +++ b/src/option/aftersales/vueTvemp.js @@ -407,7 +407,7 @@ export const Claimsfield = [ { prop: 'workOrderNumber', label: '异常工单号', - type: 2, + type:13, values: '', width: '130', checkarr: [], @@ -486,7 +486,7 @@ export const Claimsfield = [ label: '异常类型名称', type: 3, values: '', - width: '100', + width: '120', checkarr: [], fixed: false, sortable: true, @@ -508,7 +508,7 @@ export const Claimsfield = [ label: '处理结果名称', type: 3, values: '', - width: '100', + width: '120', checkarr: [], fixed: false, sortable: true, @@ -538,10 +538,10 @@ export const Claimsfield = [ // }, { prop: 'discoveryNodeName', - label: '发现环节名称', + label: '发现环节', type: 3, values: '', - width: '100', + width: '120', checkarr: [], fixed: false, sortable: true, @@ -552,7 +552,7 @@ export const Claimsfield = [ label: '处理结果说明', type: 2, values: '', - width: '100', + width: '120', checkarr: [], fixed: false, sortable: true, @@ -618,7 +618,7 @@ export const Claimsfield = [ label: '钉钉流程号', type: 2, values: '', - width: '100', + width: '120', checkarr: [], fixed: false, sortable: true, @@ -637,10 +637,10 @@ export const Claimsfield = [ // }, { prop: 'workOrderStatusName', - label: '工单状态名称', + label: '工单状态', type: 3, values: '', - width: '100', + width: '120', checkarr: [], fixed: false, sortable: true, @@ -651,14 +651,13 @@ export const Claimsfield = [ label: '操作', type: 6, values: '', - width: '80', + width: '170', checkarr: [], fixed: 'right', sortable: false, }, ] - // 申诉列表 export const AppealList = [ diff --git a/src/router/views/index.js b/src/router/views/index.js index 308cb55d..61ee401f 100644 --- a/src/router/views/index.js +++ b/src/router/views/index.js @@ -1265,6 +1265,23 @@ export default [ ], }, + { + path: '/aftersales/aftersalesWorkOrderInfoTemp', + component: Layout, + redirect: '/aftersales/aftersalesWorkOrderInfoTemp', + children: [ + { + meta: { + i18n: 'dict', + keepAlive: false, + }, + path: '/aftersales/aftersalesWorkOrderInfoTemp', + name: '重构详情', + component: () => import('@/views/aftersales/aftersalesWorkOrderInfoTemp.vue'), + }, + ], + }, + { path: '/aftersales/aftersalesWorkOrderend', component: Layout, diff --git a/src/views/aftersales/aftersalesWorkOrder.vue b/src/views/aftersales/aftersalesWorkOrder.vue index d0508562..6430cc9b 100644 --- a/src/views/aftersales/aftersalesWorkOrder.vue +++ b/src/views/aftersales/aftersalesWorkOrder.vue @@ -179,23 +179,21 @@ 查看 - + + 确定 - + 编辑 + + 编辑 + + 确定理赔金额 + + { columnList[2].checkarr = []; //重置下拉搜索框 columnList[3].checkarr = []; - + columnList[10].checkarr=[] updateDictionary(columnList[2].checkarr, 'pc_work_order'); //异常类型 updateDictionary(columnList[3].checkarr, 'pc_discovery_node'); //发现环节 - updateDictionary(columnList[17].checkarr, 'work_order_status'); //发现环节 - // 获取角色权限 + updateDictionary(columnList[10].checkarr, 'work_order_status'); //工单状态 getDictionaryBiz('after_sales_visits').then(res => { console.log(res, '角色字典'); const matchingItem = res.data.data.find( @@ -1146,7 +1158,7 @@ const IndexTable = val => { Tableheaderswitching(columnList); console.log(res, '初始化返回值'); details.loadingObj.list = false; //关闭动画加载 - + console.log(columnList[17].checkarr,'工单状态12312421'); if (res.data.data) { page.value.total = res.data.data.total; //总页数 @@ -1190,23 +1202,27 @@ const IndexTable = val => { item.discoveryNodeNameS = columnList[3].checkarr[7].label; //安装环节 } if (item.workOrderStatus == 10) { - item.workOrderStatusNameS = columnList[17].checkarr[0].label; //待处理 + item.workOrderStatusNameS = columnList[10].checkarr[0].label; //待处理 } else if (item.workOrderStatus == 20) { - item.workOrderStatusNameS = columnList[17].checkarr[1].label; //处理中 + item.workOrderStatusNameS = columnList[10].checkarr[1].label; //处理中 } else if (item.workOrderStatus == 30) { - item.workOrderStatusNameS = columnList[17].checkarr[2].label; //已处理 + item.workOrderStatusNameS = columnList[10].checkarr[2].label; //已处理 } else if (item.workOrderStatus == 40) { - item.workOrderStatusNameS = columnList[17].checkarr[4].label; //待审核 + item.workOrderStatusNameS = columnList[10].checkarr[4].label; //待审核 } else if (item.workOrderStatus == 50) { - item.workOrderStatusNameS = columnList[17].checkarr[5].label; //已审核 + item.workOrderStatusNameS = columnList[10].checkarr[5].label; //已审核 } else if (item.workOrderStatus == 60) { - item.workOrderStatusNameS = columnList[17].checkarr[3].label; //超时未处理 + item.workOrderStatusNameS = columnList[10].checkarr[3].label; //超时未处理 } else if (item.workOrderStatus == 70) { - item.workOrderStatusNameS = columnList[17].checkarr[6].label; //仲裁中 + item.workOrderStatusNameS = columnList[10].checkarr[6].label; //仲裁中 } else if (item.workOrderStatus == 80) { - item.workOrderStatusNameS = columnList[17].checkarr[7].label; //完结 + item.workOrderStatusNameS = columnList[10].checkarr[7].label; //完结 } else if (item.workOrderStatus == 90) { - item.workOrderStatusNameS = columnList[17].checkarr[8].label; //理赔金未出 + item.workOrderStatusNameS = columnList[10].checkarr[8].label; //理赔金未出 + }else if (item.workOrderStatus == 21) { + item.workOrderStatusNameS = columnList[10].checkarr[9].label; //处理结果已提交 + }else if (item.workOrderStatus == 100) { + item.workOrderStatusNameS = columnList[10].checkarr[10].label; //已结束 } }); details.data = res.data.data.records; @@ -1367,6 +1383,7 @@ const searchHide = () => { // 异常工单号点击查看 const InformationViewing = val => { + console.log(val,'当前行数据'); if (AppealStatusT.value) { // 表示当前在申诉列表 $router.push({ @@ -1387,7 +1404,27 @@ const InformationViewing = val => { }); return; } - + // 理赔金额未出 + if(TabPermissions.value==4){ + $router.push({ + // AppealStatusT为真表示是申诉列表 + path: '/aftersales/aftersalesWorkOrderInfo', + query: { + id: val.row.lawoId, + appealID: val.row.id, //只有申诉才需要的参数 + name: val.row.workOrderNumber + '-信息查看', + warehouseId: val.row.warehouseId, + workOrderNumber: val.row.workOrderNumber, //添加异常记录包条码 + businessId: val.row.businessId, + ProcessType: TabPermissions.value == 2 ? '2' : TabPermissions.value == 3 ? '1' : '', //类型 1 待处理 2 已处理 + RouteIndexs: TabPermissions.value, //当前记录参数 + Routstate: '', //申诉列表 + AppealReview: val.row.typesOf ? (val.row.typesOf == '0' ? 'true' : 'false') : 'true', //当前只能查看申诉详情信息 + workOrderStatus: val.row.workOrderStatus, //订单状态 + }, + }); + return + } $router.push({ path: '/aftersales/aftersalesWorkOrderInfo', query: { @@ -1403,7 +1440,29 @@ const InformationViewing = val => { }; // 首页查看详情按钮 const view = val => { - console.log(val.row.id); + console.log(val.row); + // 理赔查看 + if(TabPermissions.value==4){ + $router.push({ + // AppealStatusT为真表示是申诉列表 + path: '/aftersales/aftersalesWorkOrderInfo', + query: { + id: val.row.lawoId, + appealID: val.row.id, //只有申诉才需要的参数 + name: val.row.workOrderNumber + '-信息查看', + warehouseId: val.row.warehouseId, + workOrderNumber: val.row.workOrderNumber, //添加异常记录包条码 + businessId: val.row.businessId, + ProcessType: TabPermissions.value == 2 ? '2' : TabPermissions.value == 3 ? '1' : '', //类型 1 待处理 2 已处理 + RouteIndexs: TabPermissions.value, //当前记录参数 + Routstate: '', //申诉列表 + AppealReview: val.row.typesOf ? (val.row.typesOf == '0' ? 'true' : 'false') : 'true', //当前只能查看申诉详情信息 + workOrderStatus: val.row.workOrderStatus, //订单状态 + }, + }); + return + } + $router.push({ // AppealStatusT为真表示是申诉列表 path: '/aftersales/aftersalesWorkOrderInfo', @@ -1418,6 +1477,7 @@ const view = val => { RouteIndexs: TabPermissions.value, //当前记录参数 Routstate: '', //申诉列表 AppealReview: val.row.typesOf ? (val.row.typesOf == '0' ? 'true' : 'false') : 'true', //当前只能查看申诉详情信息 + workOrderStatus: val.row.workOrderStatus, //订单状态 }, }); }; @@ -1615,6 +1675,47 @@ const appeal = (val, state) => { dialogappeal.value = true; //展开申诉弹窗 } }; +// 确定理赔金额 +const DetermineClaims=(val)=>{ + console.log(val.row); + let data={ + id:val.row.lawoId, + workOrderStatus:30 + } + details.loadingObj.list = true; //开启动画加载 + + console.log(data,'处理好的值'); + $_settlementUpdate(data).then(res=>{ + console.log(res); + details.loadingObj.list = false; //关闭动画加载 + if(res.data.code==200){ + tabChenge(TabPermissions.value); + } + }).catch(res=>{ + details.loadingObj.list = false; //关闭动画加载 + }) +} +// 理赔金额未出编辑操作 +const Resultediting=(val)=>{ + console.log(val.row,'参数'); + // return + console.log(val.row,'理赔金额未出'); + $router.push({ + path: '/aftersales/aftersalesWorkOrdermodify', + query: { + id: val.row.lawoId, + subId:val.row.laprId, + name: val.row.workOrderNumber + '-理赔金额未出编辑', + businessId:val.row.businessId, + warehouseId: val.row.warehouseId, + workOrderNumber:val.row.workOrderNumber, + RouterState:'Kfend', + Processingresults:true,//理赔编辑 + index: '1', + }, + }); +} + // 工单申诉确认按钮 const Appealbutton = state => { if (UserPermissions.value == '仓库客服') { @@ -2020,8 +2121,16 @@ const settlementclaim = val => { $_listSettlement(data).then(res => { details.loadingObj.list = false; //关闭动画加载 console.log(res, '查询理赔数据'); - details.data = res.data.data.records; //数据 - page.value.total = res.data.data.total; + if(res.data.data){ + if(res.data.data.records.length){ + details.data = res.data.data.records; //数据 + }else{ + details.data=[] + } + page.value.total = res.data.data.total; + } + }).catch(res=>{ + details.loadingObj.list = false; //关闭动画加载 }); }; // 获取申诉列表 @@ -2051,6 +2160,8 @@ const appealFn = val => { details.data = []; } page.value.total = res.data.data.total; + }).catch(res=>{ + details.loadingObj.list = false; //关闭动画加载 }); }; @@ -2488,8 +2599,7 @@ const fellSuccess = (response, uploadFile) => { KFfeel.value = response.data.link; } }; -// 处理结果和完结确定 - +// 处理结果和理赔确定 const DetermineStorage = val => { let data = { assignList: [], @@ -2498,7 +2608,7 @@ const DetermineStorage = val => { ID = val.row.id; data['assignList'].push(ID); details.loadingObj.list = true; //开启加载效果 - if (TabPermissions.value == '6') { + if(UserPermissions.value =='总部客服经理' && TabPermissions.value == '2'){ $_updateManagerConfirmed(data) .then(res => { if (res.data.code == 200) { @@ -2507,7 +2617,7 @@ const DetermineStorage = val => { type: 'success', }); } - console.log(res, '完结确定'); + console.log(res, '处理完毕确定'); tabChenge(TabPermissions.value); }) .catch(res => { @@ -2515,8 +2625,12 @@ const DetermineStorage = val => { }); // 赔款方 console.log(data, '处理好的值'); + + return } - if (TabPermissions.value == '2') { +// 仓库客服 + if (TabPermissions.value == '2' && UserPermissions.value=='仓库客服' && val.row.workOrderStatus != '30') { + console.log(data, '处理好的数据'); $_updateWorkOrderStatus(data) .then(res => { diff --git a/src/views/aftersales/aftersalesWorkOrderAdd.vue b/src/views/aftersales/aftersalesWorkOrderAdd.vue index 55618a98..f5b971ad 100644 --- a/src/views/aftersales/aftersalesWorkOrderAdd.vue +++ b/src/views/aftersales/aftersalesWorkOrderAdd.vue @@ -97,7 +97,13 @@ :content="item.orderCode ? item.orderCode : '订单自编号'" placement="top" > - + @@ -105,7 +111,11 @@
- +
@@ -344,7 +354,7 @@ placeholder="请选责任人" > { warehouseId: val, }).then(res => { console.log(res, '获取责任人列表'); - personResponsibleList.value = res.data.data; + FangAddList.value[index].personResponsibleList = res.data.data; }); }; const onLoad = () => { // DeliveryTrainnumber(); //获取司机 console.log($route.query.id, '页面初始化'); routerState.value = $route.query.routerState; - Mydata.value=JSON.parse(localStorage.getItem('my_data'));//记录本地登录 - console.log(Mydata.value,'记录本地登录'); + Mydata.value = JSON.parse(localStorage.getItem('my_data')); //记录本地登录 + console.log(Mydata.value, '记录本地登录'); updateDictionary(IndexException.value, 'pc_work_order'); //异常类型 updateDictionary(DiscoveringNodes.value, 'pc_discovery_node'); //发现环节 handle(); //处理方和责任方信息 @@ -959,6 +969,7 @@ const AddPackage = () => { waybillNumber: '', brandName: '', state: false, + mallName: '', }); }; // 包件移除 @@ -995,7 +1006,14 @@ const ResponsibilityRemoval = val => { // 顶部标签切换 const TopChange = val => { PackageInfo.value = [ - { packageCode: '', orderCode: '', waybillNumber: '', brandName: '', state: false }, + { + packageCode: '', + orderCode: '', + waybillNumber: '', + brandName: '', + state: false, + mallName: '', + }, ]; //重置包件信息 Indexform.value = {}; //重置表单 @@ -1130,19 +1148,6 @@ const ConfirmForm = () => { let processorEntityList = []; - //责任方信息处理 - if (Indexform.value.processor.length) { - Indexform.value.processor.forEach(item => { - let found = warehouseData.value.find(element => element.value == item.toString()); - processorEntityList.push({ - businessName: found ? found.label : '', - businessId: item, - conditions: 1, - typesOf: 2, - }); - }); - } - DataSubmit.processorEntityList = processorEntityList; DataSubmit.decreaseImageEntityList = JSON.parse( JSON.stringify(Indexform.value['decreaseImageEntityList']) @@ -1153,18 +1158,28 @@ const ConfirmForm = () => { // 如果存在包件信息进行处理 if (PackageInfo.value.length) { PackageInfo.value.forEach(item => { - DataSubmit['packageEntityList'].push({ - number: PackageInfo.value.length, //数量 - packageCode: item.packageCode ? item.packageCode : null, //包件码 - waybillNumber: item.waybillNumber ? item.waybillNumber : null, //运单号 - orderCode: item.orderCode ? item.orderCode : null, //订单自编码 - brandName: item.brandName ? item.brandName : null, //品牌 - }); + if (item.packageCode) { + DataSubmit['packageEntityList'].push({ + number: PackageInfo.value.length, //数量 + packageCode: item.packageCode ? item.packageCode : null, //包件码 + waybillNumber: item.waybillNumber ? item.waybillNumber : null, //运单号 + orderCode: item.orderCode ? item.orderCode : null, //订单自编码 + brandName: item.brandName ? item.brandName : null, //品牌 + }); + } }); - DataSubmit.packageCode = [...new Set(PackageInfo.value.map(item => item.packageCode))].join(','); //包条码 - DataSubmit.waybillNumber = [...new Set(PackageInfo.value.map(item => item.waybillNumber))].join(','); //运单号 - DataSubmit.brandName = [...new Set(PackageInfo.value.map(item => item.brandName))].join(','); //品牌 - DataSubmit.orderCode = [...new Set(PackageInfo.value.map(item => item.orderCode))].join(','); //包件信息订单自编码 + DataSubmit.packageCode = [...new Set(PackageInfo.value.map(item => item.packageCode))].join( + ',' + ); //包条码 + DataSubmit.waybillNumber = [ + ...new Set(PackageInfo.value.map(item => item.waybillNumber)), + ].join(','); //运单号 + DataSubmit.brandName = [...new Set(PackageInfo.value.map(item => item.brandName))].join( + ',' + ); //品牌 + DataSubmit.orderCode = [...new Set(PackageInfo.value.map(item => item.orderCode))].join( + ',' + ); //包件信息订单自编码 } // DataSubmit['packageEntityList'].push({ @@ -1176,7 +1191,7 @@ const ConfirmForm = () => { // waybillNumber: PackageInfo.value.map(item => item.waybillNumber).join(','), //运单号 // orderCode: PackageInfo.value.map(item => item.orderCode).join(','), //订单自编码 // }); - + // 总件数 Indexform.value.number = PackageInfo.value.length; console.log(DataSubmit['packageEntityList'], '包件信息'); @@ -1214,10 +1229,10 @@ const ConfirmForm = () => { wordOrderId: Indexform.value.workOrderNumber, //异常工单ID description: item.description ? item.description : null, //说明 personResponsibleId: - personResponsibleList.value.find(obj => obj.id == item.personResponsibleName)?.id || + item.personResponsibleList.find(obj => obj.id == item.personResponsibleName)?.id || null, //责任人ID personResponsibleName: - personResponsibleList.value.find(obj => obj.id == item.personResponsibleName) + item.personResponsibleList.find(obj => obj.id == item.personResponsibleName) ?.name || null, //责任人名称 responsibilityRatio: item.responsibilityRatio ? item.responsibilityRatio : null, //责任比例 tripartite: item.tripartite ? item.tripartite : null, //三方责任人 @@ -1248,6 +1263,19 @@ const ConfirmForm = () => { console.log(DataSubmit['personResponsibleDTO'], '新责任方处理的数据'); //console.log(Indexform.value.duty.length); //责任方信息处理 + //责任方信息处理 + if (Indexform.value.processor.length) { + Indexform.value.processor.forEach(item => { + let found = warehouseData.value.find(element => element.value == item.toString()); + processorEntityList.push({ + businessName: found ? found.label : '', + businessId: item, + conditions: 1, + typesOf: 2, + }); + }); + } + if (FangAddList.value.length) { FangAddList.value.forEach(item => { console.log(item, 'item'); @@ -1312,9 +1340,6 @@ const ConfirmForm = () => { delete DataSubmit.processor; //移除多余字段 console.log(DataSubmit, '处理好的数据'); // 提交表单信息stringify - - - $_submit(DataSubmit) .then(res => { if (res.data.code == 200) { @@ -1433,15 +1458,13 @@ const moneyBtnB = () => { }; // 是否显示处理结果 -const Processingrelease = ()=>{ - if(Indexform.value.processor.length ==1 && Mydata.value.id==Indexform.value.processor[0] ){ - ProcessingreleaseState.value = true;//显示处理放 - }else{ - ProcessingreleaseState.value = false;//关闭处理方 +const Processingrelease = () => { + if (Indexform.value.processor.length == 1 && Mydata.value.id == Indexform.value.processor[0]) { + ProcessingreleaseState.value = true; //显示处理放 + } else { + ProcessingreleaseState.value = false; //关闭处理方 } -} - - +}; // 统计包件个数 const Statistics = () => { @@ -1467,93 +1490,116 @@ const Statistics = () => { // 查询包件信息自动回显 const ChangePackageInfo = (val, index) => { + // 判断是否有一样的包件 + if (identifying.value == '2') { Statistics(); //调用统计包件信息 return; - } - - if (NumberPackages.value > 1) { + } else { if (!val) { - PackageInfo.value[index].orderCode = ''; //订单自编码 - PackageInfo.value[index].waybillNumber = ''; //运单号 - PackageInfo.value[index].orderId = ''; //运单号 - PackageInfo.value[index].brandName = ''; //品牌 - Indexform.value.first = ''; //一级品 - Indexform.value.secondary = ''; //二级品 - Indexform.value.waybillMall = ''; //客户名称(运单商场) - Indexform.value.typeServiceName = ''; //合作模式 + return; + } + Statistics(); //调用统计包件信息 + if (!NumberPackages.value) { + if (!val) { + PackageInfo.value[index].orderCode = ''; //订单自编码 + PackageInfo.value[index].waybillNumber = ''; //运单号 + PackageInfo.value[index].orderId = ''; //运单号 + PackageInfo.value[index].brandName = ''; //品牌 + Indexform.value.first = ''; //一级品 + Indexform.value.secondary = ''; //二级品 + Indexform.value.waybillMall = ''; //客户名称(运单商场) + Indexform.value.typeServiceName = ''; //合作模式 + return; + // 如果输入框里面没有值就不请求 + } + } - return; - // 如果输入框里面没有值就不请求 - } - } + // if (NumberPackages.value > 1) { + // const found = PackageInfo.value + // .filter(item => item.packageCode !== val) + // .some(item => item.packageCode === val); + + // if (found) { + // console.log('false'); + // ElMessage({ + // message: '存在重复包条码', + // type: 'warning', + // }); + // return; + // } + // } - if(!val){ - return - } - Statistics(); //调用统计包件信息 - let data = { - packageCode: val, - }; - $_getAbnormalPackage(data).then(res => { - console.log(res, '包件信息'); - console.log(res.data.data, '包件信息'); - - if (res.data.data.length) { - const packageData = res.data.data[0]; - if (NumberPackages.value > 1) { - let mallName = PackageInfo.value.find(item => item.mallName); - if (mallName != packageData.mallName) { - ElMessageBox.confirm('请选择运单商场一致的包条码!', 'Warning', { - confirmButtonText: '确定', - type: 'warning', - }) - .then(() => { - return; + Statistics(); //调用统计包件信息 + let data = { + packageCode: val, + }; + $_getAbnormalPackage(data).then(res => { + console.log(res, '包件信息'); + console.log(res.data.data, '包件信息'); + + if (res.data.data.length) { + console.log(NumberPackages.value, 'NumberPackages.value '); + console.log(PackageInfo.value, 'PackageInfo.value'); + const packageData = res.data.data[0]; + if (NumberPackages.value > 1) { + let mallName = PackageInfo.value.find(item => item.mallName).mallName; + console.log(mallName, '筛选出来的值'); + if (mallName != packageData.mallName) { + ElMessageBox.confirm('请选择运单商场一致的包条码!', 'Warning', { + confirmButtonText: '确定', + type: 'warning', }) - .catch(() => { - ElMessage({ - type: 'info', - message: '请重新输入新包条码', + .then(() => { + return; + }) + .catch(() => { + ElMessage({ + type: 'info', + message: '请重新输入新包条码', + }); }); - }); - return; + return; + } } - } - // 如果已经有一条数据了,后面运单商场必须和后面的一样 - console.log(packageData, '获取的第一个参数'); - PackageInfo.value[index].orderCode = packageData.orderCode; //订单自编码 - PackageInfo.value[index].waybillNumber = packageData.waybillNumber; //运单号 - PackageInfo.value[index].orderId = packageData.orderId; //运单号 - PackageInfo.value[index].brandName = packageData.brandName; //品牌 - PackageInfo.value[index].state = false; //状态 - - const results = res.data.data.filter(item => { - return item.workOrderId && item.workOrderNumber; - }); - console.log(results, '筛选后的结果'); - if (results.length > 0) { - HistoricalPackageList.value = results; - PackageInfo.value[index].state = true; //状态 - } else { + console.log('跑到这里来了'); + // 如果已经有一条数据了,后面运单商场必须和后面的一样 + console.log(packageData, '获取的第一个参数'); + PackageInfo.value[index].orderCode = packageData.orderCode; //订单自编码 + PackageInfo.value[index].waybillNumber = packageData.waybillNumber; //运单号 + PackageInfo.value[index].orderId = packageData.orderId; //运单号 + PackageInfo.value[index].brandName = packageData.brandName; //品牌 + PackageInfo.value[index].mallName = packageData.mallName; //运单商场 + PackageInfo.value[index].state = false; //状态 + + const results = res.data.data.filter(item => { + return item.workOrderId && item.workOrderNumber; + }); + console.log(results, '筛选后的结果'); + if (results.length > 0) { + HistoricalPackageList.value = results; + PackageInfo.value[index].state = true; //状态 + } else { + PackageInfo.value[index].state = false; //状态 + } + // 确保在没有满足条件的元素时,不执行 HistoricalPackageList 和 PackageInfo 的赋值操作 + Indexform.value.first = packageData.firsts; //一级品 + Indexform.value.secondary = packageData.second; //二级品 + Indexform.value.waybillMall = packageData.mallName; //客户名称(运单商场) + Indexform.value.typeServiceName = packageData.typeServiceName + ? packageData.typeServiceName + : null; //合作模式 } - // 确保在没有满足条件的元素时,不执行 HistoricalPackageList 和 PackageInfo 的赋值操作 - Indexform.value.first = packageData.firsts; //一级品 - Indexform.value.secondary = packageData.second; //二级品 - Indexform.value.waybillMall = packageData.mallName; //客户名称(运单商场) - Indexform.value.typeServiceName = packageData.typeServiceName - ? packageData.typeServiceName - : null; //合作模式 - } - // packageCode; //包件码 - // //订单自编码 - // orderCode: orderId; //运单号 - // workOrderId; //工单id - // workOrderNumber; //工单名称 + // packageCode; //包件码 + // //订单自编码 + // orderCode: orderId; //运单号 + // workOrderId; //工单id + // workOrderNumber; //工单名称 - console.log(PackageInfo.value, '处理好的参数'); - }); + console.log(PackageInfo.value, '处理好的参数'); + }); + } }; // 查看历史包件 diff --git a/src/views/aftersales/aftersalesWorkOrderInfo.vue b/src/views/aftersales/aftersalesWorkOrderInfo.vue index 88de1f4e..eafac574 100644 --- a/src/views/aftersales/aftersalesWorkOrderInfo.vue +++ b/src/views/aftersales/aftersalesWorkOrderInfo.vue @@ -530,7 +530,7 @@ v-if="PermissionButton.arbitration_completed" v-if="PermissionButton.information_editing" --> 回复 - 处理结果 + 处理结果 完结 打回 客服仲裁完结 @@ -690,33 +690,18 @@ const FangAddList = ref([ // 提货责任方 const responsible = ref([ { - value: '1', + value: 1, label: '工厂', }, { - value: '2', + value: 2, label: '外包搬运', }, { - value: '3', + value: 3, label: '物流', }, ]); - -const DeliveryDriver = ref([ - { - value: '0', - label: '兰溪', - }, - { - value: '1', - label: '李华', - }, - { - value: '2', - label: '唐飞', - }, -]); // 图片列表 const fileList = ref([]); // 字典公共函数 @@ -1023,7 +1008,7 @@ const onLoad = () => { $_getInfo({ id: $route.query.id }).then(res => { console.log(res, '回显返回值参数'); Indexform.value = res.data.data; - + Indexform.value['result'] = []; Indexform.value['processor'] = []; //图片处理回显 @@ -1051,6 +1036,13 @@ const onLoad = () => { res.data.data.personResponsibleVOS.forEach(item => { sum = Number(item.responsibilityRatio) + sum; }); + + if(res.data.data.discoveryNode=='1'){ + groundlineType.value = '1' + }else{ + groundlineType.value = 'null' + } + FangAddList.value = res.data.data.personResponsibleVOS.map(res => { return { businessName: res.businessId, //责任人ID @@ -1479,6 +1471,7 @@ const EndJump = () => { name: $route.query.workOrderNumber + '-完结填写', RouterState: 'end', index: '2', + workOrderStatus: $route.query.workOrderStatus,//当前单子状态 }, }); }; diff --git a/src/views/aftersales/aftersalesWorkOrderInfoTemp.vue b/src/views/aftersales/aftersalesWorkOrderInfoTemp.vue new file mode 100644 index 00000000..55a7a0c8 --- /dev/null +++ b/src/views/aftersales/aftersalesWorkOrderInfoTemp.vue @@ -0,0 +1,2418 @@ + + + + + diff --git a/src/views/aftersales/aftersalesWorkOrderend.vue b/src/views/aftersales/aftersalesWorkOrderend.vue index 6525190f..0e2e8b8f 100644 --- a/src/views/aftersales/aftersalesWorkOrderend.vue +++ b/src/views/aftersales/aftersalesWorkOrderend.vue @@ -587,7 +587,7 @@ >客服仲裁完结
-
- - - - - - - -
- 下一条 +
+ + + + + + + +
+ + 下一条 +
- 回复 - -
+ 回复 +
- @@ -900,7 +900,7 @@ const dialogImgList = ref(false); //图片预览弹窗 const amplifyurl = ref(''); //当前点击的图片 const amplifysrcList = ref([]); //图片循环列表 const Replycopy = ref([]); //拷贝一份回复方 -const Mydata=ref();//当前登录人信息 +const Mydata = ref(); //当前登录人信息 const PackageInfo = ref([ //包件信息 { packageCode: '', orderCode: '', waybillNumber: '' }, @@ -1067,7 +1067,7 @@ const TransportChange = val => { // 页面初始化数据 const onLoad = () => { - Mydata.value=JSON.parse(localStorage.getItem('my_data'));//记录本地登录 + Mydata.value = JSON.parse(localStorage.getItem('my_data')); //记录本地登录 // 获取角色权限 getDictionaryBiz('after_sales_visits').then(res => { console.log(res, '角色字典'); @@ -1095,6 +1095,11 @@ const onLoad = () => { endFrom.value.processor = []; endFrom.value.packageImage = []; //图片处理回显 + if(res.data.data.discoveryNode=='1'){ + groundlineType.value = '1' + }else{ + groundlineType.value = 'null' + } res.data.data.decreaseImageVOList.forEach(res => { amplifysrcList.value.push(res.imagePath); endFrom.value['packageImage'].push({ @@ -1111,7 +1116,10 @@ const onLoad = () => { .map(item => { return { businessName: item.businessId }; }); - + let factorydata = res.data.data.personResponsibleVOS.find(item => item.typesOf); + if (factorydata.typesOf) { + groundlineType.value = true; //切换处理方模式 + } FangAddList.value = res.data.data.personResponsibleVOS.map(res => { console.log(groundlineType.value, '当前责任方状态'); return { @@ -1121,6 +1129,7 @@ const onLoad = () => { description: res.description, //说明 }; }); + // 要修改 res.data.data.processorVOList.forEach(item => { if (item) { @@ -1157,11 +1166,10 @@ const onLoad = () => { // 公司占比回显计算 let sum = 0; FangAddList.value.forEach(item => { - if(item.responsibilityRatio){ + if (item.responsibilityRatio) { item.responsibilityRatio = item.responsibilityRatio.replace(/%/g, ''); sum = Number(item.responsibilityRatio) + sum; } - }); FangAddList.value.forEach(item => { item.responsibilityRatio = item.responsibilityRatio + '%'; @@ -1288,81 +1296,81 @@ const Fileidentifier = val => { } return undefined; // 针对其他扩展名的情况返回 undefined }; - // 聊天记录获取 -const Chathistory = () => { - // 聊天记录获取 +const Chathistory = res => { Msgloading.value = true; //开启加载效果 MessageResponsibility.value = []; //清空选择内容 Msgtextarea.value = ''; //清空输入框消息 - $_getSurveyRecord({ - id: $route.query.id, - }).then(res => { - let filetype = ''; //文件类型 - MessageContent.value = []; //先清空内容,防止内容重复叠加 - Msgloading.value = false; //关闭加载效果 - console.log(res, '聊天记录'); - res.data.data.surveyRecordEntities.forEach(item => { - if (item.pictureUrl) { - filetype = Fileidentifier(item.pictureUrl); - } + let filetype = ''; //文件类型 + MessageContent.value = []; //先清空内容,防止内容重复叠加 + let resData = null; //用于保存返回值 + if (UserPermissions.value != '仓库客服') { + console.log(UserPermissions.value, '当前不是仓库客服'); + $_getTrackRecord({ + id: $route.query.id, + }).then(res => { + res.data.data.surveyRecordEntities.forEach(item => { + MessageContent.value.unshift({ + time: item.createTime, //时间 + content: item.processingResults, //消息内容 + name: item.addDepartment, //营业部名称 + username: item.addPeople, //用户名 + img: filetype == 'png' ? item.pictureUrl : '', + file: filetype == 'docx' ? item.pictureUrl : '', + mp4: filetype == 'mp4' ? item.pictureUrl : '', + imgList: [filetype == 'png' ? item.pictureUrl : ''], + difference: item.difference, + identifying: false, //待回复标识 + }); + }); + setTimeout(() => { + const container = scrollContainer.value; + if (container) { + container.scrollTop = container.scrollHeight; + } + }, 0); + Msgloading.value = false; //关闭加载效果 + console.log(res, '聊天记录'); + }); + } else { + $_getSurveyRecord({ + id: $route.query.id, + }).then(res => { + console.log(res, '聊天返回值'); + console.log(resData, '处理记录返回值'); + // 仓库客服不需要操作记录 if (res.data.data.processorVOList) { if (res.data.data.processorVOList.length) { msgState.value = res.data.data.processorVOList[0].processingStatus; //获取聊天状态 } } - // 仓库客服不需要操作记录 - - MessageContent.value.push({ - time: item.createTime, //时间 - content: item.content, //消息内容 - name: item.addDepartment, //营业部名称 - username: item.addPeople, //用户名 - img: filetype == 'png' ? item.pictureUrl : '', - file: filetype == 'docx' ? item.pictureUrl : '', - mp4: filetype == 'mp4' ? item.pictureUrl : '', - imgList: [filetype == 'png' ? item.pictureUrl : ''], - difference: item.difference, - identifying: true, //是否显示待回复按钮 - }); - }); - console.log(MessageContent.value, '处理好的聊天记录'); - if (UserPermissions.value != '仓库客服') { - console.log(UserPermissions.value, '当前不是仓库客服'); - $_getTrackRecord({ - id: $route.query.id, - }).then(res => { - console.log(res, '处理记录返回值'); - res.data.data.surveyRecordEntities.forEach(item => { - MessageContent.value.unshift({ - time: item.createTime, //时间 - content: item.processingResults, //消息内容 - name: item.addDepartment, //营业部名称 - username: item.addPeople, //用户名 - img: filetype == 'png' ? item.pictureUrl : '', - file: filetype == 'docx' ? item.pictureUrl : '', - mp4: filetype == 'mp4' ? item.pictureUrl : '', - imgList: [filetype == 'png' ? item.pictureUrl : ''], - difference: item.difference, - identifying: false, //待回复标识 - }); + res.data.data.surveyRecordEntities.forEach(item => { + if (item.pictureUrl) { + filetype = Fileidentifier(item.pictureUrl); + } + MessageContent.value.push({ + time: item.createTime, //时间 + content: item.content, //消息内容 + name: item.addDepartment, //营业部名称 + username: item.addPeople, //用户名 + img: filetype == 'png' ? item.pictureUrl : '', + file: filetype == 'docx' ? item.pictureUrl : '', + mp4: filetype == 'mp4' ? item.pictureUrl : '', + imgList: [filetype == 'png' ? item.pictureUrl : ''], + difference: item.difference, + identifying: true, //是否显示待回复按钮 }); - setTimeout(() => { - const container = scrollContainer.value; - if (container) { - container.scrollTop = container.scrollHeight; - } - }, 0); }); - } - setTimeout(() => { - const container = scrollContainer.value; - if (container) { - container.scrollTop = container.scrollHeight; - } - }, 0); - // 滚动到最后 - }); + setTimeout(() => { + const container = scrollContainer.value; + if (container) { + container.scrollTop = container.scrollHeight; + } + }, 0); + Msgloading.value = false; //关闭加载效果 + console.log(res, '聊天记录'); + }); + } }; onLoad(); @@ -1886,7 +1894,8 @@ const submit = () => { let info = JSON.parse(JSON.stringify(endFrom.value)); //拷贝要提交的数据 let data = { aftersalesProcessingResultsDTO: { - ...info, + // ...info, + }, processingMoneyEntityList: [], //赔付方式 }; @@ -1898,6 +1907,8 @@ const submit = () => { sum = computeNumber(sum, '+', ProcessingList.value[i].input).result; } data.aftersalesProcessingResultsDTO.money = sum; //金额汇总 + // data.resultDescription=endFrom.value.resultDescription;//处理结果说明 + data.aftersalesProcessingResultsDTO.resultDescription=endFrom.value.resultDescription;//处理结果说明 // data['compensationMethod'] = Paymentmethod.value.filter( // item => item.dictKey == endFrom.value.compensationMethod // )[0].dictValue; //目前是单选 @@ -1908,7 +1919,7 @@ const submit = () => { data.aftersalesProcessingResultsDTO['compensationMethod'] = ProcessingList.value .map(item => item.text) .join(','); - data['processingMoneyEntityList'] = ProcessingList.value + data.aftersalesProcessingResultsDTO.processingMoneyEntityList = ProcessingList.value .map(item => { console.log(item); let match = ProcessingResults.value.find(element => element.dictValue == item.name); @@ -1934,8 +1945,12 @@ const submit = () => { }) .filter(item => item !== null); // data.aftersalesProcessingResultsDTO.paymentUnit = paymentUnit.value; //支付单位 - data.aftersalesProcessingResultsDTO.processingMoneyEntityList = - data['processingMoneyEntityList']; + + data.aftersalesProcessingResultsDTO.paymentUnit = ProcessingList.value + .map(item => item.paymentUnit) + .join(','); //支付单位 + + // data.aftersalesProcessingResultsDTO.processingMoneyEntityList = data['processingMoneyEntityList']; console.log('走到了这一步'); data.aftersalesProcessingResultsDTO.workOrderId = $route.query.id; //异常工单ID data.aftersalesProcessingResultsDTO['resultType'] = ProcessingList.value @@ -1951,12 +1966,11 @@ const submit = () => { } else { data.aftersalesProcessingResultsDTO['annex'] = imgLink; } - - console.log(data, '处理好的数据'); delete data.aftersalesProcessingResultsDTO.id; //删除ID字段 data.aftersalesProcessingResultsDTO.warehouseId = info.warehouseId; //仓库ID console.log(data, '处理好的数据'); + $_addProcessingResults(data) .then(res => { console.log(res, '提交后的参数'); @@ -1975,34 +1989,31 @@ const submit = () => { }; // 消息回复 const replyMessage = () => { - - if(!Msgtextarea.value){ + if (!Msgtextarea.value) { ElMessage({ - message: '请输入回复内容', - type: 'warning', - }) - return + message: '请输入回复内容', + type: 'warning', + }); + return; } -// if (endFrom.value.processor.includes()) { -// console.log(true); -// } else { -// console.log(false); -// } - + // if (endFrom.value.processor.includes()) { + // console.log(true); + // } else { + // console.log(false); + // } console.log(MessageContent.value, '当前的聊天记录'); console.log(warehouseData.value, '参数1212312312312312'); console.log(MessageResponsibility, '责任方'); - console.log(MessageResponsibility.value,'当前处理方信息'); + console.log(MessageResponsibility.value, '当前处理方信息'); console.log(separateMessageResponsibility.value); - - if(!MessageResponsibility.value.length && !separateMessageResponsibility.value.length){ + if (!MessageResponsibility.value.length && !separateMessageResponsibility.value.length) { ElMessage({ - message: '请选择至少一个处理方', - type: 'warning', - }) - return + message: '请选择至少一个处理方', + type: 'warning', + }); + return; } let msgData = { processorEntityList: [], @@ -2524,8 +2535,8 @@ const CustomerServiceCompleted = () => { align-items: flex-end; justify-content: space-between; position: absolute; - right: 0; - bottom: 0; + right: 0; + bottom: 0; :deep(.el-button) { margin-left: 20px; } @@ -2594,23 +2605,22 @@ const CustomerServiceCompleted = () => { justify-content: space-between; align-items: center; } - .inputleft{ - display:flex; - :deep(.el-fil){ - background-color: #afbdc3; + .inputleft { + display: flex; + :deep(.el-fil) { + background-color: #409eff; border: none; } } - :deep(.el_next){ - background-color: #afbdc3; - border: none; + :deep(.el_next) { + background-color: #409eff; + border: none; } - :deep(.el_next:hover){ + :deep(.el_next:hover) { background-color: #409eff; } - } - :deep(.el-textarea){ + :deep(.el-textarea) { margin-top: 6px; } } diff --git a/src/views/aftersales/aftersalesWorkOrdermodify.vue b/src/views/aftersales/aftersalesWorkOrdermodify.vue index 018bdb3e..03bfa9b0 100644 --- a/src/views/aftersales/aftersalesWorkOrdermodify.vue +++ b/src/views/aftersales/aftersalesWorkOrdermodify.vue @@ -1,14 +1,6 @@