diff --git a/src/api/distribution/directGoMarket.js b/src/api/distribution/directGoMarket.js index 619a2d43..bae6902e 100644 --- a/src/api/distribution/directGoMarket.js +++ b/src/api/distribution/directGoMarket.js @@ -109,3 +109,14 @@ export const postUploadSignPhoto = data => { data, }); }; + +/** + * 上传签收图片 + */ +export const postSignOrderZeroSuppleList = data => { + return request({ + url: '/api/logpm-trunkline/carsLoad/signOrderZeroSuppleList', + method: 'post', + data, + }); +}; diff --git a/src/option/distribution/VehicleArrivalManagement.js b/src/option/distribution/VehicleArrivalManagement.js index 1aa68d1d..aedea67b 100644 --- a/src/option/distribution/VehicleArrivalManagement.js +++ b/src/option/distribution/VehicleArrivalManagement.js @@ -386,244 +386,3 @@ export const columnList = [ sortable: false, }, ]; - -/** 装车详情列表 */ -export const detailsColumnList = [ - { - prop: '', - label: '复选框', - type: 0, - width: 55, - fixed: true, - }, - { - prop: '', - label: '序号', - type: 12, - values: '', - width: 55, - fixed: true, - }, - { - prop: 'orderCode', - label: '运单号', - type: 6, - values: '', - width: '150', - checkarr: [], - fixed: true, - sortable: true, - head: false, - }, - { - prop: 'orderCode', - label: '合同号', - type: 6, - values: '', - width: '150', - checkarr: [], - fixed: true, - sortable: true, - head: false, - }, - { - prop: 'orderPackageCode', - label: '包条码', - type: 6, - values: '', - width: '200', - checkarr: [], - fixed: false, - sortable: true, - }, - { - prop: 'driverName', - label: '计划目的地', - type: 1, - values: '', - width: '130', - checkarr: [], - fixed: false, - sortable: true, - }, - { - prop: 'driverPhone', - label: '目的地', - type: 1, - values: '', - width: '130', - checkarr: [], - fixed: false, - sortable: true, - }, - { - prop: 'warehouseName', - label: '装卸状态', - type: 1, - values: '', - width: '130', - checkarr: [], - fixed: false, - sortable: true, - }, - { - prop: 'lineNameTitle', - label: '订单来源', - type: 1, - values: '', - width: '130', - checkarr: [], - fixed: false, - sortable: true, - }, - { - prop: 'nodeNub', - label: '装车仓库', - type: 1, - values: '', - width: '130', - checkarr: [], - fixed: false, - sortable: true, - }, - { - prop: 'startTime', - label: '扫码时间', - type: 1, - values: '', - width: '130', - checkarr: [], - fixed: false, - sortable: true, - }, - { - prop: 'endTime', - label: '装卸仓库', - type: 1, - values: '', - width: '130', - checkarr: [], - fixed: false, - sortable: true, - }, - { - prop: 'planVolume', - label: '卸车时间', - type: 1, - values: '', - width: '130', - checkarr: [], - fixed: false, - sortable: true, - }, - { - prop: 'billladingStatus', - label: '装车类型', - type: 1, - values: '', - width: '130', - checkarr: [], - fixed: false, - sortable: true, - }, - { - prop: 'chargeType', - label: '是否补录', - type: 1, - values: '', - width: '130', - checkarr: [], - fixed: false, - sortable: true, - }, - { - prop: 'totalFee', - label: '是否齐套', - type: 1, - values: '', - width: '150', - checkarr: [], - fixed: false, - sortable: true, - }, - { - prop: 'remark', - label: '托盘码', - type: 1, - values: '', - width: '150', - checkarr: [], - fixed: false, - sortable: true, - }, - { - prop: 'carrierName', - label: '一级品类', - type: 1, - values: '', - width: '130', - checkarr: [], - fixed: false, - sortable: true, - }, - { - prop: 'waybillCount', - label: '二级品类', - type: 1, - values: '', - width: '130', - checkarr: [], - fixed: false, - sortable: true, - }, - { - prop: 'totalNum', - label: '三级品类', - type: 1, - values: '', - width: '130', - checkarr: [], - fixed: false, - sortable: true, - }, - { - prop: 'totalWeight', - label: '物料名称', - type: 1, - values: '', - width: '130', - checkarr: [], - fixed: false, - sortable: true, - }, - { - prop: 'totalVolume', - label: '装车扫描人', - type: 1, - values: '', - width: '130', - checkarr: [], - fixed: false, - sortable: true, - }, - { - prop: 'createUserName', - label: '卸车人', - type: 1, - values: '', - width: '130', - checkarr: [], - fixed: false, - sortable: true, - }, - { - prop: 'totalWeight', - label: '同步状态', - type: 1, - values: '', - width: '130', - checkarr: [], - fixed: false, - sortable: true, - }, -]; diff --git a/src/option/distribution/VehicleStowage.js b/src/option/distribution/VehicleStowage.js index 0a33a0ce..144eca68 100644 --- a/src/option/distribution/VehicleStowage.js +++ b/src/option/distribution/VehicleStowage.js @@ -398,247 +398,6 @@ export const columnList = [ }, ]; -/** 装车详情列表 */ -export const detailsColumnList = [ - { - prop: '', - label: '复选框', - type: 0, - width: 55, - fixed: true, - }, - { - prop: '', - label: '序号', - type: 12, - values: '', - width: 55, - fixed: true, - }, - { - prop: 'orderCode', - label: '运单号', - type: 13, - values: '', - width: '150', - checkarr: [], - fixed: true, - sortable: true, - head: false, - }, - { - prop: 'orderCode', - label: '合同号', - type: 13, - values: '', - width: '150', - checkarr: [], - fixed: true, - sortable: true, - head: false, - }, - { - prop: 'orderPackageCode', - label: '包条码', - type: 13, - values: '', - width: '200', - checkarr: [], - fixed: false, - sortable: true, - }, - { - prop: 'driverName', - label: '计划目的地', - type: 1, - values: '', - width: '130', - checkarr: [], - fixed: false, - sortable: true, - }, - { - prop: 'driverPhone', - label: '目的地', - type: 1, - values: '', - width: '130', - checkarr: [], - fixed: false, - sortable: true, - }, - { - prop: 'warehouseName', - label: '装卸状态', - type: 1, - values: '', - width: '130', - checkarr: [], - fixed: false, - sortable: true, - }, - { - prop: 'lineNameTitle', - label: '订单来源', - type: 1, - values: '', - width: '130', - checkarr: [], - fixed: false, - sortable: true, - }, - { - prop: 'nodeNub', - label: '装车仓库', - type: 1, - values: '', - width: '130', - checkarr: [], - fixed: false, - sortable: true, - }, - { - prop: 'startTime', - label: '扫码时间', - type: 1, - values: '', - width: '130', - checkarr: [], - fixed: false, - sortable: true, - }, - { - prop: 'endTime', - label: '装卸仓库', - type: 1, - values: '', - width: '130', - checkarr: [], - fixed: false, - sortable: true, - }, - { - prop: 'planVolume', - label: '卸车时间', - type: 1, - values: '', - width: '130', - checkarr: [], - fixed: false, - sortable: true, - }, - { - prop: 'billladingStatus', - label: '装车类型', - type: 1, - values: '', - width: '130', - checkarr: [], - fixed: false, - sortable: true, - }, - { - prop: 'chargeType', - label: '是否补录', - type: 1, - values: '', - width: '130', - checkarr: [], - fixed: false, - sortable: true, - }, - { - prop: 'totalFee', - label: '是否齐套', - type: 1, - values: '', - width: '150', - checkarr: [], - fixed: false, - sortable: true, - }, - { - prop: 'remark', - label: '托盘码', - type: 1, - values: '', - width: '150', - checkarr: [], - fixed: false, - sortable: true, - }, - { - prop: 'carrierName', - label: '一级品类', - type: 1, - values: '', - width: '130', - checkarr: [], - fixed: false, - sortable: true, - }, - { - prop: 'waybillCount', - label: '二级品类', - type: 1, - values: '', - width: '130', - checkarr: [], - fixed: false, - sortable: true, - }, - { - prop: 'totalNum', - label: '三级品类', - type: 1, - values: '', - width: '130', - checkarr: [], - fixed: false, - sortable: true, - }, - { - prop: 'totalWeight', - label: '物料名称', - type: 1, - values: '', - width: '130', - checkarr: [], - fixed: false, - sortable: true, - }, - { - prop: 'totalVolume', - label: '装车扫描人', - type: 1, - values: '', - width: '130', - checkarr: [], - fixed: false, - sortable: true, - }, - { - prop: 'createUserName', - label: '卸车人', - type: 1, - values: '', - width: '130', - checkarr: [], - fixed: false, - sortable: true, - }, - { - prop: 'totalWeight', - label: '同步状态', - type: 1, - values: '', - width: '130', - checkarr: [], - fixed: false, - sortable: true, - }, -]; - /** 对比报表 -- 仓库节点 */ export const warehouseNodeColumnList = [ { diff --git a/src/option/distribution/abnormalList.js b/src/option/distribution/abnormalList.js index 22d4b4ce..69ed5b55 100644 --- a/src/option/distribution/abnormalList.js +++ b/src/option/distribution/abnormalList.js @@ -104,28 +104,37 @@ export const columnList = [ fixed: false, sortable: true, }, - // { - // prop: 'orderPackageCode', - // label: '装车异常', - // type: 2, - // values: '', - // width: '150', - // checkarr: [], - // fixed: true, - // sortable: true, - // head: false, - // }, - // { - // prop: 'orderPackageCode', - // label: '卸车异常', - // type: 2, - // values: '', - // width: '150', - // checkarr: [], - // fixed: true, - // sortable: true, - // head: false, - // }, + { + prop: 'isZeroName', + label: '是否零担', + type: 1, + values: '', + width: '150', + checkarr: [ + { + label: '是', + value: '1', + }, + { + label: '否', + value: '0', + }, + ], + fixed: false, + sortable: true, + head: false, + }, + { + prop: 'num', + label: '数量', + type: 1, + values: '', + width: '150', + checkarr: [], + fixed: false, + sortable: true, + head: false, + }, { prop: 'upUserName', label: '上报人', diff --git a/src/option/distribution/arteryDistrilbutionBillLadingList.js b/src/option/distribution/arteryDistrilbutionBillLadingList.js index ca9e7f57..ee74213c 100644 --- a/src/option/distribution/arteryDistrilbutionBillLadingList.js +++ b/src/option/distribution/arteryDistrilbutionBillLadingList.js @@ -423,6 +423,16 @@ export const columnDetailList = [ // fixed: false, // sortable: true, // }, + { + prop: 'trayName', + label: '托盘名称', + type: 2, + values: '', + width: '130', + checkarr: [], + fixed: false, + sortable: true, + }, { prop: 'trayCode', label: '托盘码', diff --git a/src/views/distribution/artery/VehicleStowage.vue b/src/views/distribution/artery/VehicleStowage.vue index 45f64236..841fd874 100644 --- a/src/views/distribution/artery/VehicleStowage.vue +++ b/src/views/distribution/artery/VehicleStowage.vue @@ -241,7 +241,7 @@ 零担补录 - 直发签收零担补录 - + --> @@ -135,13 +136,13 @@
- +
零担签收
+ +
+
+ +
+ +
+
+ + + + + + + +
+
勾选数量: {{ details.zeroInfo.selectionList.length }}
+ + + +
+ +
+
+
+ 关 闭 + 提 交 +
+
+ + ({ loading: false, /** 更新归属仓库 */ editWarehouseLoading: false, + zeroLoading: false, }, /** 列表复选框选中的数据 */ selectionList: [], @@ -434,6 +508,8 @@ const details = reactive({ transferVisited: false, /** 签收包件详情 */ SiginOrderDetailsVisited: false, + /** 直发商家零担补录 */ + directGoMarketVisited: false, /** 更新签收单归属仓库 */ editWarehouseVisited: false, /** 上传签收图片 */ @@ -510,6 +586,21 @@ const details = reactive({ }, data: [], }, + /** 直发零担补录数据 */ + zeroInfo: { + columnList: deepClone(oldColumnList), + /** 复选框被选中数据 */ + selectionList: [], + /** 查询数据 */ + query: {}, + /** 分页参 */ + page: { + pageNum: 1, + pageSize: 30, + total: 0, + }, + data: [], + }, /** 预览图片地址 */ dialogImageUrl: '', /** 上传图片文件list */ @@ -539,6 +630,8 @@ const $route = useRoute(); const tableNodeRef = ref(); +const zeroTableRef = ref(); + // vuex实例 const $store = useStore(); @@ -734,8 +827,23 @@ const selectsc = (index, row) => { }; /** 表格表头复选框选择 */ -const selectionChange = (list: any) => { - details.selectionList = list; +const selectionChange = (list: any, type) => { + switch (type) { + // 详情 + case 2: + details.detailsInfo.selectionList = list; + break; + + // 零担直发商家 + case 3: + details.zeroInfo.selectionList = list; + break; + + // 签收外层 + default: + details.selectionList = list; + break; + } }; /** 每页数量改变执行的回调 */ @@ -747,6 +855,12 @@ const sizeChange = (pageSize: number, type) => { onLoadDetails(); break; + // 零担直发商家 + case 3: + details.zeroInfo.page.pageSize = pageSize; + initZeroData(); + break; + // 签收外层 default: details.page.pageSize = pageSize; @@ -764,6 +878,12 @@ const currentChange = (pageNum: number, type) => { onLoadDetails(); break; + // 零担直发商家 + case 3: + details.zeroInfo.page.pageNum = pageNum; + initZeroData(); + break; + // 签收外层 default: details.page.pageNum = pageNum; @@ -786,6 +906,80 @@ const handleShowDetails = ({ row }) => { onLoadDetails(); }; +/** 零担补录数据 */ +const initZeroData = async () => { + try { + details.loadingObj.zeroLoading = true; + + const submitData = { + ...details.zeroInfo.query, + ...details.zeroInfo.page, + signOrderId: details.showDetailsSiginOrder.id, + }; + + const res = await postSignOrderZeroSuppleList(submitData); + + const { code, data } = res.data; + console.log('data :>> ', data); + if (code !== 200) return; + details.zeroInfo.data = data.records || []; + details.zeroInfo.page.total = data.total; + } catch (error) { + console.log('error :>> ', error); + } finally { + details.loadingObj.zeroLoading = false; + } +}; + +/** 显示零担补录弹窗 */ +const handleShowZero = async ({ row }) => { + details.showDetailsSiginOrder = row; + + details.popUpShow.directGoMarketVisited = true; + + initZeroData(); + + await nextTick(); + setNodeHeight(zeroTableRef.value.$el, '60vh'); +}; + +const handleZeroSubmit = async () => { + try { + details.loadingObj.zeroLoading = true; + + if (details.zeroInfo.selectionList.length === 0) return ElMessage.warning('请选择补录数据'); + + const submitData = { + loadId: details.pageInfo.loadId, + zeroSuppleList: [], + }; + + for (const iterator of details.zeroInfo.selectionList) { + const _obj = { + orderCode: iterator.orderCode, + waybillNo: iterator.waybillNo, + enterNum: iterator.stockNum || 0, + finalNodeId: details.showDetailsSiginOrder.loadId, + signOrderId: details.showDetailsSiginOrder.id, + }; + + submitData.zeroSuppleList.push(_obj); + } + + console.log('submitData :>> ', submitData); + const res = await postAddZeroSupple(submitData); + + const { code } = res.data; + if (code !== 200) return ElMessage.error('提交失败'); + ElMessage.success('提交成功'); + initZeroData(); + } catch (error) { + console.log('error :>> ', error); + } finally { + details.loadingObj.zeroLoading = false; + } +}; + /** 签收 -- 订单 */ const handleOrderSigin = async ({ row }) => { if (!ChecksWhetherTheWarehouseIsSelected())