Browse Source

Merge branch 'pre-production'

master
pref_mail@163.com 5 months ago
parent
commit
8ca2793b4b
  1. 11
      src/api/distribution/VehicleStowage.js
  2. 11
      src/api/distribution/truckLoadingDetails.js
  3. 15
      src/api/finance/WaybillAudit.js
  4. 2
      src/option/aftersales/vueTvemp.js
  5. 54
      src/option/distribution/VehicleStowage.js
  6. 24
      src/option/finance/CustomerSettlement.js
  7. 24
      src/option/finance/MerchantDepositSlip.js
  8. 49
      src/option/finance/ReconciliationDepositSlip.js
  9. 492
      src/views/aftersales/aftersalesWorkOrderTemp.vue
  10. 4
      src/views/distribution/artery/AddVehicleStowage.vue
  11. 97
      src/views/distribution/artery/VehicleArrivalManagement.vue
  12. 107
      src/views/distribution/artery/VehicleStowage.vue
  13. 48
      src/views/distribution/artery/truckLoadingDetails.vue
  14. 2
      src/views/distribution/inventory/CreateOrder.vue
  15. 7
      src/views/finance/CustomerSettlement.vue
  16. 54
      src/views/finance/WaybillAudit.vue
  17. 2
      src/views/waybill/CreateZeroOrder.vue

11
src/api/distribution/VehicleStowage.js

@ -170,3 +170,14 @@ export const postExportLoadCarsPageList = data => {
responseType: 'blob',
});
};
/**
* 查询订单配载锁定详情
*/
export const postFindOrderPlanCarsNum = data => {
return request({
url: '/api/logpm-trunkline/carsLoad/findOrderPlanCarsNum ',
method: 'post',
data,
});
};

11
src/api/distribution/truckLoadingDetails.js

@ -121,3 +121,14 @@ export const postUnloadZero = data => {
data,
});
};
/**
* 零担卸车确认
*/
export const postZeroUnloadEnter = data => {
return request({
url: '/api/logpm-trunkline/api/carsLoad/zeroUnloadEnter ',
method: 'post',
data,
});
};

15
src/api/finance/WaybillAudit.js

@ -23,6 +23,19 @@ export const postFinanceWaybillListExport = data => {
url: '/api/logpm-warehouse/warehouseWaybill/financeWaybillListExport',
method: 'post',
data,
responseType: 'blob'
responseType: 'blob',
});
};
/**
* 运单批量审核
* @param {*} data
* @returns
*/
export const postCheckWaybillList = data => {
return request({
url: '/api/logpm-trunkline/openOrder/checkWaybillList',
method: 'post',
data,
});
};

2
src/option/aftersales/vueTvemp.js

@ -155,7 +155,7 @@ export const columnList = [
{
prop: 'processedBy',
label: '工单处理方',
type: 1,
type: 2,
values: '',
width: '150',
checkarr: [],

54
src/option/distribution/VehicleStowage.js

@ -697,3 +697,57 @@ export const packageColumnList = [
sortable: false,
},
];
/** 对比报表 -- 仓库节点 */
export const orderDetailColumnList = [
{
prop: '',
label: '序号',
type: 12,
values: '',
width: 55,
fixed: true,
},
{
prop: 'carsNo',
label: '车次号',
width: '130',
type: 6,
values: '',
checkarr: [],
fixed: true,
sortable: false,
head: false,
},
{
prop: 'orderCode',
label: '订单号',
width: '130',
type: 1,
values: '',
checkarr: [],
fixed: true,
sortable: false,
head: false,
},
{
prop: 'waybillNo',
label: '运单号',
width: '130',
type: 1,
values: '',
checkarr: [],
fixed: false,
sortable: false,
},
{
prop: 'startNum',
label: '锁定件数',
width: '130',
type: 1,
values: '',
checkarr: [],
fixed: false,
sortable: false,
},
];

24
src/option/finance/CustomerSettlement.js

@ -138,6 +138,7 @@ export const columnList = [
fixed: false,
sortable: true,
head: false,
isshowSummary: true,
},
{
prop: 'hasBalanceFee',
@ -149,6 +150,7 @@ export const columnList = [
fixed: false,
sortable: true,
head: false,
isshowSummary: true,
},
{
prop: 'noBalanceFee',
@ -160,6 +162,7 @@ export const columnList = [
fixed: false,
sortable: true,
head: false,
isshowSummary: true,
},
{
prop: 'totalCount',
@ -171,6 +174,7 @@ export const columnList = [
fixed: false,
sortable: true,
head: false,
isshowSummary: true,
},
{
prop: 'totalWeight',
@ -182,6 +186,7 @@ export const columnList = [
fixed: false,
sortable: true,
head: false,
isshowSummary: true,
},
{
prop: 'totalVolume',
@ -193,6 +198,7 @@ export const columnList = [
fixed: false,
sortable: true,
head: false,
isshowSummary: true,
},
{
prop: 'openFee',
@ -204,6 +210,7 @@ export const columnList = [
fixed: false,
sortable: true,
head: false,
isshowSummary: true,
},
{
prop: 'pickupFee',
@ -215,6 +222,7 @@ export const columnList = [
fixed: false,
sortable: true,
head: false,
isshowSummary: true,
},
{
prop: 'freightFee',
@ -226,6 +234,7 @@ export const columnList = [
fixed: false,
sortable: true,
head: false,
isshowSummary: true,
},
{
prop: 'warehouseServiceFee',
@ -237,6 +246,7 @@ export const columnList = [
fixed: false,
sortable: true,
head: false,
isshowSummary: true,
},
{
prop: 'warehouseFee',
@ -248,6 +258,7 @@ export const columnList = [
fixed: false,
sortable: true,
head: false,
isshowSummary: true,
},
{
prop: 'warehouseManageFee',
@ -259,6 +270,7 @@ export const columnList = [
fixed: false,
sortable: true,
head: false,
isshowSummary: true,
},
{
prop: 'warehouseSortingFee',
@ -270,6 +282,7 @@ export const columnList = [
fixed: false,
sortable: true,
head: false,
isshowSummary: true,
},
{
prop: 'warehouseOperatingFee',
@ -281,6 +294,7 @@ export const columnList = [
fixed: false,
sortable: true,
head: false,
isshowSummary: true,
},
{
prop: 'deliveryServiceFee',
@ -292,6 +306,7 @@ export const columnList = [
fixed: false,
sortable: true,
head: false,
isshowSummary: true,
},
{
prop: 'deliveryFee',
@ -303,6 +318,7 @@ export const columnList = [
fixed: false,
sortable: true,
head: false,
isshowSummary: true,
},
{
prop: 'deliveryLoadingFee',
@ -314,6 +330,7 @@ export const columnList = [
fixed: false,
sortable: true,
head: false,
isshowSummary: true,
},
{
prop: 'deliverySortingFee',
@ -325,6 +342,7 @@ export const columnList = [
fixed: false,
sortable: true,
head: false,
isshowSummary: true,
},
{
prop: 'deliveryUpfloorFee',
@ -336,6 +354,7 @@ export const columnList = [
fixed: false,
sortable: true,
head: false,
isshowSummary: true,
},
{
prop: 'deliveryMoveFee',
@ -347,6 +366,7 @@ export const columnList = [
fixed: false,
sortable: true,
head: false,
isshowSummary: true,
},
{
prop: 'deliveryCrossingFee',
@ -358,6 +378,7 @@ export const columnList = [
fixed: false,
sortable: true,
head: false,
isshowSummary: true,
},
{
prop: 'installFee',
@ -369,6 +390,7 @@ export const columnList = [
fixed: false,
sortable: true,
head: false,
isshowSummary: true,
},
{
prop: 'otherFee',
@ -380,6 +402,7 @@ export const columnList = [
fixed: false,
sortable: true,
head: false,
isshowSummary: true,
},
{
prop: 'abnormalBalanceStatusName',
@ -405,6 +428,7 @@ export const columnList = [
fixed: false,
sortable: true,
head: false,
isshowSummary: true,
},
{
prop: 'abnormalRemark',

24
src/option/finance/MerchantDepositSlip.js

@ -68,6 +68,7 @@ export const columnList = [
fixed: false,
sortable: true,
head: false,
isshowSummary: true,
},
{
prop: 'totalWeight',
@ -79,6 +80,7 @@ export const columnList = [
fixed: false,
sortable: true,
head: false,
isshowSummary: true,
},
{
prop: 'totalVolume',
@ -90,6 +92,7 @@ export const columnList = [
fixed: false,
sortable: true,
head: false,
isshowSummary: true,
},
{
prop: 'realTotalFee',
@ -101,6 +104,8 @@ export const columnList = [
fixed: false,
sortable: true,
head: false,
isshowSummary: true,
isshowSummary: true,
},
{
prop: 'systemTotalFee',
@ -123,6 +128,7 @@ export const columnList = [
fixed: false,
sortable: true,
head: false,
isshowSummary: true,
},
{
prop: 'freightFee',
@ -134,6 +140,7 @@ export const columnList = [
fixed: false,
sortable: true,
head: false,
isshowSummary: true,
},
{
prop: 'warehouseServiceFee',
@ -145,6 +152,7 @@ export const columnList = [
fixed: false,
sortable: true,
head: false,
isshowSummary: true,
},
{
prop: 'warehouseFee',
@ -156,6 +164,7 @@ export const columnList = [
fixed: false,
sortable: true,
head: false,
isshowSummary: true,
},
{
prop: 'warehouseManageFee',
@ -167,6 +176,7 @@ export const columnList = [
fixed: false,
sortable: true,
head: false,
isshowSummary: true,
},
{
prop: 'warehouseSortingFee',
@ -178,6 +188,7 @@ export const columnList = [
fixed: false,
sortable: true,
head: false,
isshowSummary: true,
},
{
prop: 'warehouseOperatingFee',
@ -189,6 +200,7 @@ export const columnList = [
fixed: false,
sortable: true,
head: false,
isshowSummary: true,
},
{
prop: 'deliveryServiceFee',
@ -200,6 +212,7 @@ export const columnList = [
fixed: false,
sortable: true,
head: false,
isshowSummary: true,
},
{
prop: 'deliveryFee',
@ -211,6 +224,7 @@ export const columnList = [
fixed: false,
sortable: true,
head: false,
isshowSummary: true,
},
{
prop: 'deliveryLoadingFee',
@ -222,6 +236,7 @@ export const columnList = [
fixed: false,
sortable: true,
head: false,
isshowSummary: true,
},
{
prop: 'deliverySortingFee',
@ -233,6 +248,7 @@ export const columnList = [
fixed: false,
sortable: true,
head: false,
isshowSummary: true,
},
{
prop: 'deliveryUpfloorFee',
@ -244,6 +260,7 @@ export const columnList = [
fixed: false,
sortable: true,
head: false,
isshowSummary: true,
},
{
prop: 'deliveryMoveFee',
@ -255,6 +272,7 @@ export const columnList = [
fixed: false,
sortable: true,
head: false,
isshowSummary: true,
},
{
prop: 'deliveryCrossingFee',
@ -266,6 +284,7 @@ export const columnList = [
fixed: false,
sortable: true,
head: false,
isshowSummary: true,
},
{
prop: 'installFee',
@ -277,6 +296,7 @@ export const columnList = [
fixed: false,
sortable: true,
head: false,
isshowSummary: true,
},
{
prop: 'otherFee',
@ -288,6 +308,7 @@ export const columnList = [
fixed: false,
sortable: true,
head: false,
isshowSummary: true,
},
{
prop: 'destinationWarehouseName',
@ -335,6 +356,7 @@ export const columnList = [
fixed: false,
sortable: true,
head: false,
isshowSummary: true,
},
{
prop: 'realTotalFee',
@ -346,6 +368,7 @@ export const columnList = [
fixed: false,
sortable: true,
head: false,
isshowSummary: true,
},
{
prop: 'createUserName',
@ -393,6 +416,7 @@ export const columnList = [
fixed: false,
sortable: true,
head: false,
isshowSummary: true,
},
{
prop: 'changesItems',

49
src/option/finance/ReconciliationDepositSlip.js

@ -184,6 +184,7 @@ export const columnList = [
fixed: false,
sortable: true,
head: false,
isshowSummary: true,
},
{
prop: 'totalWeight',
@ -195,6 +196,7 @@ export const columnList = [
fixed: false,
sortable: true,
head: false,
isshowSummary: true,
},
{
prop: 'totalVolume',
@ -206,6 +208,7 @@ export const columnList = [
fixed: false,
sortable: true,
head: false,
isshowSummary: true,
},
{
prop: 'sysTotalFee',
@ -228,6 +231,7 @@ export const columnList = [
fixed: false,
sortable: true,
head: false,
isshowSummary: true,
},
{
prop: 'systemFreightPrice',
@ -239,6 +243,7 @@ export const columnList = [
fixed: false,
sortable: true,
head: false,
isshowSummary: true,
},
{
prop: 'freightPrice',
@ -250,6 +255,7 @@ export const columnList = [
fixed: false,
sortable: true,
head: false,
isshowSummary: true,
},
{
prop: 'systemPickupPrice',
@ -261,6 +267,7 @@ export const columnList = [
fixed: false,
sortable: true,
head: false,
isshowSummary: true,
},
{
prop: 'pickupPrice',
@ -272,6 +279,7 @@ export const columnList = [
fixed: false,
sortable: true,
head: false,
isshowSummary: true,
},
{
prop: 'warehouseServiceFee',
@ -283,6 +291,7 @@ export const columnList = [
fixed: false,
sortable: true,
head: false,
isshowSummary: true,
},
{
prop: 'warehouseFee',
@ -294,6 +303,7 @@ export const columnList = [
fixed: false,
sortable: true,
head: false,
isshowSummary: true,
},
{
prop: 'warehouseManageFee',
@ -305,6 +315,7 @@ export const columnList = [
fixed: false,
sortable: true,
head: false,
isshowSummary: true,
},
{
prop: 'warehouseSortingFee',
@ -316,6 +327,7 @@ export const columnList = [
fixed: false,
sortable: true,
head: false,
isshowSummary: true,
},
{
prop: 'warehouseOperatingFee',
@ -327,6 +339,7 @@ export const columnList = [
fixed: false,
sortable: true,
head: false,
isshowSummary: true,
},
{
prop: 'deliveryServiceFee',
@ -338,6 +351,7 @@ export const columnList = [
fixed: false,
sortable: true,
head: false,
isshowSummary: true,
},
{
prop: 'systemDeliveryFee',
@ -349,6 +363,7 @@ export const columnList = [
fixed: false,
sortable: true,
head: false,
isshowSummary: true,
},
{
prop: 'deliveryFee',
@ -360,6 +375,7 @@ export const columnList = [
fixed: false,
sortable: true,
head: false,
isshowSummary: true,
},
{
prop: 'deliveryLoadingFee',
@ -371,6 +387,7 @@ export const columnList = [
fixed: false,
sortable: true,
head: false,
isshowSummary: true,
},
{
prop: 'deliverySortingFee',
@ -382,6 +399,7 @@ export const columnList = [
fixed: false,
sortable: true,
head: false,
isshowSummary: true,
},
{
prop: 'deliveryUpfloorFee',
@ -393,6 +411,7 @@ export const columnList = [
fixed: false,
sortable: true,
head: false,
isshowSummary: true,
},
{
prop: 'deliveryMoveFee',
@ -404,6 +423,7 @@ export const columnList = [
fixed: false,
sortable: true,
head: false,
isshowSummary: true,
},
{
prop: 'deliveryOtherFee',
@ -415,6 +435,7 @@ export const columnList = [
fixed: false,
sortable: true,
head: false,
isshowSummary: true,
},
{
prop: 'deliveryCrossingFee',
@ -426,6 +447,7 @@ export const columnList = [
fixed: false,
sortable: true,
head: false,
isshowSummary: true,
},
{
prop: 'installFee',
@ -437,6 +459,7 @@ export const columnList = [
fixed: false,
sortable: true,
head: false,
isshowSummary: true,
},
{
prop: 'otherFee',
@ -448,6 +471,7 @@ export const columnList = [
fixed: false,
sortable: true,
head: false,
isshowSummary: true,
},
{
prop: 'shipperPerson',
@ -818,6 +842,7 @@ export const columnListB = [
fixed: false,
sortable: true,
head: false,
isshowSummary: true,
},
{
prop: 'totalWeight',
@ -829,6 +854,7 @@ export const columnListB = [
fixed: false,
sortable: true,
head: false,
isshowSummary: true,
},
{
prop: 'totalVolume',
@ -840,6 +866,7 @@ export const columnListB = [
fixed: false,
sortable: true,
head: false,
isshowSummary: true,
},
{
prop: 'sysTotalFee',
@ -851,6 +878,7 @@ export const columnListB = [
fixed: false,
sortable: true,
head: false,
isshowSummary: true,
},
{
prop: 'totalFee',
@ -862,6 +890,7 @@ export const columnListB = [
fixed: false,
sortable: true,
head: false,
isshowSummary: true,
},
{
prop: 'systemFreightPrice',
@ -873,6 +902,7 @@ export const columnListB = [
fixed: false,
sortable: true,
head: false,
isshowSummary: true,
},
{
prop: 'freightPrice',
@ -884,6 +914,7 @@ export const columnListB = [
fixed: false,
sortable: true,
head: false,
isshowSummary: true,
},
{
prop: 'systemPickupPrice',
@ -895,6 +926,7 @@ export const columnListB = [
fixed: false,
sortable: true,
head: false,
isshowSummary: true,
},
{
prop: 'pickupPrice',
@ -906,6 +938,7 @@ export const columnListB = [
fixed: false,
sortable: true,
head: false,
isshowSummary: true,
},
{
prop: 'warehouseServiceFee',
@ -917,6 +950,7 @@ export const columnListB = [
fixed: false,
sortable: true,
head: false,
isshowSummary: true,
},
{
prop: 'warehouseFee',
@ -928,6 +962,7 @@ export const columnListB = [
fixed: false,
sortable: true,
head: false,
isshowSummary: true,
},
{
prop: 'warehouseManageFee',
@ -939,6 +974,7 @@ export const columnListB = [
fixed: false,
sortable: true,
head: false,
isshowSummary: true,
},
{
prop: 'warehouseSortingFee',
@ -950,6 +986,7 @@ export const columnListB = [
fixed: false,
sortable: true,
head: false,
isshowSummary: true,
},
{
prop: 'warehouseOperatingFee',
@ -961,6 +998,7 @@ export const columnListB = [
fixed: false,
sortable: true,
head: false,
isshowSummary: true,
},
{
prop: 'deliveryServiceFee',
@ -972,6 +1010,7 @@ export const columnListB = [
fixed: false,
sortable: true,
head: false,
isshowSummary: true,
},
{
prop: 'systemDeliveryFee',
@ -983,6 +1022,7 @@ export const columnListB = [
fixed: false,
sortable: true,
head: false,
isshowSummary: true,
},
{
prop: 'deliveryFee',
@ -994,6 +1034,7 @@ export const columnListB = [
fixed: false,
sortable: true,
head: false,
isshowSummary: true,
},
{
prop: 'deliveryLoadingFee',
@ -1005,6 +1046,7 @@ export const columnListB = [
fixed: false,
sortable: true,
head: false,
isshowSummary: true,
},
{
prop: 'deliverySortingFee',
@ -1016,6 +1058,7 @@ export const columnListB = [
fixed: false,
sortable: true,
head: false,
isshowSummary: true,
},
{
prop: 'deliveryUpfloorFee',
@ -1027,6 +1070,7 @@ export const columnListB = [
fixed: false,
sortable: true,
head: false,
isshowSummary: true,
},
{
prop: 'deliveryMoveFee',
@ -1038,6 +1082,7 @@ export const columnListB = [
fixed: false,
sortable: true,
head: false,
isshowSummary: true,
},
{
prop: 'deliveryOtherFee',
@ -1049,6 +1094,7 @@ export const columnListB = [
fixed: false,
sortable: true,
head: false,
isshowSummary: true,
},
{
prop: 'deliveryCrossingFee',
@ -1060,6 +1106,7 @@ export const columnListB = [
fixed: false,
sortable: true,
head: false,
isshowSummary: true,
},
{
prop: 'installFee',
@ -1071,6 +1118,7 @@ export const columnListB = [
fixed: false,
sortable: true,
head: false,
isshowSummary: true,
},
{
prop: 'otherFee',
@ -1082,6 +1130,7 @@ export const columnListB = [
fixed: false,
sortable: true,
head: false,
isshowSummary: true,
},
{
prop: 'shipperPerson',

492
src/views/aftersales/aftersalesWorkOrderTemp.vue

@ -5,13 +5,30 @@
<!-- 搜索模块 -->
<div v-h5uShow="search">
<!-- 查询模块 -->
<el-form :inline="true" :model="query" class="el-fr-d">
<!-- 查询按钮 -->
<el-form-item class="el-btn">
<el-button type="primary" icon="el-icon-search" @click="searchChange"> </el-button>
<el-button icon="el-icon-delete" @click="searchReset()"> </el-button>
<el-form :inline="true" :model="TopQuery" class="el-fr-d">
<el-form-item label="工单号" class="el-times">
<div class="el_div_input">
<el-input
type="text"
clearable
v-model="TopQuery.workOrderNumber"
placeholder="请输入工单号"
/><el-icon @click="MultilineSearch('', TopQuery.workOrderNumber)"
><CirclePlusFilled
/></el-icon>
</div>
</el-form-item>
<el-form-item label="配送日期">
<el-form-item label="订单自编号" class="el-times">
<div class="el_div_input">
<el-input
clearable
type="text"
v-model="TopQuery.orderCode"
placeholder="请输入订单自编号"
/><el-icon @click="MultilineSearch('订单自编号搜索')"><CirclePlusFilled /></el-icon>
</div>
</el-form-item>
<!-- <el-form-item label="配送日期">
<el-date-picker
v-model="TopQuery.time"
type="datetimerange"
@ -22,6 +39,11 @@
:shortcuts="shortcuts"
:default-time="defaultTime2"
/>
</el-form-item> -->
<!-- 查询按钮 -->
<el-form-item class="el-btn">
<el-button type="primary" icon="el-icon-search" @click="searchChange"> </el-button>
<el-button icon="el-icon-delete" @click="searchReset()"> </el-button>
</el-form-item>
</el-form>
</div>
@ -73,7 +95,11 @@
<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
type="primary"
icon="Pointer"
v-if="ButtonPermissions.assignment"
@click="WorkOrderAssignment"
>工单指派</el-button
>
<el-button type="primary" icon="User" v-if="ButtonPermissions.applyArbitration"
@ -289,6 +315,90 @@
</span>
</template>
</el-dialog>
<!-- 工单指派弹窗 -->
<el-dialog v-model="assignFrom.dialogassign" title="工单指派" width="40%" class="plAllret">
<el-form
v-loading="assignFrom.AssignLoad"
element-loading-text="正在处理中..."
label-position="top"
label-width="100px"
:model="assignFrom"
:rules="assignFrom.rules"
ref="assignFromForm"
>
<el-form-item label="客服列表" prop="businessDepartment">
<el-select
v-model="assignFrom.businessDepartment"
filterable
default-first-option
:reserve-keyword="false"
placeholder="请选择指派客服"
>
<el-option
v-for="item in assignFrom.customerService"
:key="item.value"
:label="item.realName"
:value="item.id"
/>
</el-select>
</el-form-item>
</el-form>
<template #footer>
<span class="dialog-footer">
<el-button @click="assignFrom.dialogassign = false">取消</el-button>
<el-button type="primary" @click="Assignbutton" :disabled="assignFrom.AssignLoad">
确定
</el-button>
</span>
</template>
</el-dialog>
<!-- 搜索弹窗 -->
<div class="Searchboxpop-upwindow">
<el-dialog
v-model="Searchboxpop.dialogSearch"
:title="Searchboxpop.SearchboxpopUpwindowtitle"
:show-close="false"
:fullscreen="Searchboxpop.fullscreen"
:close-on-click-modal="false"
:draggable="true"
:overflow="false"
width="50%"
>
<template #header>
<div class="title">
<span>{{ Searchboxpop.SearchboxpopUpwindowtitle }}</span>
</div>
<div class="div_icon">
<el-icon @click="minimize"><Minus /></el-icon>
<el-icon @click="maximize"><FullScreen /></el-icon>
<el-icon @click="close"><CloseBold /></el-icon>
</div>
</template>
<el-input
v-model="TopQuery.inputAll"
style="width: 100%; height: 100%"
:autosize="{ minRows: 24 }"
type="textarea"
placeholder="每一行算一个搜索单位“多个请【换行】输入"
/>
<template #footer>
<div class="dialog-footer">
<el-button type="primary" @click="dialogSearchSubmit"> 确认 </el-button>
</div>
</template>
</el-dialog>
</div>
<!-- 最小化窗口 -->
<div class="minimize_windows" v-if="Searchboxpop.MinimizeState">
<div class="title">
<span>{{ Searchboxpop.SearchboxpopUpwindowtitle }}</span>
</div>
<div class="div_icon">
<el-icon @click="ExpandWindow"><FullScreen /></el-icon>
<el-icon @click="DestroyWindow"><Close /></el-icon>
</div>
</div>
</basic-container>
<!-- 列表配置显示 -->
@ -401,6 +511,23 @@ const workOrderStatus = ref(30); //工单状态
const PageLoading = ref(false); //loading
const warehouseData = ref([]); //
const UserInfo = ref({}); //
const assignFromForm = ref(null); //
const dialogSearch = ref(false); //
//
const Searchboxpop = ref({
SearchboxpopUpwindowtitle: '', //
dialogSearch: false, ///
fullscreen: false, //
MinimizeState: false, //
});
const assignFrom = ref({
dialogassign: false,
AssignLoad: false,
customerService: [], //
rules: {
businessDepartment: [{ required: true, message: '请选择要指派的客服', trigger: 'blur' }],
},
}); //
const batchReturnForm = ref(null);
const BatchReturn = ref({
//
@ -608,7 +735,7 @@ const ButtonPermissions = computed(() => {
return {
add: false, //
batchReject: UserPermissions.value == Useridentity.Headquarters_customer_service, //
assignment: false, //
assignment: UserPermissions.value != Useridentity.Warehouse_customer_service, //
applyArbitration: false, //
DingTalkNumber: false, //
batchFinish: false, //
@ -857,9 +984,7 @@ watch(
TabPermissions.value = $useStore.state.Customer.Customerobj;
tabValue.value = $useStore.state.Customer.Customerobj; //
if ([0, 1, 2, 3, 4, 5, 6, 7, 8, 9, 10].includes(TabPermissions.value)) {
let _Obj = MatchCurrentMenu(); //
_Obj.request = true; //
PublicDataRequest(TabPermissions.value); //
updateMenuAndData(); //
$useStore.commit('Customer_Menu', 0); //
}
$useStore.commit('EDIT_REFRESHITEM', { title: 'aftersalesWorkOrderTemp', status: false }); //
@ -920,15 +1045,12 @@ const selectionChange = list => {
};
//
const searchChange = () => {
PublicDataRequest();
updateMenuAndData(); //
};
//
const searchChangeS = () => {
details.search = false; //
let _Obj = MatchCurrentMenu();
_Obj.request = true;
PublicDataRequest(TabPermissions.value);
updateMenuAndData(); //
};
//
const ResetTableSearch = async () => {
@ -941,7 +1063,32 @@ const ResetTableSearch = async () => {
PublicDataRequest(TabPermissions.value, true);
};
//
const searchReset = () => {};
const searchReset = () => {
TopQuery.value={}
TabList.value.forEach(item => {
item.query = {};
});
const TabcolumnList = [
columnList,
columnList1,
columnList2,
columnList3,
columnList4,
columnList5,
columnList6,
columnList7,
columnList8,
columnList9,
columnList10,
];
TabcolumnList.forEach(item => {
handleClearTableQuery(item);
});
details.search = false; //
updateMenuAndData(); //
autoscaling();
};
//
const searchHide = () => {
console.log(details);
@ -1082,6 +1229,25 @@ const GetWarehouse = () => {
});
});
};
/**
* 获取客服人员
*
* @returns {Promise<void>}
*/
const GetCustomerService = async () => {
try {
let _res = await $_getCustomerServicePersonnel();
const { code, data } = _res.data;
if (code != 200) {
return;
}
assignFrom.value.customerService = data;
} catch (e) {
console.log(e);
} finally {
}
};
/**
*页面初始化函数包含字典等必要请求
*/
@ -1094,10 +1260,11 @@ const PageOnlaod = async () => {
Roleverification(), //
SelectionInitialization(), //
GetWarehouse(), //
GetCustomerService(), //
]);
//
PublicDataRequest(TabPermissions.value);
await PublicDataRequest(TabPermissions.value);
} catch (error) {
console.log(error);
} finally {
@ -1358,7 +1525,17 @@ const getQuery = () => {
let _Obj = MatchCurrentMenu();
return _Obj.query;
};
/**
* @description: 更新当前菜单的请求状态并请求数据
* @return {void} 无返回值
*/
const updateMenuAndData = () => {
const currentMenu = MatchCurrentMenu(); //
if (currentMenu) {
currentMenu.request = true; //
}
PublicDataRequest(TabPermissions.value); //
};
/**
* @description 通用函数用于处理数据请求包含待回复理赔金额未出申诉超时未处理
* @param {Function} fetchFunction - 用于执行具体数据请求的函数
@ -1566,9 +1743,7 @@ const Appealbutton = async state => {
}
appeal.value.dialogappeal = false;
const currentMenu = MatchCurrentMenu();
currentMenu.request = true;
PublicDataRequest(TabPermissions.value);
updateMenuAndData(); //
} finally {
appeal.value.loadingappeal = false;
}
@ -1593,9 +1768,7 @@ const Deleteappealrecords = async row => {
message: '删除成功',
type: 'success',
});
let _Obj = MatchCurrentMenu();
_Obj.request = true;
PublicDataRequest(TabPermissions.value); //
updateMenuAndData(); //
}
} catch {
} finally {
@ -1626,9 +1799,7 @@ const CancelWorkOrderAppeal = row => {
.then(res => {
console.log(res, '取消申诉返回值');
if (res.data.code == 200) {
let _Obj = MatchCurrentMenu();
_Obj.request = true;
PublicDataRequest(TabPermissions.value); //
updateMenuAndData(); //
ElMessage({
message: '取消申诉成功',
type: 'success',
@ -1930,9 +2101,7 @@ const ResultConfirmed = async row => {
if (code == 200) {
console.log(_res, '理赔金额未出处理结果确定');
ElMessage.success(msg);
let _Obj = MatchCurrentMenu();
_Obj.request = true;
PublicDataRequest(TabPermissions.value);
updateMenuAndData(); //
}
})
.catch(() => {});
@ -1984,9 +2153,7 @@ const ConfirmReturn = async () => {
if (code === 200) {
ElMessage.success(msg);
BatchReturn.value.dialogReturn = false; //
const _Obj = MatchCurrentMenu();
_Obj.request = true;
PublicDataRequest(TabPermissions.value);
updateMenuAndData(); //
}
} catch (e) {
console.error(e);
@ -2007,6 +2174,159 @@ const ConfirmReturn = async () => {
}
});
};
/**
* @description 工单指派
* @return {void} 无返回值
*/
const WorkOrderAssignment = () => {
//
if (!details.selectionList.length) {
//
ElMessage({
message: '请勾选要处理的数据',
type: 'warning',
});
return;
}
//
assignFrom.value = { ...assignFrom.value, businessDepartment: '', dialogassign: true };
};
/**
* 工单指派确定按钮
* 1.根据选择的客服ID,名称,和选择的工单ID,将其组装成一个data对象
* 2.然后调用$_assignCustomerService(data)接口,
* 3.成功后关闭加载,关闭弹窗,重新拉取数据
*/
const Assignbutton = async () => {
const WorkOrderAssignmentFunction = async () => {
const assignForm = assignFrom.value;
assignForm.AssignLoad = true; //
try {
//
const foundObjs = assignForm.customerService.find(
obj => obj.id == assignForm.businessDepartment
);
if (!foundObjs) {
console.error('未找到对应的工单信息');
return;
}
//
const data = {
customerServiceId: foundObjs.id, // ID
customerServiceName: foundObjs.realName, //
assignList: details.selectionList.map(item => item.id), // ID/ID
};
//
const _res = await $_assignCustomerService(data);
const { code, msg } = _res.data;
if (code !== 200) {
console.error('分配客服失败:', msg);
return;
}
//
assignForm.dialogassign = false;
//
updateMenuAndData();
} catch (error) {
console.error('分配客服时发生错误:', error);
} finally {
assignForm.AssignLoad = false; //
}
};
assignFromForm.value.validate(async valid => {
if (valid) {
ElMessageBox.confirm('是否确认指派该客服?', '提示', {
confirmButtonText: '确认',
cancelButtonText: '取消',
type: 'warning',
}).then(async () => {
await WorkOrderAssignmentFunction();
});
} else {
ElMessage.warning('请检查表单是否填写否完整');
}
});
};
/**
* 弹窗多行搜索
* 1.获取当前选中的客户信息
* 2.然后根据客户信息,去后台查询对应的客服信息
* 3.将查询到的客服信息显示在弹窗中
* 4.然后用户可以选择对应的客服
* 5.最终将选择的客服信息,分配给对应的工单
*/
const MultilineSearch = (title, input) => {
if (input) {
const formattedInput = input.split(',').join('\n');
TopQuery.value.inputAll = formattedInput; // inputAll
} else {
TopQuery.value.inputAll = '';
}
Searchboxpop.value.SearchboxpopUpwindowtitle = title; //
Searchboxpop.value.dialogSearch = true; //
};
/**
* @description dialogSearchSubmit
* 1.获取用户输入的所有数据
* 2.将其拆分成每一行
* 3.然后将每一行的前后空格去除
* 4.然后将所有的行连接起来
* 5.将连接起来的数据重新赋值给workOrderNumber
* @param {void} 无参数
* @return {void} 无返回值
*/
const dialogSearchSubmit = () => {
// 1.
const inputAll = TopQuery.value.inputAll;
// 2.
const lines = inputAll
.split('\n') //
.map(line => line.trim()) //
.filter(line => line !== ''); //
// 3.
// 4.
const joinedLines = lines.join(','); // 使
// 5.workOrderNumber
TopQuery.value.workOrderNumber = joinedLines;
Searchboxpop.value.dialogSearch = false; //
};
//
const close = () => {
Searchboxpop.value.dialogSearch = false; //
Searchboxpop.value.MinimizeState = false; //
};
//
const maximize = () => {
Searchboxpop.value.fullscreen = !Searchboxpop.value.fullscreen; //
};
//
const minimize = () => {
Searchboxpop.value.dialogSearch = false; //
Searchboxpop.value.MinimizeState = true; //
};
const ExpandWindow = () => {
Searchboxpop.value.dialogSearch = true; //
Searchboxpop.value.MinimizeState = false; //
};
const DestroyWindow = () => {
Searchboxpop.value.MinimizeState = false; //
};
</script>
<style scoped lang="scss">
@ -2064,12 +2384,110 @@ const ConfirmReturn = async () => {
}
}
}
.plAllret {
:deep(.el-select) {
:deep(.plAllret) {
height: 30%;
display: flex;
flex-direction: column;
.el-select {
width: 100%;
}
.el-select {
.el-dialog__footer {
display: flex;
flex: 1;
align-items: flex-end;
justify-content: flex-end;
}
}
:deep(.el-fr-d) {
display: flex;
.el-form-item {
width: 20%;
}
.el_div_input {
width: 100%;
display: flex;
align-items: center;
.el-icon {
font-size: 2em;
}
}
.el-form-item {
margin: 0;
margin: 10px 6px;
}
}
:deep(.Searchboxpop-upwindow) {
.el-overlay {
position: absolute;
.el-dialog {
min-height: 70%;
}
.el-overlay-dialog {
position: absolute;
}
.el-dialog__header {
display: flex;
justify-content: space-between;
.title {
position: relative;
padding: 0 10px;
}
.title::after {
content: '*';
color: #172e60;
position: absolute;
font-size: 20px;
top: 0;
left: 0;
}
.div_icon {
width: 100px;
display: flex;
justify-content: space-between;
font-size: 19px;
cursor: pointer;
}
}
.el-dialog__footer {
display: flex;
justify-content: center;
padding: 6px;
.el-button {
width: 160px;
height: 35px;
}
}
}
}
.minimize_windows {
width: 200px;
height: 49px;
border: 1px solid #cccccc82;
position: absolute;
bottom: 1px;
left: 10px;
box-shadow: 2px -1px 0.15625vw #c1c1c187;
display: flex;
align-items: center;
justify-content: space-around;
.title {
height: 100%;
display: flex;
align-items: center;
span {
font-size: 16px;
}
}
span {
font-size: 14px;
}
.div_icon {
display: flex;
align-items: center;
width: 54px;
justify-content: space-between;
font-size: 20px;
}
}
</style>

4
src/views/distribution/artery/AddVehicleStowage.vue

@ -657,7 +657,9 @@
<!-- 底部提交 -->
<div class="button-container">
<!-- 关闭 -->
<el-button class="submitButton" icon="CircleClose" @click="back"> 关闭 </el-button>
<el-button class="submitButton" type="warning" icon="CircleClose" @click="back" plain>
关闭
</el-button>
<!-- 提交 -->
<el-button

97
src/views/distribution/artery/VehicleArrivalManagement.vue

@ -175,6 +175,11 @@
卸车报告
</el-button>
<!-- 查询订单配载锁定详情 -->
<el-button type="primary" icon="Search" @click="handleSeachOrder">
查询订单配载锁定详情
</el-button>
<!-- 导出 -->
<el-button type="primary" icon="Download" @click="handleExport"> </el-button>
</div>
@ -419,6 +424,44 @@
>
</el-pagination>
</div>
<!-- 查询订单配载锁定详情 -->
<el-dialog
title="查询订单配载锁定详情"
v-model="details.popUpShow.searchOrderVisited"
width="80%"
:append-to-body="false"
>
<div class="flex-c-sb mb20">
<el-input
v-model="details.searchOrderOption.searchText"
class="flex1 mr20"
placeholder="请输入订单号"
/>
<el-button icon="Edit" type="primary" @click="searchOrder"> </el-button>
</div>
<tablecmt
ref="searchOrderTableNode"
:columnList="details.searchOrderOption.columnList"
:tableData="details.searchOrderOption.data"
:loading="details.loadingObj.searchOrder"
>
<template #default="slotProps">
<el-text
@click="
() => {
const row = { ...slotProps.scope.row };
row.id = row.loadId;
handleGoWaybill({ row });
}
"
>{{ slotProps.scope.row.carsNo }}</el-text
>
</template>
</tablecmt>
</el-dialog>
</div>
</basic-container>
@ -621,7 +664,7 @@ import {
ChecksWhetherTheWarehouseIsSelected,
} from '@/utils/util';
import { columnList } from '@/option/distribution/VehicleArrivalManagement';
import { packageColumnList } from '@/option/distribution/VehicleStowage';
import { packageColumnList, orderDetailColumnList } from '@/option/distribution/VehicleStowage';
import {
postloadArriveCarsPageList,
postloadArriveCarByLoadId,
@ -641,6 +684,7 @@ import {
postManualLoadingloadId,
postFindLoadingListData,
postFindWarehouseUnloadReport,
postFindOrderPlanCarsNum,
} from '@/api/distribution/VehicleStowage';
import { getListName } from '@/api/basicdata/basicdataVehicle';
import { useRouter, useRoute } from 'vue-router';
@ -660,6 +704,7 @@ const Mydata = ref<any>({});
Mydata.value = JSON.parse(localStorage.getItem('my_data')); //
const truckLoadingDetailNodeRef = ref();
const searchOrderTableNode = ref();
const details = reactive({
/** 是否开启搜索 */
@ -708,6 +753,8 @@ const details = reactive({
truckLoadingDetailPopUpLoading: false,
/** 全屏Loading */
pageLoading: false,
/** 订单配载锁定详情 */
searchOrder: false,
},
/** 列表复选框选中的数据 */
selectionList: [],
@ -731,6 +778,8 @@ const details = reactive({
listOfLoadedWagons: false,
/** 卸车清单 */
unloadReport: false,
/** 订单配载锁定详情 */
searchOrderVisited: false,
},
/** 全屏 */
fullscreenObj: {
@ -782,6 +831,12 @@ const details = reactive({
unloadReportInfo: {},
/** 仓库信息 */
warehouseOption: [] as [{ dictKey: string; dictValue: string }] | [],
/** 订单配载锁定详情 */
searchOrderOption: {
data: [],
columnList: deepClone(orderDetailColumnList),
searchText: '',
},
});
const tableNode = ref();
@ -1723,6 +1778,33 @@ const handleExport = () => {
}
});
};
/** 查询订单锁定详情 */
const handleSeachOrder = async () => {
details.popUpShow.searchOrderVisited = true;
details.searchOrderOption.searchText = '';
details.searchOrderOption.data = [];
await nextTick();
setNodeHeight(searchOrderTableNode.value.$el, '');
};
/** 搜索订单锁定详情 */
const searchOrder = async () => {
const orderCode = details.searchOrderOption.searchText;
if (!orderCode) return ElMessage.warning('请输入需要查询的订单号');
try {
details.loadingObj.searchOrder = true;
const res = await postFindOrderPlanCarsNum({ orderCode });
const { code, data } = res.data;
if (code !== 200 || getObjType(data) !== 'array') return;
details.searchOrderOption.data = data;
} catch (error) {
console.log('error :>> ', error);
} finally {
details.loadingObj.searchOrder = false;
}
};
</script>
<style scoped lang="scss">
@ -1809,4 +1891,17 @@ const handleExport = () => {
font-size: 20px;
}
}
.avue-crud {
position: relative;
height: inherit;
//
:deep(.el-overlay) {
position: absolute;
}
:deep(.el-overlay-dialog) {
position: absolute;
}
}
</style>

107
src/views/distribution/artery/VehicleStowage.vue

@ -156,6 +156,11 @@
对比报表
</el-button> -->
<!-- 查询订单配载锁定详情 -->
<el-button type="primary" icon="Search" @click="handleSeachOrder">
查询订单配载锁定详情
</el-button>
<!-- 导出 -->
<el-button type="primary" icon="Download" @click="handleExport"> </el-button>
</div>
@ -392,6 +397,44 @@
</el-pagination>
</div>
</el-row>
<!-- 查询订单配载锁定详情 -->
<el-dialog
title="查询订单配载锁定详情"
v-model="details.popUpShow.searchOrderVisited"
width="80%"
:append-to-body="false"
>
<div class="flex-c-sb mb20">
<el-input
v-model="details.searchOrderOption.searchText"
class="flex1 mr20"
placeholder="请输入订单号"
/>
<el-button icon="Edit" type="primary" @click="searchOrder"> </el-button>
</div>
<tablecmt
ref="searchOrderTableNode"
:columnList="details.searchOrderOption.columnList"
:tableData="details.searchOrderOption.data"
:loading="details.loadingObj.searchOrder"
>
<template #default="slotProps">
<el-text
@click="
() => {
const row = { ...slotProps.scope.row };
row.id = row.loadId;
handleGoWaybill({ row });
}
"
>{{ slotProps.scope.row.carsNo }}</el-text
>
</template>
</tablecmt>
</el-dialog>
</div>
</basic-container>
@ -559,7 +602,11 @@ import {
getObjType,
ChecksWhetherTheWarehouseIsSelected,
} from '@/utils/util';
import { columnList, packageColumnList } from '@/option/distribution/VehicleStowage';
import {
columnList,
packageColumnList,
orderDetailColumnList,
} from '@/option/distribution/VehicleStowage';
import {
postloadCarsPageList,
postStartCarByLoadId,
@ -572,6 +619,7 @@ import {
postManualLoadingloadId,
postFindLoadingListData,
postExportLoadCarsPageList,
postFindOrderPlanCarsNum,
} from '@/api/distribution/VehicleStowage';
import { getListName } from '@/api/basicdata/basicdataVehicle';
import { useStore } from 'vuex';
@ -579,8 +627,6 @@ import { useRouter, useRoute } from 'vue-router';
import { ElMessage, ElMessageBox } from 'element-plus';
import print from '@/utils/print';
import { dateNow } from '@/utils/date';
import { exportExcelByDom } from '@/utils/export';
// import * as XLSX from 'xlsx';
//
const $router = useRouter();
@ -597,6 +643,7 @@ Mydata.value = JSON.parse(localStorage.getItem('my_data')); //获取本地仓库
console.log('Mydata :>> ', Mydata);
const tableNodeRef = ref();
const truckLoadingDetailNodeRef = ref();
const searchOrderTableNode = ref();
const details = reactive<any>({
/** 是否开启搜索 */
@ -645,6 +692,8 @@ const details = reactive<any>({
truckLoadingDetailPopUpLoading: false,
/** 页面laoding */
pageLoading: false,
/** 订单配载锁定详情 */
searchOrder: false,
},
/** 列表复选框选中的数据 */
selectionList: [],
@ -666,6 +715,8 @@ const details = reactive<any>({
chooseDestinationVisited: false,
/** 装载清单 */
listOfLoadedWagons: false,
/** 订单配载锁定详情 */
searchOrderVisited: false,
},
/** 列表Dom节点 */
listNode: '',
@ -696,6 +747,12 @@ const details = reactive<any>({
listOfLoadedWagonsData: {},
/** 仓库信息 */
warehouseOption: [] as [{ dictKey: string; dictValue: string }] | [],
/** 订单配载锁定详情 */
searchOrderOption: {
data: [],
columnList: deepClone(orderDetailColumnList),
searchText: '',
},
});
const loadStatus = reactive([
@ -1317,7 +1374,7 @@ const handleCancelStartCar = () => {
type: 'warning',
});
}
ElMessageBox.confirm('确认取消发车吗?', 'Warning', {
ElMessageBox.confirm('确认取消发车吗?', '提示', {
confirmButtonText: '确认',
cancelButtonText: '取消',
type: 'warning',
@ -1364,7 +1421,7 @@ const handleCancelCarsLoad = () => {
type: 'warning',
});
}
ElMessageBox.confirm('确认取消配载吗?', 'Warning', {
ElMessageBox.confirm('确认取消配载吗?', '提示', {
confirmButtonText: '确认',
cancelButtonText: '取消',
type: 'warning',
@ -1530,6 +1587,33 @@ const handleExport = () => {
}
});
};
/** 查询订单锁定详情 */
const handleSeachOrder = async () => {
details.popUpShow.searchOrderVisited = true;
details.searchOrderOption.searchText = '';
details.searchOrderOption.data = [];
await nextTick();
setNodeHeight(searchOrderTableNode.value.$el, '');
};
/** 搜索订单锁定详情 */
const searchOrder = async () => {
const orderCode = details.searchOrderOption.searchText;
if (!orderCode) return ElMessage.warning('请输入需要查询的订单号');
try {
details.loadingObj.searchOrder = true;
const res = await postFindOrderPlanCarsNum({ orderCode });
const { code, data } = res.data;
if (code !== 200 || getObjType(data) !== 'array') return;
details.searchOrderOption.data = data;
} catch (error) {
console.log('error :>> ', error);
} finally {
details.loadingObj.searchOrder = false;
}
};
</script>
<style scoped lang="scss">
@ -1641,4 +1725,17 @@ const handleExport = () => {
font-size: 20px;
}
}
.avue-crud {
position: relative;
height: inherit;
//
:deep(.el-overlay) {
position: absolute;
}
:deep(.el-overlay-dialog) {
position: absolute;
}
}
</style>

48
src/views/distribution/artery/truckLoadingDetails.vue

@ -83,6 +83,15 @@
>删除
</el-button>
<!-- 零担批量卸车确认 -->
<el-button
v-if="permissionObj.truckLoadingDetails_delete"
type="primary"
icon="Delete"
@click="handleBatchLoadConfirm"
>零担批量卸车确认
</el-button>
<!-- 二维码 -->
<el-button type="primary" icon="Printer" @click="handleBatchBarcode">二维码</el-button>
@ -371,6 +380,7 @@ import {
postShowOrderCodeByCode,
postFindZeroDetailByCarsLoadScanId,
postUnloadZero,
postZeroUnloadEnter,
} from '@/api/distribution/truckLoadingDetails';
import {
postFindNextNodeList,
@ -662,7 +672,6 @@ const tableNodeRef = ref();
/** 初始化表格表头 */
const initTableSelect = () => {
for (const iterator of details.detailsColumnList) {
console.log('iterator :>> ', iterator);
iterator.checkarr = details[iterator.prop.replace('Name', '') + 'Option'] || [];
}
};
@ -1600,6 +1609,43 @@ const handleEditSubmit = async () => {
}
};
/** 零担批量卸车确认 */
const handleBatchLoadConfirm = () => {
if (details.selectionList.length === 0) return ElMessage.warning('请选择需要确认的零担数据');
const loadScanIds = [];
for (let i = 0; i < details.selectionList.length; i++) {
const val = details.selectionList[i];
if (Number(val.type) !== 2) return ElMessage.warning('请勿选择包件数据');
loadScanIds.push(val.id);
}
ElMessageBox.confirm('是否批量确认零担数据', '提示', {
confirmButtonText: '确认',
cancelButtonText: '取消',
type: 'warning',
center: true,
}).then(async () => {
try {
details.loadingObj.pageLoading = true;
const submitData = { loadScanIds };
const response = await postZeroUnloadEnter(submitData);
const { code, msg } = response.data;
if (code !== 200) return;
if (msg) ElMessage.success({ message: msg });
onLoad();
} catch (error) {
console.log('error :>> ', error);
} finally {
details.loadingObj.pageLoading = false;
}
});
};
watch(
$route,
(newVal, oldVal) => {

2
src/views/distribution/inventory/CreateOrder.vue

@ -737,7 +737,7 @@
:step="0.1"
v-model="query.totalFreight"
:value-on-clear="0"
disabled
:disabled="!query.trunklineCompleteOrNot"
></el-input-number>
</el-form-item>

7
src/views/finance/CustomerSettlement.vue

@ -155,7 +155,7 @@
</template>
<script setup lang="ts">
import { ref, reactive, toRefs, computed, onMounted, nextTick } from 'vue';
import { ref, reactive, toRefs, computed, onMounted, nextTick, onActivated } from 'vue';
import dayjs from 'dayjs';
import { mapGetters } from 'vuex';
/** 获取字典 */
@ -439,6 +439,11 @@ const handleConfirmCustomer = ({ row }) => {
}
});
};
onActivated(() => {
console.log('actived');
onLoad();
});
</script>
<style scoped lang="scss">

54
src/views/finance/WaybillAudit.vue

@ -12,9 +12,10 @@
<!-- 审核状态 -->
<el-form-item label="审核状态">
<el-select v-model="details.query.checkStatus" placeholder="请选择审核状态">
<el-select v-model="details.query.checkStatus" placeholder="请选择审核状态" clearable>
<el-option
v-for="item in [
{ label: '全部', value: '' },
{ label: '已审核', value: 1 },
{ label: '待审核', value: 0 },
]"
@ -70,6 +71,16 @@
<div class="avue-crud__header">
<!-- 头部左侧按钮模块 -->
<div class="avue-crud__left">
<!-- 批量审核 -->
<el-button
type="primary"
icon="CircleCheck"
v-if="permissionObj.WaybillAudit_BatchAudit"
@click="handleBatchAudit"
>
批量审核
</el-button>
<!-- 作废 -->
<el-button type="primary" icon="WarningFilled" @click="handleCancellation">
@ -180,7 +191,10 @@
:show-close="false"
v-model="details.popUpShow.checkVisted"
>
<div class="title">运单号{{ details.form.waybillNo }}</div>
<div class="title">
<template v-if="details.isBatch"> 批量审核 </template>
<template v-else> 运单号{{ details.form.waybillNo }} </template>
</div>
<el-form label-width="100px">
<el-form-item label="审核意见:">
<el-input placeholder="请输入审核意见" v-model="details.form.checkReson"></el-input>
@ -219,6 +233,7 @@ import {
import {
postPageFinanceWaybillList,
postFinanceWaybillListExport,
postCheckWaybillList,
} from '@/api/finance/WaybillAudit';
import { postCheckWaybill, postCancleCheckWaybill } from '@/api/distribution/CreateOrder.js';
import { compressImageBlob } from '@/components/IMGcompressor/imgcompressor.js';
@ -235,12 +250,14 @@ import {
} from '@/utils/util';
import { columnList } from '@/option/finance/WaybillAudit';
import { useRouter } from 'vue-router';
import { useStore } from 'vuex';
import { deepClone } from '@/utils/util';
import { getToken } from '@/utils/auth';
import { ElMessage, ElMessageBox, type UploadProps } from 'element-plus';
//
const $router = useRouter();
const $store = useStore();
const details = reactive<any>({
/** 是否开启搜索 */
@ -319,6 +336,8 @@ const details = reactive<any>({
header: computed(() => {
return { 'Blade-Auth': 'Bearer ' + getToken() };
}),
/** 是否为批量操作 */
isBatch: false,
});
const tableNodeRef = ref();
@ -327,6 +346,12 @@ const { search, query, shortcuts, selectionList, drawerShow, page } = toRefs(det
/** vuex */
const permission = computed(() => mapGetters(['permission', 'tagWel', 'tagList']));
/** 权限 */
const permissionObj = reactive({
/** 批量审核 */
WaybillAudit_BatchAudit: computed(() => $store.getters.permission.WaybillAudit_BatchAudit),
});
console.log('permission :>> ', permission);
details.query.checkStatus = 0;
@ -485,21 +510,44 @@ const currentChange = pageNum => {
/** 审核 */
const handleCheck = ({ row }) => {
details.isBatch = false;
details.form = { ...row };
details.popUpShow.checkVisted = true;
};
/** 批量审核 */
const handleBatchAudit = () => {
if (details.selectionList.length === 0) return ElMessage.warning('请选择需要审核的数据');
for (let index = 0; index < details.selectionList.length; index++) {
const val = details.selectionList[index];
if (Number(val.checkStatus) === 1) return ElMessage.warning('请选择未审核的数据');
}
details.isBatch = true;
details.form = {};
details.popUpShow.checkVisted = true;
};
/** 确认审核审核 */
const handleAudit = async () => {
details.popUpShow.checkVisted = false;
details.loadingObj.pageLoading = true;
try {
const res = await postCheckWaybill({
const res = details.isBatch
? await postCheckWaybillList({
waybillIds: details.selectionList.map(val => val.id),
checkReson: details.form.checkReson || '',
checkRemark: details.form.checkRemark || '',
})
: await postCheckWaybill({
waybillId: details.form.id,
checkReson: details.form.checkReson || '',
checkRemark: details.form.checkRemark || '',
});
console.log('res :>> ', res);
const { code, msg } = res.data;
if (code !== 200) return;
ElMessage.success({

2
src/views/waybill/CreateZeroOrder.vue

@ -666,7 +666,7 @@
:min="0"
:step="0.1"
v-model="query.totalFreight"
disabled
:disabled="!query.trunklineCompleteOrNot"
:value-on-clear="0"
></el-input-number>
</el-form-item>

Loading…
Cancel
Save