Browse Source

客服

master
马远东 1 year ago
parent
commit
ae26757932
  1. 20
      src/api/aftersales/aftersalesWorkOrder.js
  2. 23
      src/option/aftersales/vueTvemp.js
  3. 24
      src/router/views/index.js
  4. 10
      src/views/aftersales/aftersalesWorkOrder.vue
  5. 8
      src/views/aftersales/aftersalesWorkOrderAdd.vue
  6. 500
      src/views/aftersales/aftersalesWorkOrderInfo.vue
  7. 346
      src/views/aftersales/aftersalesWorkOrderend.vue
  8. 2855
      src/views/aftersales/aftersalesWorkOrdermodify.vue

20
src/api/aftersales/aftersalesWorkOrder.js

@ -313,4 +313,24 @@ export const $_arbitrateEnd = (data) => {
method: 'post',
data
})
}
// 查询处理记录
export const $_getTrackRecord = (params) => {
return request({
url: '/api/logpm-aftersales/aftersalesWorkOrder/getTrackRecord',
method: 'get',
params
})
}
// 修改工单数据
export const $_modifyData = (data) => {
return request({
url: '/api/logpm-aftersales/aftersalesWorkOrder/submit',
method: 'post',
data
})
}

23
src/option/aftersales/vueTvemp.js

@ -306,7 +306,7 @@ export const columnList = [
export const recordList = [
{
prop: 'entryTime',
prop: 'createTime',
label: '跟进时间',
type: 1,
values: '',
@ -317,7 +317,7 @@ export const recordList = [
head: false,
},
{
prop: 'entryTime',
prop: 'followWarehouseName',
label: '跟进仓库',
type: 1,
values: '',
@ -328,7 +328,7 @@ export const recordList = [
head: false,
},
{
prop: 'entryTime',
prop: 'addDepartment',
label: '跟进人',
type: 1,
values: '',
@ -339,7 +339,7 @@ export const recordList = [
head: false,
},
{
prop: 'entryTime',
prop: 'processingResults',
label: '处理结果',
type: 1,
values: '',
@ -350,7 +350,7 @@ export const recordList = [
head: false,
},
{
prop: 'entryTime',
prop: 'remark',
label: '备注',
type: 1,
values: '',
@ -361,7 +361,7 @@ export const recordList = [
head: false,
},
{
prop: 'entryTime',
prop: 'pictureUrl',
label: '图片',
type: 1,
values: '',
@ -371,17 +371,6 @@ export const recordList = [
sortable: false,
head: false,
},
{
prop: 'entryTime',
label: '更新日志',
type: 1,
values: '',
width: '150',
checkarr: [],
fixed: false,
sortable: false,
head: false,
},
]

24
src/router/views/index.js

@ -1203,18 +1203,18 @@ export default [
],
},
// {
// path: '/aftersales/VueTemp',
// component: Layout,
// redirect: '/aftersales/VueTemp',
// children: [
// {
// path: '/aftersales/VueTemp',
// name: '工单',
// component: () => import('@/views/aftersales/aftersalesWorkOrder.vue'),
// },
// ],
// },
{
path: '/aftersales/aftersalesWorkOrder',
component: Layout,
redirect: '/aftersales/aftersalesWorkOrder',
children: [
{
path: '/aftersales/aftersalesWorkOrder',
name: '异常工单',
component: () => import('@/views/aftersales/aftersalesWorkOrder.vue'),
},
],
},
{
path: '/aftersales/aftersalesWorkOrderAdd',
component: Layout,

10
src/views/aftersales/aftersalesWorkOrder.vue

@ -158,16 +158,16 @@
<div class="ElBtnClass">
<div v-if="!TimeoutStatus">
<!-- <el-button @click="addingRecord(slotProps.scope)">新增记录</el-button> -->
<el-button v-if="!ClaimStatus" @click="view(slotProps.scope)"
<el-button @click="view(slotProps.scope)"
>查看</el-button
>
<!-- <el-button @click="ViewEvent(slotProps.scope)">编辑</el-button> -->
<!-- <el-button @click="reply(slotProps.scope)">回复</el-button> -->
<!-- <el-button @click="ViewDelete(slotProps.scope)">删除</el-button> -->
<!-- <el-button @click="CompletionButton(slotProps.scope)">完结</el-button> -->
<el-button v-if="ClaimStatus" @click="appeal(slotProps.scope)"
<!-- <el-button v-if="ClaimStatus" @click="appeal(slotProps.scope)"
>申诉</el-button
>
> -->
</div>
<el-button v-if="TimeoutStatus" @click="BtnModifyAmount(slotProps.scope)"
>修改金额</el-button
@ -1103,6 +1103,9 @@ const scrollContainer = ref(null); //客服实例
const workOrderStatus = ref(null); //
const BatchFrom = ref({}); //
const currentPage = ref(1); //
const TransportlossList = ref([
//
]);
const pageSize = ref(30); //
const total = ref(0); //
const KFinput = ref(''); //
@ -1558,6 +1561,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');
// null
for (const property in item) {
if (item[property] == null) {

8
src/views/aftersales/aftersalesWorkOrderAdd.vue

@ -44,7 +44,7 @@
</div>
</div>
<div class="NumTotal">
<span>总件数:{{ Indexform.number }}</span>
<span>总件数:{{ PackageInfo.length }}</span>
</div>
</div>
</el-tab-pane>
@ -269,6 +269,11 @@
<el-form-item label="异常问题描述">
<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>
<!-- 必填 -->
@ -1119,6 +1124,7 @@ const ViewPackageDetails = val => {
margin-left: 20px;
font-size: 14px;
width: 100px !important;
justify-content: flex-start;
}
.el-form-item {
margin: 0;

500
src/views/aftersales/aftersalesWorkOrderInfo.vue

@ -1,17 +1,8 @@
<template>
<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>
</el-tabs>
<!-- <el-divider content-position="left">
<span> {{ routerState ? '信息查看' : '工单新增' }}</span>
</el-divider> -->
<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 class="el_btbox" v-for="(item, index) in PackageInfo" :key="index">
<div class="leftbox">
<div class="maxBox">
@ -46,13 +37,6 @@
/>
</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)"> 移除 </el-button>
</div> -->
</div>
<div class="NumTotal">
<span>总件数:{{ PackageInfo.length }}</span>
@ -96,50 +80,6 @@
<el-form-item label="异常工单号">
<el-input v-model="Indexform.workOrderNumber" disabled placeholder="异常工单号" clearable />
</el-form-item>
<!-- 必填(提货环节可以不填写运单号) -->
<!-- <el-form-item label="运单号" v-if="groundlineType != 1">
<el-input v-model="Indexform.waybillNumber" placeholder="请输入运单号" clearable />
</el-form-item> -->
<!-- <el-form-item label="少货件数" v-if="StateType || SelectType == 2">
<div class="moneyNum">
<el-input
@change="ShortageTtems"
v-model="Indexform.number"
placeholder="请输入少货件数"
clearable
/>
<div class="el_btn" @click="moneyBtnA"><span>编辑</span></div>
</div>
</el-form-item> -->
<!-- <el-form-item label="窜货件数" v-if="StateType || SelectType == 3">
<div class="moneyNum">
<el-input
@change="fleeingTtems"
v-model="Indexform.number"
placeholder="请输入窜货件数"
clearable
/>
<div class="el_btn" @click="moneyBtnB"><span>编辑</span></div>
</div>
</el-form-item> -->
<!-- <el-form-item
label="包条码"
v-if="SelectType == 1 || SelectType == 2 || SelectType == 3 || StateType"
>
<el-input
v-model="Indexform.packageCode"
placeholder="请输入包条码,多个用逗号隔开"
clearable
/>
</el-form-item> -->
<!-- 必填 -->
<!-- <el-form-item label="订单自编号">
<el-input v-model="Indexform.orderCode" placeholder="请输入订单自编号" clearable />
</el-form-item> -->
<el-form-item
label="车次号"
@ -280,11 +220,10 @@
<el-form-item label="异常问题描述">
<el-input v-model="Indexform.problemDescription" placeholder="请输入异常问题" clearable />
</el-form-item>
</el-form>
<!-- 必填 -->
<div class="el_clzr">
<el-form-item class="investigate" label="调查经过">
<!-- 必填 -->
<el-form-item label="调查经过">
<el-input
disabled
v-model="Indexform.investigationPocess"
@ -312,12 +251,78 @@
/>
</el-select>
</el-form-item>
<el-form-item label="处理结果">
<el-select
v-model="Indexform.result"
multiple
filterable
default-first-option
:reserve-keyword="false"
placeholder="请选择处理结果"
@change="changeProcessingResults"
disabled
>
<el-option
v-for="item in ProcessingResults"
:key="item.dictKey"
:label="item.dictValue"
:value="item.dictKey"
/>
</el-select>
</el-form-item>
</el-form>
<div class="ProcessingResults" v-if="ProcessingList.length">
<div class="title">处理结果-理赔金额</div>
<div class="Listadmiration">
<div class="name" v-for="(item, index) in ProcessingList" :key="index">
<span>{{ item.name }}:</span>
<el-input-number
v-model="item.input"
:min="item.min"
:max="item.max"
@change="TotalChange"
disabled
/>
<div class="Paymentname">
{{ item.payment ? item.text : '支付方式' }}
</div>
</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">
<el-input
v-model="Indexform.resultDescription"
placeholder="请输入处理结果说明"
clearable
:autosize="{ minRows: 3, maxRows: 4 }"
type="textarea"
disabled
/>
</el-form-item>
<el-tabs type="border-card">
<el-tab-pane label="责任方选择">
<el-tab-pane label="责任方信息">
<div class="ResponsibilityBox">
<!-- <div><el-button type="primary" @click="responsibleParty"> 添加信息 </el-button></div> -->
<div class="el_btbox" v-for="(item, index) in FangAddList" :key="index">
<div class="leftbox">
<div class="maxBox">
@ -396,9 +401,6 @@
/>
</div>
</div>
<div class="el-btn">
<!-- <el-button type="primary" @click="ResponsibilityRemoval(index)"> 移除 </el-button> -->
</div>
</div>
<div class="Proportion">
<span class="title">公司占比:{{ companyProportion }}</span>
@ -432,90 +434,50 @@
</el-dialog> -->
</div>
<!-- <div class="dialog-footer">
<el-button @click="Indexdialog = false">取消</el-button>
<el-button type="primary" @click="ConfirmForm"> 提交 </el-button>
</div> -->
<div class="foot_btn">
<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="ConfirmForm">打回 </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>
</div>
</el-card>
<!-- 批量打回弹窗 -->
<el-dialog v-model="dialogReturn" title="批量打回" width="40%" draggable class="plAllret">
<el-form
v-loading="repulse"
element-loading-text="正在打回中..."
label-position="top"
label-width="100px"
:model="BatchFrom"
>
<el-form-item label="打回原因">
<el-input v-model="BatchFrom.txt" type="textarea" :rows="4" />
</el-form-item>
<!-- <div v-if="routerState" class="foot_btn">
<el-button type="primary" @click="ConfirmForm">新增记录</el-button>
<el-button type="primary" @click="ConfirmForm">完结 </el-button>
<el-button type="primary" @click="ConfirmForm">打回 </el-button>
</div> -->
<!-- 少货件数大于3 -->
<el-dialog
:show-close="false"
v-model="ShortageState"
title="少货件数"
width="40%"
@close="ShortageStateFun"
lock-scroll
draggable
>
<div class="ShortageStatenum" v-for="item in ShortageList">
<span class="title">件数{{ item.number }}</span
><el-input v-model="item.packageCode" placeholder="请输入包条码" />
</div>
<template #footer>
<span class="dialog-footer">
<el-button @click="ShortageCancellation">取消</el-button>
<el-button type="primary" @click="ShortageState = false"> 确认信息 </el-button>
</span>
</template>
</el-dialog>
<!-- 窜货件数大于3 -->
<el-dialog
:show-close="false"
v-model="fleeingState"
title="窜货件数"
width="40%"
@close="fleeingFun"
lock-scroll
draggable
>
<div class="ShortageStatenum" v-for="item in fleeingList">
<span class="title">件数{{ item.number }}</span
><el-input v-model="item.packageCode" placeholder="请输入包条码" />
</div>
<template #footer>
<span class="dialog-footer">
<el-button @click="fleeingCancellation">取消</el-button>
<el-button type="primary" @click="ShortageState = false"> 确认信息 </el-button>
</span>
</template>
</el-dialog>
<el-dialog v-model="dialogHistoricalPackage" title="查看历史包件" width="30%">
<el-form-item label="历史包件选择">
<el-select v-model="HistoricalPackageinput" clearable filterable placeholder="请选择包件">
<el-option
v-for="item in HistoricalPackageList"
:key="item.value"
:label="item.workOrderNumber"
:value="item.workOrderId"
/>
</el-select>
<el-button @click="ViewPackageDetails(HistoricalPackageinput)">查看详情</el-button>
</el-form-item>
<el-form-item label="流转营业部">
<el-select
v-model="BatchFrom.businessDepartment"
multiple
filterable
default-first-option
:reserve-keyword="false"
placeholder="请选择活动区域"
>
<el-option
v-for="item in warehouseData"
:key="item.value"
:label="item.label"
:value="item.value"
/>
</el-select>
</el-form-item>
</el-form>
<template #footer>
<span class="dialog-footer">
<el-button @click="dialogHistoricalPackage = false">取消</el-button>
<el-button type="primary" @click="HistoricalPackage(HistoricalPackageinput)">
确定选择
</el-button>
<el-button @click="dialogReturn = false">取消</el-button>
<el-button type="primary" @click="ConfirmReturn" :disabled="repulse"> 确定 </el-button>
</span>
</template>
</el-dialog>
@ -535,6 +497,7 @@ import {
$_getBusinessDepartmentUser,
$_getAbnormalPackage,
$_getInfo,
$_batchReturn,
} from '@/api/aftersales/aftersalesWorkOrder';
import { ref, reactive, toRefs, computed, onMounted, nextTick } from 'vue';
import { getToken } from '@/utils/auth';
@ -546,12 +509,15 @@ const Indexform = ref({
}); //
const IndexException = ref([]); //
const DiscoveringNodes = ref([]); //
const ProcessingResults = ref([]); //
const warehouseData = ref([]); //
const SelectType = ref(null); //
const BatchFrom = ref({}); //
const StateType = ref(true); //
const HistoricalPackageinput = ref(''); //
const dialogImageUrl = ref(null); //
const dialogVisible = ref(null); //
const ProcessingList = ref([]); //
const groundlineSet = ref(true); //线
const groundlineType = ref(null); //线
const ShortageState = ref(false); //
@ -567,6 +533,9 @@ const identifying = ref(1); //订单,零担状态
const dialogHistoricalPackage = ref(false); //
const HistoricalPackageList = ref([]); //
const HistorIndex = ref(0); //
const TotalClaimAmount = ref(0); //
const dialogReturn = ref(false); //
const repulse = ref(false); //
const PackageInfo = ref([
//
{ packageCode: '', orderCode: '', waybillNumber: '' },
@ -671,7 +640,47 @@ const handle = () => {
});
});
};
const changeProcessingResults = val => {
//
ProcessingList.value = ProcessingList.value.filter(item => val.includes(item.state - 1));
//
val.forEach(num => {
let newItem = { input: 0, min: 0, max: 9999999999999, state: num + 1, payment: '', text: '' };
// numnewItemname
switch (num) {
case '1':
newItem.name = '下补单';
break;
case '2':
newItem.name = '维修/补漆';
break;
case '3':
newItem.name = '客户未要求理赔';
break;
case '4':
newItem.name = '用库存';
break;
case '5':
newItem.name = '赔商家';
break;
case '6':
newItem.name = '赔付运费';
break;
case '7':
newItem.name = '工厂考核';
break;
default:
return;
}
//
if (!ProcessingList.value.some(item => item.state === newItem.state)) {
ProcessingList.value.push(newItem);
console.log(`添加:${newItem.name}`);
}
});
};
//
const ResponsiblePartychange = (val, index) => {
FangAddList.value[index].personResponsibleName = null; //
@ -687,6 +696,7 @@ const onLoad = () => {
routerState.value = $route.query.routerState;
updateDictionary(IndexException.value, 'pc_work_order'); //
updateDictionary(DiscoveringNodes.value, 'pc_discovery_node'); //
updateDictionary(DiscoveringNodes.value, 'pc_discovery_node'); //
handle(); //
$_getInfo({ id: $route.query.id }).then(res => {
@ -738,10 +748,6 @@ const onLoad = () => {
Indexform.value.processor.push(item.businessId);
}
});
//
let sum = 0;
@ -752,20 +758,29 @@ const onLoad = () => {
// updateDictionary(columnList[2].checkarr, 'pc_work_order'); //
// updateDictionary(columnList[3].checkarr, 'pc_discovery_node'); //
getDictionaryBiz('result_handling').then(res => {
console.log(res, '发现环节');
ProcessingResults.value = res.data.data;
});
//
// res.data.data.processingResultsVO.processingMoneyEntityList.forEach(item => {
// ProcessingList.value.push({
// input: item.money,
// min: 0,
// max: 9999999999999,
// state: item.resultType,
// payment: item.compensationMethod,
// name: item.resultTypeName,
// text: '',
// });
// Indexform.value.result.push(item.resultType);
// });
res.data.data.processingResultsVO.processingMoneyEntityList.forEach(item => {
ProcessingList.value.push({
input: item.money,
min: 0,
max: 9999999999999999999999999999,
state: item.resultType,
payment: item.compensationMethod,
name: item.resultTypeName,
text: item.compensationMethodName,
});
Indexform.value.result.push(item.resultType);
});
//
TotalClaimAmount.value = res.data.data.processingResultsVO.money;
//
Indexform.value.compensationTime = res.data.data.processingResultsVO.compensationTime;
//
Indexform.value.resultDescription = res.data.data.processingResultsVO.resultDescription;
});
};
onLoad(); //
@ -825,6 +840,7 @@ const responsibleParty = () => {
description: '',
});
};
//
const ResponsibilityRemoval = val => {
FangAddList.value.splice(val, 1); //
@ -1006,6 +1022,51 @@ const ConfirmForm = () => {
});
};
//
const BatchReturn = () => {
BatchFrom.value.businessDepartment = [];
BatchFrom.value.txt = null;
dialogReturn.value = true;
};
//
const ConfirmReturn = () => {
repulse.value = true; //
let data = {
processorList: [],
};
//
let foundObjs = warehouseData.value.filter(obj =>
BatchFrom.value.businessDepartment.includes(obj.value)
);
data['businessId'] = foundObjs.map(item => item.value).join(',');
data['businessName'] = foundObjs.map(item => item.label).join(',');
//
foundObjs.forEach(item => {
data['processorList'].push({ id: item.value, name: item.label });
});
data.reasonReturn = BatchFrom.value.txt; //
data.workOrderIds = [$route.query.id]; //ID
console.log(data, '处理好的值');
$_batchReturn(data)
.then(res => {
repulse.value = false; //
dialogReturn.value = false; //
if (res.data.code == 200) {
ElMessage({
message: res.data.msg,
type: 'success',
});
$router.push('/aftersales/aftersalesWorkOrder'); //
}
})
.catch(error => {
repulse.value = false; //
dialogReturn.value = false; //
});
};
//
const ShortageTtems = val => {
ShortageList.value = []; //
@ -1185,6 +1246,34 @@ const addingRecord = () => {
},
});
};
//
const CustomerServiceCompleted = () => {
$router.push({
path: '/aftersales/aftersalesWorkOrdermodify',
query: {
id: $route.query.id,
name: $route.query.workOrderNumber + '-客服仲裁完结',
businessId: $route.query.businessId,
warehouseId: $route.query.warehouseId,
workOrderNumber: $route.query.workOrderNumber,
RouterState: false,
},
});
};
//
const EditInformation = () => {
$router.push({
path: '/aftersales/aftersalesWorkOrdermodify',
query: {
id: $route.query.id,
name: $route.query.workOrderNumber + '-信息编辑',
businessId: $route.query.businessId,
warehouseId: $route.query.warehouseId,
workOrderNumber: $route.query.workOrderNumber,
RouterState: true,
},
});
};
const EndJump = () => {
$router.push({
path: '/aftersales/aftersalesWorkOrderend',
@ -1255,7 +1344,7 @@ const EndJump = () => {
margin-left: 20px;
font-size: 14px;
width: 100px !important;
justify-content: flex-start;
justify-content: flex-start;
}
.el-form-item {
margin: 0;
@ -1439,4 +1528,93 @@ justify-content: flex-start;
:deep(.el-card__body) {
margin-bottom: 50px;
}
.ProcessingResults {
width: 100%;
min-height: 260px;
border: 1px solid #ccc;
position: relative;
padding: 26px;
box-sizing: border-box;
margin-top: 20px;
color: #606266;
display: flex;
flex-direction: column;
justify-content: space-between;
margin-bottom: 16px;
.title {
position: absolute;
top: -20px;
left: 20px;
font-size: 26px;
background-color: #fff;
}
.Listadmiration {
display: flex;
flex-wrap: wrap;
margin-top: 26px;
justify-content: space-between;
.name {
display: flex;
margin-bottom: 20px;
height: 30px;
width: 30%;
span {
display: block;
width: 30%;
color: #606266;
font-size: 16px;
}
}
}
.lptime,
.ZFlptime {
display: flex;
.name {
width: 10%;
color: #606266;
}
.el-input {
width: auto;
}
:deep(.el-input--prefix) {
width: 200px;
}
}
.ZFlptime {
margin: 10px 0;
}
}
.Paymentname {
display: flex;
justify-content: center;
align-items: center;
border: 1px solid #bfbfbf;
margin-left: 2px;
border-radius: 4px;
width: 100px;
font-size: 14px;
padding: 10px;
cursor: pointer;
width: 100px;
margin-left: 14px;
}
.Paymentname:hover {
border: 1px solid #172e60;
}
.el_resj {
margin-top: 20px !important;
:deep(.el-form-item__label) {
justify-content: flex-start;
margin-left: 20px;
font-size: 14px;
width: 100px !important;
}
}
.lptime {
height: 30px !important;
:deep(.el-input) {
height: 30px !important;
}
}
</style>

346
src/views/aftersales/aftersalesWorkOrderend.vue

@ -2,7 +2,9 @@
<el-card class="box-card">
<template #header>
<div class="card-header">
<span>{{$route.query.index=='0'?'回复': $route.query.index=='1'?'新增记录':'完结' }}</span>
<span>{{
$route.query.index == '0' ? '回复' : $route.query.index == '1' ? '新增记录' : '完结'
}}</span>
<!-- <el-button class="button" v-if="$route.query.index=='1' || $route.query.index=='2'" @click="submit">提交</el-button> -->
</div>
</template>
@ -27,7 +29,7 @@
</el-form-item> -->
<!-- <div class="selector"> -->
<div class="el-form-item el_lab" >
<div class="el-form-item el_lab">
<span class="el-form-item__label">运损节点</span>
<el-select
v-model="endFrom.discoveryNode"
@ -105,7 +107,7 @@
/>
</el-select>
</el-form-item>
<el-form-item> </el-form-item>
<el-form-item label="" class="el_lab"> </el-form-item>
<div class="el_dcl">
<!-- <div class="selector">
<div class="el-form-item">
@ -211,7 +213,7 @@
</div>
</div>
<div class="NumTotal">
<span>总件数:{{ endFrom.number }}</span>
<span>总件数:{{ PackageInfo.length }}</span>
</div>
</div>
</el-tab-pane>
@ -333,40 +335,45 @@
</div>
<div class="payanindemnity" v-for="(item, index) in CompensationParty" :key="index">
<div class="el_pklab">
<span class="title" :style="{ color: item.state != 0 ? '#000' : '#F56C6C' }"
>{{ item.state == 0 ? '赔款方' : '收款方' }}{{ item.cld }}</span
>
</div>
<div class="el_pkLi">
<div class="sk_input">
<el-input
v-model="item.name"
:placeholder="item.state == 0 ? '请填写赔款方' : '请填写收款方'"
/>
</div>
<div class="sk_input">
<el-input v-model="item.reason" placeholder="请填写原因" />
</div>
<div class="sk_input">
<el-input @input="amountMoney" :min="0" v-model="item.num" placeholder="金额" />
<div class="el_pklab">
<span class="title" :style="{ color: item.state != 0 ? '#000' : '#F56C6C' }"
>{{ item.state == 0 ? '赔款方' : '收款方' }}{{ item.cld }}</span
>
</div>
<div class="sk_input" v-if="item.state == 0">
<el-input v-model="item.explain" placeholder="请填写说明" />
</div>
<div class="sk_input" v-if="item.state == 1">
<!-- <el-input v-model="item.explain" placeholder="请填写说明" /> -->
</div>
<div class="el_cwBtn">
<el-button type="primary" v-if="item.state == 0"> 财务处理 </el-button>
<el-button type="primary" @click="payremove(item.state, index)">
移除
</el-button>
<div class="el_pkLi">
<div class="sk_input">
<el-input
v-model="item.name"
:placeholder="item.state == 0 ? '请填写赔款方' : '请填写收款方'"
/>
</div>
<div class="sk_input">
<el-input v-model="item.reason" placeholder="请填写原因" />
</div>
<div class="sk_input">
<el-input
@input="amountMoney"
:min="0"
v-model="item.num"
placeholder="金额"
/>
</div>
<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">
<!-- <el-input v-model="item.explain" placeholder="请填写说明" /> -->
</div>
<div class="el_cwBtn">
<el-button type="primary" v-if="item.state == 0"> 财务处理 </el-button>
<el-button type="primary" @click="payremove(item.state, index)">
移除
</el-button>
</div>
</div>
</div>
</div>
<div class="paySum">
<span>
<el-icon><Coin /></el-icon>:<b>{{
@ -391,7 +398,7 @@
:reserve-keyword="false"
placeholder="请选择处理结果"
@change="changeProcessingResults"
:disabled="$route.query.index=='0' || $route.query.index=='2'"
:disabled="$route.query.index == '0' || $route.query.index == '2'"
>
<el-option
v-for="item in ProcessingResults"
@ -413,6 +420,7 @@
:min="item.min"
:max="item.max"
@change="TotalChange"
:disabled="$route.query.index == '0' || $route.query.index == '2'"
/>
<div class="Paymentname" @click="PaymentSelection(item)">
{{ item.payment ? item.text : '支付方式' }}
@ -452,31 +460,32 @@
type="datetime"
format="YYYY-MM-DD"
value-format="YYYY-MM-DD HH:mm:ss"
:disabled="$route.query.index == '0' || $route.query.index == '2'"
placeholder="请选择运理赔支付时间"
/>
</div>
</div>
<!-- 处理结果说明 -->
<el-form-item label="处理结果说明" v-if="routerState != 'end'" class="el_resj">
<el-form-item label="处理结果说明" class="el_resj">
<el-input
v-model="endFrom.resultDescription"
placeholder="请输入处理结果说明"
clearable
:autosize="{ minRows: 3, maxRows: 4 }"
type="textarea"
:disabled="$route.query.index=='0' || $route.query.index=='2'"
:disabled="$route.query.index == '0' || $route.query.index == '2'"
/>
</el-form-item>
<!-- 备注信息 -->
<div class="notes" v-if="routerState != 'end'">
<div class="notes">
<el-form-item label="异常问题描述">
<el-input
v-model="endFrom.problemDescription"
type="textarea"
:autosize="{ minRows: 3, maxRows: 4 }"
placeholder="请输入异常问题描述"
:disabled="$route.query.index =='0' "
:disabled="$route.query.index == '0'"
/>
</el-form-item>
</div>
@ -485,7 +494,7 @@
<div class="Transport_damage_photos">
<span class="title">图片</span>
<el-upload
:disabled="$route.query.index =='0' "
disabled
v-model:file-list="endFrom.packageImage"
list-type="picture-card"
:on-preview="pictureList"
@ -506,7 +515,7 @@
</div>
<!-- 视频 -->
<div class="Transport_damage_photos void">
<!-- <div class="Transport_damage_photos void">
<span class="title">视频</span>
<el-upload
class="upload-demo"
@ -514,7 +523,7 @@
:action="doubledCount"
:headers="headers"
:on-success="ViodSuccess"
:disabled="$route.query.index =='0' "
:disabled="$route.query.index == '0'"
>
<el-icon class="el-icon--upload"><upload-filled /></el-icon>
<div class="el-upload__text">
@ -522,10 +531,8 @@
<span v-if="videoUrl" class="PreviewVoid" @click.stop="Clickviod">点击预览</span>
</div>
</el-upload>
</div>
<div class="el_sub" v-if="$route.query.index !='0'">
<el-button type="primary" class="button" @click="submit">提交</el-button>
</div>
</div> -->
<!-- 视频预览弹窗 -->
<el-dialog v-model="VideoPreviewStatus" title="视频预览" width="40%">
<video height="360" controls class="video-player">
@ -582,9 +589,13 @@
</el-tab-pane>
</el-tabs>
</div>
<div class="el_sub" v-if="$route.query.index != '0'">
<el-button type="primary" class="button" @click="submit">提交</el-button>
</div>
</el-form>
</div>
<el-affix :offset="msgTop" >
<el-affix :offset="msgTop">
<div class="right">
<el-tabs type="border-card">
<div class="content">
@ -635,9 +646,17 @@
<p>{{ item.time }}</p>
</div>
<div class="tag">
<div class="tag" v-if="msgState == 1 || msgState == 2 || msgState == 3">
<el-tag class="mx-1" effect="dark"
>{{ msgState == 1 ? ' 待回复' : msgState == 2 ? '已回复' : '已超时' }}
>{{
msgState == 1
? ' 待回复'
: msgState == 2
? '已回复'
: msgState == 3
? '已超时'
: ''
}}
</el-tag>
</div>
</el-card>
@ -758,6 +777,7 @@ import {
$_addProcessingResults,
$_getSurveyRecord,
$_getAbnormalPackage,
$_getTrackRecord,
} from '@/api/aftersales/aftersalesWorkOrder';
import { columnList, recordList } from '@/option/aftersales/vueTvemp.js';
import { getToken } from '@/utils/auth';
@ -788,6 +808,7 @@ const companyProportion = ref(0); //公司占比
const HistoricalPackageList = ref([]); //
const dialogHistoricalPackage = ref(false); //
const HistoricalPackageinput = ref(''); //
const UserPermissions = ref(''); //
const PackageInfo = ref([
//
{ packageCode: '', orderCode: '', waybillNumber: '' },
@ -818,24 +839,10 @@ const viodUrl = ref({});
const videoUrl = ref(null); //
const VideoPreviewStatus = ref(false); //
const warehouseData = ref([]); //
const MessageContent = ref([
// {
// time: '2021-08-03 16:00:00',
// content: '1',
// name: '',
// username: '',
// img: 'https://fuss10.elemecdn.com/3/63/4e7f3a15429bfda99bce42a18cdd1jpeg.jpeg?imageMogr2/thumbnail/360x360/format/webp/quality/100',
// file: 'http://192.168.10.100:9000/627683-logpm/upload/20231211/19d4e462c3ebe3026cb9b27868659554.docx',
// mp4: 'http://192.168.10.100:9000/627683-logpm/upload/20231211/d4619612ebca02ca1318935b31bc6940.mp4',
// imgList: [
// 'https://fuss10.elemecdn.com/3/63/4e7f3a15429bfda99bce42a18cdd1jpeg.jpeg?imageMogr2/thumbnail/360x360/format/webp/quality/100',
// 'https://fuss10.elemecdn.com/2/11/6535bcfb26e4c79b48ddde44f4b6fjpeg.jpeg',
// ],
// },
]);
const MessageContent = ref([]);
const CompensationParty = ref([
{ name: '', state: 0, num: null, reason: '', cld: 1, explain: '' }, //
{ name: '', state: 1, num: null, reason: '', cld: 1, explain: '' }, //
{ name: '', state: 0, num: null, reason: '', cld: 1, explains: '' }, //
{ name: '', state: 1, num: null, reason: '', cld: 1, explains: '' }, //
]); ///
const ProcessingList = ref([]); //
//
@ -888,25 +895,12 @@ const details = reactive({
columnList,
/** 列表数据 */
data: [{}],
data: [],
//
recordList,
//
recorddata: [
{ entryTime: '测试' },
{ entryTime: '测试' },
{ entryTime: '测试' },
{ entryTime: '测试' },
{ entryTime: '测试' },
{ entryTime: '测试' },
{ entryTime: '测试' },
{ entryTime: '测试' },
{ entryTime: '测试' },
{ entryTime: '测试' },
{ entryTime: '测试' },
{ entryTime: '测试' },
{ entryTime: '测试' },
{ entryTime: '测试' },
],
/** 页面loading */
loadingObj: {
@ -965,6 +959,21 @@ const TransportChange = val => {
//
const onLoad = () => {
//
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, '当前角色权限');
});
//
if ($route.query.id) {
console.log($route.query);
@ -1014,6 +1023,7 @@ const onLoad = () => {
description: res.description, //
};
});
res.data.data.processorVOList.forEach(item => {
if (item.typesOf == 2) {
//
@ -1048,24 +1058,69 @@ const onLoad = () => {
sum = Number(item.responsibilityRatio) + sum;
});
companyProportion.value = 100 - sum;
// updateDictionary(columnList[2].checkarr, 'pc_work_order'); //
// updateDictionary(columnList[3].checkarr, 'pc_discovery_node'); //
//
// res.data.data.processingResultsVO.processingMoneyEntityList.forEach(item => {
// ProcessingList.value.push({
// input: item.money,
// min: 0,
// max: 9999999999999,
// state: item.resultType,
// payment: item.compensationMethod,
// name: item.resultTypeName,
// text: '',
// });
// endFrom.value.result.push(item.resultType);
// });
ProcessingList.value = res.data.data.processingResultsVO.processingMoneyEntityList.map(
item => {
endFrom.value.result.push(item.resultType);
return {
input: item.money,
min: 0,
max: 9999999999999999999999999999,
state: item.resultType,
payment: item.compensationMethod,
name: item.resultTypeName,
text: item.compensationMethodName,
};
}
);
//
TotalClaimAmount.value = res.data.data.processingResultsVO.money;
//
endFrom.value.compensationTime = res.data.data.processingResultsVO.compensationTime;
//
endFrom.value.resultDescription = res.data.data.processingResultsVO.resultDescription;
//
//
CompensationParty.value = [];
if (res.data.data.completionRecipientEntityList.length > 0) {
res.data.data.completionRecipientEntityList.forEach((item, index) => {
TotalamountReceived.value += Number(item.money);
CompensationParty.value.push({
state: 1, //
num: item.money, //
name: item.recipient, //
reason: item.reasonReceivingPayment, //
explains: item.explains, //
cld: index + 1,
});
});
}
//
if (res.data.data.completionRecordEntities.length > 0) {
res.data.data.completionRecordEntities.forEach((item, index) => {
TotalamountCompensation.value += Number(item.money);
CompensationParty.value.push({
state: 0, //
num: item.money, //
name: item.indemnitor, //
reason: item.reason, //
explains: item.explains, //
cld: index + 1,
});
});
}
endFrom.value.arbitrate= res.data.data.reasonArbitration; //
});
//
$_getTrackRecord({
id:$route.query.id
}).then(res=>{
console.log(res,'处理记录返回值');
details.recorddata=res.data.data.surveyRecordEntities
})
}
//
@ -1293,7 +1348,7 @@ const AddCompensation = () => {
som++;
}
});
CompensationParty.value.push({ name: '', state: 0, num: 0, reason: '', cld: som, explain: '' });
CompensationParty.value.push({ name: '', state: 0, num: 0, reason: '', cld: som, explains: '' });
};
//
const AddPayee = () => {
@ -1303,7 +1358,7 @@ const AddPayee = () => {
som++;
}
});
CompensationParty.value.push({ name: '', state: 1, num: 0, reason: '', cld: som, explain: '' });
CompensationParty.value.push({ name: '', state: 1, num: 0, reason: '', cld: som, explains: '' });
};
//
const TotalChange = () => {
@ -1455,6 +1510,9 @@ const personResponsiblechange = (val, index) => {
};
//
const PaymentSelection = val => {
if ($route.query.index == '0' || $route.query.index == '2') {
return;
}
console.log(val, '支付');
console.log(Paymentmethod.value);
if (val.payment) {
@ -1484,30 +1542,9 @@ const PaymentConfirmation = val => {
//
const submit = () => {
// console.log(FangAddList.value,'businessName');
// console.log(warehouseData.value,'');
// let a= [
// {
// "businessName": "1711993021509234689",
// "personResponsibleName": "1712365249019097089",
// "responsibilityRatio": ""
// },
// {
// "businessName": "1713372843170975745",
// "personResponsibleName": "1712376790741266433",
// "responsibilityRatio": ""
// }
// ]
// let b=[
// {value: '1711993021509234689', label: ''},
// {value: '1713372842906734594', label: ''},
// {value: '1713372842990620674', label: ''},
// ]
// const result = FangAddList.value.map(aItem => warehouseData.value.filter(bItem => bItem.value === aItem.businessName).map(match => match.label).join(',')).join(',');
// console.log(result,'');
console.log(UserPermissions.value, '当前角色');
// if (UserPermissions.value == '' || UserPermissions.value == '' ) {
//
//
if (routerState.value == 'end') {
@ -1535,7 +1572,8 @@ const submit = () => {
let data = [
{
completionRecipientEntities: [], //
completionRecordEntities: [],
completionRecordEntities: [], //
reasonArbitration: endFrom.value.arbitrate, //
...info,
},
];
@ -1550,7 +1588,7 @@ const submit = () => {
indemnitor: item.name, //
reason: item.reason, //
money: Number(item.num), //
reasonArbitration: endFrom.value.arbitrate, //
reasonArbitration: item.reason, //
workOrderId: info.id, //
warehouseId: info.warehouseId, //ID
});
@ -1578,19 +1616,35 @@ const submit = () => {
//
console.log(data, '处理好的值');
$_addCompletionEnd(data).then(res => {
$router.push('/aftersales/aftersalesWorkOrder');
console.log(res, '完结成功返回值');
if (res.data.code == 200) {
ElMessage({
showClose: true,
message: res.data.msg,
type: 'success',
});
}
});
// $_addCompletionEnd(data).then(res => {
// $router.push('/aftersales/aftersalesWorkOrder');
// console.log(res, '');
// if (res.data.code == 200) {
// ElMessage({
// showClose: true,
// message: res.data.msg,
// type: 'success',
// });
// }
// });
// }else{
// ElMessage({
// message: '',
// type: 'warning',
// });
// console.log(UserPermissions.value);
// return;
// }
} else {
//
if (UserPermissions.value != '仓库客服') {
ElMessage({
message: '权限不足',
type: 'warning',
});
console.log(UserPermissions.value);
return;
}
//
console.log($route.query.id, '异常ID');
console.log(ProcessingList.value, 'ProcessingList12312');
let info = JSON.parse(JSON.stringify(endFrom.value)); //
@ -1858,7 +1912,7 @@ const ViewPackageDetails = val => {
}
.notes {
width: 100%;
margin-top:40px;
margin-top: 40px;
}
.Transport_damage_photos {
width: 100%;
@ -1926,11 +1980,11 @@ const ViewPackageDetails = val => {
display: flex;
align-items: center;
}
.el_pklab{
.el_pklab {
width: 50px;
}
.el_pkLi{
.el_pkLi {
width: 100%;
display: flex;
justify-content: space-between;
@ -2182,7 +2236,7 @@ const ViewPackageDetails = val => {
flex-direction: column;
margin-bottom: 10px;
.leftbox {
width: 80%;
width: 100%;
display: flex;
justify-content: space-between;
}
@ -2225,10 +2279,10 @@ const ViewPackageDetails = val => {
justify-content: flex-end;
margin: 4px 0;
}
.el_resj{
margin-top:20px !important;
.el_resj {
margin-top: 20px !important;
}
.el_lab{
.el_lab {
margin-right: 10px !important;
}
</style>

2855
src/views/aftersales/aftersalesWorkOrdermodify.vue

File diff suppressed because it is too large Load Diff
Loading…
Cancel
Save