Browse Source

货位可视化分区样式修复

master
马远东 1 year ago
parent
commit
ed94cf8cd3
  1. 2
      src/api/aftersales/aftersalesWorkOrder.js
  2. 15
      src/option/aftersales/vueTvemp.js
  3. 233
      src/views/aftersales/aftersalesWorkOrder.vue
  4. 162
      src/views/aftersales/aftersalesWorkOrderAdd.vue
  5. 12
      src/views/aftersales/aftersalesWorkOrderInfo.vue
  6. 17
      src/views/aftersales/aftersalesWorkOrderend.vue
  7. 121
      src/views/aftersales/aftersalesWorkOrdermodify.vue
  8. 9
      src/views/basicdata/warehouse/goodsShelf/basicdataGoodsShelfView.vue

2
src/api/aftersales/aftersalesWorkOrder.js

@ -245,8 +245,6 @@ export const $_getSurveyRecord = (params) => {
}
// 工单申诉
export const $_appealSubmit = (data) => {
return request({
url: '/api/logpm-aftersales/aftersalesAppeal/submit',

15
src/option/aftersales/vueTvemp.js

@ -69,6 +69,17 @@ export const columnList = [
sortable: true,
head: false,
},
{
prop: 'brandName',
label: '品牌',
type: 2,
values: '',
width: '150',
checkarr: [],
fixed: false,
sortable: true,
head: false,
},
{
prop: 'trainNumber',
label: '车次号',
@ -182,9 +193,9 @@ export const columnList = [
},
{
prop: 'workOrderStatus',
prop: 'workOrderStatusNameS', //workOrderStatus
label: '工单状态',
type: 2,
type: 3,
values: '',
width: '150',
checkarr: [],

233
src/views/aftersales/aftersalesWorkOrder.vue

@ -80,44 +80,45 @@
<div class="avue-crud__header">
<!-- 头部左侧按钮模块 -->
<div class="avue-crud__left">
<el-button
type="primary"
@click="AddInfo"
v-if="ButtonPermissions.add"
>
<!-- v-if="ButtonPermissions.add" -->
<el-button type="primary" @click="AddInfo">
<el-icon><Plus /></el-icon> </el-button
>
<!-- <el-button type="primary" @click="BatchDelete">
<el-icon><Delete /></el-icon></el-button
> -->
<!-- v-if="ButtonPermissions.batchReject" -->
<el-button
type="primary"
@click="BatchReturn"
v-if="ButtonPermissions.batchReject"
>批量打回</el-button
>
<el-button
type="primary"
@click="assign"
v-if="ButtonPermissions.assignment"
<!-- v-if="ButtonPermissions.assignment" -->
<el-button type="primary" @click="assign"
>工单指派</el-button
>
<!-- v-if="ButtonPermissions.applyArbitration" -->
<el-button
type="primary"
@click="arbitrate"
v-if="ButtonPermissions.applyArbitration"
>申请仲裁</el-button
>
<!-- v-if="ButtonPermissions.batchFinish" -->
<el-button
type="primary"
@click="Batchcompletion"
v-if="ButtonPermissions.batchFinish"
>批量完结</el-button
>
<el-button
type="primary"
@click="appeal"
v-if="ButtonPermissions.appeal"
<!-- v-if="ButtonPermissions.appeal" -->
<el-button type="primary" @click="appeal"
>申诉</el-button
>
<!-- v-if="details.query.workOrderStatus == 30" -->
@ -154,11 +155,11 @@
@selection="selectionChange"
>
<template #default="slotProps">
<template v-if="slotProps.scope.column.label === '操作'" >
<template v-if="slotProps.scope.column.label === '操作'">
<div class="ElBtnClass">
<div >
<div>
<!-- <el-button @click="addingRecord(slotProps.scope)">新增记录</el-button> -->
<el-button v-if="TabPermissions !='4'" @click="view(slotProps.scope)"
<el-button v-if="TabPermissions != '4'" @click="view(slotProps.scope)"
>查看</el-button
>
<!-- <el-button @click="ViewEvent(slotProps.scope)">编辑</el-button> -->
@ -169,7 +170,9 @@
>申诉</el-button
> -->
</div>
<el-button v-if='TabPermissions==4' @click="BtnModifyAmount(slotProps.scope)"
<el-button
v-if="TabPermissions == 7"
@click="BtnModifyAmount(slotProps.scope)"
>修改金额</el-button
>
</div>
@ -1309,12 +1312,10 @@ const {
// { label: '', value: 7 },
// ];
// //
// // 1. 2. 3. 4. 5. 6.
// //
// //
// // 1.
// // 2.
// // 3.
@ -1337,7 +1338,6 @@ const {
// // value==2
//
// // value==3
// 1.
// 2.
@ -1354,7 +1354,6 @@ const {
// 5.
// 6.
// // value==5
// 1.
// 2.
@ -1362,7 +1361,7 @@ const {
// 4.
// 5.
// 6.
// // value==6
// 1.
// 2.
@ -1371,7 +1370,6 @@ const {
// 5.
// 6.
// // value== 7
// 1.
// 2.
@ -1389,77 +1387,77 @@ const {
const ButtonPermissions = computed(() => {
// TabPermissions
switch (TabPermissions.value) {
case 0://
case 0: //
return {
add: UserPermissions.value == '仓库客服', //
batchReject: UserPermissions.value == '职能客服',//
assignment: UserPermissions.value == '客服经理',//
applyArbitration: UserPermissions.value == '仓库客服',//
batchFinish: UserPermissions.value == '职能客服',//
appeal: false//
batchReject: UserPermissions.value == '职能客服', //
assignment: UserPermissions.value == '客服经理', //
applyArbitration: UserPermissions.value == '仓库客服', //
batchFinish: UserPermissions.value == '职能客服', //
appeal: false, //
};
case 1://
case 1: //
return {
add: false,//
batchReject: UserPermissions.value != '仓库客服',//
assignment: false,//
applyArbitration: UserPermissions.value == '仓库客服',//
batchFinish:UserPermissions.value != '仓库客服',//
appeal: false//
add: false, //
batchReject: UserPermissions.value != '仓库客服', //
assignment: false, //
applyArbitration: UserPermissions.value == '仓库客服', //
batchFinish: UserPermissions.value != '仓库客服', //
appeal: false, //
};
case 2://
case 2: //
return {
add: false,//
batchReject: false,//
assignment: false,//
applyArbitration: false,//
batchFinish:false,//
appeal: UserPermissions.value == '仓库客服' && AppealStatusT.value//
add: false, //
batchReject: false, //
assignment: false, //
applyArbitration: false, //
batchFinish: false, //
appeal: UserPermissions.value == '仓库客服' && AppealStatusT.value, //
};
case 3://
case 3: //
return {
add: false,//
batchReject: UserPermissions.value == '仓库客服',//
assignment:UserPermissions.value == '客服经理',//
applyArbitration: false,//
batchFinish:false,//
appeal: false//
add: false, //
batchReject: UserPermissions.value == '仓库客服', //
assignment: UserPermissions.value == '客服经理', //
applyArbitration: false, //
batchFinish: false, //
appeal: false, //
};
case 4://
case 4: //
return {
add: false,//
batchReject: false,//
assignment:false,//
applyArbitration: false,//
batchFinish:false,//
appeal: UserPermissions.value == '仓库客服'//
add: false, //
batchReject: false, //
assignment: false, //
applyArbitration: false, //
batchFinish: false, //
appeal: UserPermissions.value == '仓库客服', //
};
case 5://
case 5: //
return {
add: false,//
batchReject: false,//
assignment:false,//
applyArbitration: false,//
batchFinish:false,//
appeal:false//
add: false, //
batchReject: false, //
assignment: false, //
applyArbitration: false, //
batchFinish: false, //
appeal: false, //
};
case 6://
case 6: //
return {
add: false,//
batchReject: false,//
assignment:false,//
applyArbitration: false,//
batchFinish:false,//
appeal:false//
add: false, //
batchReject: false, //
assignment: false, //
applyArbitration: false, //
batchFinish: false, //
appeal: false, //
};
case 7://
case 7: //
return {
add: false,//
batchReject: false,//
assignment:false,//
applyArbitration: false,//
batchFinish:false,//
appeal:false//
add: false, //
batchReject: false, //
assignment: false, //
applyArbitration: false, //
batchFinish: false, //
appeal: false, //
};
//
default:
@ -1469,12 +1467,11 @@ const ButtonPermissions = computed(() => {
assignment: false,
applyArbitration: false,
batchFinish: false,
appeal: false
appeal: false,
};
}
});
const ProcessingResults = [
{
value: '0',
@ -1542,6 +1539,7 @@ const IndexTable = val => {
data.size = page.value.pageSize; //
updateDictionary(columnList[2].checkarr, 'pc_work_order'); //
updateDictionary(columnList[3].checkarr, 'pc_discovery_node'); //
updateDictionary(columnList[17].checkarr, 'work_order_status'); //
//
getDictionaryBiz('after_sales_visits').then(res => {
console.log(res, '角色字典');
@ -1561,7 +1559,7 @@ const IndexTable = val => {
page.value.total = res.data.data.total; //
if (res.data.data.records.length) {
res.data.data.records.forEach(item => {
console.log(item,'item');
console.log(item, 'item');
// null
for (const property in item) {
if (item[property] == null) {
@ -1598,6 +1596,25 @@ const IndexTable = val => {
} else if (item.discoveryNode == 8) {
item.discoveryNodeNameS = columnList[3].checkarr[7].label; //
}
if (item.workOrderStatus == 10) {
item.workOrderStatusNameS = columnList[17].checkarr[0].label; //
} else if (item.workOrderStatus == 20) {
item.workOrderStatusNameS = columnList[17].checkarr[1].label; //
} else if (item.workOrderStatus == 30) {
item.workOrderStatusNameS = columnList[17].checkarr[2].label; //
} else if (item.workOrderStatus == 40) {
item.workOrderStatusNameS = columnList[17].checkarr[4].label; //
} else if (item.workOrderStatus == 50) {
item.workOrderStatusNameS = columnList[17].checkarr[5].label; //
} else if (item.workOrderStatus == 60) {
item.workOrderStatusNameS = columnList[17].checkarr[3].label; //
} else if (item.workOrderStatus == 70) {
item.workOrderStatusNameS = columnList[17].checkarr[6].label; //
} else if (item.workOrderStatus == 80) {
item.workOrderStatusNameS = columnList[17].checkarr[7].label; //
} else if (item.workOrderStatus == 90) {
item.workOrderStatusNameS = columnList[17].checkarr[8].label; //
}
});
details.data = res.data.data.records;
} else {
@ -1753,7 +1770,7 @@ const view = val => {
warehouseId: val.row.warehouseId,
workOrderNumber: val.row.workOrderNumber, //
businessId: val.row.businessId,
ProcessType:TabPermissions.value==2?'2':TabPermissions.value==3?'1':'', // 1 2
ProcessType: TabPermissions.value == 2 ? '2' : TabPermissions.value == 3 ? '1' : '', // 1 2
},
});
return;
@ -1877,14 +1894,14 @@ const appeal = val => {
};
//
const Appealbutton = () => {
console.log(details.selectionList,'当前申诉的东西');
console.log(details.selectionList, '当前申诉的东西');
loadingappeal.value = true; //
console.log(Appealselection.value, '当前选择的责任人');
console.log(warehouseData.value, '要循环处理的参数');
let data = {
peopleEntityList: [], //
};
data.workOrderId = details.selectionList[0].id;
data.workOrderId = details.selectionList[0].lawoId;
data.reason = Reasonforappeal.value;
(data.appealPeopleName = warehouseData.value
@ -1907,24 +1924,24 @@ const Appealbutton = () => {
});
});
console.log(data, '处理好的值');
// $_appealSubmit(data).then(res => {
// dialogappeal.value = false; //
// loadingappeal.value = false; //
// console.log(res, '');
// ProcessingPartyState.value = false; //
// data.workOrderStatus = 30;
// details.query.workOrderStatus = 30;
// ArbitrationStatus.value = false; //
// tabValue.value = 2;
// empty(); //
// IndexTable({ workOrderStatus: 30 });
// if (res.data.code == 200) {
// ElMessage({
// message: res.data.msg,
// type: 'success',
// });
// }
// });
$_appealSubmit(data).then(res => {
dialogappeal.value = false; //
loadingappeal.value = false; //
console.log(res, '申诉成功返回值');
ProcessingPartyState.value = false; //
data.workOrderStatus = 30;
details.query.workOrderStatus = 30;
ArbitrationStatus.value = false; //
tabValue.value = 2;
empty(); //
IndexTable({ workOrderStatus: 30 });
if (res.data.code == 200) {
ElMessage({
message: res.data.msg,
type: 'success',
});
}
});
};
//
@ -2308,7 +2325,6 @@ const appealFn = val => {
//
const AppealTab = val => {
if (val == 0) {
AppealStatusT.value = false; //
Tableheaderswitching(columnList); //
@ -2335,10 +2351,11 @@ const AppealTab = val => {
};
//
const BtnModifyAmount = val => {
console.log(val, '超时金额修改');
dialogModifyAmount.value = true; //
fromamount.value.title = val.row.workOrderNumber; //
fromamount.value.ytimeout = val.row.money; //
fromamount.value.id = val.row.id; //id
fromamount.value.id = val.row.lawoId; //id
};
//
const ModifyAmountFn = () => {

162
src/views/aftersales/aftersalesWorkOrderAdd.vue

@ -275,12 +275,48 @@
<el-input v-model="Indexform.problemDescription" placeholder="请输入异常问题" clearable />
</el-form-item>
<el-form-item> </el-form-item>
<el-form-item> </el-form-item>
<el-form-item label="处理方">
<el-select
v-model="Indexform.processor"
clearable
filterable
multiple
placeholder="请选择处理方"
>
<el-option
v-for="item in warehouseData"
:key="item.value"
:label="item.label"
:value="item.value"
/>
</el-select>
</el-form-item>
<el-form-item label="调查经过">
<el-input
v-model="Indexform.investigationPocess"
placeholder="请输入调查经过"
clearable
:rows="2"
type="textarea"
/>
</el-form-item>
<el-form-item >
</el-form-item>
<el-form-item >
</el-form-item>
</el-form>
<!-- 必填 -->
<div class="el_clzr">
<!-- <div class="el_clzr">
<el-form-item class="investigate" label="调查经过">
<el-input
v-model="Indexform.investigationPocess"
@ -307,7 +343,7 @@
/>
</el-select>
</el-form-item>
</div>
</div> -->
<el-tabs type="border-card">
<el-tab-pane label="责任方选择">
@ -353,6 +389,7 @@
<div class="maxBox">
<span class="title">责任人</span>
<el-select
v-if="groundlineType !=1"
v-model="item.personResponsibleName"
clearable
filterable
@ -365,6 +402,9 @@
:value="item.id"
/>
</el-select>
<el-input v-else v-model="item.personResponsibleName" placeholder="请输入责任人"/>
</div>
<div class="maxBox">
<span class="title">占比:</span>
@ -373,6 +413,8 @@
placeholder="请输入占比 "
clearable
:rows="2"
@input="CompanyProportionInput"
/>
</div>
@ -522,14 +564,6 @@ const $router = useRouter();
const $route = useRoute();
const Indexform = ref({
packList: [
{
name: 'food.jpeg',
url: 'https://fuss10.elemecdn.com/3/63/4e7f3a15429bfda99bce42a18cdd1jpeg.jpeg?imageMogr2/thumbnail/360x360/format/webp/quality/100',
},
{
name: 'food.jpeg',
url: 'https://fuss10.elemecdn.com/3/63/4e7f3a15429bfda99bce42a18cdd1jpeg.jpeg?imageMogr2/thumbnail/360x360/format/webp/quality/100',
},
],
decreaseImageEntityList: [], //
}); //
@ -623,10 +657,10 @@ const doubledCount = computed(() => {
const ImgSuccess = (response, uploadFile) => {
if (response.success === true) {
console.log(response);
Indexform.value['packList'].push({
name: response.data.originalName,
url: response.data.link,
});
// Indexform.value['packList'].push({
// name: response.data.originalName,
// url: response.data.link,
// });
console.log(Indexform.value['packList'], '图片列表');
}
};
@ -721,7 +755,7 @@ const handlePictureCardPreview = uploadFile => {
//
const AddPackage = () => {
PackageInfo.value.push({ packageCode: '', orderCode: '', waybillNumber: '' });
PackageInfo.value.push({ packageCode: '', orderCode: '', waybillNumber: '',brandName:'' });
};
//
const PackagRemoval = val => {
@ -740,6 +774,7 @@ const responsibleParty = () => {
//
const ResponsibilityRemoval = val => {
FangAddList.value.splice(val, 1); //
CompanyProportion()
};
//
const TopChange = val => {
@ -750,9 +785,34 @@ const TopChange = val => {
identifying.value = 2;
}
};
//
const CompanyProportion=()=>{
let proportion = 0; //
FangAddList.value.forEach(item=>{
proportion += item.responsibilityRatio
})
companyProportion.value = 100 - proportion;
}
//
const CompanyProportionInput=()=>{
CompanyProportion()
}
//
const ConfirmForm = () => {
//
console.log(Indexform.value.businessMame, '提货责任方');
let DataSubmit = {
personResponsibleDTO: [],
packageEntityList: [], ////
decreaseImageEntityList:[],//
...Indexform.value,
}; //
// :10,20
// decreaseImageEntityList:[
// {imageType:10,imageName:'',imagePath:''},
@ -763,18 +823,20 @@ const ConfirmForm = () => {
if (SelectType.value == 1 || SelectType.value == 3) {
if (Indexform.value['packList']) {
Indexform.value['packList'].forEach(item => {
Indexform.value['decreaseImageEntityList'].push({
DataSubmit['decreaseImageEntityList'].push({
imageType: SelectType.value == 1 ? 10 : SelectType.value == 3 ? 20 : '',
imageName: item.name,
imagePath: item.url,
imageName: item.response.data.originalName,
imagePath: item.response.data.link,
});
});
}
}
console.log(Indexform.value['decreaseImageEntityList'], '处理好的图片');
//
if (Indexform.value.deliveryDriver) {
console.log(DataSubmit['decreaseImageEntityList'], '处理好的图片');
//
if (Indexform.value.deliveryDriver) {
Indexform.value.deliveryDriver = DeliveryDriver.value.find(
item => item.value == Indexform.value.deliveryDriver
);
@ -808,14 +870,11 @@ const ConfirmForm = () => {
// });
// }
// }
//
console.log(Indexform.value.businessMame, '提货责任方');
let DataSubmit = {
personResponsibleDTO: [],
packageEntityList: [], ////
...Indexform.value,
}; //
DataSubmit.processorEntityList = processorEntityList;
DataSubmit.decreaseImageEntityList = JSON.parse(
JSON.stringify(Indexform.value['decreaseImageEntityList'])
@ -832,6 +891,7 @@ const ConfirmForm = () => {
// warehouseId: '', //ID
waybillNumber: item.waybillNumber, //
orderCode: item.orderCode, //
brandName:item.brandName,//
});
});
}
@ -857,7 +917,9 @@ const ConfirmForm = () => {
console.log(DataSubmit.surveyRecordDTO, '调查经过');
//
// FangAddList.value
if(FangAddList.value.length){
//
if(groundlineType.value !=1 ){
if(FangAddList.value.length){
//
FangAddList.value.forEach(item => {
DataSubmit['personResponsibleDTO'].push({
@ -873,13 +935,28 @@ const ConfirmForm = () => {
});
});
}
//
let proportion = 0; //
DataSubmit['personResponsibleDTO'].forEach(item => {
proportion += Number(item.responsibilityRatio);
}else{
//
FangAddList.value.forEach(item => {
DataSubmit['personResponsibleDTO'].push({
businessName: warehouseData.value.find(obj => obj.value == item.businessName)?.label || null, //
businessId: warehouseData.value.find(obj => obj.value == item.businessName)?.value || null,
wordOrderId: Indexform.value.workOrderNumber, //ID
description: item.description,
personResponsibleId:'',
personResponsibleName:item.personResponsibleName,//
responsibilityRatio: item.responsibilityRatio, //
});
});
console.log(proportion, '责任比例之和');
companyProportion.value = 100 - proportion;
}
//
// let proportion = 0; //
// DataSubmit['personResponsibleDTO'].forEach(item => {
// proportion += Number(item.responsibilityRatio);
// });
// console.log(proportion, '');
// companyProportion.value = 100 - proportion;
DataSubmit.companyProportion = companyProportion.value; //
console.log(DataSubmit.companyProportion, '公司占比');
console.log(DataSubmit['personResponsibleDTO'], '新责任方处理的数据');
@ -916,10 +993,10 @@ const ConfirmForm = () => {
// }
delete DataSubmit.duty, //
delete DataSubmit.packList; //
delete DataSubmit.packList; //
delete DataSubmit.processor; //
console.log(DataSubmit, '处理好的数据');
//stringify
// stringify
$_submit(DataSubmit).then(res => {
if (res.data.code == 200) {
ElMessage({
@ -1040,6 +1117,7 @@ const ChangePackageInfo = (val, index) => {
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; //
if (res.data.data.length > 1) {
@ -1068,6 +1146,7 @@ const HistoricalPackage = val => {
PackageInfo.value[HistorIndex.value].orderCode = info.orderCode; //
PackageInfo.value[HistorIndex.value].waybillNumber = info.waybillNumber; //
PackageInfo.value[HistorIndex.value].orderId = info.orderId; //
PackageInfo.value[HistorIndex.value].brandName = packageData.brandName; //
dialogHistoricalPackage.value = false; //
PackageInfo.value[HistorIndex.value].relatedWorkOrdersId = info.workOrderId;
@ -1340,4 +1419,9 @@ const ViewPackageDetails = val => {
:deep(.el-card__body) {
margin-bottom: 50px;
}
:deep(.el-upload-dragger){
display: flex;
align-items: center;
justify-content: center;
}
</style>

12
src/views/aftersales/aftersalesWorkOrderInfo.vue

@ -36,6 +36,10 @@
clearable
/>
</div>
<div class="maxBox">
<span class="title">品牌:</span>
<el-input disabled v-model="item.brandName" placeholder="请输入品牌" clearable />
</div>
</div>
</div>
<div class="NumTotal">
@ -538,7 +542,7 @@ const dialogReturn = ref(false); //打回弹窗
const repulse = ref(false); //
const PackageInfo = ref([
//
{ packageCode: '', orderCode: '', waybillNumber: '' },
{ packageCode: '', orderCode: '', waybillNumber: '',brandName:'' },
]);
//
const FangAddList = ref([
@ -713,7 +717,7 @@ 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')
@ -989,6 +993,7 @@ const ChangePackageInfo = (val, index) => {
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; //
if (res.data.data.length > 1) {
@ -1017,6 +1022,7 @@ const HistoricalPackage = val => {
PackageInfo.value[HistorIndex.value].orderCode = info.orderCode; //
PackageInfo.value[HistorIndex.value].waybillNumber = info.waybillNumber; //
PackageInfo.value[HistorIndex.value].orderId = info.orderId; //
PackageInfo.value[HistorIndex.value].brandName = packageData.brandName; //
dialogHistoricalPackage.value = false; //
PackageInfo.value[HistorIndex.value].relatedWorkOrdersId = info.workOrderId;
@ -1287,6 +1293,7 @@ const EndJump = () => {
display: flex;
flex-direction: column;
margin-bottom: 10px;
.leftbox {
width: 80%;
display: flex;
@ -1296,6 +1303,7 @@ const EndJump = () => {
display: flex;
align-items: center;
width: 30%;
margin-right: 20px;
.title {
width: 140px;
color: #606266;

17
src/views/aftersales/aftersalesWorkOrderend.vue

@ -2110,6 +2110,15 @@ const ViewPackageDetails = val => {
font-size: 14px;
color: #606266;
margin-top: 30px;
.title{
border: 1px solid #ccc;
padding: 2px 8px;
display: flex;
align-items: center;
justify-content: center;
width: max-content;
color: #000;
}
}
.el_tool {
span {
@ -2238,9 +2247,17 @@ const ViewPackageDetails = val => {
margin-top: 16px;
display: flex;
align-items: center;
span {
width: 120px;
font-size: 14px;
width: 30%;
margin-top: 4px;
display: flex;
align-items: center;
justify-content: center;
padding: 2px 0;
border: 1px solid #dcdfe6;
}
}
.el_sub {

121
src/views/aftersales/aftersalesWorkOrdermodify.vue

@ -11,7 +11,7 @@
<el-tabs type="border-card" class="PackageInformation">
<el-tab-pane label="包件信息">
<div class="ResponsibilityBoxS">
<div><el-button type="primary" @click="AddPackage"> 添加信息 </el-button></div>
<div><el-button type="primary" v-if="RouterState !='Kfend'" @click="AddPackage"> 添加信息 </el-button></div>
<div class="el_btbox" v-for="(item, index) in PackageInfo" :key="index">
<div class="leftbox">
<div class="maxBox">
@ -22,25 +22,32 @@
clearable
:rows="2"
@change="ChangePackageInfo(item.packageCode, index)"
:disabled="RouterState == 'Kfend'"
/>
</div>
<div class="maxBox">
<span class="title">订单自编码:</span>
<el-input v-model="item.orderCode" placeholder="请输入订单自编号" clearable />
<el-input :disabled="RouterState == 'Kfend'" v-model="item.orderCode" placeholder="请输入订单自编号" clearable />
</div>
<div class="maxBox">
<span class="title">运单号:</span>
<el-input v-model="item.waybillNumber" placeholder="请输入运单号" clearable />
<el-input :disabled="RouterState == 'Kfend'" v-model="item.waybillNumber" placeholder="请输入运单号" clearable />
</div>
<div class="maxBox">
<span class="title">品牌:</span>
<el-input :disabled="RouterState == 'Kfend'" v-model="item.brandName" placeholder="请输入品牌" clearable />
</div>
</div>
<div class="el-btn">
<el-button v-if="item.state" type="primary" @click="historicalPackages(index)">
查看历史包件
</el-button>
<el-button type="primary" @click="PackagRemoval(index, item)"> 移除 </el-button>
<el-button type="primary" v-if="RouterState !='Kfend'" @click="PackagRemoval(index, item)"> 移除 </el-button>
</div>
</div>
<div class="NumTotal">
@ -50,11 +57,12 @@
</el-tab-pane>
</el-tabs>
<el-form
:disabled="RouterState == 'false'"
:disabled="RouterState == 'Kfend'"
:model="Indexform"
label-width="100px"
class="IndexFrom"
ref="IndexForm"
>
<el-form-item label="异常类型">
<el-select
@ -164,15 +172,6 @@
</el-form-item>
<el-form-item
label="配送司机"
v-if="
groundlineSet ||
groundlineType == 3 ||
groundlineType == 4 ||
groundlineType == 8 ||
groundlineType == 5 ||
groundlineType == 7 ||
groundlineType == 8
"
>
<el-select
v-model="Indexform.deliveryDriver"
@ -193,12 +192,46 @@
<el-form-item label="异常问题描述">
<el-input v-model="Indexform.problemDescription" placeholder="请输入异常问题" clearable />
</el-form-item>
<el-form-item label="调查经过">
<el-input
:disabled="RouterState == 'Kfend'"
v-model="Indexform.investigationPocess"
placeholder="请输入调查经过"
clearable
:rows="2"
type="textarea"
/>
</el-form-item>
<el-form-item label="处理方">
<el-select
:disabled="RouterState == 'Kfend'"
v-model="Indexform.processor"
clearable
filterable
multiple
placeholder="请选择处理方"
>
<el-option
v-for="item in warehouseData"
:key="item.value"
:label="item.label"
:value="item.value"
/>
</el-select>
</el-form-item>
<el-form-item>
</el-form-item>
</el-form>
<!-- 必填 -->
<div class="el_clzr">
<!-- <div class="el_clzr">
<el-form-item class="investigate" label="调查经过">
<el-input
:disabled="RouterState == 'Kfend'"
v-model="Indexform.investigationPocess"
placeholder="请输入调查经过"
clearable
@ -209,6 +242,7 @@
<el-form-item label="处理方">
<el-select
:disabled="RouterState == 'Kfend'"
v-model="Indexform.processor"
clearable
filterable
@ -223,12 +257,12 @@
/>
</el-select>
</el-form-item>
</div>
</div> -->
<el-tabs type="border-card">
<el-tab-pane label="责任方选择">
<div class="ResponsibilityBox">
<div><el-button type="primary" @click="responsibleParty"> 添加信息 </el-button></div>
<div><el-button type="primary" @click="responsibleParty" v-if="RouterState != 'Kfend'"> 添加信息 </el-button></div>
<div class="el_btbox" v-for="(item, index) in FangAddList" :key="index">
<div class="leftbox">
<div class="maxBox">
@ -241,6 +275,7 @@
clearable
placeholder="请选提货择责任方"
v-if="groundlineType == 1"
>
<el-option
v-for="item in responsible"
@ -255,6 +290,7 @@
v-model="item.businessName"
filterable
placeholder="请选择责任方"
:disabled="RouterState == 'Kfend'"
@change="ResponsiblePartychange(item.businessName, index)"
>
<el-option
@ -269,6 +305,7 @@
<div class="maxBox">
<span class="title">责任人</span>
<el-select
:disabled="RouterState == 'Kfend'"
v-model="item.personResponsibleName"
clearable
filterable
@ -286,7 +323,8 @@
<span class="title">占比:</span>
<el-input
v-model="item.responsibilityRatio"
placeholder="请输入占比 "
placeholder="请输入占比"
:disabled="RouterState == 'Kfend'"
clearable
:rows="2"
@input="ProportionInput"
@ -296,6 +334,7 @@
<div class="maxBox">
<span class="title">说明:</span>
<el-input
:disabled="RouterState == 'Kfend'"
v-model="item.description"
placeholder="请输入说明 "
clearable
@ -304,7 +343,7 @@
</div>
</div>
<div class="el-btn">
<el-button type="primary" @click="ResponsibilityRemoval(index, item)">
<el-button v-if="RouterState != 'Kfend'" type="primary" @click="ResponsibilityRemoval(index, item)">
移除
</el-button>
</div>
@ -380,7 +419,7 @@
</span>
</template>
<div class="el-ckbtn">
<div class="el-ckbtn" v-if="RouterState !='Infoedit'">
<el-button type="primary" @click="AddCompensation">添加赔款方</el-button>
<el-button type="primary" @click="AddPayee">添加收款方</el-button>
</div>
@ -395,24 +434,25 @@
<div class="el_pkLi">
<div class="sk_input">
<el-input
:disabled="RouterState =='Infoedit'"
v-model="item.name"
:placeholder="item.state == 0 ? '请填写赔款方' : '请填写收款方'"
/>
</div>
<div class="sk_input">
<el-input v-model="item.reason" placeholder="请填写原因" />
<el-input v-model="item.reason" :disabled="RouterState =='Infoedit'" placeholder="请填写原因" />
</div>
<div class="sk_input">
<el-input @input="amountMoney" :min="0" v-model="item.num" placeholder="金额" />
<el-input @input="amountMoney" :disabled="RouterState =='Infoedit'" :min="0" v-model="item.num" placeholder="金额" />
</div>
<div class="sk_input" v-if="item.state == 0">
<el-input v-model="item.explains" placeholder="请填写说明" />
<el-input v-model="item.explains" :disabled="RouterState =='Infoedit'" placeholder="请填写说明" />
</div>
<div class="sk_input" v-if="item.state == 1">
<!-- <el-input v-model="item.explain" placeholder="请填写说明" /> -->
</div>
<div class="el_cwBtn">
<div class="el_cwBtn" v-if="RouterState !='Infoedit'">
<el-button type="primary" v-if="item.state == 0"> 财务处理 </el-button>
<el-button type="primary" @click="payremove(item.state, index)"> 移除 </el-button>
</div>
@ -649,7 +689,7 @@ const CompensationParty = ref([
]); ///
const PackageInfo = ref([
//
{ packageCode: '', orderCode: '', waybillNumber: '', state: 0 },
{ packageCode: '', orderCode: '', waybillNumber: '', state: 0 ,brandName:''},
]);
//
const FangAddList = ref([
@ -983,7 +1023,7 @@ const handlePictureCardPreview = uploadFile => {
//
const AddPackage = () => {
PackageInfo.value.push({ packageCode: '', orderCode: '', waybillNumber: '', state: 1 });
PackageInfo.value.push({ packageCode: '', orderCode: '', waybillNumber: '', state: 1 ,brandName:''});
};
//
const PackagRemoval = (val, item) => {
@ -1434,10 +1474,10 @@ const Arbitrationcompleted = () => {
aftersalesProcessingResultsDTO: {
workOrderId: '', //ID
},
assignList:[]
assignList: [],
};
data.aftersalesProcessingResultsDTO.workOrderId = $route.query.id; //ID
data['assignList'].push($route.query.id)
data['assignList'].push($route.query.id);
data['completionRecordEntities'] = CompensationParty.value
.filter(item => item.state === 0) // 0
.map(item => {
@ -1447,11 +1487,11 @@ const Arbitrationcompleted = () => {
money: Number(item.num), //
reasonArbitration: item.reason, //
workOrderId: $route.query.id, //
warehouseId: $route.query.warehouseId, // ID
warehouseId: $route.query.warehouseId == '/' ? '' : $route.query.warehouseId, // ID
};
});
data['completionRecipientEntities'] = CompensationParty.value
data['completionRecipientEntities'] = CompensationParty.value
.filter(item => item.state === 1) // 1
.map(item => {
return {
@ -1467,7 +1507,7 @@ const Arbitrationcompleted = () => {
.join(',')
)
.join(','),
warehouseId: $route.query.warehouseId, // ID
warehouseId: $route.query.warehouseId == '/' ? '' : $route.query.warehouseId, // ID
workOrderId: $route.query.id, //
};
});
@ -1505,9 +1545,16 @@ const Arbitrationcompleted = () => {
}
data.aftersalesProcessingResultsDTO.money = sum; //
console.log(data, '处理好的值');
$_arbitrateEnd(data).then(res=>{
console.log(res,'处理结果');
})
$_arbitrateEnd(data).then(res => {
console.log(res, '处理结果');
ElMessage({
message: res.data.msg,
type: 'success',
});
if (res.data.code == 200) {
$router.push('/aftersales/aftersalesWorkOrder'); //
}
});
};
//
@ -1607,6 +1654,8 @@ const ChangePackageInfo = (val, index) => {
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; //
if (res.data.data.length > 1) {
@ -1634,6 +1683,9 @@ const HistoricalPackage = val => {
PackageInfo.value[HistorIndex.value].orderCode = info.orderCode; //
PackageInfo.value[HistorIndex.value].waybillNumber = info.waybillNumber; //
PackageInfo.value[HistorIndex.value].orderId = info.orderId; //
PackageInfo.value[HistorIndex.value].brandName = info.brandName; //
dialogHistoricalPackage.value = false; //
PackageInfo.value[HistorIndex.value].relatedWorkOrdersId = info.workOrderId;
@ -1841,6 +1893,7 @@ const ViewPackageDetails = val => {
display: flex;
align-items: center;
width: 30%;
margin-right: 20px;
.title {
width: 140px;
color: #606266;

9
src/views/basicdata/warehouse/goodsShelf/basicdataGoodsShelfView.vue

@ -66,7 +66,7 @@
:class="index == checksele ? 'item xz' : 'item'"
@click="ckindexs(index)"
v-for="(item, index) in arrlist[checkselect]?.warehouseGoodsAreaVOList[checkregionselect]
?.warehouseGoodsShelfEntitieList"
?.warehouseGoodsShelfEntitieList" :key="index"
>
{{ item.goodsShelfName }}
</div>
@ -2603,14 +2603,17 @@ const {
padding: 5px 10px;
box-sizing: border-box;
background-color: skyblue;
border-radius: 30px;
color: #fff;
cursor: pointer;
font-size: 15px;
min-width: 130px;
display: flex;
align-items: center;
justify-content: center;
border-radius: 4px;
}
.xz {
width: 120px;
height: 36px;
background: #2f4370;
border-radius: 4px 4px 4px 4px;
opacity: 1;

Loading…
Cancel
Save