|
|
|
@ -112,7 +112,11 @@
|
|
|
|
|
@click="WorkOrderAssignment" |
|
|
|
|
>工单指派</el-button |
|
|
|
|
> |
|
|
|
|
<el-button type="primary" icon="User" v-if="ButtonPermissions.applyArbitration" |
|
|
|
|
<el-button |
|
|
|
|
type="primary" |
|
|
|
|
icon="User" |
|
|
|
|
v-if="ButtonPermissions.applyArbitration" |
|
|
|
|
@click="CustomerServiceIntervention" |
|
|
|
|
>客服介入</el-button |
|
|
|
|
> |
|
|
|
|
<el-button |
|
|
|
@ -371,6 +375,44 @@
|
|
|
|
|
</template> |
|
|
|
|
</el-dialog> |
|
|
|
|
|
|
|
|
|
<!-- 客服介入 --> |
|
|
|
|
<el-dialog |
|
|
|
|
v-model="CustomerServiceForm.loadingCustomer" |
|
|
|
|
:close-on-click-modal="false" |
|
|
|
|
title="客服介入" |
|
|
|
|
width="35%" |
|
|
|
|
class="el_Customer" |
|
|
|
|
> |
|
|
|
|
<el-form |
|
|
|
|
:model="CustomerServiceForm" |
|
|
|
|
v-loading="CustomerServiceForm.dialog" |
|
|
|
|
element-loading-text="正在处理中..." |
|
|
|
|
label-position="top" |
|
|
|
|
> |
|
|
|
|
<el-form-item label="介入原因"> |
|
|
|
|
<el-input |
|
|
|
|
v-model="CustomerServiceForm.reasonRemarks" |
|
|
|
|
:autosize="{ minRows: 6, maxRows: 6 }" |
|
|
|
|
type="textarea" |
|
|
|
|
placeholder="请输入介入原因" |
|
|
|
|
/> |
|
|
|
|
</el-form-item> |
|
|
|
|
</el-form> |
|
|
|
|
|
|
|
|
|
<template #footer> |
|
|
|
|
<span class="dialog-footer"> |
|
|
|
|
<el-button @click="CustomerServiceForm.loadingCustomer = false">关闭</el-button> |
|
|
|
|
<el-button |
|
|
|
|
type="primary" |
|
|
|
|
@click="InterventionSubmission" |
|
|
|
|
:disabled="CustomerServiceForm.dialog" |
|
|
|
|
> |
|
|
|
|
提交 |
|
|
|
|
</el-button> |
|
|
|
|
</span> |
|
|
|
|
</template> |
|
|
|
|
</el-dialog> |
|
|
|
|
|
|
|
|
|
<!-- 搜索弹窗 --> |
|
|
|
|
<div class="Searchboxpop-upwindow"> |
|
|
|
|
<el-dialog |
|
|
|
@ -437,7 +479,7 @@
|
|
|
|
|
content="从服务器导出数据,数据量大时可能会导致卡顿" |
|
|
|
|
placement="top-start" |
|
|
|
|
> |
|
|
|
|
<el-button type="primary" @click="NetworkExport"> 网络导出 </el-button> |
|
|
|
|
<el-button class="el_title_a" type="primary" @click="NetworkExport"> 全部导出 </el-button> |
|
|
|
|
</el-tooltip> |
|
|
|
|
<el-tooltip |
|
|
|
|
class="box-item" |
|
|
|
@ -445,7 +487,7 @@
|
|
|
|
|
content="从本地导出,导出当前页面支持自【定义导出字段】和【自定义表名】" |
|
|
|
|
placement="top-end" |
|
|
|
|
> |
|
|
|
|
<el-button type="primary" @click="LocalExport"> 本地导出 </el-button> |
|
|
|
|
<el-button class="el_title_b" type="primary" @click="LocalExport"> 本地导出 </el-button> |
|
|
|
|
</el-tooltip> |
|
|
|
|
</el-dialog> |
|
|
|
|
|
|
|
|
@ -615,6 +657,7 @@ import {
|
|
|
|
|
MallassignmentColumnList, |
|
|
|
|
customerserviceColumnList, |
|
|
|
|
} from '@/option/aftersales/vueTvemp.js'; |
|
|
|
|
import { objectKeys } from '@antfu/utils'; |
|
|
|
|
const Tableexportcomponent = defineAsyncComponent(() => |
|
|
|
|
import('@/components/Tableexportcomponent/Tableexportcomponent.vue') |
|
|
|
|
); |
|
|
|
@ -660,6 +703,11 @@ const ExportObjects = ref({
|
|
|
|
|
tcTableexport: false, //本地导出 |
|
|
|
|
ExportSelection: false, //导出选择弹窗 |
|
|
|
|
}); |
|
|
|
|
// 客服介入 |
|
|
|
|
const CustomerServiceForm = ref({ |
|
|
|
|
loadingCustomer: false, |
|
|
|
|
dialog: false, |
|
|
|
|
}); |
|
|
|
|
// 钉钉号 |
|
|
|
|
const DingTalkfilling = ref({ |
|
|
|
|
dialogDingTalk: false, |
|
|
|
@ -1230,6 +1278,8 @@ const selectionChange = list => {
|
|
|
|
|
}; |
|
|
|
|
// 网页顶部搜索按钮 |
|
|
|
|
const searchChange = async () => { |
|
|
|
|
let _Obj = MatchCurrentMenu(); //匹配出当前菜单 |
|
|
|
|
_Obj.currentPage = 1; |
|
|
|
|
await ProcessSearch(); |
|
|
|
|
updateMenuAndData(); //获取最新数据 |
|
|
|
|
}; |
|
|
|
@ -1241,6 +1291,7 @@ const searchChangeS = () => {
|
|
|
|
|
// 重置表格搜索 |
|
|
|
|
const ResetTableSearch = async () => { |
|
|
|
|
let _Obj = MatchCurrentMenu(); |
|
|
|
|
_Obj.currentPage = 1; |
|
|
|
|
console.log(TabPermissions.value, '123123123'); |
|
|
|
|
_Obj.request = true; |
|
|
|
|
console.log(_Obj, 'Obj'); |
|
|
|
@ -1251,6 +1302,8 @@ const ResetTableSearch = async () => {
|
|
|
|
|
//清空 |
|
|
|
|
const searchReset = () => { |
|
|
|
|
TopQuery.value = {}; |
|
|
|
|
let _Obj = MatchCurrentMenu(); |
|
|
|
|
_Obj.currentPage = 1; |
|
|
|
|
TabList.value.forEach(item => { |
|
|
|
|
item.query = {}; |
|
|
|
|
}); |
|
|
|
@ -1722,6 +1775,27 @@ const updateMenuAndData = () => {
|
|
|
|
|
} |
|
|
|
|
PublicDataRequest(TabPermissions.value); // 请求数据 |
|
|
|
|
}; |
|
|
|
|
/** |
|
|
|
|
* @description: 处理空白数据 |
|
|
|
|
* @param {object} data - 包含记录的数据对象 |
|
|
|
|
* @returns {array} - 处理后的记录数组 |
|
|
|
|
*/ |
|
|
|
|
const replaceNullWithSlash = data => { |
|
|
|
|
const newRecords = []; |
|
|
|
|
const records = data.records; |
|
|
|
|
|
|
|
|
|
for (let i = 0; i < records.length; i++) { |
|
|
|
|
const newRecord = { ...records[i] }; |
|
|
|
|
for (const key in newRecord) { |
|
|
|
|
if (newRecord[key] === null || newRecord[key] === '') { |
|
|
|
|
newRecord[key] = '/'; |
|
|
|
|
} |
|
|
|
|
} |
|
|
|
|
newRecords.push(newRecord); |
|
|
|
|
} |
|
|
|
|
|
|
|
|
|
return newRecords; |
|
|
|
|
}; |
|
|
|
|
/** |
|
|
|
|
* @description 通用函数用于处理数据请求(包含待回复、理赔金额未出、申诉、超时未处理) |
|
|
|
|
* @param {Function} fetchFunction - 用于执行具体数据请求的函数 |
|
|
|
@ -1743,8 +1817,8 @@ const fetchData = async (fetchFunction, reset) => {
|
|
|
|
|
if (code !== 200) { |
|
|
|
|
return; |
|
|
|
|
} |
|
|
|
|
|
|
|
|
|
DataAndStateProcessing(data); // 对数据和状态处理 |
|
|
|
|
details.data = replaceNullWithSlash(data); |
|
|
|
|
} catch (error) { |
|
|
|
|
console.log(error); |
|
|
|
|
} |
|
|
|
@ -1792,6 +1866,8 @@ const Publicaccessdata = async Reset => {
|
|
|
|
|
return; |
|
|
|
|
} |
|
|
|
|
DataAndStateProcessing(data); //对数据和状态处理 |
|
|
|
|
details.data = replaceNullWithSlash(data); |
|
|
|
|
|
|
|
|
|
console.log(_res, '公共数据菜单=:' + TabPermissions.value); |
|
|
|
|
console.log(TabList.value, '公共菜单'); |
|
|
|
|
} catch (error) { |
|
|
|
@ -2493,6 +2569,60 @@ const WorkOrderAssignment = () => {
|
|
|
|
|
assignFrom.value = { ...assignFrom.value, businessDepartment: '', dialogassign: true }; |
|
|
|
|
}; |
|
|
|
|
|
|
|
|
|
/** |
|
|
|
|
* @description 客服介入 |
|
|
|
|
* @return {void} 无返回值 |
|
|
|
|
*/ |
|
|
|
|
const CustomerServiceIntervention = () => { |
|
|
|
|
|
|
|
|
|
if (!details.selectionList.length) { |
|
|
|
|
// 提示用户选择数据 |
|
|
|
|
ElMessage({ |
|
|
|
|
message: '请勾选要客服介入的数据', |
|
|
|
|
type: 'warning', |
|
|
|
|
}); |
|
|
|
|
return; |
|
|
|
|
} |
|
|
|
|
ElMessage({ |
|
|
|
|
message: '功能维护中...', |
|
|
|
|
type: 'warning', |
|
|
|
|
}); |
|
|
|
|
return; |
|
|
|
|
CustomerServiceForm.value.loadingCustomer = true; |
|
|
|
|
CustomerServiceForm.value.reasonRemarks = ''; |
|
|
|
|
}; |
|
|
|
|
/** |
|
|
|
|
* @description 客服介入提交 |
|
|
|
|
* @return {void} 无返回值 |
|
|
|
|
*/ |
|
|
|
|
const InterventionSubmission = async () => { |
|
|
|
|
CustomerServiceForm.value.loading = true; |
|
|
|
|
|
|
|
|
|
try { |
|
|
|
|
let data = { |
|
|
|
|
assignList: [], |
|
|
|
|
reasonRemarks: CustomerServiceForm.value.reasonRemarks, //客服介入原因 |
|
|
|
|
}; |
|
|
|
|
data['assignList'] = details.selectionList.map(item => { |
|
|
|
|
return item.id; |
|
|
|
|
}); |
|
|
|
|
let res = await $_arbitrate(data); |
|
|
|
|
const { code, msg } = res.data; |
|
|
|
|
if (code == 200) { |
|
|
|
|
CustomerServiceForm.value.loadingCustomer = false; |
|
|
|
|
updateMenuAndData(); //获取最新数据 |
|
|
|
|
ElMessage({ |
|
|
|
|
message: msg, |
|
|
|
|
type: 'success', |
|
|
|
|
}); |
|
|
|
|
} |
|
|
|
|
} catch (error) { |
|
|
|
|
console.log(error); |
|
|
|
|
} finally { |
|
|
|
|
CustomerServiceForm.value.loading = false; |
|
|
|
|
} |
|
|
|
|
// 处理中,待处理可申请 |
|
|
|
|
}; |
|
|
|
|
/** |
|
|
|
|
* 工单指派确定按钮 |
|
|
|
|
* 1.根据选择的客服ID,名称,和选择的工单ID,将其组装成一个data对象 |
|
|
|
@ -2888,7 +3018,6 @@ const ProcessedExported = async dataID => {
|
|
|
|
|
} |
|
|
|
|
:deep(.plAllret) { |
|
|
|
|
height: 30%; |
|
|
|
|
|
|
|
|
|
display: flex; |
|
|
|
|
flex-direction: column; |
|
|
|
|
.el-select { |
|
|
|
@ -2901,6 +3030,11 @@ const ProcessedExported = async dataID => {
|
|
|
|
|
justify-content: flex-end; |
|
|
|
|
} |
|
|
|
|
} |
|
|
|
|
:deep(.el_Customer) { |
|
|
|
|
.el-form-item { |
|
|
|
|
flex-direction: column; |
|
|
|
|
} |
|
|
|
|
} |
|
|
|
|
:deep(.el-fr-d) { |
|
|
|
|
display: flex; |
|
|
|
|
.el-form-item { |
|
|
|
@ -3001,16 +3135,56 @@ const ProcessedExported = async dataID => {
|
|
|
|
|
align-items: center; |
|
|
|
|
justify-content: center; |
|
|
|
|
flex-direction: column; |
|
|
|
|
.el_title_a, |
|
|
|
|
.el_title_b { |
|
|
|
|
position: relative; |
|
|
|
|
} |
|
|
|
|
.el_title_a::after { |
|
|
|
|
content: '导出全部数据【如果存在“ 勾选 ”数据则默认导出“ 勾选 ”数据】'; |
|
|
|
|
position: absolute; |
|
|
|
|
color: #ff0000; |
|
|
|
|
border: 1px solid #ff0000; |
|
|
|
|
border-top: none; |
|
|
|
|
padding: 4px; |
|
|
|
|
border-radius: 22px; |
|
|
|
|
top: -40px; |
|
|
|
|
left: -50%; |
|
|
|
|
} |
|
|
|
|
.el_title_a::before { |
|
|
|
|
content: '▼'; |
|
|
|
|
position: absolute; |
|
|
|
|
color: #ff0000; |
|
|
|
|
top: -18px; |
|
|
|
|
left: 80px; |
|
|
|
|
} |
|
|
|
|
.el_title_b::after { |
|
|
|
|
content: '目前只支持导出 " 当前页面 " 不会卡顿,速度很快'; |
|
|
|
|
position: absolute; |
|
|
|
|
color: #ff0000; |
|
|
|
|
border: 1px solid #ff0000; |
|
|
|
|
border-bottom: none; |
|
|
|
|
padding: 4px; |
|
|
|
|
border-radius: 10px; |
|
|
|
|
bottom: -40px; |
|
|
|
|
right: -50%; |
|
|
|
|
} |
|
|
|
|
.el_title_b::before { |
|
|
|
|
content: '▲'; |
|
|
|
|
position: absolute; |
|
|
|
|
color: #ff0000; |
|
|
|
|
bottom: -18px; |
|
|
|
|
left: 80px; |
|
|
|
|
} |
|
|
|
|
.el-dialog__body { |
|
|
|
|
width: 100%; |
|
|
|
|
height: 100%; |
|
|
|
|
height: 44%; |
|
|
|
|
display: flex; |
|
|
|
|
align-items: center; |
|
|
|
|
justify-content: space-evenly; |
|
|
|
|
border-radius: 12px; |
|
|
|
|
.el-button { |
|
|
|
|
width: 30%; |
|
|
|
|
height: 44%; |
|
|
|
|
height: 100%; |
|
|
|
|
} |
|
|
|
|
} |
|
|
|
|
} |
|
|
|
|