|
|
|
@ -114,11 +114,7 @@
|
|
|
|
|
</el-form-item> |
|
|
|
|
|
|
|
|
|
<el-form-item label="车辆路线" v-if="groundlineSet || groundlineType == 3"> |
|
|
|
|
<el-input |
|
|
|
|
v-model="Indexform.vehicleRoute" |
|
|
|
|
placeholder="请输入车辆路线车次号" |
|
|
|
|
clearable |
|
|
|
|
/> |
|
|
|
|
<el-input v-model="Indexform.vehicleRoute" placeholder="请输入车辆路线车次号" clearable /> |
|
|
|
|
</el-form-item> |
|
|
|
|
|
|
|
|
|
<el-form-item label="发货时间"> |
|
|
|
@ -274,9 +270,7 @@
|
|
|
|
|
/> |
|
|
|
|
</el-select> |
|
|
|
|
</el-form-item> |
|
|
|
|
<el-form-item> |
|
|
|
|
|
|
|
|
|
</el-form-item> |
|
|
|
|
<el-form-item> </el-form-item> |
|
|
|
|
</el-form> |
|
|
|
|
|
|
|
|
|
<div class="ProcessingResults" v-if="ProcessingList.length"> |
|
|
|
@ -294,26 +288,21 @@
|
|
|
|
|
<div class="Paymentname"> |
|
|
|
|
{{ item.payment ? item.text : '支付方式' }} |
|
|
|
|
</div> |
|
|
|
|
|
|
|
|
|
<el-date-picker |
|
|
|
|
disabled |
|
|
|
|
v-model="item.compensationTime" |
|
|
|
|
type="datetime" |
|
|
|
|
format="YYYY-MM-DD" |
|
|
|
|
value-format="YYYY-MM-DD HH:mm:ss" |
|
|
|
|
placeholder="理赔支付时间" |
|
|
|
|
/> |
|
|
|
|
</div> |
|
|
|
|
</div> |
|
|
|
|
|
|
|
|
|
<div class="el_tool"> |
|
|
|
|
<span>总金额:{{ TotalClaimAmount }}</span> |
|
|
|
|
</div> |
|
|
|
|
|
|
|
|
|
<el-divider> |
|
|
|
|
<span class="ZFname">理赔支付时间</span> |
|
|
|
|
</el-divider> |
|
|
|
|
<div class="lptime"> |
|
|
|
|
<el-date-picker |
|
|
|
|
disabled |
|
|
|
|
v-model="Indexform.compensationTime" |
|
|
|
|
type="datetime" |
|
|
|
|
format="YYYY-MM-DD" |
|
|
|
|
value-format="YYYY-MM-DD HH:mm:ss" |
|
|
|
|
placeholder="请选择运理赔支付时间" |
|
|
|
|
/> |
|
|
|
|
</div> |
|
|
|
|
</div> |
|
|
|
|
<!-- 处理结果说明 --> |
|
|
|
|
<el-form-item label="处理结果说明" class="el_resj"> |
|
|
|
@ -452,12 +441,13 @@
|
|
|
|
|
v-if="PermissionButton.repulse" |
|
|
|
|
v-if="PermissionButton.arbitration_completed" |
|
|
|
|
v-if="PermissionButton.information_editing" --> |
|
|
|
|
<el-button type="primary" @click="addireply">回复</el-button> |
|
|
|
|
<el-button type="primary" @click="addingRecord">处理结果</el-button> |
|
|
|
|
<el-button type="primary" @click="EndJump">完结 </el-button> |
|
|
|
|
<el-button type="primary" @click="BatchReturn">打回 </el-button> |
|
|
|
|
<el-button type="primary" @click="CustomerServiceCompleted">客服仲裁完结 </el-button> |
|
|
|
|
<el-button type="primary" @click="EditInformation">信息编辑</el-button> |
|
|
|
|
|
|
|
|
|
<el-button v-if="ButtonPermissions.reply" type="primary" @click="addireply">回复</el-button> |
|
|
|
|
<el-button v-if="ButtonPermissions.ProcessingResults" type="primary" @click="addingRecord">处理结果</el-button> |
|
|
|
|
<el-button v-if="ButtonPermissions.end" type="primary" @click="EndJump">完结 </el-button> |
|
|
|
|
<el-button v-if="ButtonPermissions.repulse" type="primary" @click="BatchReturn">打回 </el-button> |
|
|
|
|
<el-button v-if="ButtonPermissions.ArbitrationCompleted" type="primary" @click="CustomerServiceCompleted">客服仲裁完结 </el-button> |
|
|
|
|
<el-button v-if="ButtonPermissions.edit" type="primary" @click="EditInformation">信息编辑</el-button> |
|
|
|
|
</div> |
|
|
|
|
</el-card> |
|
|
|
|
<!-- 批量打回弹窗 --> |
|
|
|
@ -507,7 +497,7 @@ import { useRouter, useRoute } from 'vue-router';
|
|
|
|
|
import { getDictionaryBiz } from '@/api/system/dict'; //字典 |
|
|
|
|
import { getDetailWarehouse, getDeptWarehouse } from '@/api/basicdata/basicdataWarehouse'; //处理方 |
|
|
|
|
import { AddressClosed } from '@/utils/util'; |
|
|
|
|
import { useStore } from "vuex"; |
|
|
|
|
import { useStore } from 'vuex'; |
|
|
|
|
import { |
|
|
|
|
$_getList, |
|
|
|
|
$_submit, |
|
|
|
@ -556,17 +546,17 @@ const HistoricalPackageList = ref([]); //历史包件数组
|
|
|
|
|
const HistorIndex = ref(0); //历史包件索引 |
|
|
|
|
const TotalClaimAmount = ref(0); //总金额 |
|
|
|
|
const dialogReturn = ref(false); //打回弹窗 |
|
|
|
|
const ProcessingRecords =ref([]);//处理放记录用于匹配按钮 |
|
|
|
|
const ProcessingRecordsName=ref([]);//匹配的处理方中文名字 |
|
|
|
|
const ProcessingRecords = ref([]); //处理放记录用于匹配按钮 |
|
|
|
|
const ProcessingRecordsName = ref([]); //匹配的处理方中文名字 |
|
|
|
|
const repulse = ref(false); //加载效果 |
|
|
|
|
const amplifyurl = ref(''); //当前点击的图片 |
|
|
|
|
const amplifysrcList = ref([]); //图片循环列表 |
|
|
|
|
const RouteIndexs = ref(''); //进入前的页面索引 |
|
|
|
|
const UserPermissions = ref('');//当前状态 |
|
|
|
|
const warehouseInfo=ref('');//仓库信息 |
|
|
|
|
const warehouseState=ref(false);//仓库权限 |
|
|
|
|
const UserPermissions = ref(''); //当前状态 |
|
|
|
|
const warehouseInfo = ref(''); //仓库信息 |
|
|
|
|
const warehouseState = ref(false); //仓库权限 |
|
|
|
|
const $useStore = useStore(); |
|
|
|
|
const accessControl= $useStore.getters.permission |
|
|
|
|
const accessControl = $useStore.getters.permission; |
|
|
|
|
const PackageInfo = ref([ |
|
|
|
|
//包件信息 |
|
|
|
|
{ packageCode: '', orderCode: '', waybillNumber: '', brandName: '' }, |
|
|
|
@ -620,23 +610,22 @@ function updateDictionary(targetArray, dictionaryType) {
|
|
|
|
|
}); |
|
|
|
|
} |
|
|
|
|
|
|
|
|
|
// 获取角色权限 |
|
|
|
|
getDictionaryBiz('after_sales_visits').then(res => { |
|
|
|
|
console.log(res, '角色字典'); |
|
|
|
|
const matchingItem = res.data.data.find( |
|
|
|
|
item => item.dictValue == JSON.parse(localStorage.getItem('TWMS-userInfo')).content.role_name |
|
|
|
|
); |
|
|
|
|
if (matchingItem) { |
|
|
|
|
UserPermissions.value = matchingItem.dictValue; |
|
|
|
|
} else { |
|
|
|
|
UserPermissions.value = '仓库客服'; |
|
|
|
|
} |
|
|
|
|
console.log(UserPermissions.value, '当前角色权限'); |
|
|
|
|
}); |
|
|
|
|
// 获取角色权限 |
|
|
|
|
getDictionaryBiz('after_sales_visits').then(res => { |
|
|
|
|
console.log(res, '角色字典'); |
|
|
|
|
const matchingItem = res.data.data.find( |
|
|
|
|
item => item.dictValue == JSON.parse(localStorage.getItem('TWMS-userInfo')).content.role_name |
|
|
|
|
); |
|
|
|
|
if (matchingItem) { |
|
|
|
|
UserPermissions.value = matchingItem.dictValue; |
|
|
|
|
} else { |
|
|
|
|
UserPermissions.value = '仓库客服'; |
|
|
|
|
} |
|
|
|
|
console.log(UserPermissions.value, '当前角色权限'); |
|
|
|
|
}); |
|
|
|
|
|
|
|
|
|
warehouseInfo.value = localStorage.getItem('WarehouseName'); |
|
|
|
|
|
|
|
|
|
|
|
|
|
|
// 图片上传必须携带TOKEN |
|
|
|
|
const headers = computed(() => { |
|
|
|
|
return { 'Blade-Auth': 'Bearer ' + getToken() }; |
|
|
|
@ -659,52 +648,51 @@ const ImgSuccess = (response, uploadFile) => {
|
|
|
|
|
} |
|
|
|
|
}; |
|
|
|
|
|
|
|
|
|
|
|
|
|
|
// 后台控制权限按钮 |
|
|
|
|
const PermissionButton = computed(() => { |
|
|
|
|
return { |
|
|
|
|
workAdd:accessControl.workAdd,//新增 |
|
|
|
|
batch_return:accessControl.batch_return,//批量打回 |
|
|
|
|
assign:accessControl.assign,//工单指派 |
|
|
|
|
apply_arbitration:accessControl.apply_arbitration,//申请仲裁 |
|
|
|
|
batch_completion:accessControl.batch_completion,//批量完结 |
|
|
|
|
representations:accessControl.representations,//申诉 |
|
|
|
|
reply:accessControl.reply,//回复 |
|
|
|
|
processing_completed:accessControl.processing_completed,//处理完结 |
|
|
|
|
work_order_completion:accessControl.work_order_completion,//完结 |
|
|
|
|
repulse:accessControl.repulse,//打回 |
|
|
|
|
arbitration_completed:accessControl.arbitration_completed,//仲裁完结 |
|
|
|
|
information_editing:accessControl.information_editing,//信息编辑 |
|
|
|
|
} |
|
|
|
|
}); |
|
|
|
|
// const PermissionButtonS = computed(() => { |
|
|
|
|
// return { |
|
|
|
|
// workAdd:accessControl.workAdd,//新增 |
|
|
|
|
// batch_return:accessControl.batch_return,//批量打回 |
|
|
|
|
// assign:accessControl.assign, //工单指派 |
|
|
|
|
// apply_arbitration:accessControl.apply_arbitration,//申请仲裁 |
|
|
|
|
// batch_completion:accessControl.batch_completion,//批量完结 |
|
|
|
|
// representations:accessControl.representations,//申诉 |
|
|
|
|
// reply:accessControl.reply,//回复 |
|
|
|
|
// processing_completed:accessControl.processing_completed,//处理完结 |
|
|
|
|
// work_order_completion:accessControl.work_order_completion,//完结 |
|
|
|
|
// repulse:accessControl.repulse,//打回 |
|
|
|
|
// arbitration_completed:accessControl.arbitration_completed,//仲裁完结 |
|
|
|
|
// information_editing:accessControl.information_editing,//信息编辑 |
|
|
|
|
// } |
|
|
|
|
// }); |
|
|
|
|
return { |
|
|
|
|
workAdd: accessControl.workAdd, //新增 |
|
|
|
|
batch_return: accessControl.batch_return, //批量打回 |
|
|
|
|
assign: accessControl.assign, //工单指派 |
|
|
|
|
apply_arbitration: accessControl.apply_arbitration, //申请仲裁 |
|
|
|
|
batch_completion: accessControl.batch_completion, //批量完结 |
|
|
|
|
representations: accessControl.representations, //申诉 |
|
|
|
|
reply: accessControl.reply, //回复 |
|
|
|
|
processing_completed: accessControl.processing_completed, //处理完结 |
|
|
|
|
work_order_completion: accessControl.work_order_completion, //完结 |
|
|
|
|
repulse: accessControl.repulse, //打回 |
|
|
|
|
arbitration_completed: accessControl.arbitration_completed, //仲裁完结 |
|
|
|
|
information_editing: accessControl.information_editing, //信息编辑 |
|
|
|
|
}; |
|
|
|
|
}); |
|
|
|
|
// const PermissionButtonS = computed(() => { |
|
|
|
|
// return { |
|
|
|
|
// workAdd:accessControl.workAdd,//新增 |
|
|
|
|
// batch_return:accessControl.batch_return,//批量打回 |
|
|
|
|
// assign:accessControl.assign, //工单指派 |
|
|
|
|
// apply_arbitration:accessControl.apply_arbitration,//申请仲裁 |
|
|
|
|
// batch_completion:accessControl.batch_completion,//批量完结 |
|
|
|
|
// representations:accessControl.representations,//申诉 |
|
|
|
|
// reply:accessControl.reply,//回复 |
|
|
|
|
// processing_completed:accessControl.processing_completed,//处理完结 |
|
|
|
|
// work_order_completion:accessControl.work_order_completion,//完结 |
|
|
|
|
// repulse:accessControl.repulse,//打回 |
|
|
|
|
// arbitration_completed:accessControl.arbitration_completed,//仲裁完结 |
|
|
|
|
// information_editing:accessControl.information_editing,//信息编辑 |
|
|
|
|
// } |
|
|
|
|
// }); |
|
|
|
|
// 详情按钮权限 |
|
|
|
|
const ButtonPermissions = computed(() => { |
|
|
|
|
// 根据 TabPermissions 的状态,决定每个按钮的显示隐藏逻辑 |
|
|
|
|
switch (RouteIndexs.value !='null') { |
|
|
|
|
switch (RouteIndexs.value != 'null') { |
|
|
|
|
case RouteIndexs.value == 0: //全部 |
|
|
|
|
return { |
|
|
|
|
reply: false, //回复按钮(都可以查看) |
|
|
|
|
ProcessingResults:false, //处理结果按钮 |
|
|
|
|
ProcessingResults: false, //处理结果按钮 |
|
|
|
|
end: false, //完结按钮 |
|
|
|
|
repulse: false, //打回按钮 |
|
|
|
|
ArbitrationCompleted:false, //客服仲裁完结 |
|
|
|
|
edit:false, //编辑 |
|
|
|
|
ArbitrationCompleted: false, //客服仲裁完结 |
|
|
|
|
edit: false, //编辑 |
|
|
|
|
}; |
|
|
|
|
case RouteIndexs.value == 1: //处理中 |
|
|
|
|
return { |
|
|
|
@ -731,7 +719,7 @@ const ButtonPermissions = computed(() => {
|
|
|
|
|
end: UserPermissions.value != '仓库客服', //完结按钮 |
|
|
|
|
repulse: UserPermissions.value != '仓库客服', //打回按钮 |
|
|
|
|
ArbitrationCompleted: false, //客服仲裁完结 |
|
|
|
|
edit:UserPermissions.value == '仓库客服', //编辑 |
|
|
|
|
edit: UserPermissions.value == '仓库客服', //编辑 |
|
|
|
|
}; |
|
|
|
|
case RouteIndexs.value == 4: //理赔金额未出 |
|
|
|
|
return { |
|
|
|
@ -769,6 +757,16 @@ const ButtonPermissions = computed(() => {
|
|
|
|
|
ArbitrationCompleted: false, //客服仲裁完结 |
|
|
|
|
edit: false, //编辑 |
|
|
|
|
}; |
|
|
|
|
case RouteIndexs.value == 8: //待回复 |
|
|
|
|
return { |
|
|
|
|
reply: UserPermissions.value == '仓库客服', //回复按钮 |
|
|
|
|
ProcessingResults: UserPermissions.value == '仓库客服', //处理结果按钮 |
|
|
|
|
end: UserPermissions.value != '仓库客服', //完结按钮 |
|
|
|
|
repulse: UserPermissions.value != '仓库客服', //打回按钮 |
|
|
|
|
ArbitrationCompleted: false, //客服仲裁完结 |
|
|
|
|
edit: UserPermissions.value == '仓库客服', //编辑 |
|
|
|
|
}; |
|
|
|
|
|
|
|
|
|
// 其他任何情况下的默认情况 |
|
|
|
|
default: |
|
|
|
|
return { |
|
|
|
@ -820,7 +818,15 @@ const changeProcessingResults = val => {
|
|
|
|
|
|
|
|
|
|
// 然后添加或保持新的项目 |
|
|
|
|
val.forEach(num => { |
|
|
|
|
let newItem = { input: 0, min: 0, max: 9999999999999, state: num + 1, payment: '', text: '' }; |
|
|
|
|
let newItem = { |
|
|
|
|
input: 0, |
|
|
|
|
min: 0, |
|
|
|
|
max: 9999999999999, |
|
|
|
|
state: num + 1, |
|
|
|
|
payment: '', |
|
|
|
|
text: '', |
|
|
|
|
compensationTime: '', |
|
|
|
|
}; |
|
|
|
|
// 根据num为newItem的name字段赋值 |
|
|
|
|
switch (num) { |
|
|
|
|
case '1': |
|
|
|
@ -866,10 +872,10 @@ const ResponsiblePartychange = (val, index) => {
|
|
|
|
|
}); |
|
|
|
|
}; |
|
|
|
|
const onLoad = () => { |
|
|
|
|
if($route.query.RouteIndexs!='null'){ |
|
|
|
|
RouteIndexs.value = $route.query.RouteIndexs;//记录当前状态 |
|
|
|
|
if ($route.query.RouteIndexs != 'null') { |
|
|
|
|
RouteIndexs.value = $route.query.RouteIndexs; //记录当前状态 |
|
|
|
|
} |
|
|
|
|
|
|
|
|
|
|
|
|
|
|
console.log($route.query.id, '页面初始化'); |
|
|
|
|
routerState.value = $route.query.routerState; |
|
|
|
|
updateDictionary(IndexException.value, 'pc_work_order'); //异常类型 |
|
|
|
@ -895,13 +901,13 @@ const onLoad = () => {
|
|
|
|
|
PackageInfo.value = res.data.data.abnormalPackageVOList; |
|
|
|
|
console.log(res.data.data.abnormalPackageVOList, '包件信息'); |
|
|
|
|
// 责任方回显 |
|
|
|
|
|
|
|
|
|
FangAddList.value = res.data.data.processorVOList |
|
|
|
|
.filter(item => item.typesOf == '1') |
|
|
|
|
.map(res => { |
|
|
|
|
return { |
|
|
|
|
businessName: res.businessId, |
|
|
|
|
}; |
|
|
|
|
.filter(item => item && item.typesOf && item.typesOf == '1') |
|
|
|
|
.map(item => { |
|
|
|
|
return { businessName: item.businessId }; |
|
|
|
|
}); |
|
|
|
|
|
|
|
|
|
// 公司占比回显计算 |
|
|
|
|
let sum = 0; |
|
|
|
|
res.data.data.personResponsibleVOS.forEach(item => { |
|
|
|
@ -916,18 +922,21 @@ const onLoad = () => {
|
|
|
|
|
}; |
|
|
|
|
}); |
|
|
|
|
res.data.data.processorVOList.forEach(item => { |
|
|
|
|
if (item.typesOf == 2) { |
|
|
|
|
// 处理方 |
|
|
|
|
ProcessingRecords.value.push(item.businessId) |
|
|
|
|
Indexform.value.processor.push(item.businessId); |
|
|
|
|
} |
|
|
|
|
}); |
|
|
|
|
if (item) { |
|
|
|
|
if (item.typesOf == 2) { |
|
|
|
|
// 处理方 |
|
|
|
|
Indexform.value.processor.push(item.businessId); |
|
|
|
|
} |
|
|
|
|
} |
|
|
|
|
}); |
|
|
|
|
// let a=['张三','李四'] |
|
|
|
|
// let b=['张三'] |
|
|
|
|
// let result = b.some(item => a.includes(item)); |
|
|
|
|
companyProportion.value = 100 - sum; |
|
|
|
|
ProcessingRecordsName.value = ProcessingRecords.value.filter(item => warehouseData.value.includes(item.value)).label; |
|
|
|
|
console.log( ProcessingRecordsName.value ,'匹配到的中文处理方'); |
|
|
|
|
ProcessingRecordsName.value = ProcessingRecords.value.filter(item => |
|
|
|
|
warehouseData.value.includes(item.value) |
|
|
|
|
).label; |
|
|
|
|
console.log(ProcessingRecordsName.value, '匹配到的中文处理方'); |
|
|
|
|
// updateDictionary(columnList[2].checkarr, 'pc_work_order'); //异常类型 |
|
|
|
|
// updateDictionary(columnList[3].checkarr, 'pc_discovery_node'); //发现环节 |
|
|
|
|
getDictionaryBiz('result_handling').then(res => { |
|
|
|
@ -947,6 +956,7 @@ const onLoad = () => {
|
|
|
|
|
payment: item.compensationMethod, |
|
|
|
|
name: item.resultTypeName, |
|
|
|
|
text: item.compensationMethodName, |
|
|
|
|
compensationTime: item.compensationTime, |
|
|
|
|
}; |
|
|
|
|
} |
|
|
|
|
); |
|
|
|
@ -958,7 +968,6 @@ const onLoad = () => {
|
|
|
|
|
// 处理结果说明回显 |
|
|
|
|
Indexform.value.resultDescription = res.data.data.processingResultsVO.resultDescription; |
|
|
|
|
}); |
|
|
|
|
|
|
|
|
|
}; |
|
|
|
|
onLoad(); //初始化程序 |
|
|
|
|
// 异常类型事件 |
|
|
|
@ -1535,7 +1544,7 @@ const EndJump = () => {
|
|
|
|
|
} |
|
|
|
|
} |
|
|
|
|
.foot_btn { |
|
|
|
|
width: 100%; |
|
|
|
|
width: 100%; |
|
|
|
|
position: fixed; |
|
|
|
|
bottom: 0; |
|
|
|
|
left: 50%; |
|
|
|
@ -1577,11 +1586,15 @@ width: 100%;
|
|
|
|
|
margin-bottom: 20px; |
|
|
|
|
height: 30px; |
|
|
|
|
width: 30%; |
|
|
|
|
margin-right: 38px; |
|
|
|
|
span { |
|
|
|
|
display: block; |
|
|
|
|
width: 30%; |
|
|
|
|
color: #606266; |
|
|
|
|
font-size: 16px; |
|
|
|
|
display: flex; |
|
|
|
|
align-items: center; |
|
|
|
|
justify-content: center; |
|
|
|
|
} |
|
|
|
|
} |
|
|
|
|
} |
|
|
|
@ -1592,13 +1605,14 @@ width: 100%;
|
|
|
|
|
.name { |
|
|
|
|
width: 10%; |
|
|
|
|
color: #606266; |
|
|
|
|
|
|
|
|
|
:deep(.el-input--prefix) { |
|
|
|
|
width: 200px; |
|
|
|
|
} |
|
|
|
|
} |
|
|
|
|
.el-input { |
|
|
|
|
:deep(.el-input) { |
|
|
|
|
width: auto; |
|
|
|
|
} |
|
|
|
|
:deep(.el-input--prefix) { |
|
|
|
|
width: 200px; |
|
|
|
|
} |
|
|
|
|
} |
|
|
|
|
.ZFlptime { |
|
|
|
|
margin: 10px 0; |
|
|
|
@ -1615,8 +1629,8 @@ width: 100%;
|
|
|
|
|
font-size: 14px; |
|
|
|
|
padding: 10px; |
|
|
|
|
cursor: pointer; |
|
|
|
|
width: 100px; |
|
|
|
|
margin-left: 14px; |
|
|
|
|
width: 180px; |
|
|
|
|
margin: 0 10px; |
|
|
|
|
} |
|
|
|
|
.Paymentname:hover { |
|
|
|
|
border: 1px solid #172e60; |
|
|
|
@ -1632,12 +1646,12 @@ width: 100%;
|
|
|
|
|
} |
|
|
|
|
.lptime { |
|
|
|
|
height: 30px !important; |
|
|
|
|
:deep(.el-input) { |
|
|
|
|
height: 30px !important; |
|
|
|
|
} |
|
|
|
|
} |
|
|
|
|
:deep(.el-image) { |
|
|
|
|
width: 100% !important; |
|
|
|
|
height: 300px !important; |
|
|
|
|
} |
|
|
|
|
:deep(.el-input) { |
|
|
|
|
height: 100% !important; |
|
|
|
|
} |
|
|
|
|
</style> |
|
|
|
|