qb 5 months ago
parent
commit
1994167b93
  1. 4
      src/api/finance/SettlementInformation.js
  2. 11
      src/components/distributionDeliveryListmar/distributionDeliveryListmar.vue
  3. 3000
      src/option/aftersales/vueTvemp.js
  4. 8
      src/option/finance/CustomerSettlement.js
  5. 2
      src/option/finance/MerchantDepositSlip.js
  6. 636
      src/option/finance/ReconciliationDepositSlip.js
  7. 529
      src/views/aftersales/aftersalesWorkOrderTemp.vue
  8. 112
      src/views/basicdata/brand/basicClient.vue
  9. 34
      src/views/distribution/deliverylist/distributionDeliveryListmar.vue
  10. 117
      src/views/finance/CustomerSettlement.vue
  11. 209
      src/views/finance/MerchantDepositSlip.vue
  12. 249
      src/views/finance/ReconciliationDepositSlip.vue

4
src/api/finance/SettlementInformation.js

@ -46,7 +46,7 @@ export const postAddBalanceRecord = data => {
*/
export const postFindAbnormalList = data => {
return request({
url: '/api/logpm-statisticsdata-zhy/merchantBalance/findAbnormalList',
url: '/api/logpm-statisticsdata/merchantBalance/findAbnormalList',
method: 'post',
data,
});
@ -59,7 +59,7 @@ export const postFindAbnormalList = data => {
*/
export const postAddAbnormal = data => {
return request({
url: '/api/logpm-statisticsdata-zhy/merchantBalance/addAbnormal',
url: '/api/logpm-statisticsdata/merchantBalance/addAbnormal',
method: 'post',
data,
});

11
src/components/distributionDeliveryListmar/distributionDeliveryListmar.vue

@ -0,0 +1,11 @@
<template>
</template>
<script setup>
</script>
<style scoped lang='scss'>
</style>

3000
src/option/aftersales/vueTvemp.js

File diff suppressed because it is too large Load Diff

8
src/option/finance/CustomerSettlement.js

@ -17,7 +17,7 @@ export const columnList = [
{
prop: 'balanceOrderNo',
label: '结算单号',
type: 1,
type: 2,
values: '',
width: '150',
checkarr: [],
@ -28,7 +28,7 @@ export const columnList = [
{
prop: 'brand',
label: '品牌',
type: 1,
type: 2,
values: '',
width: '150',
checkarr: [],
@ -39,7 +39,7 @@ export const columnList = [
{
prop: 'waybillNo',
label: '运单号',
type: 1,
type: 2,
values: '',
width: '150',
checkarr: [],
@ -50,7 +50,7 @@ export const columnList = [
{
prop: 'orderCode',
label: '订单编号',
type: 1,
type: 2,
values: '',
width: '150',
checkarr: [],

2
src/option/finance/MerchantDepositSlip.js

@ -17,7 +17,7 @@ export const columnList = [
{
prop: 'brand',
label: '品牌',
type: 1,
type: 2,
values: '',
width: '150',
checkarr: [],

636
src/option/finance/ReconciliationDepositSlip.js

@ -27,8 +27,8 @@ export const columnList = [
},
{
prop: 'orderCode',
label: '订单编号',
type: 1,
label: '订单编号',
type: 2,
values: '',
width: '150',
checkarr: [],
@ -50,7 +50,7 @@ export const columnList = [
{
prop: 'shipper',
label: '发货单位',
type: 1,
type: 2,
values: '',
width: '150',
checkarr: [],
@ -72,7 +72,7 @@ export const columnList = [
{
prop: 'destinationWarehouseName',
label: '目的仓',
type: 1,
type: 2,
values: '',
width: '150',
checkarr: [],
@ -83,7 +83,7 @@ export const columnList = [
{
prop: 'departureWarehouseName',
label: '发站仓',
type: 1,
type: 2,
values: '',
width: '150',
checkarr: [],
@ -109,6 +109,261 @@ export const columnList = [
{
prop: 'typeServiceName',
label: '订单类型',
type: 3,
values: '',
width: '150',
checkarr: [
{
label:'商配',
value:1
},
{
label:'市配',
value:2
},
{
label:'自提',
value:3
},
],
fixed: false,
sortable: true,
head: false,
},
{
prop: 'openTime',
label: '开单时间',
type: 1,
values: '',
width: '150',
checkarr: [],
fixed: false,
sortable: true,
head: false,
},
{
prop: 'goodsName',
label: '货物品类',
type: 1,
values: '',
width: '150',
checkarr: [],
fixed: false,
sortable: true,
head: false,
},
{
prop: 'totalNum',
label: '总件数',
type: 1,
values: '',
width: '150',
checkarr: [],
fixed: false,
sortable: true,
head: false,
},
{
prop: 'totalWeight',
label: '总重量',
type: 1,
values: '',
width: '150',
checkarr: [],
fixed: false,
sortable: true,
head: false,
},
{
prop: 'totalVolume',
label: '总体积',
type: 1,
values: '',
width: '150',
checkarr: [],
fixed: false,
sortable: true,
head: false,
},
{
prop: 'sysTotalFee',
label: '订单开单价',
type: 1,
values: '',
width: '150',
checkarr: [],
fixed: false,
sortable: true,
head: false,
},
{
prop: 'totalFee',
label: '实际费用',
type: 1,
values: '',
width: '150',
checkarr: [],
fixed: false,
sortable: true,
head: false,
},
{
prop: 'systemFreightPrice',
label: '开单运费',
type: 1,
values: '',
width: '150',
checkarr: [],
fixed: false,
sortable: true,
head: false,
},
{
prop: 'freightPrice',
label: '实际运费',
type: 1,
values: '',
width: '150',
checkarr: [],
fixed: false,
sortable: true,
head: false,
},
{
prop: 'systemPickupPrice',
label: '开单提货费',
type: 1,
values: '',
width: '150',
checkarr: [],
fixed: false,
sortable: true,
head: false,
},
{
prop: 'pickupPrice',
label: '实际提货费',
type: 1,
values: '',
width: '150',
checkarr: [],
fixed: false,
sortable: true,
head: false,
},
{
prop: 'warehouseServiceFee',
label: '仓储服务费合计',
type: 1,
values: '',
width: '150',
checkarr: [],
fixed: false,
sortable: true,
head: false,
},
{
prop: 'warehouseFee',
label: '仓储费',
type: 1,
values: '',
width: '150',
checkarr: [],
fixed: false,
sortable: true,
head: false,
},
{
prop: 'warehouseManageFee',
label: '仓储管理费',
type: 1,
values: '',
width: '150',
checkarr: [],
fixed: false,
sortable: true,
head: false,
},
{
prop: 'warehouseSortingFee',
label: '仓储分拣费',
type: 1,
values: '',
width: '150',
checkarr: [],
fixed: false,
sortable: true,
head: false,
},
{
prop: 'warehouseOperatingFee',
label: '仓储操作费',
type: 1,
values: '',
width: '150',
checkarr: [],
fixed: false,
sortable: true,
head: false,
},
{
prop: 'deliveryServiceFee',
label: '配送费服务费合计',
type: 1,
values: '',
width: '150',
checkarr: [],
fixed: false,
sortable: true,
head: false,
},
{
prop: 'systemDeliveryFee',
label: '开单配送费',
type: 1,
values: '',
width: '150',
checkarr: [],
fixed: false,
sortable: true,
head: false,
},
{
prop: 'deliveryFee',
label: '实际配送费',
type: 1,
values: '',
width: '150',
checkarr: [],
fixed: false,
sortable: true,
head: false,
},
{
prop: 'deliveryLoadingFee',
label: '配送装卸费',
type: 1,
values: '',
width: '150',
checkarr: [],
fixed: false,
sortable: true,
head: false,
},
{
prop: 'deliverySortingFee',
label: '配送分货费',
type: 1,
values: '',
width: '150',
checkarr: [],
fixed: false,
sortable: true,
head: false,
},
{
prop: 'deliveryUpfloorFee',
label: '配送上楼费',
type: 1,
values: '',
width: '150',
@ -117,6 +372,376 @@ export const columnList = [
sortable: true,
head: false,
},
{
prop: 'deliveryMoveFee',
label: '配送平移费',
type: 1,
values: '',
width: '150',
checkarr: [],
fixed: false,
sortable: true,
head: false,
},
{
prop: 'deliveryOtherFee',
label: '配送其它费',
type: 1,
values: '',
width: '150',
checkarr: [],
fixed: false,
sortable: true,
head: false,
},
{
prop: 'deliveryCrossingFee',
label: '超区公里费',
type: 1,
values: '',
width: '150',
checkarr: [],
fixed: false,
sortable: true,
head: false,
},
{
prop: 'installFee',
label: '安装费',
type: 1,
values: '',
width: '150',
checkarr: [],
fixed: false,
sortable: true,
head: false,
},
{
prop: 'otherFee',
label: '其他费用',
type: 1,
values: '',
width: '150',
checkarr: [],
fixed: false,
sortable: true,
head: false,
},
{
prop: 'shipperPerson',
label: '发货人',
type: 2,
values: '',
width: '150',
checkarr: [],
fixed: false,
sortable: true,
head: false,
},
{
prop: 'shipperMobile',
label: '发货人手机号',
type: 2,
values: '',
width: '150',
checkarr: [],
fixed: false,
sortable: true,
head: false,
},
{
prop: 'shipperAddress',
label: '发货地址',
type: 1,
values: '',
width: '150',
checkarr: [],
fixed: false,
sortable: true,
head: false,
},
{
prop: 'destination',
label: '到站',
type: 2,
values: '',
width: '150',
checkarr: [],
fixed: false,
sortable: true,
head: false,
},
{
prop: 'consigneePerson',
label: '收货人',
type: 2,
values: '',
width: '150',
checkarr: [],
fixed: false,
sortable: true,
head: false,
},
{
prop: 'consigneeMobile',
label: '收货人手机号',
type: 2,
values: '',
width: '150',
checkarr: [],
fixed: false,
sortable: true,
head: false,
},
{
prop: 'consigneeAddress',
label: '收货地址',
type: 1,
values: '',
width: '150',
checkarr: [],
fixed: false,
sortable: true,
head: false,
},
{
prop: 'customerTrain',
label: '客户车次',
type: 2,
values: '',
width: '150',
checkarr: [],
fixed: false,
sortable: true,
head: false,
},
{
prop: 'cleanObjTypeName',
label: '结算方',
type: 3,
values: '',
width: '150',
checkarr: [
{ label: '工厂', value: 1 },
{ label: '商场', value: 2 },
{ label: '商家个人', value: 3 },
],
fixed: false,
sortable: true,
head: false,
},
{
prop: 'payTypeName',
label: '支付方式',
type: 3,
values: '',
width: '150',
checkarr: [],
fixed: false,
sortable: true,
head: false,
},
{
prop: 'payWayName',
label: '付款方式',
type: 3,
values: '',
width: '150',
checkarr: [],
fixed: false,
sortable: true,
head: false,
},
{
prop: 'signNum',
label: '已签收件数',
type: 1,
values: '',
width: '150',
checkarr: [],
fixed: false,
sortable: true,
head: false,
},
{
prop: 'signTime',
label: '签收时间',
type: 1,
values: '',
width: '150',
checkarr: [],
fixed: false,
sortable: true,
head: false,
},
{
prop: 'syncFeeStatus',
label: '是否计算价格',
type: 1,
values: '',
width: '150',
checkarr: [
{ label: '是', value: 1 },
{ label: '否', value: 0 },
],
fixed: false,
sortable: true,
head: false,
},
{
prop: 'syncFeeDate',
label: '计算价格时间',
type: 1,
values: '',
width: '150',
checkarr: [],
fixed: false,
sortable: true,
head: false,
},
{
prop: '',
label: '操作',
type: 6,
values: '',
width: '120',
checkarr: [],
fixed: 'right',
sortable: false,
},
];
export const columnListB = [
{
prop: '',
label: '复选框',
type: 0,
width: 55,
fixed: true,
},
{
prop: '',
label: '序号',
type: 12,
values: '',
width: 55,
fixed: true,
},
{
prop: 'brand',
label: '品牌',
type: 2,
values: '',
width: '150',
checkarr: [],
fixed: true,
sortable: true,
head: false,
},
{
prop: 'orderCode',
label: '订单自编号',
type: 2,
values: '',
width: '150',
checkarr: [],
fixed: true,
sortable: true,
head: false,
},
{
prop: 'waybillNo',
label: '运单号',
type: 2,
values: '',
width: '150',
checkarr: [],
fixed: true,
sortable: true,
head: false,
},
{
prop: 'shipper',
label: '发货单位',
type: 2,
values: '',
width: '150',
checkarr: [],
fixed: false,
sortable: true,
head: false,
},
{
prop: 'consignee',
label: '收货单位',
type: 1,
values: '',
width: '150',
checkarr: [],
fixed: false,
sortable: true,
head: false,
},
{
prop: 'destinationWarehouseName',
label: '目的仓',
type: 2,
values: '',
width: '150',
checkarr: [],
fixed: false,
sortable: true,
head: false,
},
{
prop: 'departureWarehouseName',
label: '发站仓',
type: 2,
values: '',
width: '150',
checkarr: [],
fixed: false,
sortable: true,
head: false,
},
{
prop: 'signStatusName',
label: '签收状态',
type: 3,
values: '',
width: '150',
checkarr: [
{ label: '未签收', value: 0 },
{ label: '部分签收', value: 1 },
{ label: '已签收', value: 2 },
],
fixed: false,
sortable: true,
head: false,
},
{
prop: 'typeServiceName',
label: '订单类型',
type: 3,
values: '',
width: '150',
checkarr: [
{
label:'商配1',
value:1
},
{
label:'市配',
value:2
},
{
label:'自提',
value:3
},
],
fixed: false,
sortable: true,
head: false,
},
{
prop: 'openTime',
label: '开单时间',
@ -597,7 +1222,6 @@ export const columnList = [
sortable: false,
},
];
/** 生成对账单 */
export const confirmColumnList = [
{

529
src/views/aftersales/aftersalesWorkOrderTemp.vue

@ -1,5 +1,5 @@
<template>
<basic-container v-loading="PageLoading" element-loading-text="数据正在加载中..." >
<basic-container v-loading="PageLoading" element-loading-text="数据正在加载中...">
<!-- 首页表格 -->
<div class="avue-crud">
<!-- 搜索模块 -->
@ -37,19 +37,46 @@
<div class="avue-crud__header">
<!-- 头部左侧按钮模块 -->
<div class="avue-crud__left">
<el-button type="primary" icon="Edit">创建工单</el-button>
<el-button type="primary" icon="Download">Excel导出</el-button>
<el-button type="primary" icon="Download">Excel超时导出</el-button>
<el-button type="primary" icon="Avatar">默认指派</el-button>
<el-button type="primary" icon="CloseBold">批量打回</el-button>
<el-button type="primary" icon="Select">批量确定</el-button>
<el-button type="primary" icon="FolderChecked">批量审核</el-button>
<el-button type="primary" icon="Pointer">工单指派</el-button>
<el-button type="primary" icon="User">客服介入</el-button>
<el-button type="primary" icon="EditPen">钉钉号填写</el-button>
<el-button type="primary" icon="Stamp">批量完结</el-button>
<el-button type="primary" icon="Stamp">批量完结审核</el-button>
<el-button type="primary" icon="Coin">财务入账</el-button>
<el-button type="primary" icon="Edit" v-if="ButtonPermissions.add">创建工单</el-button>
<el-button type="primary" icon="Download" v-if="ButtonPermissions.export_Report"
>Excel导出</el-button
>
<el-button type="primary" icon="Download" v-if="ButtonPermissions.Timed_outexport"
>Excel超时导出</el-button
>
<el-button type="primary" icon="Avatar" v-if="ButtonPermissions.defaultassignments"
>默认指派</el-button
>
<el-button type="primary" icon="CloseBold" v-if="ButtonPermissions.batchReject"
>结果批量打回</el-button
>
<el-button type="primary" icon="FolderChecked" v-if="ButtonPermissions.ManagerConfirmed"
>完结批量审核</el-button
>
<el-button type="primary" icon="Select" v-if="ButtonPermissions.Batchdetermination"
>批量确定</el-button
>
<el-button type="primary" icon="Stamp" v-if="ButtonPermissions.Result_review"
>结果批量审核</el-button
>
<el-button type="primary" icon="Pointer" v-if="ButtonPermissions.assignment"
>工单指派</el-button
>
<el-button type="primary" icon="User" v-if="ButtonPermissions.applyArbitration"
>客服介入</el-button
>
<el-button type="primary" icon="EditPen" v-if="ButtonPermissions.DingTalkNumber"
>钉钉号填写</el-button
>
<el-button type="primary" icon="Stamp" v-if="ButtonPermissions.batchFinish"
>批量完结</el-button
>
<el-button type="primary" icon="Stamp" v-if="ButtonPermissions.ArbitrationDetermination"
>批量完结审核</el-button
>
<el-button type="primary" icon="Coin" v-if="ButtonPermissions.Financial_accounting"
>财务入账</el-button
>
</div>
<!-- 头部右侧按钮模块 -->
<div class="avue-crud__right">
@ -65,7 +92,7 @@
<!-- 列表模块 -->
<tablecmt
class="tableNode"
:columnList="details.columnList"
:columnList="details.columnListPublic"
:tableData="data"
:loading="loadingObj.list"
@inputTxt="inputsc"
@ -74,6 +101,16 @@
@selection="selectionChange"
>
<template #default="slotProps">
<template v-if="slotProps.scope.column.label === '异常工单号'">
<el-text class="el_textBtn" @click="InformationViewing(slotProps.scope)">
{{
slotProps.scope.column.label === '异常工单号'
? slotProps.scope.row.workOrderNumber
: ''
}}
</el-text>
</template>
<template v-if="slotProps.scope.column.label === '操作'">
<el-text>查看</el-text>
</template>
@ -103,11 +140,11 @@
</basic-container>
<!-- 列表配置显示 -->
<edittablehead
@setcolum="setnewcolum"
@closce="showdrawer"
:drawerShow="drawerShow"
:columnList="details.columnList"
v-model="details.columnList"
:columnList="details.columnListPublic"
v-model="details.columnListPublic"
:columnListName="columnListName"
></edittablehead>
</template>
@ -119,6 +156,7 @@ import {
setNodeHeight,
downloadXls,
handleClearTableQuery,
deepClone,
} from '@/utils/util';
import { ElMessageBox, ElMessage } from 'element-plus';
import { getDictionaryBiz } from '@/api/system/dict';
@ -162,6 +200,16 @@ import {
} from '@/api/aftersales/aftersalesWorkOrder';
import {
columnList,
columnList1,
columnList2,
columnList3,
columnList4,
columnList5,
columnList6,
columnList7,
columnList8,
columnList9,
columnList10,
recordList,
Claimsfield,
AppealList,
@ -170,17 +218,38 @@ import {
MallassignmentColumnList,
customerserviceColumnList,
} from '@/option/aftersales/vueTvemp.js';
// (0, ''),
// (8, ''),
// (3, '()'),
// (1, ''),
// (4, ''),
// (2, ''),
// (5, ''),
// (9, ''),
// (6, ''),
// (10, ''),
// (7, ''),
const $router = useRouter(); //
const $useStore = useStore(); //
const $route = useRoute(); //
const tabValue = ref(0); //
const UserPermissions = ref(''); //
const PageLoading = ref(true); //loading
const workOrderStatus = ref(30); //
const PageLoading = ref(false); //loading
const columnListName = ref('columnList');
/**
* 人身份
* Warehouse_customer_service 仓库客服
* Headquarters_customer_service 总部客服
* Headquarters_Manager 总部客服经理
*/
const Useridentity = {
Warehouse_customer_service: '仓库客服',
Headquarters_customer_service: '总部客服',
Headquarters_Manager: '总部客服经理',
};
const TabPermissions = ref(0); //
const TopQuery = ref({
time: [],
});
@ -192,13 +261,13 @@ const dictionaries = {
after_sales_visits: ref([]), //
};
//
const createTabItem = (name, label, state = true) => ({
const createTabItem = (name, label) => ({
name,
label,
state,
request: true,
state: true,
DataList: [],
total: 0,
request: true, //
currentPage: 1,
pageSize: 50,
});
@ -213,10 +282,10 @@ const TabList = ref([
createTabItem(5, '客服介入'),
createTabItem(9, '待审核'),
createTabItem(6, '完结'),
createTabItem(7, '超时未处理'),
createTabItem(10, '申诉列表'),
createTabItem(7, '超时未处理'),
]);
//
const ButtonPermissions = computed(() => {
// TabPermissions
switch (TabPermissions.value) {
@ -228,11 +297,12 @@ const ButtonPermissions = computed(() => {
applyArbitration: false, //
DingTalkNumber: false, //
batchFinish: false, //
appeal: false, //
Batchdetermination: false, //
ManagerConfirmed: false, //
ArbitrationDetermination: false, //
Result_review: false, //
Financial_accounting: false, //
defaultassignments: UserPermissions.value != '仓库客服', //
defaultassignments: UserPermissions.value != Useridentity.Warehouse_customer_service, //
export_Report: true, //
Timed_outexport: false, //
};
@ -240,34 +310,34 @@ const ButtonPermissions = computed(() => {
return {
add: false, //
batchReject: false, //
assignment: UserPermissions.value != '仓库客服', //
applyArbitration: UserPermissions.value == '仓库客服', //
assignment: UserPermissions.value != Useridentity.Warehouse_customer_service, //
applyArbitration: UserPermissions.value == Useridentity.Warehouse_customer_service, //
DingTalkNumber: false, //
batchFinish: false, //
Batchdetermination: UserPermissions.value != '仓库客服', //
appeal: false, //
Batchdetermination: false, //
ManagerConfirmed: false, //
ArbitrationDetermination: false, //
Financial_accounting: false, //
Result_review: UserPermissions.value == Useridentity.Headquarters_customer_service, //
defaultassignments: false, //
export_Report: true, //
export_Report: false, //
Timed_outexport: false, //
};
case 2: //
return {
add: false, //
batchReject: UserPermissions.value == '总部客服', //
batchReject: UserPermissions.value == Useridentity.Headquarters_customer_service, //
assignment: false, //
applyArbitration: false, //
DingTalkNumber: false, //
batchFinish: false, //
appeal: UserPermissions.value == '仓库客服' && AppealStatusT.value, //
Batchdetermination: UserPermissions.value == '仓库客服', //
batchFinish: UserPermissions.value != Useridentity.Warehouse_customer_service, //
Batchdetermination: false, //
ManagerConfirmed: false, //
ArbitrationDetermination: false, //
Result_review: false, //
Financial_accounting: false, //
defaultassignments: false, //
export_Report: true, //
export_Report: false, //
Timed_outexport: false, //
};
case 3: //
@ -277,14 +347,14 @@ const ButtonPermissions = computed(() => {
assignment: false, //
applyArbitration: false, //
batchFinish: false, //
appeal: false, //
Batchdetermination: false, //
DingTalkNumber: false, //
ManagerConfirmed: false, //
ArbitrationDetermination: false, //
Result_review: false, //
Financial_accounting: false, //
defaultassignments: false, //
export_Report: true, //
export_Report: false, //
Timed_outexport: false, //
};
case 4: //
@ -294,14 +364,14 @@ const ButtonPermissions = computed(() => {
assignment: false, //
applyArbitration: false, //
batchFinish: false, //
appeal: false, //
DingTalkNumber: false, //
Batchdetermination: false, //
Batchdetermination: UserPermissions.value == Useridentity.Warehouse_customer_service, //
ManagerConfirmed: false, //
ArbitrationDetermination: false, //
Financial_accounting: false, //
Result_review: false, //
defaultassignments: false, //
export_Report: true, //
export_Report: false, //
Timed_outexport: false, //
};
case 5: //
@ -311,14 +381,14 @@ const ButtonPermissions = computed(() => {
assignment: false, //
applyArbitration: false, //
batchFinish: false, //
appeal: false, //
DingTalkNumber: false, //
Batchdetermination: false, //
ManagerConfirmed: false, //
ArbitrationDetermination: UserPermissions.value != '仓库客服', //
ArbitrationDetermination: UserPermissions.value != Useridentity.Warehouse_customer_service, //
Financial_accounting: false, //
Result_review: false, //
defaultassignments: false, //
export_Report: true, //
export_Report: false, //
Timed_outexport: false, //
};
case 6: //
@ -328,14 +398,14 @@ const ButtonPermissions = computed(() => {
assignment: false, //
applyArbitration: false, //
batchFinish: false, //
DingTalkNumber: UserPermissions.value == '总部客服经理' && !AppealStatusT.value, //, //
appeal: UserPermissions.value == '仓库客服', //
DingTalkNumber: UserPermissions.value != Useridentity.Warehouse_customer_service, //, //
Batchdetermination: false, //
ManagerConfirmed: false, //
ArbitrationDetermination: false, //
Financial_accounting: UserPermissions.value != '仓库客服' && !AppealStatusT.value, //
Financial_accounting: UserPermissions.value != Useridentity.Warehouse_customer_service, //
defaultassignments: false, //
export_Report: true, //
Result_review: false, //
export_Report: false, //
Timed_outexport: false, //
};
case 7: //
@ -345,13 +415,13 @@ const ButtonPermissions = computed(() => {
assignment: false, //
applyArbitration: false, //
batchFinish: false, //
appeal: false, //
Batchdetermination: false, //
ManagerConfirmed: false, //
ArbitrationDetermination: false, //
Financial_accounting: false, //
defaultassignments: false, //
export_Report: false, //
Result_review: false, //
Timed_outexport: true, //
};
case 8: //
@ -361,13 +431,13 @@ const ButtonPermissions = computed(() => {
assignment: false, //
applyArbitration: true, //
batchFinish: false, //
appeal: false, //
Batchdetermination: false, //
ManagerConfirmed: false, //
ArbitrationDetermination: false, //
Financial_accounting: false, //
defaultassignments: false, //
export_Report: false, //
Result_review: false, //
Timed_outexport: false, //
};
case 9: //
@ -376,30 +446,14 @@ const ButtonPermissions = computed(() => {
batchReject: false, //
assignment: false, //
applyArbitration: false, //
batchFinish: UserPermissions.value != '仓库客服', //
appeal: false, //
Batchdetermination: false, //
ManagerConfirmed: UserPermissions.value == '总部客服经理', //
ArbitrationDetermination: false, //
Financial_accounting: false, //
defaultassignments: false, //
export_Report: true, //
Timed_outexport: false, //
};
case 10: //
return {
add: false, //
batchReject: false, //
assignment: false, //
applyArbitration: false, //
batchFinish: UserPermissions.value != '仓库客服', //
appeal: false, //
batchFinish: false, //
Batchdetermination: false, //
ManagerConfirmed: UserPermissions.value == '总部客服经理', //
ManagerConfirmed: UserPermissions.value == Useridentity.Headquarters_Manager, //
ArbitrationDetermination: false, //
Financial_accounting: false, //
defaultassignments: false, //
export_Report: true, //
export_Report: false, //
Result_review: false, //
Timed_outexport: false, //
};
//
@ -410,18 +464,17 @@ const ButtonPermissions = computed(() => {
assignment: false,
applyArbitration: false,
batchFinish: false,
appeal: false,
Batchdetermination: false, //
ManagerConfirmed: false, //
ArbitrationDetermination: false, //
Financial_accounting: false, //
defaultassignments: false, //
export_Report: false, //
Result_review: false, //
Timed_outexport: false, //
};
}
});
const details = reactive({
/** 是否开启搜索 */
search: false,
@ -461,10 +514,9 @@ const details = reactive({
/** 时间选择器数据 */
stockupDate: [],
/** 列表 */
columnList,
columnListPublic: deepClone(columnList), //
/** 列表数据 */
data: [{}],
data: [],
/** 页面loading */
loadingObj: {
/** 列表加载loading */
@ -568,7 +620,7 @@ const currentChange = val => {
//
const searchChangeS = () => {
details.search = false; //
onLoad();
Publicaccessdata();
};
//
const searchReset = () => {
@ -623,7 +675,6 @@ const Roleverification = () => {
console.error('用户信息未找到');
return;
}
let roleNames = [];
try {
roleNames = JSON.parse(userInfo).content.role_name.split(',');
@ -631,17 +682,14 @@ const Roleverification = () => {
console.error('解析用户角色信息出错:', error);
return;
}
//
const matchingItem = dictionaries.after_sales_visits.value.find(item =>
roleNames.includes(item.label)
);
//
if (matchingItem) {
UserPermissions.value = matchingItem.label;
}
// TabList
const updateTabState = (tabName, condition) => {
const tab = TabList.value.find(res => res.name == tabName);
@ -649,7 +697,6 @@ const Roleverification = () => {
tab.state = condition;
}
};
if (UserPermissions.value) {
updateTabState('8', UserPermissions.value == Useridentity.Warehouse_customer_service);
updateTabState('9', UserPermissions.value == Useridentity.Headquarters_Manager);
@ -657,6 +704,7 @@ const Roleverification = () => {
// ()
updateTabState('9', false);
}
console.log('内部执行完毕');
console.log(matchingItem, '匹配出来的角色');
};
@ -666,13 +714,326 @@ const onLoad = () => {};
*页面初始化函数包含字典等必要请求
*/
const PageOnlaod = async () => {
await Dictionaryrequest();
Roleverification();
console.log(Useridentity, 'Useridentity');
PageLoading.value = true;
try {
await Dictionaryrequest(); //
await Roleverification(); //
tabChenge(TabPermissions.value); //
} catch (error) {
console.log(error);
}
PageLoading.value = false;
console.log(Useridentity, 'Useridentity');
console.log('外部执行完毕');
console.log(dictionaries);
};
//
PageOnlaod();
/**
* @description: 点击tabBar时记录当前点击的tab
* @param {number} value 当前点击的tab的value
* @return {void} 无返回值
*/
const tabChenge = async value => {
try {
PageLoading.value = true; // loading
TabPermissions.value = value; //
console.log(tabValue.value, 'tabValue');
await Processingworkorderstatus(value); //
await MenuHeaderProcessing(value); //
//
const dataProcessingMap = {
0: Publicaccessdata,
1: Publicaccessdata,
2: Publicaccessdata,
3: Publicaccessdata,
4: ClaimAmountData,
5: Publicaccessdata,
6: Publicaccessdata,
7: OverdueUnprocessedData,
8: DataAwaitingReplyData,
9: Publicaccessdata,
10: AppealData,
};
//
const processDataFn = dataProcessingMap[value] || Publicaccessdata;
await processDataFn(); // 使await
} catch (error) {
console.error('An error occurred:', error);
} finally {
PageLoading.value = false; // loading
}
};
/**
* @description: 菜单状态处理
* @param {number} value 当前点击的tab的value
* @return {void} 无返回值
*/
const Processingworkorderstatus = value => {
switch (value) {
case 0: //
workOrderStatus.value = UserPermissions.value === Useridentity.Warehouse_customer_service ? 1000 : null;
break;
case 1: //
workOrderStatus.value = UserPermissions.value === Useridentity.Warehouse_customer_service ? 20 : 40;
break;
case 2: //
workOrderStatus.value = 30;
break;
case 3: //
workOrderStatus.value = 10;
break;
case 5: //
workOrderStatus.value = 70;
break;
case 6: //
workOrderStatus.value = 90;
break;
case 9: //
workOrderStatus.value = UserPermissions.value === Useridentity.Headquarters_Manager? 500 : null;
break;
default:
workOrderStatus.value = null;
break;
}
};
//
const PublicDataProcessing = data => {
details.data = data.records;
console.log(TabList.value, 'TabList');
let _Obj = {};
_Obj = TabList.value.find(res => res.name == TabPermissions.value);
console.log(_Obj, '匹配出来的公共菜单');
_Obj.DataList = data.records; //
_Obj.total = data.total; //
_Obj.currentPage = data.current; //
_Obj.pageSize = data.size; //
if (_Obj.DataList?.length) {
_Obj.request = true;
} else {
_Obj.request = false;
}
};
/**
* @description: 菜单表头处理
* @param {number} value 当前点击的tab的value
* @return {void} 无返回值
*/
const MenuHeaderProcessing = value => {
const columnLists = {
columnList, // 0:
columnList1, // 1:
columnList2, // 2:
columnList3, // 3:
columnList4, // 4:
columnList5, // 5:
columnList6, // 6:
columnList7, // 7:
columnList8, // 8:
columnList9, // 9:
columnList10, // 10:
};
const keys = Object.keys(columnLists);
const selectedKey = value >= 0 && value < keys.length ? keys[value] : 'columnList';
// 使
details.columnListPublic = deepClone(columnLists[selectedKey]);
// columnListName.value
columnListName.value = selectedKey;
console.log(details.columnListPublic, 'details.columnListPublic');
console.log(columnListName.value, 'columnListName.value');
};
//
const DataStateProcessing = data => {
console.log(data, '状态处理');
console.log(dictionaries, 'dictionaries.pc_work_order.value');
//
const findLabelByValue = (collection, value) => {
const entry = collection.find(res => res.value === value);
return entry ? entry.label : '/';
};
//
if (data.records?.length) {
data.records.forEach(item => {
//
item.workOrderTypeNameS = findLabelByValue(
dictionaries.pc_work_order.value,
item.workOrderType
);
//
item.discoveryNodeNameS = findLabelByValue(
dictionaries.pc_discovery_node.value,
item.discoveryNode
);
//
item.workOrderStatusNameS = findLabelByValue(
dictionaries.work_order_status.value,
item.workOrderStatus
);
});
}
};
/**
* @description: 对数据进行处理
* @return {void} 无返回值
*/
const DataAndStateProcessing = data => {
PublicDataProcessing(data); //
DataStateProcessing(data); //
};
/**
* @description: 待回复菜单数据请求
* @return {Object} 包含待回复菜单数据的对象
*/
const DataAwaitingReplyData = async () => {
try {
let _submitData = {
current: details.page.currentPage, //
size: details.page.pageSize, //
};
let _res = await $_getProcessor(_submitData);
console.log(_res, '待回复菜单数据请求');
const { code, data } = _res.data;
console.log(data, 'data');
console.log(code, 'code');
if (code !== 200) {
return;
}
DataAndStateProcessing(data); //
} catch (error) {
console.log(error);
} finally {
}
};
/**
* @description: 理赔金额未出菜单数据请求
* @return {Object} 包含待回复菜单数据的对象
*/
const ClaimAmountData = async () => {
try {
let _submitData = {
current: details.page.currentPage, //
size: details.page.pageSize, //
};
let _res = await $_listSettlement(_submitData);
console.log(_res, '理赔金额未出菜单数据请求');
const { code, data } = _res.data;
console.log(data, 'data');
console.log(code, 'code');
if (code !== 200) {
return;
}
DataAndStateProcessing(data); //
} catch (error) {
console.log(error);
} finally {
}
};
/**
* @description: 申诉菜单数据请求
* @return {Object} 包含申诉菜单数据的对象
*/
const AppealData = async () => {
try {
let _submitData = {
current: details.page.currentPage, //
size: details.page.pageSize, //
};
let _res = await $_listAppeal(_submitData);
console.log(_res, '申诉列表菜单数据请求');
const { code, data } = _res.data;
console.log(data, 'data');
console.log(code, 'code');
if (code !== 200) {
return;
}
DataAndStateProcessing(data); //
} catch (error) {
console.log(error);
} finally {
}
};
/**
* @description: 超时未处理菜单数据请求
* @return {Object} 包含超时未处理菜单数据的对象
*/
const OverdueUnprocessedData = async () => {
try {
let _submitData = {
current: details.page.currentPage, //
size: details.page.pageSize, //
};
let _res = await $_listOwn(_submitData);
console.log(_res, '超时未处理表菜单数据请求');
const { code, data } = _res.data;
console.log(data, 'data');
console.log(code, 'code');
if (code !== 200) {
return;
}
DataAndStateProcessing(data); //
} catch (error) {
console.log(error);
} finally {
}
};
/**
* @description: 公共数据请求包含全部待处理处理中处理完毕客服介入待审核完结
*/
const Publicaccessdata = async () => {
try {
let _submitData = {
workOrderStatus: workOrderStatus.value, //
current: details.page.currentPage, //
size: details.page.pageSize, //
};
let _res = await $_getList(_submitData);
const { code, data } = _res.data;
console.log(data, 'data');
console.log(code, 'code');
if (code !== 200) {
return;
}
DataAndStateProcessing(data); //
console.log(_res, '公共数据菜单=:' + TabPermissions.value);
} catch (error) {
console.log(error);
} finally {
}
};
//
const InformationViewing = val => {
console.log(val, '当前行数据');
const workOrderInfoPath = '/aftersales/aftersalesWorkOrderInfo';
const queryParams = {
id: val.row.workOrderId,
name: `${val.row.workOrderNumber}-信息查看`,
warehouseId: val.row.warehouseId,
workOrderNumber: val.row.workOrderNumber,
businessId: val.row.businessId,
RouteIndexs: TabPermissions.value,
workOrderStatus: val.row.workOrderStatus,
};
$router.push({ path: workOrderInfoPath, query: { ...queryParams, id: val.row.id } });
};
</script>
<style scoped lang="scss">

112
src/views/basicdata/brand/basicClient.vue

@ -306,6 +306,21 @@
/>
</el-select>
</el-form-item>
<el-form-item label="结算对象类型" prop="cleanObjType">
<el-select
v-model="form.cleanObjType"
class="m-2"
placeholder="请选择客户端类型"
style="width: 100%"
>
<el-option
v-for="item in Settlementobjecttype"
:key="item.dictKey"
:label="item.dictValue"
:value="item.dictKey"
/>
</el-select>
</el-form-item>
<el-form-item label="服务类型" prop="typeServiceList">
<el-select
v-model="form.typeServiceList"
@ -595,6 +610,20 @@ export default {
excelBox: false,
Fileverification: false,
FileverificationLoadong: false,
Settlementobjecttype: [
{
dictValue: '工厂',
dictKey: '1',
},
{
dictValue: '商场',
dictKey: '2',
},
{
dictValue: '个人',
dictKey: '3',
},
],
excelOption: {
submitBtn: false,
emptyBtn: false,
@ -663,6 +692,30 @@ export default {
sortable: true,
head: false,
},
{
prop: 'cleanObjTypeName',
label: '结算对象类型',
type: 3,
values: '',
width: '130',
checkarr: [
{
label: '工厂',
value: '1',
},
{
label: '商场',
value: '2',
},
{
label: '个人',
value: '3',
},
],
fixed: false,
sortable: true,
head: false,
},
{
prop: 'brandName',
label: '品牌',
@ -748,7 +801,7 @@ export default {
{
prop: 'bladeRegionProvinceId',
label: '地址',
type:1,
type: 1,
values: '',
width: '200',
checkarr: [],
@ -912,6 +965,7 @@ export default {
// { min: 3, max: 5, message: ' 3 5 ', trigger: ['blur', 'change'] }
],
clientType: [{ required: true, message: '请选择客户类型', trigger: 'change' }],
cleanObjType: [{ required: true, message: '请选择结算对象类型', trigger: 'change' }],
typeServiceList: [{ required: true, message: '请选择服务类型', trigger: 'change' }],
linkman: [{ required: true, message: '请填写联系人', trigger: ['blur', 'change'] }],
detailedly: [{ required: true, message: '请填写详细地址', trigger: ['blur', 'change'] }],
@ -1067,14 +1121,19 @@ export default {
console.log(index, row);
},
selectsc(index, row) {
console.log('123123123', index, row);
if (row.prop === 'clientTypeName') {
this.query['clientType'] = index;
} else {
this.query[row.prop] = index;
}
this.onLoad(this.page);
},
console.log('123123123', index, row);
// 'Name' row.prop
const nameIndex = row.prop.indexOf('Name');
if (nameIndex !== -1) {
// 'Name'
const key = row.prop.substring(0, nameIndex);
this.query[key] = index;
} else {
// 'Name'使 prop
this.query[row.prop] = index;
}
this.onLoad(this.page);
},
timesc(index, row) {
console.log(index, row);
if (!!index) {
@ -1394,9 +1453,19 @@ export default {
handleClearTableQuery(this.columnList);
this.onLoad(this.page);
},
handleSubmit(from) {
if(!this.form.typeServiceList.includes('3')){
delete this.form.businessType
async handleSubmit(from) {
try {
//
let isValid = await this.$refs[formRef].validate();
if (!isValid) {
//
return;
}
} catch (error) {
}
if (!this.form.typeServiceList.includes('3')) {
delete this.form.businessType;
}
console.log('上传的集合。。', JSON.parse(JSON.stringify(this.fileList)));
if (this.title == '编辑' && this.bianji == false) {
@ -1422,7 +1491,6 @@ export default {
// return this.$message.warning('');
}
}
if (!this.form.id) {
console.log('添加提交的数据:', this.form);
this.$refs[from].validate(async valid => {
@ -1470,10 +1538,9 @@ export default {
this.$refs[from].validate(async valid => {
if (valid) {
try {
this.loadingObj.submitLoading = true;
console.log('修改提交的数据:', this.form);
this.loadingObj.submitLoading = true;
console.log('修改提交的数据:', this.form);
// this.form.typeService = !!this.form.typeService ? parseInt(this.form.typeService) : undefined;
this.form.bladeRegionCityId = this.form.bladeRegionProvinceId[1];
this.form.bladeRegionAreaId = this.form.bladeRegionProvinceId[2];
@ -1547,7 +1614,7 @@ export default {
this.viewClientEntd = true;
this.CustomerEntd = true;
getDetail(row.id).then(res => {
console.log(res.data.data,'res.data.data');
console.log(res.data.data, 'res.data.data');
this.form = res.data.data;
if (this.form.detailedly == '0' || this.form.detailedly == '-1') {
@ -1564,7 +1631,7 @@ export default {
if (!!bus) {
this.form.typeServiceList = bus;
}
let a = [];
if (!!this.form.bladeRegionProvinceId) {
if (res.data.data?.bladeRegionProvinceId) {
@ -1599,7 +1666,6 @@ export default {
];
}
}
});
},
handleView(row) {
@ -1772,8 +1838,14 @@ export default {
.then(res => {
const data = res.data.data;
console.log(data);
data.records.forEach(i => {
if(i.cleanObjType =='1'){
i.cleanObjTypeName = '工厂';
}else if(i.cleanObjType =='2'){
i.cleanObjTypeName = '商场';
}else if(i.cleanObjType =='3'){
i.cleanObjTypeName = '个人';
}
let ke = this.clientType.find(kh => parseInt(kh.dictKey) == parseInt(i.clientType));
// console.log("<><><>",ke);
if (!!ke) {

34
src/views/distribution/deliverylist/distributionDeliveryListmar.vue

@ -124,6 +124,9 @@
<el-button type="primary" icon="el-icon-plus" @click="printBatchOrder"
>批量打印</el-button
>
<!-- <el-button type="primary" icon="el-icon-plus" @click="printBatchOrderA"
>批量打印测试</el-button
> -->
<!-- <el-button type="danger" icon="el-icon-delete" @click="handleDelete" plain> </el-button>-->
<el-button type="danger" icon="el-icon-download" @click="handleExportInfo" plain
>导出
@ -193,6 +196,10 @@
</el-pagination>
</div>
</div>
<!-- <el-dialog v-model="dydialogVisible" title="二维码" width="50%">
<distributionDeliveryListmar></distributionDeliveryListmar>
</el-dialog> -->
<!-- 打印模块 -->
<!-- <el-dialog title="二维码" :visible.sync="isShow" width="70%" v-model="isShow">
<div>
@ -232,6 +239,7 @@ import {
getDeliveryListExport,
} from '@/api/distribution/distributionDeliveryList';
import option from '@/option/distribution/distributionDeliveryList';
// import distributionDeliveryListmar from '@/components/distributionDeliveryListmar/distributionDeliveryListmar.vue';
import { mapGetters } from 'vuex';
import { getDictionaryBiz } from '@/api/system/dict';
import { addIncrement } from '@/api/distribution/distributionStockArticle';
@ -249,9 +257,13 @@ import {
} from '@/utils/util';
export default {
// components: {
// distributionDeliveryListmar, //
// },
data() {
return {
height: 0,
dydialogVisible: false,
//
title: '',
//
@ -697,18 +709,16 @@ export default {
this.title = '查看';
this.view = true;
this.box = true;
if(row.id){
if (row.id) {
getDetail(row.id).then(res => {
this.form = res.data.data;
});
}else{
ElMessage({
message: '数据错误,刷新页面重新尝试',
type: 'warning',
})
this.form = res.data.data;
});
} else {
ElMessage({
message: '数据错误,刷新页面重新尝试',
type: 'warning',
});
}
},
// handleViewBlank (row) {
// this.$router.push({
@ -829,7 +839,9 @@ export default {
// this.form = res.data.data;
// });
},
printBatchOrderA() {
this.dydialogVisible = true;
},
/**
* 批量打印
*/

117
src/views/finance/CustomerSettlement.vue

@ -4,8 +4,82 @@
<!-- 搜索模块 -->
<div v-h5uShow="!search">
<!-- 查询模块 -->
<el-form :inline="true" :model="query" class="header_search">
<el-form :inline="true" :model="details.query" class="header_search">
<!-- 查询按钮 -->
<el-form-item label="收货单位">
<el-input v-model="details.query.consignee" clearable placeholder="请输入收货单位" />
</el-form-item>
<el-form-item label="目的仓">
<el-select
v-model="details.query.destinationWarehouseName"
filterable
clearable
placeholder="请选择目的仓"
style="width: 240px"
>
<el-option
v-for="item in warehouseList"
:key="item.value"
:label="item.label"
:value="item.label"
/>
</el-select>
</el-form-item>
<el-form-item label="结算状态">
<el-select
v-model="details.query.balanceStatus"
placeholder="请选择"
style="width: 240px"
clearable
>
<el-option label="未结算" value="0" />
<el-option label="部分结算" value="1" />
<el-option label="已结算" value="2" />
</el-select>
</el-form-item>
<el-form-item label="对账确认时间">
<el-date-picker
v-model="details.query.ReconciliationconfirmationTime"
type="datetimerange"
unlink-panels
range-separator="至"
start-placeholder="开始时间"
end-placeholder="结束时间"
:shortcuts="shortcuts"
:default-time="defaultTime2"
value-format="YYYY-MM-DD HH:mm:ss"
format="YYYY/MM/DD HH:mm:ss"
/>
</el-form-item>
<el-form-item label="结算时间">
<el-date-picker
v-model="details.query.SettlementTime"
type="datetimerange"
unlink-panels
range-separator="至"
start-placeholder="开始时间"
end-placeholder="结束时间"
:shortcuts="shortcuts"
:default-time="defaultTime2"
value-format="YYYY-MM-DD HH:mm:ss"
format="YYYY/MM/DD HH:mm:ss"
/>
</el-form-item>
<el-form-item label="异常时间">
<el-date-picker
v-model="query.abnormalTime"
type="datetimerange"
unlink-panels
range-separator="至"
start-placeholder="开始时间"
end-placeholder="结束时间"
:shortcuts="shortcuts"
:default-time="defaultTime2"
value-format="YYYY-MM-DD HH:mm:ss"
format="YYYY/MM/DD HH:mm:ss"
/>
</el-form-item>
<el-form-item>
<el-button type="primary" icon="el-icon-search" @click="searchChange"> </el-button>
<el-button icon="el-icon-delete" @click="searchReset"> </el-button>
@ -76,7 +150,6 @@
<script setup lang="ts">
import { ref, reactive, toRefs, computed, onMounted, nextTick } from 'vue';
import functions from '@/utils/functions.js';
import dayjs from 'dayjs';
import { mapGetters } from 'vuex';
/** 获取字典 */
@ -99,16 +172,27 @@ import { columnList } from '@/option/finance/CustomerSettlement';
import { useRouter } from 'vue-router';
import { deepClone } from '@/utils/util';
import { ElMessage, ElMessageBox } from 'element-plus';
import { $_getMyWarehouseList } from '@/api/reportforms/index.js';
//
const $router = useRouter();
const warehouseList = ref([]);
$_getMyWarehouseList().then(res => {
console.log(res, '仓库列表');
if (res.data.data.length)
res.data.data.forEach(item => {
warehouseList.value.push({
value: item.name,
label: item.name,
});
});
});
const details = reactive<any>({
/** 是否开启搜索 */
search: true,
/** 表格搜索条件 */
query: {},
/** 时间快捷选择设置 */
defaultTime2: [new Date(2000, 1, 1, 0, 0, 0), new Date(2000, 2, 1, 23, 59, 59)], // '12:00:00', '08:00:00'
shortcuts: [
{
text: '最近一周',
@ -165,7 +249,7 @@ const details = reactive<any>({
const tableNodeRef = ref();
const { search, query, shortcuts, selectionList, drawerShow, page } = toRefs(details);
const { search, query, shortcuts, selectionList, drawerShow, page, defaultTime2 } = toRefs(details);
/** vuex */
const permission = computed(() => mapGetters(['permission', 'tagWel', 'tagList']));
@ -184,9 +268,9 @@ const onLoad = async (params = {}) => {
try {
// loading
details.loadingObj.list = true;
const submitData = { ...details.query, ...params, ...details.page };
const queryCopy = { ...details.query };
await TimeProcessing(queryCopy);
const submitData = { ...queryCopy, ...params, ...details.page };
//
const res = await postPageList(submitData);
console.log('res :>> ', res);
@ -204,6 +288,23 @@ const onLoad = async (params = {}) => {
}
};
const processTimeSection = (query, sectionKey, startKey, endKey) => {
if (query[sectionKey]?.length) {
query[startKey] = query[sectionKey][0];
query[endKey] = query[sectionKey][1];
delete query[sectionKey];
} else {
delete query[startKey];
delete query[endKey];
}
};
const TimeProcessing = query => {
console.log(query, 'query');
processTimeSection(query, 'ReconciliationconfirmationTime', 'createTimeStart', 'createTimeEnd');
processTimeSection(query, 'SettlementTime', 'balanceTimeStart', 'balanceTimeEnd');
processTimeSection(query, 'abnormalTime', 'abnormalTimeStart', 'abnormalTimeEnd');
};
const initOnLoad = (params = {}) => {
details.page.pageNum = 1;
details.page.total = 0;

209
src/views/finance/MerchantDepositSlip.vue

@ -4,7 +4,51 @@
<!-- 搜索模块 -->
<div v-h5uShow="!search">
<!-- 查询模块 -->
<el-form :inline="true" :model="details.query1" class="header_search">
<el-form :inline="true" :model="details.query" class="header_search">
<el-form-item label="收货单位">
<el-input v-model="details.query.consignee" clearable placeholder="请输入收货单位" />
</el-form-item>
<el-form-item label="收货仓库">
<el-select
v-model="details.query.destinationWarehouseName"
filterable
clearable
placeholder="请选择仓库搜索"
style="width: 240px"
>
<el-option
v-for="item in warehouseList"
:key="item.value"
:label="item.label"
:value="item.label"
/>
</el-select>
</el-form-item>
<!-- <el-form-item label="是否关联售后">
<el-select
v-model="details.query.syncFeeSstatus"
placeholder="请选择"
style="width: 240px"
clearable
>
<el-option label="是" value="1" />
<el-option label="否" value="0" />
</el-select>
</el-form-item> -->
<el-form-item label="对账单创建时间">
<el-date-picker
v-model="details.query.calculateTimeSection"
type="datetimerange"
unlink-panels
range-separator="至"
start-placeholder="开始时间"
end-placeholder="结束时间"
:shortcuts="shortcuts"
:default-time="defaultTime2"
value-format="YYYY-MM-DD HH:mm:ss"
format="YYYY/MM/DD HH:mm:ss"
/>
</el-form-item>
<!-- 查询按钮 -->
<el-form-item>
<el-button type="primary" icon="el-icon-search" @click="searchChange">
@ -45,14 +89,9 @@
>
<template #default="slotProps">
<template v-if="slotProps.scope.column.label === '操作'">
<el-text @click="() => ViewTransactionInformation(slotProps.scope)"> 异动信息 </el-text>
<el-text @click="() => ViewTransactionInformation(slotProps.scope)">
异动信息
</el-text>
<el-text @click="() => ViewOrderList(slotProps.scope)">
订单详情
</el-text>
<el-text @click="() => ViewOrderList(slotProps.scope)"> 订单详情 </el-text>
</template>
</template>
</tablecmt>
@ -86,9 +125,7 @@
:loading="details.loadingObj.orderList"
>
<template #default="slotProps">
<el-text @click="()=> handleRemoveOrder(slotProps.scope)">
</el-text>
<el-text @click="() => handleRemoveOrder(slotProps.scope)"> </el-text>
</template>
</tablecmt>
</el-dialog>
@ -103,18 +140,17 @@
<script setup lang="ts">
import { ref, reactive, toRefs, computed, onMounted, nextTick } from 'vue';
import functions from '@/utils/functions.js';
import dayjs from 'dayjs';
import { mapGetters } from 'vuex';
/** 获取字典 */
import { getDictionaryBiz } from '@/api/system/dict';
import {
import {
postPageReconciliationList,
postCheckBalance,
postFindOrderDetail,
postCancleOrderInfoBindReconcilitionOrder,
postReconciliationListExport
} from '@/api/finance/MerchantDepositSlip';
postReconciliationListExport,
} from '@/api/finance/MerchantDepositSlip';
import {
downloadXls,
setNodeHeight,
@ -128,16 +164,27 @@ import { columnList, orderColumnList } from '@/option/finance/MerchantDepositSli
import { useRouter } from 'vue-router';
import { deepClone } from '@/utils/util';
import { ElMessage, ElMessageBox } from 'element-plus';
import { $_getMyWarehouseList } from '@/api/reportforms/index.js';
//
const $router = useRouter();
const warehouseList=ref([])
$_getMyWarehouseList().then(res => {
console.log(res, '仓库列表');
if (res.data.data.length)
res.data.data.forEach(item => {
warehouseList.value.push({
value: item.name,
label: item.name,
});
});
});
const details = reactive<any>({
/** 是否开启搜索 */
search: true,
/** 表格搜索条件 */
query: {},
/** 时间快捷选择设置 */
defaultTime2: [new Date(2000, 1, 1, 0, 0, 0), new Date(2000, 2, 1, 23, 59, 59)], // '12:00:00', '08:00:00'
shortcuts: [
{
text: '最近一周',
@ -176,7 +223,7 @@ const details = reactive<any>({
/** 列表加载loading */
list: false,
pageLoading: false,
orderList: false
orderList: false,
},
/** 列表复选框选中的数据 */
selectionList: [],
@ -190,20 +237,20 @@ const details = reactive<any>({
},
form: {},
popUpShow: {
orderVisted: false
orderVisted: false,
},
orderInfo: {
reconciliationOrderId: '',
data: [],
query: {},
columnList: deepClone(orderColumnList)
}
columnList: deepClone(orderColumnList),
},
});
const tableNodeRef1 = ref();
const orderTableNodeRef = ref();
const { search, shortcuts, selectionList, drawerShow, page } = toRefs(details);
const { search, shortcuts, selectionList, drawerShow, page, defaultTime2 } = toRefs(details);
/** vuex */
const permission = computed(() => mapGetters(['permission', 'tagWel', 'tagList']));
@ -212,7 +259,7 @@ console.log('permission :>> ', permission);
onMounted(async () => {
await nextTick();
setNodeHeight(tableNodeRef1.value.$el , '', true);
setNodeHeight(tableNodeRef1.value.$el, '', true);
});
/** 请求页面数据 */
@ -220,9 +267,9 @@ const onLoad = async (params = {}) => {
try {
// loading
details.loadingObj.list = true;
const submitData = { ...details.query, ...params, ...details.page };
const queryCopy = { ...details.query };
await TimeProcessing(queryCopy);
const submitData = { ...queryCopy, ...params, ...details.page };
//
const res = await postPageReconciliationList(submitData);
console.log('res :>> ', res);
@ -230,10 +277,7 @@ const onLoad = async (params = {}) => {
if (code !== 200) return;
details.data = data.records;
details.page.total = data.total;
handleTranslationDataSeclect(
details.data,
details.columnList
);
handleTranslationDataSeclect(details.data, details.columnList);
return res.data;
} catch (error) {
@ -243,6 +287,21 @@ const onLoad = async (params = {}) => {
}
};
const processTimeSection = (query, sectionKey, startKey, endKey) => {
if (query[sectionKey]?.length) {
query[startKey] = query[sectionKey][0];
query[endKey] = query[sectionKey][1];
delete query[sectionKey];
} else {
delete query[startKey];
delete query[endKey];
}
};
const TimeProcessing = query => {
console.log(query,'query');
processTimeSection(query, 'calculateTimeSection', 'openTimeStart', 'openTimeEnd');
};
const initOnLoad = (params = {}) => {
details.page.pageNum = 1;
details.page.total = 0;
@ -274,7 +333,7 @@ const showdrawer = (_flag?: boolean) => {
const searchHide = () => {
details.search = !details.search;
const node = tableNodeRef1.value.$el;
const node = tableNodeRef1.value.$el;
setNodeHeight(node, '', true);
};
@ -369,23 +428,23 @@ const handleExport = () => {
confirmButtonText: '确定',
cancelButtonText: '取消',
type: 'warning',
}).then(async() => {
}).then(async () => {
try {
details.loadingObj.pageLoading = true
details.loadingObj.pageLoading = true;
const submitData= {...details.query}
const submitData = { ...details.query };
const res = await postReconciliationListExport(submitData)
const {status, data} = res
if (status !== 200) return
downloadXls(data, '对账单数据.xlsx')
const res = await postReconciliationListExport(submitData);
const { status, data } = res;
if (status !== 200) return;
downloadXls(data, '对账单数据.xlsx');
ElMessage.success('导出成功!');
} catch (error) {
console.log('error :>> ', error);
}finally{
details.loadingObj.pageLoading = false
} finally {
details.loadingObj.pageLoading = false;
}
});
};
@ -401,61 +460,63 @@ const ViewTransactionInformation = ({ row }) => {
};
/** 查看订单列表 */
const ViewOrderList =async ({row})=>{
const ViewOrderList = async ({ row }) => {
try {
details.loadingObj.pageLoading = true
details.loadingObj.pageLoading = true;
const res = await postFindOrderDetail({ reconciliationOrderId: row.id })
const res = await postFindOrderDetail({ reconciliationOrderId: row.id });
const {code, data} = res.data
if (code !== 200) return
details.orderInfo.reconciliationOrderId = row.id
details.orderInfo.data = data || []
details.popUpShow.orderVisted = true
const { code, data } = res.data;
if (code !== 200) return;
details.orderInfo.reconciliationOrderId = row.id;
details.orderInfo.data = data || [];
details.popUpShow.orderVisted = true;
await nextTick()
setNodeHeight(orderTableNodeRef.value.$el, '60vh')
await nextTick();
setNodeHeight(orderTableNodeRef.value.$el, '60vh');
} catch (error) {
console.log('error :>> ', error);
}finally{
details.loadingObj.pageLoading = false
} finally {
details.loadingObj.pageLoading = false;
}
}
};
/** 移除订单 */
const handleRemoveOrder = ({row}) => {
const handleRemoveOrder = ({ row }) => {
ElMessageBox.confirm('是否确认移除?', '提示', {
confirmButtonText: '确定',
cancelButtonText: '取消',
type: 'warning',
}).then(async() => {
}).then(async () => {
try {
details.loadingObj.orderList = true
details.loadingObj.orderList = true;
const submitData= {reconciliationOrderId: details.orderInfo.reconciliationOrderId, orderInfoIds: [row.orderInfoId]}
const res = await postCancleOrderInfoBindReconcilitionOrder(submitData)
const {code, msg} = res.data
if (code !== 200) return
ElMessage.success(msg)
onLoad()
const resp = await postFindOrderDetail({ reconciliationOrderId: details.orderInfo.reconciliationOrderId })
const submitData = {
reconciliationOrderId: details.orderInfo.reconciliationOrderId,
orderInfoIds: [row.orderInfoId],
};
const {code: code1,data: data1} = resp.data
if (code1 !== 200) return
details.orderInfo.data = data1 || []
if (details.orderInfo.data.length === 0) details.popUpShow.orderVisted = false
const res = await postCancleOrderInfoBindReconcilitionOrder(submitData);
const { code, msg } = res.data;
if (code !== 200) return;
ElMessage.success(msg);
onLoad();
const resp = await postFindOrderDetail({
reconciliationOrderId: details.orderInfo.reconciliationOrderId,
});
const { code: code1, data: data1 } = resp.data;
if (code1 !== 200) return;
details.orderInfo.data = data1 || [];
if (details.orderInfo.data.length === 0) details.popUpShow.orderVisted = false;
} catch (error) {
console.log('error :>> ', error);
} finally {
details.loadingObj.orderList = false
details.loadingObj.orderList = false;
}
});
}
};
</script>
<style scoped lang="scss">

249
src/views/finance/ReconciliationDepositSlip.vue

@ -5,12 +5,82 @@
<!-- toB -->
<el-tab-pane
v-for="(item, index) in details.pageInfo"
:name="item.name" :label="item.title">
:name="item.name"
:label="item.title"
>
<!-- 搜索模块 -->
<div v-h5uShow="!search">
<!-- 查询模块 -->
<el-form :inline="true" :model="item.query" class="header_search">
<!-- 查询按钮 -->
<el-form-item label="收货单位">
<el-input v-model="item.query.consignee" clearable placeholder="请输入客户名称" />
</el-form-item>
<el-form-item label="是否计算价格">
<el-select
v-model="item.query.syncFeeSstatus"
placeholder="请选择"
style="width: 240px"
clearable
>
<el-option label="未计算" value="0" />
<el-option label="已计算" value="1" />
</el-select>
</el-form-item>
<el-form-item label="签收状态">
<el-select
v-model="item.query.signStatus"
placeholder="请选择"
style="width: 240px"
clearable
>
<el-option label="已签收" value="2" />
<el-option label="未签收" value="0" />
<el-option label="部分签收" value="1" />
</el-select>
</el-form-item>
<el-form-item label="计算时间">
<el-date-picker
v-model="item.query.calculateTimeSection"
type="datetimerange"
unlink-panels
range-separator="至"
start-placeholder="开始时间"
end-placeholder="结束时间"
:shortcuts="shortcuts"
:default-time="defaultTime2"
value-format="YYYY-MM-DD HH:mm:ss"
format="YYYY/MM/DD HH:mm:ss"
/>
</el-form-item>
<el-form-item label="签收时间">
<el-date-picker
v-model="item.query.signTimeSection"
type="datetimerange"
unlink-panels
range-separator="至"
start-placeholder="开始日期"
end-placeholder="结束日期"
:shortcuts="shortcuts"
:default-time="defaultTime2"
value-format="YYYY-MM-DD HH:mm:ss"
format="YYYY/MM/DD HH:mm:ss"
/>
</el-form-item>
<el-form-item label="计算价格时间">
<el-date-picker
v-model="item.query.calculatePriceTimeSection"
type="datetimerange"
unlink-panels
range-separator="至"
start-placeholder="开始日期"
end-placeholder="结束日期"
:default-time="defaultTime2"
:shortcuts="shortcuts"
value-format="YYYY-MM-DD HH:mm:ss"
format="YYYY/MM/DD HH:mm:ss"
/></el-form-item>
<el-form-item>
<el-button type="primary" icon="el-icon-search" @click="searchChange">
@ -43,9 +113,9 @@
:columnList="item.columnList"
:tableData="details.data"
:loading="details.loadingObj.list"
@inputTxt="(val, col)=> inputsc(val, col, item)"
@inputTxt="(val, col) => inputsc(val, col, item)"
@timeCheck="timesc"
@selectCheck="(val, col)=> selectsc(val, col, item)"
@selectCheck="(val, col) => selectsc(val, col, item)"
@selection="selectionChange"
>
<template #default="slotProps">
@ -74,7 +144,7 @@
</div>
<!-- 列表配置显示 -->
<edittablehead
@closce="(flag)=> showdrawer(item, flag)"
@closce="flag => showdrawer(item, flag)"
:drawerShow="item.drawerShow"
v-model="item.columnList"
></edittablehead>
@ -118,10 +188,7 @@
</div>
</template>
<tablecmt
:columnList="details.confirmColumnList"
:tableData="details.selectionList"
>
<tablecmt :columnList="details.confirmColumnList" :tableData="details.selectionList">
</tablecmt>
<div class="flex-c-c dialog-footer">
@ -142,7 +209,6 @@
</el-dialog>
</div>
</basic-container>
</template>
<script setup lang="ts">
@ -152,7 +218,13 @@ import dayjs from 'dayjs';
import { mapGetters } from 'vuex';
/** 获取字典 */
import { getDictionaryBiz } from '@/api/system/dict';
import { postPageList, postCheckBalance, postReal,postOrderInfoListExport, postCreateReconciliationOrder } from '@/api/finance/ReconciliationDepositSlip';
import {
postPageList,
postCheckBalance,
postReal,
postOrderInfoListExport,
postCreateReconciliationOrder,
} from '@/api/finance/ReconciliationDepositSlip';
import {
downloadXls,
setNodeHeight,
@ -161,9 +233,9 @@ import {
handleInputQuery,
handleSelectQuery,
handleTranslationDataSeclect,
getObjType
getObjType,
} from '@/utils/util';
import { columnList, confirmColumnList } from '@/option/finance/ReconciliationDepositSlip';
import { columnList, confirmColumnList,columnListB } from '@/option/finance/ReconciliationDepositSlip';
import { useRouter } from 'vue-router';
import { deepClone } from '@/utils/util';
import { ElMessage, ElMessageBox } from 'element-plus';
@ -182,15 +254,16 @@ const details = reactive<any>({
columnList: deepClone(columnList),
//
query: {},
name: 1
name: 1,
},
{
title: 'toC订单对账',
columnList: deepClone(columnList),
columnList: deepClone(columnListB),
query: {},
name: 2
}
name: 2,
},
],
defaultTime2: [new Date(2000, 1, 1, 0, 0, 0), new Date(2000, 2, 1, 23, 59, 59)], // '12:00:00', '08:00:00'
/** 时间快捷选择设置 */
shortcuts: [
{
@ -234,7 +307,7 @@ const details = reactive<any>({
/** 开标签 */
confirmVisited: false,
},
/** 弹出层显示 */
/** 弹出层显示 */
popUpShow: {
/** 新增标签 */
confirmVisited: false,
@ -256,7 +329,7 @@ const details = reactive<any>({
const tableNodeRef = ref();
const { search, shortcuts, selectionList, drawerShow, page } = toRefs(details);
const { search, shortcuts, selectionList, drawerShow, page, defaultTime2 } = toRefs(details);
/** vuex */
const permission = computed(() => mapGetters(['permission', 'tagWel', 'tagList']));
@ -276,9 +349,15 @@ const onLoad = async () => {
// loading
details.loadingObj.list = true;
const {query, columnList} = ( details.pageStatus === 1 ?details.pageInfo[0]: details.pageInfo[1])
const { query, columnList } =
details.pageStatus === 1 ? details.pageInfo[0] : details.pageInfo[1];
// query
const queryCopy = { ...query };
await TimeProcessing(queryCopy);
const submitData = { ...queryCopy, ...details.page };
const submitData = { query, ...details.page };
// const submitData = { ...query, ...details.page };
// listType 1 -- toB ; 2 -- toC
submitData.listType = details.pageStatus;
@ -290,10 +369,7 @@ const onLoad = async () => {
details.data = data.records;
details.page.total = data.total;
console.log('columnList :>> ', columnList);
handleTranslationDataSeclect(
details.data,
columnList
);
handleTranslationDataSeclect(details.data, columnList);
return res.data;
} catch (error) {
@ -303,6 +379,22 @@ const onLoad = async () => {
}
};
const processTimeSection = (query, sectionKey, startKey, endKey) => {
if (query[sectionKey]?.length) {
query[startKey] = query[sectionKey][0];
query[endKey] = query[sectionKey][1];
delete query[sectionKey];
} else {
delete query[startKey];
delete query[endKey];
}
};
const TimeProcessing = query => {
processTimeSection(query, 'calculateTimeSection', 'syncFeeDateStart', 'syncFeeDateEnd');
processTimeSection(query, 'signTimeSection', 'signTimeStart', 'signTimeEnd');
processTimeSection(query, 'calculatePriceTimeSection', 'openTimeStart', 'openTimeEnd');
};
const handleData = (key, res) => {
const { code, data } = res.data;
if (code !== 200) return;
@ -334,31 +426,28 @@ const handleData = (key, res) => {
}
};
const initData = async ()=>{
await Promise.all([
const initData = async () => {
await Promise.all([
//
getDictionaryBiz('distribution_type').then(res => handleData('订单类型', res)),
// getDictionaryBiz('distribution_type').then(res => handleData('', res)),
//
getDictionaryBiz('open_order_pay_type').then(res => handleData('支付方式', res)),
getDictionaryBiz('open_order_pay_type').then(res => handleData('支付方式', res)),
//
getDictionaryBiz('open_order_pay_way').then(res => handleData('付款方式', res)),
initOnLoad()
])
initOnLoad(),
]);
await nextTick();
const {columnList} = ( details.pageStatus === 1 ?details.pageInfo[0]: details.pageInfo[1])
const { columnList } = details.pageStatus === 1 ? details.pageInfo[0] : details.pageInfo[1];
handleTranslationDataSeclect(
details.data,
columnList
);
}
handleTranslationDataSeclect(details.data, columnList);
};
/** 初始化请求 */
const initOnLoad = () => {
details.page.pageNum = 1;
details.page.total = 0;
return onLoad()
return onLoad();
};
initData();
@ -371,14 +460,16 @@ const searchChange = () => {
/** 清空表单 */
const searchReset = () => {
// details.query = {};
details.pageStatus === 1 ? (details.query1 = {}) : (details.query2 = {});
console.log(details,'details');
details.pageStatus == 1 ? (details.pageInfo[0].query={}) : (details.pageInfo[1].query={});
details.page.pageNum = 1;
handleClearTableQuery(details.pageStatus === 1 ? details.columnList1 : details.columnList2);
initOnLoad();
};
/** 展开列表控件 */
const showdrawer = ( item:any, _flag?: boolean) => {
const showdrawer = (item: any, _flag?: boolean) => {
item.drawerShow = _flag;
};
@ -455,13 +546,12 @@ const handleFullScrean = (_type: 'open' | 'close', _name: string) => {
switch (_name) {
case 'confirmVisited':
details.fullscreenObj.confirmVisited =
!details.fullscreenObj.confirmVisited;
details.fullscreenObj.confirmVisited = !details.fullscreenObj.confirmVisited;
if (_type === 'close') {
if (_node) setNodeHeight(_node, '500px', true);
} else {
if (_node) setNodeHeight(_node,'', true);
if (_node) setNodeHeight(_node, '', true);
}
break;
@ -478,35 +568,37 @@ const handleConfirm = async () => {
const _errorArr = [];
//
let _destinationWarehouseName = ''
let _destinationWarehouseName = '';
//
let _consignee = ''
let _consignee = '';
for (let index = 0; index < details.selectionList.length; index++) {
const value = details.selectionList[index];
if (index === 0) {
_destinationWarehouseName = value.destinationWarehouseName
_consignee = value.consignee
_destinationWarehouseName = value.destinationWarehouseName;
_consignee = value.consignee;
}
if (value.consignee !== _consignee) return ElMessage.warning(`收货单位不一致,请移除不一致数据`)
if (value.destinationWarehouseName !== _destinationWarehouseName) return ElMessage.warning(`目的仓不一致,请移除不一致数据`)
if (Number(value.signStatus) !== 2) return ElMessage.warning(`存在未签收完成的数据`)
if (value.consignee !== _consignee)
return ElMessage.warning(`收货单位不一致,请移除不一致数据`);
if (value.destinationWarehouseName !== _destinationWarehouseName)
return ElMessage.warning(`目的仓不一致,请移除不一致数据`);
if (Number(value.signStatus) !== 2) return ElMessage.warning(`存在未签收完成的数据`);
}
details.popUpShow.confirmVisited = true
await nextTick()
details.popUpShow.confirmVisited = true;
await nextTick();
const _node = document.querySelector(`.confirmVisited .maboxhi`);
setNodeHeight(_node, details.popUpShow.confirmVisited ? '' : '500px', true);
setNodeHeight(_node, details.popUpShow.confirmVisited ? '' : '500px', true);
};
const handleSubmitConfrim= ()=>{
const handleSubmitConfrim = () => {
ElMessageBox.confirm('是否确认对账单?', '提示', {
confirmButtonText: '确定',
cancelButtonText: '取消',
type: 'warning',
}).then(async () => {
details.popUpShow.confirmVisited = false
details.popUpShow.confirmVisited = false;
try {
details.loadingObj.pageLoading = true;
@ -526,7 +618,7 @@ const handleSubmitConfrim= ()=>{
details.loadingObj.pageLoading = false;
}
});
}
};
/** 计算仓储&配送费用 */
const handleComputedPrice = ({ row }) => {
@ -558,43 +650,42 @@ const handleExport = () => {
confirmButtonText: '确定',
cancelButtonText: '取消',
type: 'warning',
}).then(async() => {
}).then(async () => {
try {
details.loadingObj.pageLoading = true
details.loadingObj.pageLoading = true;
const submitData =
details.pageStatus === 1
? { ...details.pageInfo[0].query }
: { ...details.pageInfo[1].query };
const submitData=details.pageStatus === 1 ?
{ ...details.pageInfo[0].query } :
{ ...details.pageInfo[1].query }
submitData.listType = details.pageStatus;
if (getObjType(submitData.createTimeArr) === 'array' && submitData.createTimeArr.length > 0){
submitData.createTimeStartStr = submitData.createTimeArr[0]
submitData.createTimeEndStr = submitData.createTimeArr[1]
if (getObjType(submitData.createTimeArr) === 'array' && submitData.createTimeArr.length > 0) {
submitData.createTimeStartStr = submitData.createTimeArr[0];
submitData.createTimeEndStr = submitData.createTimeArr[1];
}
if (getObjType(submitData.checkTimeArr) === 'array' && submitData.checkTimeArr.length > 0){
submitData.checkTimeStartStr = submitData.checkTimeArr[0]
submitData.checkTimeEndStr = submitData.checkTimeArr[1]
if (getObjType(submitData.checkTimeArr) === 'array' && submitData.checkTimeArr.length > 0) {
submitData.checkTimeStartStr = submitData.checkTimeArr[0];
submitData.checkTimeEndStr = submitData.checkTimeArr[1];
}
delete submitData.createTimeArr
delete submitData.checkTimeArr
delete submitData.createTimeArr;
delete submitData.checkTimeArr;
const res = await postOrderInfoListExport(submitData);
const res = await postOrderInfoListExport(submitData)
const {status, data} = res
if (status !== 200) return
downloadXls(data, details.pageStatus === 1 ? '对账预存单toB.xlsx': '对账预存单toC.xlsx')
const { status, data } = res;
if (status !== 200) return;
downloadXls(data, details.pageStatus === 1 ? '对账预存单toB.xlsx' : '对账预存单toC.xlsx');
ElMessage.success('导出成功!');
} catch (error) {
console.log('error :>> ', error);
}finally{
details.loadingObj.pageLoading = false
} finally {
details.loadingObj.pageLoading = false;
}
});
};
</script>

Loading…
Cancel
Save