Browse Source

解决客服已知bug

dev-xx
马远东 1 year ago
parent
commit
551c39a471
  1. 28
      src/api/aftersales/aftersalesWorkOrder.js
  2. 121
      src/option/aftersales/vueTvemp.js
  3. 437
      src/views/aftersales/aftersalesWorkOrder.vue
  4. 11
      src/views/aftersales/aftersalesWorkOrderAdd.vue
  5. 87
      src/views/aftersales/aftersalesWorkOrderInfo.vue
  6. 14
      src/views/aftersales/aftersalesWorkOrderend.vue
  7. 52
      src/views/aftersales/aftersalesWorkOrdermodify.vue
  8. 70
      src/views/distribution/inventory/distrilbutionBillLadingView.vue
  9. 34
      src/views/warehouse/parcelList/distributionParcelList.vue

28
src/api/aftersales/aftersalesWorkOrder.js

@ -502,4 +502,32 @@ export const $_aftersalesCustomerMallsetDefault = (data) => {
method: 'post',
data
})
}
// 财务入账填写
export const $_updateFinanceTime = (data) => {
return request({
url: '/api/logpm-aftersales/aftersalesWorkOrder/updateFinanceTime',
method: 'post',
data
})
}
// 创建指派商场
export const $_basicdataTripartiteMall = (params) => {
return request({
url: '/api/logpm-basicdata/basicdataTripartiteMall/getOwn',
method: 'get',
params
})
}
export const $_aftersalesCustomerMallgetByClientId = (params) => {
return request({
url: '/api/logpm-aftersales/aftersalesCustomerMall/getByClientId',
method: 'get',
params
})
}

121
src/option/aftersales/vueTvemp.js

@ -135,7 +135,17 @@ export const columnList = [
sortable: true,
head: false,
},
{
prop: 'totalAmount',
label: '赔款金额',
type: 2,
values: '',
width: '150',
checkarr: [],
fixed: false,
sortable: true,
head: false,
},
{
prop: 'deliverGoodsTime',
label: '送货时间',
@ -252,17 +262,17 @@ export const columnList = [
// sortable: true,
// head: false,
// },
// {
// prop: 'processNumber',
// label: '钉钉流程号',
// type: 2,
// values: '',
// width: '150',
// checkarr: [],
// fixed: false,
// sortable: true,
// head: false,
// },
{
prop: 'processNumber',
label: '钉钉流程号',
type: 2,
values: '',
width: '150',
checkarr: [],
fixed: false,
sortable: true,
head: false,
},
{
prop: 'reviewedBy',
label: '审核人',
@ -285,6 +295,7 @@ export const columnList = [
sortable: true,
head: false,
},
{
prop: 'entryTime',
label: '财务入账时间',
@ -296,6 +307,17 @@ export const columnList = [
sortable: true,
head: false,
},
{
prop: 'operator',
label: '操作人',
type: 2,
values: '',
width: '150',
checkarr: [],
fixed: false,
sortable: true,
head: false,
},
{
prop: 'remarks',
label: '备注',
@ -962,4 +984,79 @@ export const CustomerColumnList = [
sortable: false,
},
]
export const MallassignmentColumnList = [
{
prop: '',
label: '序号',
type: 12,
values: '',
width: 55,
fixed: true,
},
{
prop: 'clientName',
label: '商场名称',
type: 1,
values: '',
width: '130',
checkarr: [],
fixed: false,
sortable: true,
head: false,
},
{
prop: 'customerServiceName',
label: '客服名称',
type: 1,
values: '',
width: '130',
checkarr: [],
fixed: false,
sortable: true,
head: false,
},
{
prop: 'createTime',
label: '创建时间',
type: 1,
values: '',
width: '130',
checkarr: [],
fixed: false,
sortable: true,
head: false,
},
{
prop: '',
label: '操作',
type: 6,
values: '',
width: '120',
checkarr: [],
fixed: 'right',
sortable: false,
},
]
export const customerserviceColumnList = [
{
prop: 'customerServiceName',
label: '客服名称',
type: 1,
values: '',
width: '130',
checkarr: [],
fixed: false,
sortable: true,
head: false,
},
]

437
src/views/aftersales/aftersalesWorkOrder.vue

@ -17,16 +17,17 @@
<el-form :inline="true" :model="query" class="el-fr-d">
<div class="el_tims_box">
<div class="topText">
<el-input
v-model="query.workOrderNumber"
:rows="4"
type="textarea"
placeholder="请输入工单号"
/>
<el-form-item label="工单号" class="el-times">
<el-input
v-model="query.workOrderNumber"
:rows="4"
placeholder="请输入工单号"
/>
</el-form-item>
</div>
<div class="el_times">
<el-form-item label="上报日期" class="el-times">
<!-- <div class="el_times">
<el-form-item label="上报日期" class="el-times">
<el-date-picker
v-model="value1"
type="daterange"
@ -65,8 +66,8 @@
end-placeholder="结束日期"
:size="size"
/>
</el-form-item>
</div>
</el-form-item
</div> >-->
</div>
<!-- 查询按钮 -->
<el-form-item class="el-btn">
@ -87,11 +88,19 @@
<el-icon><Plus /></el-icon> </el-button
>
<el-button type="primary" @click="exportReport">
<el-button
v-if="ButtonPermissions.export_Report"
type="primary"
@click="exportReport"
>
<el-icon><Download /></el-icon></el-button
>
<el-button type="primary" @click="defaultAssignments">
<el-button
v-if="ButtonPermissions.defaultassignments"
type="primary"
@click="defaultAssignments"
>
<el-icon><Pointer /></el-icon></el-button
>
<!-- <el-button type="primary" @click="BatchDelete">
@ -111,13 +120,13 @@
@click="ResultConfirmation"
>批量确定</el-button
>
<!-- 总部客服批量确定 -->
<!-- <el-button
<!-- 总部客服批量确定 待审核-->
<el-button
v-if="ButtonPermissions.ManagerConfirmed"
type="primary"
@click="DetermineStorage"
>批量确定</el-button
> -->
>批量确定</el-button
>
<el-button type="primary" v-if="ButtonPermissions.assignment" @click="assign"
>工单指派</el-button
>
@ -159,7 +168,13 @@
<el-button v-if="ButtonPermissions.appeal" type="primary" @click="appeal"
>申诉</el-button
>
<!-- 财务入账 -->
<el-button
type="primary"
v-if="ButtonPermissions.Financial_accounting"
@click="Financialfillingbtn"
>财务入账</el-button
>
<!-- v-if="details.query.workOrderStatus == 30" -->
<!-- <el-button type="primary" @click="ProcessingParty"> 处理方信息</el-button> -->
</div>
@ -167,7 +182,7 @@
<div class="avue-crud__right">
<el-button icon="el-icon-refresh" @click="searchChangeS" circle></el-button>
<el-button icon="Operation" @click="showdrawer(true)" circle></el-button>
<!-- <el-button icon="Search" @click="searchHide" circle></el-button> -->
<el-button icon="Search" @click="searchHide" circle></el-button>
</div>
</div>
</el-row>
@ -684,7 +699,7 @@
type="datetime"
format="YYYY-MM-DD"
value-format="YYYY-MM-DD HH:mm:ss"
placeholder="请选择运损发现时间"
placeholder="请选择审核时间"
/>
</el-form-item>
@ -694,7 +709,7 @@
type="datetime"
format="YYYY-MM-DD"
value-format="YYYY-MM-DD HH:mm:ss"
placeholder="请选择运损发现时间"
placeholder="请选择时间"
/>
</el-form-item>
</el-form>
@ -720,7 +735,7 @@
<el-tab-pane name="0" label="总部指派"></el-tab-pane>
<el-tab-pane name="1" label="商场指派"></el-tab-pane>
</el-tabs>
<el-row>
<el-row v-if="AssignmentType == '1'">
<!-- 列表模块 -->
<tablecmt
:columnList="CustomerColumnList"
@ -752,7 +767,38 @@
</template>
</tablecmt>
</el-row>
<el-row v-else>
<!-- 列表模块 -->
<tablecmt
:columnList="MallassignmentColumnList"
:tableData="CustomerData"
:loading="CustomerLoad"
@inputTxt="inputsc"
@timeCheck="timesc"
@btnCheck="btnsc"
@selectCheck="selectsc"
@selection="selectionChange"
:tableRowClassName="
(row, index) => {
if (row.conditions != null && row.conditions == '1') return 'Abnormal';
else return '';
}
"
>
<template #default="slotProps">
<template v-if="slotProps.scope.column.label === '操作'">
<div class="ElBtnClass">
<el-button @click="Unbindassignment(slotProps.scope)">解绑</el-button>
<el-button
v-if="slotProps.scope.row.conditions != '1'"
@click="setAsdefault(slotProps.scope)"
>设为默认</el-button
>
</div>
</template>
</template>
</tablecmt>
</el-row>
<!-- 分页模块 -->
<el-row class="el_FyCustomer">
<div></div>
@ -761,9 +807,9 @@
background
@size-change="assignsizeChange"
@current-change="assigncurrentChange"
:current-page="page.currentPage"
:current-page="assigncurrentPage"
:page-sizes="[30, 50, 80, 120]"
:page-size="page.pageSize"
:page-size="assignpageSize"
layout="total, sizes, prev, pager, next, jumper"
:total="CustomerTotal"
>
@ -805,22 +851,44 @@
v-loading="CreateassignmentLoading"
element-loading-text="正在处理中..."
>
<el-form-item label="仓库选择">
<el-form-item :label="AssignmentType == '1'?'仓库选择':'商场选择'" >
<el-select
v-if="AssignmentType == '1'"
v-model="BatchFrom.AssignWarehouse"
filterable
default-first-option
:reserve-keyword="false"
placeholder="请选择仓库"
:placeholder="'请选择仓库'"
@change="scChange"
>
<el-option
v-for="item in warehouseData"
:key="item.value"
:label="item.label"
:value="item.value"
:disabled="item.disabled"
/>
</el-select>
<el-select
v-else
v-model="BatchFrom.AssignWarehouse"
filterable
default-first-option
:reserve-keyword="false"
:placeholder="'请选择商场'"
@change="scChange"
>
<el-option
v-for="item in Malldropdown"
:key="item.value"
:label="item.tripartiteMall"
:value="item.id"
/>
</el-select>
</el-form-item>
<el-form-item label="客服选择" class="el_Customer">
<el-select
v-model="AssignCustomerlist"
@ -835,10 +903,26 @@
:key="item.value"
:label="item.realName"
:value="item.id"
:disabled="item.disabled"
/>
</el-select>
</el-form-item>
</div>
<div class='el_bqList'>
<tablecmt
:columnList="customerserviceColumnList"
:tableData="customerData"
:loading="CustomerLoad"
@inputTxt="inputsc"
@timeCheck="timesc"
@btnCheck="btnsc"
@selectCheck="selectsc"
@selection="selectionChange"
>
</tablecmt>
</div>
<template #footer>
<span class="dialog-footer">
<el-button @click="Createassignment = false">取消</el-button>
@ -852,6 +936,38 @@
</span>
</template>
</el-dialog>
<!-- 财务入账弹窗 -->
<el-dialog v-model="dialogFinancialaccounting" title="财务入账" width="30%">
<div
class="el_DingTalk"
v-loading="loadingFinancial"
element-loading-text="正在处理中..."
>
<el-form :model="FinancialFrom" label-width="120px">
<el-form-item label="操作人">
<el-input v-model="FinancialFrom.operator" placeholder="请填写操作人" />
</el-form-item>
<el-form-item label="财务入账时间">
<el-date-picker
v-model="FinancialFrom.entryTime"
type="datetime"
format="YYYY-MM-DD"
value-format="YYYY-MM-DD HH:mm:ss"
placeholder="请选择财务入账时间"
/>
</el-form-item>
</el-form>
</div>
<template #footer>
<span class="dialog-footer">
<el-button @click="dialogFinancialaccounting = false">取消</el-button>
<el-button type="primary" @click="Financialfilling" :disabled="loadingFinancial">
确认
</el-button>
</span>
</template>
</el-dialog>
</basic-container>
</div>
</el-tabs>
@ -902,6 +1018,9 @@ import {
$_aftersalesCustomerMallremove,
$_aftersalesCustomerMallsave,
$_aftersalesCustomerMallsetDefault,
$_updateFinanceTime,
$_basicdataTripartiteMall,
$_aftersalesCustomerMallgetByClientId,
} from '@/api/aftersales/aftersalesWorkOrder';
import { getToken } from '@/utils/auth';
import NProgress from 'nprogress';
@ -925,6 +1044,8 @@ import {
AppealList,
timeoutList,
CustomerColumnList,
MallassignmentColumnList,
customerserviceColumnList,
} from '@/option/aftersales/vueTvemp.js';
import { processRowProperty, isNumer, computeNumber } from '@/utils/util';
import { useRouter } from 'vue-router';
@ -934,9 +1055,25 @@ const $router = useRouter();
const $useStore = useStore();
const $route = useRoute();
/** vuex */
const customerData=ref([]);//
const accessControl = $useStore.getters.permission;
console.log(accessControl, '权限按钮');
const loadingFinancial = ref(false);
const assigncurrentPage = ref(1); //
const assignpageSize = ref(30);
const Malldropdown = ref([]); //
const scChange=(val)=>{
CreateassignmentLoading.value=true;//
$_aftersalesCustomerMallgetByClientId({clientId:val}).then(res=>{
customerData.value=res.data.data
AssignCustomerservice.value.forEach((itemA) => {
let exists = customerData.value.some((itemB) => itemB.customerServiceId == itemA.id);
itemA.disabled = exists ? true : false;
});
CreateassignmentLoading.value=false;//
console.log(AssignCustomerservice.value,'处理好的数据');
})
}
// workAdd;//
// batch_return;//
// assign;//
@ -984,6 +1121,7 @@ const PermissionButton = computed(() => {
};
});
const CustomerServicea = ref(false); //
const dialogFinancialaccounting = ref(false); //
const dialogCustomer = ref(false); //
const CustomerServiceForm = ref({}); //
const DingTalkfilling = ref({}); //
@ -996,6 +1134,7 @@ const BatchFrom = ref({}); //批量打回
const AssignCustomerlist = ref([]); //
const selectList = ref([]); //
const CustomerLoad = ref(false); //
const FinancialFrom = ref({}); //
const currentPage = ref(1); //
const TransportlossList = ref([
//
@ -1067,21 +1206,21 @@ const AppealStatus = ref(false); //申诉列表状态
const dialogModifyAmount = ref(false); //
const UserPermissions = ref('仓库客服'); //
const TabPermissions = ref(0); //
const AssignmentType = ref('1');//
const AssignmentType = ref('1'); //
const AppealeditorState = ref(false); //()
const AppealStatusT = ref(false); //
const loadingCustomer = ref(false); //
const TabList = ref([
{ name: 0, label: '全部', state: true },
{ name: 3, label: '待处理', state: true },
{ name: 9, label: '待审核', state: true },
{ name: 8, label: '待回复', state: false },
{ name: 1, label: '处理中', state: true },
{ name: 2, label: '处理完毕', state: true },
{ name: 6, label: '仲裁中', state: true },
{ name: 5, label: '客服介入', state: true },
{ name: 4, label: '理赔金额未出', state: true },
{ name: 7, label: '超时未处理', state: true },
{ name: 0, label: '全部', state: true, request: true },
{ name: 3, label: '待处理', state: true, request: true },
{ name: 9, label: '待审核', state: true, request: true },
{ name: 8, label: '待回复', state: false, request: true },
{ name: 1, label: '处理中', state: true, request: true },
{ name: 2, label: '处理完毕', state: true, request: true },
{ name: 6, label: '仲裁中', state: true, request: true },
{ name: 5, label: '客服介入', state: true, request: true },
{ name: 4, label: '理赔金额未出', state: true, request: true },
{ name: 7, label: '超时未处理', state: true, request: true },
]); //
const DeliveryDriver = ref([]);
@ -1289,12 +1428,15 @@ const ButtonPermissions = computed(() => {
add: true, //
batchReject: UserPermissions.value != '仓库客服', //
assignment: UserPermissions.value == '总部客服经理', //
applyArbitration: UserPermissions.value == '仓库客服', //
applyArbitration: false, //
DingTalkNumber: UserPermissions.value == '总部客服经理', //
batchFinish: UserPermissions.value != '仓库客服', //
appeal: false, //
ManagerConfirmed: false, //
ArbitrationDetermination: false, //
Financial_accounting: false, //
defaultassignments: UserPermissions.value != '仓库客服', //
export_Report: true, //
};
case 1: //
return {
@ -1307,6 +1449,9 @@ const ButtonPermissions = computed(() => {
appeal: false, //
ManagerConfirmed: false, //
ArbitrationDetermination: false, //
Financial_accounting: false, //
defaultassignments: false, //
export_Report: true, //
};
case 2: //
return {
@ -1319,18 +1464,24 @@ const ButtonPermissions = computed(() => {
Batchdetermination: UserPermissions.value == '仓库客服', //
ManagerConfirmed: UserPermissions.value == '总部客服经理', //
ArbitrationDetermination: false, //
Financial_accounting: false, //
defaultassignments: false, //
export_Report: true, //
};
case 3: //
return {
add: false, //
batchReject: UserPermissions.value == '总部客服', //
assignment: UserPermissions.value == '总部客服经理', //
applyArbitration: UserPermissions.value == '仓库客服', //
applyArbitration: false, //
batchFinish: UserPermissions.value != '仓库客服', //
appeal: false, //
Batchdetermination: false, //
ManagerConfirmed: false, //
ArbitrationDetermination: false, //
Financial_accounting: false, //
defaultassignments: false, //
export_Report: true, //
};
case 4: //
return {
@ -1343,6 +1494,9 @@ const ButtonPermissions = computed(() => {
Batchdetermination: false, //
ManagerConfirmed: false, //
ArbitrationDetermination: false, //
Financial_accounting: false, //
defaultassignments: false, //
export_Report: true, //
};
case 5: //
return {
@ -1355,6 +1509,9 @@ const ButtonPermissions = computed(() => {
Batchdetermination: false, //
ManagerConfirmed: false, //
ArbitrationDetermination: true, //
Financial_accounting: false, //
defaultassignments: false, //
export_Report: true, //
};
case 6: //
return {
@ -1367,6 +1524,9 @@ const ButtonPermissions = computed(() => {
Batchdetermination: false, //
ManagerConfirmed: false, //
ArbitrationDetermination: false, //
Financial_accounting: true, //
defaultassignments: false, //
export_Report: true, //
};
case 7: //
return {
@ -1379,6 +1539,9 @@ const ButtonPermissions = computed(() => {
Batchdetermination: false, //
ManagerConfirmed: false, //
ArbitrationDetermination: false, //
Financial_accounting: false, //
defaultassignments: false, //
export_Report: false, //
};
case 8: //
return {
@ -1391,6 +1554,24 @@ const ButtonPermissions = computed(() => {
Batchdetermination: false, //
ManagerConfirmed: false, //
ArbitrationDetermination: false, //
Financial_accounting: false, //
defaultassignments: false, //
export_Report: false, //
};
case 9: //
return {
add: false, //
batchReject: false, //
assignment: false, //
applyArbitration: false, //
batchFinish: false, //
appeal: false, //
Batchdetermination: false, //
ManagerConfirmed: UserPermissions.value == '总部客服经理', //
ArbitrationDetermination: false, //
Financial_accounting: false, //
defaultassignments: false, //
export_Report: true, //
};
//
default:
@ -1404,6 +1585,9 @@ const ButtonPermissions = computed(() => {
Batchdetermination: false, //
ManagerConfirmed: false, //
ArbitrationDetermination: false, //
Financial_accounting: false, //
defaultassignments: false, //
export_Report: false, //
};
}
});
@ -1450,7 +1634,7 @@ const TransportLossNode = ref([
]);
const Statusprocessing = val => {
val.forEach(item => {
val.forEach(item => {
// null
// for (const property in item) {
// if (item[property] == null) {
@ -1458,7 +1642,7 @@ const Statusprocessing = val => {
// }
// }
//
console.log(columnList[10],'columnList[10]');
console.log(columnList[10], 'columnList[10]');
if (item.workOrderType == 1) {
item.workOrderTypeNameS = columnList[2].checkarr[0].label; //
} else if (item.workOrderType == 2) {
@ -1587,9 +1771,17 @@ const Tableheaderswitching = val => {
publicColumnList.value = val; //
details.columnList = val; //
};
const state = ref(0);
//
const OnLoad = () => {
// state.value = localStorage.getItem('state');
// console.log(state.value,'');
// if(state.value==1){
// return
// }
// state.value=1
// localStorage.setItem('state', state.value);
//
userInfo.value = JSON.parse(localStorage.getItem('TWMS-userInfo')); //
if (localStorage.getItem('my_data')) {
@ -2792,6 +2984,7 @@ const DataRendering = (val, input) => {
// data.workOrderStatus = 10;
// details.query.workOrderStatus = 10;
// }
data.workOrderStatus = 10;
details.query.workOrderStatus = 10;
ArbitrationStatus.value = true; //
@ -3190,49 +3383,17 @@ const fellSuccess = (response, uploadFile) => {
};
//
const DetermineStorage = val => {
if (!details.selectionList.length) {
ElMessage({
message: '请勾选数据',
type: 'warning',
});
return;
}
let data = {
assignList: [],
};
let ConfirmStatus = false; //
if (!val.row) {
//
console.log('当前点击的批量确定');
if (!details.selectionList.length) {
ElMessage({
message: '请勾选要处理的数据数据',
type: 'warning',
});
return;
} else {
ConfirmStatus = true; //
data['assignList'] = details.selectionList.map(item => item.id);
console.log(data['assignList'], '批量确定处理好的参数');
}
} else {
let ID = {};
ID = val.row.id;
data['assignList'].push(ID);
}
if (ConfirmStatus) {
//
let state = details.selectionList.every(item => item.workOrderStatus == '40');
if (!state) {
ElMessage({
message: '批量确认中状态只能为待审核',
type: 'warning',
});
return;
}
} else {
if (val.workOrderStatus != '40') {
ElMessage({
message: '状态错误,已经确认过',
type: 'warning',
});
return;
}
}
data['assignList'] = details.selectionList.map(item => item.id);
details.loadingObj.list = true; //
//
@ -3749,7 +3910,47 @@ const amountMoney = () => {
console.log('赔款总计金额', TotalamountCompensation.value);
console.log('收款总计金额', TotalamountReceived.value);
};
//
const Financialfillingbtn = () => {
if (!details.selectionList.length) {
ElMessage({
message: '请勾选选择要删除的数据',
type: 'warning',
});
return;
}
dialogFinancialaccounting.value = true; //
};
//
const Financialfilling = () => {
let data = {
ids: '',
...FinancialFrom.value,
};
if (details.selectionList.length) {
data.ids = details.selectionList.map(item => item.id).join(',');
loadingFinancial.value = true; //
$_updateFinanceTime(data)
.then(res => {
console.log(res, '财务入账填写成功');
if (res.data.code == 200) {
ElMessage({
message: res.data.msg,
type: 'success',
});
dialogFinancialaccounting.value = false; //
DataRendering(TabPermissions.value, details.query);
}
AppealListFn();
})
.catch(res => {
console.log(res, '财务入账成功返回值');
})
.finally(() => {
loadingFinancial.value = false; //
});
}
};
//
const Batchcompletion = () => {
console.log(details.selectionList);
@ -3932,9 +4133,9 @@ const exportReport = () => {
const defaultAssignments = () => {
CustomerServicea.value = true; //
let data = {
current: details.page.currentPage,
size: details.page.pageSize,
typesOf:AssignmentType.value,
current: assigncurrentPage.value,
size: assignpageSize.value,
typesOf: AssignmentType.value,
};
CustomerLoad.value = true; //
$_aftersalesCustomerMall(data)
@ -3948,7 +4149,16 @@ const defaultAssignments = () => {
CustomerLoad.value = false; //
});
};
//
const assignsizeChange = val => {
console.log('123');
(assignpageSize.value = val), defaultAssignments();
};
//
const assigncurrentChange = val => {
assigncurrentPage.value = val;
defaultAssignments();
};
//
const Unbindassignment = val => {
// let data=
@ -3985,20 +4195,32 @@ const setAsdefault = val => {
let data = {};
data = val.row;
CreateassignmentLoading.value = true; //
$_aftersalesCustomerMallsetDefault(data).then(res => {
$_aftersalesCustomerMallsetDefault(data)
.then(res => {
console.log(res, '设为默认');
if(res.data.code == 200){
defaultAssignments()
if (res.data.code == 200) {
defaultAssignments();
}
}).catch(res=>{
}).finally(()=>{
})
.catch(res => {})
.finally(() => {
CreateassignmentLoading.value = false; //
});
};
//
const CreateAdditions = () => {
// Malldropdown.value
let a=[{a:1,disabled:false},{a:2,disabled:false},{a:3,disabled:false}]
let tab=[{}]
if (AssignmentType.value == '2') {
$_basicdataTripartiteMall({}).then(res => {
console.log(res, '商场指派列表');
if(res.data.data){
Malldropdown.value = res.data.data;
}
});
}
Createassignment.value = true; //
$_getCustomerServicePersonnel({})
.then(res => {
@ -4010,20 +4232,21 @@ const CreateAdditions = () => {
});
};
//
const AssignSwitch=(val)=>{
const AssignSwitch = val => {
console.log(val);
if(val.props.name == '0'){
if (val.props.name == '0') {
//
AssignmentType.value='1'
}else if(val.props.name == '1'){
AssignmentType.value = '1';
} else if (val.props.name == '1') {
//
AssignmentType.value='2'
AssignmentType.value = '2';
}
defaultAssignments()
}
defaultAssignments();
};
//
const AssignSubmission = () => {
let data = {
aftersalesCustomerMallEntities: [],
};
@ -4032,9 +4255,11 @@ const AssignSubmission = () => {
customerServiceId: AssignCustomerservice.value.find(data => data.id == res).id, //ID
customerServiceName: AssignCustomerservice.value.find(data => data.id == res).realName, //
clientId: BatchFrom.value.AssignWarehouse, //ID
clientName: warehouseData.value.find(res => res.value == BatchFrom.value.AssignWarehouse)
.label, //
typesOf:AssignmentType.value,
clientName:
AssignmentType.value == '1'
? warehouseData.value.find(res => res.value == BatchFrom.value.AssignWarehouse).label
: Malldropdown.value.find(res => res.id == BatchFrom.value.AssignWarehouse).tripartiteMall, //
typesOf: AssignmentType.value,
conditions: '2',
});
});
@ -4052,7 +4277,7 @@ const AssignSubmission = () => {
Createassignment.value = false; //
AssignCustomerlist.value = []; //
BatchFrom.value.AssignWarehouse = ''; //
defaultAssignments()
defaultAssignments();
})
.catch(() => {});
}
@ -4637,7 +4862,7 @@ const AssignSubmission = () => {
justify-content: space-between;
}
.el_Createbinding {
height: 450px;
height:110px;
display: flex;
align-items: flex-start;
justify-content: flex-start;

11
src/views/aftersales/aftersalesWorkOrderAdd.vue

@ -1,5 +1,7 @@
<template>
<el-card class="box-card">
<div v-loading="Addloading"
element-loading-text="Loading...">
<el-card class="box-card" >
<el-tabs type="border-card" class="topClass" @tab-change="TopChange">
<el-tab-pane label="订单填写"></el-tab-pane>
<el-tab-pane label="零担填写"></el-tab-pane>
@ -597,6 +599,7 @@
</span>
</template>
</el-dialog>
</div>
</template>
<script setup>
@ -626,6 +629,7 @@ const Indexform = ref({
discoveryNode: '1',
}); //
const ProcessingResults = ref([]); //
const Addloading= ref(false)
const IndexException = ref([]); //
const ZFname = ref(''); //
const IndexForm = ref(null); //ref
@ -1347,12 +1351,13 @@ const ConfirmForm = () => {
delete DataSubmit.processor; //
console.log(DataSubmit, '处理好的数据');
// stringify
Addloading.value=true;//
$_submit(DataSubmit)
.then(res => {
if (res.data.code == 200) {
ElMessage({
message: res.data.msg,
type: 'success',
type: 'success'
});
Indexform.value = {}; //
$store.commit('DEL_TAG_CURRENT'); //
@ -1362,6 +1367,8 @@ const ConfirmForm = () => {
.catch(res => {
console.log(res, '错误信息');
ElMessage.error('提交失败,请刷新页面重新尝试');
}).finally(()=>{
Addloading.value=false;//
});
} else {
console.log('表单验证失败');

87
src/views/aftersales/aftersalesWorkOrderInfo.vue

@ -487,7 +487,7 @@
<el-tabs
type="border-card"
class="demo-tabs el-endtabs"
v-if="UserPermissions != '仓库客服'"
v-if="CompensationParty.length"
>
<el-tab-pane>
<template #label>
@ -553,7 +553,7 @@
</div>
<div class="sk_input" v-if="item.state == 1"></div>
<!-- <div class="sk_input" v-if="item.state == 1"></div> -->
<!-- 责任人 -->
<div class="sk_input" v-if="item.state == 0">
<span>责任人</span>
@ -692,12 +692,20 @@
<el-button type="primary" v-if="PermissionButton.Appeal_rejection" @click="AppealRejection"
>申诉驳回</el-button
>
<!-- 待处理确定 -->
<el-button
type="primary"
v-if="PermissionButton.Processing_confirmation"
@click="ResultConfirmation"
>确定</el-button
>
<!-- 仓库客服处理结果确定 -->
<el-button
type="primary"
v-if="PermissionButton.Result_determination"
@click="ResultDetermination"
>确定</el-button
>
</div>
</el-card>
@ -1059,14 +1067,10 @@ const PermissionButton = computed(() => {
warehouseIdState.value, //
Appeal_established: appeal.value && AppealReview.value, //
Appeal_rejection: appeal.value && AppealReview.value, //
Processing_confirmation:(
(UserPermissions.value != '仓库客服' &&
$route.query.RouteIndexs == '0' &&
$route.query.workOrderStatus == '40') ||
(UserPermissions.value != '仓库客服' &&
$route.query.RouteIndexs == '1' &&
$route.query.workOrderStatus == '40') ||
($route.query.RouteIndexs == '2' && $route.query.workOrderStatus == '40')),
Processing_confirmation:(UserPermissions.value != '仓库客服' && $route.query.RouteIndexs == '0' && $route.query.workOrderStatus == '40') || (UserPermissions.value != '仓库客服' &&
$route.query.RouteIndexs == '9' &&
$route.query.workOrderStatus == '40'),//
Result_determination: (UserPermissions.value == '仓库客服' && $route.query.RouteIndexs == '0' && $route.query.workOrderStatus == '21') || (UserPermissions.value == '仓库客服' && $route.query.RouteIndexs == '2' && $route.query.workOrderStatus == '21'),//
};
});
@ -1621,34 +1625,25 @@ const ConfirmReturn = () => {
});
};
//
//
//
const ResultConfirmation = () => {
if (UserPermissions.value == '仓库客服') {
//
let data = {
let data = {
assignList: [],
};
let ID = {};
ID = $route.query.id;
data['assignList'].push(ID);
if ($route.query.workOrderStatus != '30') {
if ($route.query.workOrderStatus != '40') {
ElMessage({
message: '状态错误,已经确认过',
type: 'warning',
});
return;
}
//
console.log(data, '处理好的数据');
pageState.value = true; //
$_updateWorkOrderStatus(data)
//
$_updateManagerConfirmed(data)
.then(res => {
console.log(res, '确定提交存储');
if (res.data.code == 200) {
ElMessage({
message: res.data.msg,
@ -1659,29 +1654,40 @@ const ResultConfirmation = () => {
$router.push({
path: '/aftersales/aftersalesWorkOrder',
});
console.log(res, '处理完毕确定');
})
.catch(res => {})
.finally(() => {
.catch(res => {
console.log(res, '错误信息');
})
.finally(res => {
pageState.value = false; //
});
} else {
//
console.log(data, '处理好的值');
};
//
const ResultDetermination=()=>{
//
let data = {
assignList: [],
};
let ID = {};
ID = $route.query.id;
data['assignList'].push(ID);
if ($route.query.workOrderStatus != '40') {
if ($route.query.workOrderStatus != '21') {
ElMessage({
message: '状态错误,已经确认过',
message: '状态错误',
type: 'warning',
});
return;
}
//
console.log(data, '处理好的数据');
pageState.value = true; //
//
$_updateManagerConfirmed(data)
$_updateWorkOrderStatus(data)
.then(res => {
console.log(res, '确定提交存储');
if (res.data.code == 200) {
ElMessage({
message: res.data.msg,
@ -1692,18 +1698,13 @@ const ResultConfirmation = () => {
$router.push({
path: '/aftersales/aftersalesWorkOrder',
});
console.log(res, '处理完毕确定');
})
.catch(res => {
console.log(res, '错误信息');
})
.finally(res => {
.catch(res => {})
.finally(() => {
pageState.value = false; //
});
//
console.log(data, '处理好的值');
}
};
}
</script>
<style scoped lang="scss">
@ -2262,7 +2263,7 @@ const ResultConfirmation = () => {
justify-content: space-between;
width: 100%;
background-color: #fff;
height: 100%;
:deep(.el-card) {
width: 70%;
}
@ -2607,8 +2608,8 @@ const ResultConfirmation = () => {
}
}
:deep(#avue-view) {
background-color: #fff;
#avue-view {
background-color: #fff !important;
}
:deep(.el_resj) {

14
src/views/aftersales/aftersalesWorkOrderend.vue

@ -393,7 +393,7 @@
/>
</div> -->
<!-- 赔款方是那个仓库的 -->
<div class="sk_input">
<div class="sk_input">
<el-select v-model="item.warehouseId" filterable placeholder="请选择仓库">
<el-option
v-for="item in warehouseData"
@ -575,11 +575,11 @@
>提交</el-button
>
<el-button
v-if="$route.query.index != '0'"
v-if="$route.query.index != '0' && $route.query.RouterState !='end'"
type="primary"
class="button"
@click="submit(2)"
>保存</el-button
>处理结果保存</el-button
>
<!-- <el-button
@click="DetermineStorage"
@ -836,6 +836,9 @@
</template>
</el-dialog>
<!-- 财务处理弹窗 -->
<!-- 弹出框 -->
@ -886,6 +889,7 @@ import { computeNumber, isNumer, AddressClosed } from '@/utils/util';
import { useStore } from 'vuex';
// vuex
const $store = useStore();
const ZFdialog = ref(false); //
const $route = useRoute();
const $router = useRouter();
@ -1896,8 +1900,8 @@ const submit = async(val) => {
'是否提交完结信息?',
'完结',
{
confirmButtonText: 'OK',
cancelButtonText: 'Cancel',
confirmButtonText: '确定',
cancelButtonText: '取消',
type: 'warning',
}
)

52
src/views/aftersales/aftersalesWorkOrdermodify.vue

@ -521,13 +521,31 @@
</div>
<div class="el_pkLi">
<div class="sk_input">
<!-- <div class="sk_input">
<el-input
v-model="item.name"
:placeholder="item.state == 0 ? '请填写赔款方' : '请填写受款方'"
:disabled="Processingresults"
/>
<!-- Processingresults表示此刻只能编辑处理结果 -->
Processingresults表示此刻只能编辑处理结果
</div> -->
<div class="sk_input">
<el-form-item label="仓库">
<el-select
v-model="item.warehouseId"
filterable
placeholder="请选择仓库"
:disabled="Processingresults"
>
<el-option
v-for="item in warehouseData"
:key="item.value"
:label="item.label"
:value="item.value"
/>
</el-select>
</el-form-item>
</div>
<div class="sk_input">
<el-form-item label="原因">
@ -549,23 +567,7 @@
/>
</el-form-item>
</div>
<div class="sk_input" v-if="item.state == 0">
<el-form-item label="仓库">
<el-select
v-model="item.warehouseId"
filterable
placeholder="请选择仓库"
:disabled="Processingresults"
>
<el-option
v-for="item in warehouseData"
:key="item.value"
:label="item.label"
:value="item.value"
/>
</el-select>
</el-form-item>
</div>
<div class="sk_input" v-if="item.state == 0">
<el-form-item label="责任人">
@ -585,9 +587,9 @@
<div class="sk_input" v-if="item.state == 0">
<!-- <el-input v-model="item.explains" placeholder="请填写说明" /> -->
</div>
<div class="sk_input" v-if="item.state == 1">
<!-- <div class="sk_input" v-if="item.state == 1"> -->
<!-- <el-input v-model="item.explain" placeholder="请填写说明" /> -->
</div>
<!-- </div> -->
<!-- v-if="RouterState != 'Infoedit'" -->
<div class="el_cwBtn">
<el-button type="primary" @click="payremove(item.state, index, item)">
@ -1960,8 +1962,6 @@ const Arbitrationcompleted = () => {
//
if ($route.query.Appealeditor == 'appeal' && $route.query.AppealEstablished) {
editloading.value = true; //
let data = {
completionRecipientEntities: [], //
@ -1985,7 +1985,7 @@ const Arbitrationcompleted = () => {
.filter(item => item.state === 0) // 0
.map(item => {
return {
indemnitor: item.name, //
// indemnitor: item.name, //
reason: item.reason, //
money: Number(item.num), //
reasonArbitration: Indexform.value.arbitrate, //
@ -2000,7 +2000,7 @@ const Arbitrationcompleted = () => {
.filter(item => item.state === 1) // 1
.map(item => {
return {
recipient: item.name, //
// recipient: item.name, //
reasonReceivingPayment: item.reason, //
money: Number(item.num), //
workOrderNumber: $route.query.workOrderNumber, //
@ -2012,7 +2012,7 @@ const Arbitrationcompleted = () => {
.join(',')
)
.join(','),
warehouseId: $route.query.warehouseId == '/' ? '' : $route.query.warehouseId, // ID
warehouseId: item.warehouseId, //ID
workOrderId: $route.query.id, //
id: item.id,
};

70
src/views/distribution/inventory/distrilbutionBillLadingView.vue

@ -57,6 +57,8 @@
<el-divider>订单列表</el-divider>
<el-tabs type="border-card" v-model="activeTab" @tab-click="handleTabClick">
<el-tab-pane label="订 单 列 表" name="tab2">
<el-button type="primary" icon="Position" @click="Orderexport">订单导出</el-button>
<!-- 列表模块 -->
<tablecmt
:columnList="columnListarrs.ordoption"
@ -87,6 +89,8 @@
</div>
</el-tab-pane>
<el-tab-pane label="包 件 列 表" name="tab3">
<el-button type="primary" icon="Position" @click="Packageexport">包件导出</el-button>
<!-- 列表模块 -->
<tablecmt
:columnList="columnListarrs.wrapoption"
@ -117,6 +121,8 @@
</div>
</el-tab-pane>
<el-tab-pane label="库 存 品 列 表" name="tab4">
<el-button type="primary" icon="Position" @click="Inventoryexport">库存品导出</el-button>
<!-- 列表模块 -->
<tablecmt
:columnList="columnListarrs.inventoryoption"
@ -182,7 +188,11 @@ import option from '@/option/basic/basicPdarecords';
import { mapGetters } from 'vuex';
import { getDictionaryBiz } from '@/api/system/dict';
import dayjs from 'dayjs';
import {getToken} from '@/utils/auth';
import NProgress from 'nprogress';
import {downloadXls} from "@/utils/util";
import {exportBlob} from "@/api/common";
import {dateNow} from "@/utils/date";
export default {
data() {
return {
@ -1334,6 +1344,64 @@ export default {
},
},
methods: {
//
Orderexport(){
let downloadUrl = `/logpm-distribution/distrilbutionBillStock/billOrderDetailExcel?${this.website.tokenHeader}=${getToken()}`;
let values = {
billLadingId:this.$route.query.id
};
this.$confirm("是否导出数据?", "提示", {
confirmButtonText: "确定",
cancelButtonText: "取消",
type: "warning"
}).then(() => {
NProgress.start();
exportBlob(downloadUrl, values).then(res => {
downloadXls(res.data, `订单列表${dateNow()}.xlsx`);
NProgress.done();
})
});
},
//
Packageexport(){
let downloadUrl = `/logpm-distribution/distrilbutionBillStock/billOrderPackExcel?${this.website.tokenHeader}=${getToken()}`;
let values = {
billLadingId:this.$route.query.id
};
this.$confirm("是否导出数据?", "提示", {
confirmButtonText: "确定",
cancelButtonText: "取消",
type: "warning"
}).then(() => {
NProgress.start();
exportBlob(downloadUrl, values).then(res => {
downloadXls(res.data, `包件导出${dateNow()}.xlsx`);
NProgress.done();
})
});
},
//
Inventoryexport(){
let downloadUrl = `/logpm-distribution/distributionDeliveryDetails/billOrderInventoryExcel?${this.website.tokenHeader}=${getToken()}`;
let values = {
billLadingId:this.$route.query.id
};
this.$confirm("是否导出数据?", "提示", {
confirmButtonText: "确定",
cancelButtonText: "取消",
type: "warning"
}).then(() => {
NProgress.start();
exportBlob(downloadUrl, values).then(res => {
downloadXls(res.data, `库存品导出${dateNow()}.xlsx`);
NProgress.done();
})
});
},
beforeOpen(done, type) {
if (['edit', 'view'].includes(type)) {
getDetail(this.form.id).then(res => {

34
src/views/warehouse/parcelList/distributionParcelList.vue

@ -301,12 +301,46 @@ export default {
label: '仓库',
type: 2,
values: '',
width: '100',
checkarr: [],
fixed: false,
sortable: true,
head: false,
},
{
prop: 'typeServiceName',
label: '服务类型',
type: 2,
values: '',
width: '80',
checkarr: [],
fixed: false,
sortable: true,
head: false,
},
{
prop: 'pickupBatch',
label: '提货批次',
type: 2,
values: '',
width: '80',
checkarr: [],
fixed: false,
sortable: true,
head: false,
},
{
prop: 'scanTime',
label: '装车时间',
type: 2,
values: '',
width: '100',
checkarr: [],
fixed: false,
sortable: true,
head: false,
},
{
prop: 'carNumber',
label: '客户车次号',

Loading…
Cancel
Save