|
|
|
@ -410,13 +410,13 @@
|
|
|
|
|
</div> |
|
|
|
|
</div> |
|
|
|
|
|
|
|
|
|
<el-dialog v-model="ExportObjects.tcTableexport" title="本地导出" width="40%"> |
|
|
|
|
<Tableexportcomponent |
|
|
|
|
:menuData="details.columnListPublic" |
|
|
|
|
:data="data" |
|
|
|
|
:checkedData="details.selectionList" |
|
|
|
|
></Tableexportcomponent> |
|
|
|
|
</el-dialog> |
|
|
|
|
<Tableexportcomponent |
|
|
|
|
:menuData="details.columnListPublic" |
|
|
|
|
:data="data" |
|
|
|
|
:checkedData="details.selectionList" |
|
|
|
|
:tcTableexport="ExportObjects.tcTableexport" |
|
|
|
|
@update:tcTableexport="updateTcTableexport" |
|
|
|
|
></Tableexportcomponent> |
|
|
|
|
|
|
|
|
|
<el-dialog |
|
|
|
|
v-model="ExportObjects.ExportSelection" |
|
|
|
@ -473,6 +473,7 @@ import {
|
|
|
|
|
import { ElMessageBox, ElMessage } from 'element-plus'; |
|
|
|
|
import { getDictionaryBiz } from '@/api/system/dict'; |
|
|
|
|
import { getToken } from '@/utils/auth'; |
|
|
|
|
import { setStore, getStore } from 'utils/store'; // 从 'utils/store' 导入 setStore 和 getStore 方法 |
|
|
|
|
import dayjs from 'dayjs'; |
|
|
|
|
import { getDetailWarehouse, getDeptWarehouse } from '@/api/basicdata/basicdataWarehouse'; //处理方 |
|
|
|
|
import { |
|
|
|
@ -511,6 +512,10 @@ import {
|
|
|
|
|
$_basicdataTripartiteMall, |
|
|
|
|
$_aftersalesCustomerMallgetByClientId, |
|
|
|
|
$_exportaftersalesOvertimeFine, |
|
|
|
|
$_exportWorkOrder0, |
|
|
|
|
$_exportWorkOrder1, |
|
|
|
|
$_exportWorkOrder2, |
|
|
|
|
$_exportWorkOrder3, |
|
|
|
|
} from '@/api/aftersales/aftersalesWorkOrder'; |
|
|
|
|
import { |
|
|
|
|
columnList, |
|
|
|
@ -572,7 +577,7 @@ const warehouseData = ref([]); //仓库信息
|
|
|
|
|
const UserInfo = ref({}); //登陆人信息 |
|
|
|
|
const assignFromForm = ref(null); //指派客服表单实例 |
|
|
|
|
const dialogSearch = ref(false); //弹窗搜索 |
|
|
|
|
const dialogSearchTitle=ref('');//弹出搜索记录 |
|
|
|
|
const dialogSearchTitle = ref(''); //弹出搜索记录 |
|
|
|
|
const ExportObjects = ref({ |
|
|
|
|
tcTableexport: false, //本地导出 |
|
|
|
|
ExportSelection: false, //导出选择弹窗 |
|
|
|
@ -2076,38 +2081,49 @@ const ViewDetails10 = row => {
|
|
|
|
|
}; |
|
|
|
|
// 全部异常工单号点击查看 |
|
|
|
|
const ViewDetailsRow = row => { |
|
|
|
|
$useStore.commit('DEL_ONCE_TAG', '/aftersales/aftersalesWorkOrderInfo'); |
|
|
|
|
let tagList = getStore({ name: 'tagList' }); |
|
|
|
|
|
|
|
|
|
console.log(row, '异常工单号点击查看详情当前行数据'); |
|
|
|
|
switch (TabPermissions.value) { |
|
|
|
|
case 0: |
|
|
|
|
ViewDetails0(row); |
|
|
|
|
$useStore.commit('DEL_ONCE_TAG', '/aftersales/aftersalesWorkOrderInfo'); |
|
|
|
|
break; |
|
|
|
|
case 1: |
|
|
|
|
ViewDetails1(row); |
|
|
|
|
$useStore.commit('DEL_ONCE_TAG', '/aftersales/aftersalesWorkOrderend'); |
|
|
|
|
break; |
|
|
|
|
case 2: |
|
|
|
|
ViewDetails2(row); |
|
|
|
|
$useStore.commit('DEL_ONCE_TAG', '/aftersales/aftersalesWorkOrderend'); |
|
|
|
|
break; |
|
|
|
|
case 3: |
|
|
|
|
ViewDetails3(row); |
|
|
|
|
$useStore.commit('DEL_ONCE_TAG', '/aftersales/aftersalesWorkOrderend'); |
|
|
|
|
break; |
|
|
|
|
case 4: |
|
|
|
|
ViewDetails4(row); |
|
|
|
|
$useStore.commit('DEL_ONCE_TAG', '/aftersales/aftersalesWorkOrderend'); |
|
|
|
|
break; |
|
|
|
|
case 5: |
|
|
|
|
ViewDetails5(row); |
|
|
|
|
$useStore.commit('DEL_ONCE_TAG', '/aftersales/aftersalesWorkOrderend'); |
|
|
|
|
break; |
|
|
|
|
case 6: |
|
|
|
|
ViewDetails6(row); |
|
|
|
|
$useStore.commit('DEL_ONCE_TAG', '/aftersales/aftersalesWorkOrderend'); |
|
|
|
|
break; |
|
|
|
|
case 8: |
|
|
|
|
ViewDetails8(row); |
|
|
|
|
$useStore.commit('DEL_ONCE_TAG', '/aftersales/aftersalesWorkOrderend'); |
|
|
|
|
break; |
|
|
|
|
case 9: |
|
|
|
|
ViewDetails9(row); |
|
|
|
|
$useStore.commit('DEL_ONCE_TAG', '/aftersales/aftersalesWorkOrderend'); |
|
|
|
|
break; |
|
|
|
|
case 10: |
|
|
|
|
ViewDetails10(row); |
|
|
|
|
$useStore.commit('DEL_ONCE_TAG', '/aftersales/aftersalesWorkOrderend'); |
|
|
|
|
break; |
|
|
|
|
default: |
|
|
|
|
break; |
|
|
|
@ -2124,33 +2140,43 @@ const ViewDetails = row => {
|
|
|
|
|
switch (TabPermissions.value) { |
|
|
|
|
case 0: |
|
|
|
|
ViewDetails0(row); //全部 |
|
|
|
|
$useStore.commit('DEL_ONCE_TAG', '/aftersales/aftersalesWorkOrderInfo'); |
|
|
|
|
break; |
|
|
|
|
case 1: |
|
|
|
|
ViewDetails1(row); |
|
|
|
|
$useStore.commit('DEL_ONCE_TAG', '/aftersales/aftersalesWorkOrderend'); |
|
|
|
|
break; |
|
|
|
|
case 2: |
|
|
|
|
ViewDetails2(row); |
|
|
|
|
$useStore.commit('DEL_ONCE_TAG', '/aftersales/aftersalesWorkOrderend'); |
|
|
|
|
break; |
|
|
|
|
case 3: |
|
|
|
|
ViewDetails3(row); |
|
|
|
|
$useStore.commit('DEL_ONCE_TAG', '/aftersales/aftersalesWorkOrderend'); |
|
|
|
|
break; |
|
|
|
|
case 4: |
|
|
|
|
ViewDetails4(row); |
|
|
|
|
$useStore.commit('DEL_ONCE_TAG', '/aftersales/aftersalesWorkOrderend'); |
|
|
|
|
break; |
|
|
|
|
case 5: |
|
|
|
|
ViewDetails5(row); |
|
|
|
|
$useStore.commit('DEL_ONCE_TAG', '/aftersales/aftersalesWorkOrderend'); |
|
|
|
|
break; |
|
|
|
|
case 6: |
|
|
|
|
ViewDetails6(row); |
|
|
|
|
$useStore.commit('DEL_ONCE_TAG', '/aftersales/aftersalesWorkOrderend'); |
|
|
|
|
break; |
|
|
|
|
case 8: |
|
|
|
|
ViewDetails8(row); |
|
|
|
|
$useStore.commit('DEL_ONCE_TAG', '/aftersales/aftersalesWorkOrderend'); |
|
|
|
|
break; |
|
|
|
|
case 9: |
|
|
|
|
ViewDetails9(row); |
|
|
|
|
$useStore.commit('DEL_ONCE_TAG', '/aftersales/aftersalesWorkOrderend'); |
|
|
|
|
break; |
|
|
|
|
case 10: |
|
|
|
|
ViewDetails10(row); |
|
|
|
|
$useStore.commit('DEL_ONCE_TAG', '/aftersales/aftersalesWorkOrderend'); |
|
|
|
|
break; |
|
|
|
|
default: |
|
|
|
|
break; |
|
|
|
@ -2349,9 +2375,9 @@ const Assignbutton = async () => {
|
|
|
|
|
* 5.最终将选择的客服信息,分配给对应的工单 |
|
|
|
|
*/ |
|
|
|
|
const MultilineSearch = (title, input) => { |
|
|
|
|
dialogSearchTitle.value = title |
|
|
|
|
console.log(dialogSearchTitle.value,'dialogSearchTitle.value'); |
|
|
|
|
|
|
|
|
|
dialogSearchTitle.value = title; |
|
|
|
|
console.log(dialogSearchTitle.value, 'dialogSearchTitle.value'); |
|
|
|
|
|
|
|
|
|
if (input) { |
|
|
|
|
const formattedInput = input.split(',').join('\n'); |
|
|
|
|
TopQuery.value.inputAll = formattedInput; // 赋值给 inputAll |
|
|
|
@ -2390,11 +2416,10 @@ const dialogSearchSubmit = () => {
|
|
|
|
|
|
|
|
|
|
// 5.将连接起来的数据重新赋值给workOrderNumber |
|
|
|
|
|
|
|
|
|
if(dialogSearchTitle.value == '工单号搜索'){ |
|
|
|
|
if (dialogSearchTitle.value == '工单号搜索') { |
|
|
|
|
TopQuery.value.workOrderNumbers = joinedLines; |
|
|
|
|
}else if(dialogSearchTitle.value == '订单自编号搜索'){ |
|
|
|
|
} else if (dialogSearchTitle.value == '订单自编号搜索') { |
|
|
|
|
TopQuery.value.orderCodes = joinedLines; |
|
|
|
|
|
|
|
|
|
} |
|
|
|
|
Searchboxpop.value.dialogSearch = false; //关闭弹窗 |
|
|
|
|
|
|
|
|
@ -2455,7 +2480,6 @@ const ExportSelection = () => {
|
|
|
|
|
// 导出表格 |
|
|
|
|
const exportReport = () => { |
|
|
|
|
console.log('12312'); |
|
|
|
|
|
|
|
|
|
ElMessageBox.confirm('是否导出报表?', { |
|
|
|
|
confirmButtonText: '确定', |
|
|
|
|
cancelButtonText: '取消', |
|
|
|
@ -2470,28 +2494,32 @@ const exportReport = () => {
|
|
|
|
|
if (details.selectionList.length) { |
|
|
|
|
dataID.ids = details.selectionList.map(item => item.id).join(','); |
|
|
|
|
} |
|
|
|
|
$_exportAftersalesWorkOrder(dataID) |
|
|
|
|
.then(res => { |
|
|
|
|
const currentDate = new Date(); |
|
|
|
|
const formattedDate = `${currentDate.getFullYear()}${(currentDate.getMonth() + 1) |
|
|
|
|
.toString() |
|
|
|
|
.padStart(2, '0')}${currentDate.getDate().toString().padStart(2, '0')}${currentDate |
|
|
|
|
.getHours() |
|
|
|
|
.toString() |
|
|
|
|
.padStart(2, '0')}${currentDate.getMinutes().toString().padStart(2, '0')}${currentDate |
|
|
|
|
.getSeconds() |
|
|
|
|
.toString() |
|
|
|
|
.padStart(2, '0')}`; |
|
|
|
|
console.log(res, '导出'); |
|
|
|
|
downloadXls(res.data, `导出工单数据${formattedDate}.xlsx`); |
|
|
|
|
}) |
|
|
|
|
.catch(e => { |
|
|
|
|
console.log(e, 'error'); |
|
|
|
|
}) |
|
|
|
|
.finally(() => {}); |
|
|
|
|
JExportAll(dataID); |
|
|
|
|
// switch (TabPermissions.value) { |
|
|
|
|
// case 0: |
|
|
|
|
// ExportAll(dataID); //全部 |
|
|
|
|
// break; |
|
|
|
|
// case 1: |
|
|
|
|
// ExportingDuringProcessing(dataID); |
|
|
|
|
// break; |
|
|
|
|
// case 2: |
|
|
|
|
// ProcessedExported(dataID); |
|
|
|
|
// break; |
|
|
|
|
// case 4: |
|
|
|
|
// // 理赔金额未出 |
|
|
|
|
// ExportClaimAmount(dataID); |
|
|
|
|
// break; |
|
|
|
|
// default: |
|
|
|
|
// ExportAll(dataID); |
|
|
|
|
// break; |
|
|
|
|
// } |
|
|
|
|
}) |
|
|
|
|
.catch(() => {}); |
|
|
|
|
}; |
|
|
|
|
// 更新本地导出显示状态 |
|
|
|
|
const updateTcTableexport = newValue => { |
|
|
|
|
ExportObjects.value.tcTableexport = newValue; |
|
|
|
|
}; |
|
|
|
|
// 本地导出 |
|
|
|
|
const LocalExport = () => { |
|
|
|
|
ExportObjects.value.tcTableexport = true; |
|
|
|
@ -2500,6 +2528,111 @@ const LocalExport = () => {
|
|
|
|
|
const NetworkExport = () => { |
|
|
|
|
exportReport(); |
|
|
|
|
}; |
|
|
|
|
|
|
|
|
|
// 旧版本导出 |
|
|
|
|
|
|
|
|
|
const JExportAll = async dataID => { |
|
|
|
|
try { |
|
|
|
|
PageLoading.value = true; |
|
|
|
|
let res = await $_exportAftersalesWorkOrder(dataID); |
|
|
|
|
const currentDate = new Date(); |
|
|
|
|
const formattedDate = `${currentDate.getFullYear()}${(currentDate.getMonth() + 1) |
|
|
|
|
.toString() |
|
|
|
|
.padStart(2, '0')}${currentDate.getDate().toString().padStart(2, '0')}${currentDate |
|
|
|
|
.getHours() |
|
|
|
|
.toString() |
|
|
|
|
.padStart(2, '0')}${currentDate.getMinutes().toString().padStart(2, '0')}${currentDate |
|
|
|
|
.getSeconds() |
|
|
|
|
.toString() |
|
|
|
|
.padStart(2, '0')}`; |
|
|
|
|
downloadXls(res.data, `导出工单数据${formattedDate}.xlsx`); |
|
|
|
|
PageLoading.value = false; |
|
|
|
|
} catch (e) { |
|
|
|
|
console.log(e); |
|
|
|
|
} finally { |
|
|
|
|
} |
|
|
|
|
}; |
|
|
|
|
|
|
|
|
|
// 全部导出 |
|
|
|
|
const ExportAll = async dataID => { |
|
|
|
|
try { |
|
|
|
|
let res = await $_exportWorkOrder0(dataID); |
|
|
|
|
const currentDate = new Date(); |
|
|
|
|
const formattedDate = `${currentDate.getFullYear()}${(currentDate.getMonth() + 1) |
|
|
|
|
.toString() |
|
|
|
|
.padStart(2, '0')}${currentDate.getDate().toString().padStart(2, '0')}${currentDate |
|
|
|
|
.getHours() |
|
|
|
|
.toString() |
|
|
|
|
.padStart(2, '0')}${currentDate.getMinutes().toString().padStart(2, '0')}${currentDate |
|
|
|
|
.getSeconds() |
|
|
|
|
.toString() |
|
|
|
|
.padStart(2, '0')}`; |
|
|
|
|
downloadXls(res.data, `导出工单数据${formattedDate}.xlsx`); |
|
|
|
|
} catch (e) { |
|
|
|
|
console.log(e); |
|
|
|
|
} finally { |
|
|
|
|
} |
|
|
|
|
}; |
|
|
|
|
// 处理中导出 |
|
|
|
|
const ExportingDuringProcessing = async dataID => { |
|
|
|
|
try { |
|
|
|
|
let res = await $_exportWorkOrder1(dataID); |
|
|
|
|
const currentDate = new Date(); |
|
|
|
|
const formattedDate = `${currentDate.getFullYear()}${(currentDate.getMonth() + 1) |
|
|
|
|
.toString() |
|
|
|
|
.padStart(2, '0')}${currentDate.getDate().toString().padStart(2, '0')}${currentDate |
|
|
|
|
.getHours() |
|
|
|
|
.toString() |
|
|
|
|
.padStart(2, '0')}${currentDate.getMinutes().toString().padStart(2, '0')}${currentDate |
|
|
|
|
.getSeconds() |
|
|
|
|
.toString() |
|
|
|
|
.padStart(2, '0')}`; |
|
|
|
|
downloadXls(res.data, `导出工单数据${formattedDate}.xlsx`); |
|
|
|
|
} catch (e) { |
|
|
|
|
console.log(e); |
|
|
|
|
} finally { |
|
|
|
|
} |
|
|
|
|
}; |
|
|
|
|
// 理赔金未出导出 |
|
|
|
|
const ExportClaimAmount = async dataID => { |
|
|
|
|
try { |
|
|
|
|
let res = await $_exportWorkOrder2(dataID); |
|
|
|
|
const currentDate = new Date(); |
|
|
|
|
const formattedDate = `${currentDate.getFullYear()}${(currentDate.getMonth() + 1) |
|
|
|
|
.toString() |
|
|
|
|
.padStart(2, '0')}${currentDate.getDate().toString().padStart(2, '0')}${currentDate |
|
|
|
|
.getHours() |
|
|
|
|
.toString() |
|
|
|
|
.padStart(2, '0')}${currentDate.getMinutes().toString().padStart(2, '0')}${currentDate |
|
|
|
|
.getSeconds() |
|
|
|
|
.toString() |
|
|
|
|
.padStart(2, '0')}`; |
|
|
|
|
downloadXls(res.data, `导出工单数据${formattedDate}.xlsx`); |
|
|
|
|
} catch (e) { |
|
|
|
|
console.log(e); |
|
|
|
|
} finally { |
|
|
|
|
} |
|
|
|
|
}; |
|
|
|
|
// 处理完毕导出 |
|
|
|
|
const ProcessedExported = async dataID => { |
|
|
|
|
try { |
|
|
|
|
let res = await $_exportWorkOrder3(dataID); |
|
|
|
|
const currentDate = new Date(); |
|
|
|
|
const formattedDate = `${currentDate.getFullYear()}${(currentDate.getMonth() + 1) |
|
|
|
|
.toString() |
|
|
|
|
.padStart(2, '0')}${currentDate.getDate().toString().padStart(2, '0')}${currentDate |
|
|
|
|
.getHours() |
|
|
|
|
.toString() |
|
|
|
|
.padStart(2, '0')}${currentDate.getMinutes().toString().padStart(2, '0')}${currentDate |
|
|
|
|
.getSeconds() |
|
|
|
|
.toString() |
|
|
|
|
.padStart(2, '0')}`; |
|
|
|
|
downloadXls(res.data, `导出工单数据${formattedDate}.xlsx`); |
|
|
|
|
} catch (e) { |
|
|
|
|
console.log(e); |
|
|
|
|
} finally { |
|
|
|
|
} |
|
|
|
|
}; |
|
|
|
|
</script> |
|
|
|
|
|
|
|
|
|
<style scoped lang="scss"> |
|
|
|
@ -2598,6 +2731,7 @@ const NetworkExport = () => {
|
|
|
|
|
:deep(.Searchboxpop-upwindow) { |
|
|
|
|
.el-overlay { |
|
|
|
|
position: absolute; |
|
|
|
|
|
|
|
|
|
.el-dialog { |
|
|
|
|
min-height: 70%; |
|
|
|
|
} |
|
|
|
@ -2627,6 +2761,7 @@ const NetworkExport = () => {
|
|
|
|
|
cursor: pointer; |
|
|
|
|
} |
|
|
|
|
} |
|
|
|
|
|
|
|
|
|
.el-dialog__footer { |
|
|
|
|
display: flex; |
|
|
|
|
justify-content: center; |
|
|
|
@ -2677,8 +2812,15 @@ const NetworkExport = () => {
|
|
|
|
|
flex-direction: column; |
|
|
|
|
.el-dialog__body { |
|
|
|
|
width: 100%; |
|
|
|
|
height: 100%; |
|
|
|
|
display: flex; |
|
|
|
|
align-items: center; |
|
|
|
|
justify-content: space-evenly; |
|
|
|
|
border-radius: 12px; |
|
|
|
|
.el-button { |
|
|
|
|
width: 30%; |
|
|
|
|
height: 44%; |
|
|
|
|
} |
|
|
|
|
} |
|
|
|
|
} |
|
|
|
|
</style> |
|
|
|
|