Browse Source

修复开单bug, 重新对接对账预存单

dev-xx
qb 6 months ago
parent
commit
41ebd22421
  1. 14
      src/api/finance/ReconciliationDepositSlip.js
  2. 618
      src/option/finance/ReconciliationDepositSlip.js
  3. 1
      src/views/distribution/artery/TripartiteTransfer.vue
  4. 4
      src/views/distribution/artery/truckLoadingDetails.vue
  5. 12
      src/views/distribution/inventory/CreateOrder.vue
  6. 94
      src/views/finance/ReconciliationDepositSlip.vue
  7. 2
      src/views/finance/WaybillAudit.vue

14
src/api/finance/ReconciliationDepositSlip.js

@ -49,3 +49,17 @@ export const postReal = data => {
method: 'patch',
});
};
/**
* 生成对账单
* @param {*} data
* @returns
*/
export const postCreateReconciliationOrder = data => {
return request({
url: '/api/logpm-statisticsdata/merchantStatistics/createReconciliationOrder',
method: 'post',
data,
});
};
//

618
src/option/finance/ReconciliationDepositSlip.js

@ -1,5 +1,4 @@
// toB
export const columnListByToB = [
export const columnList = [
{
prop: '',
label: '复选框',
@ -95,608 +94,18 @@ export const columnListByToB = [
{
prop: 'signStatusName',
label: '签收状态',
type: 1,
values: '',
width: '150',
checkarr: [],
fixed: false,
sortable: true,
head: false,
},
{
prop: 'typeServiceName',
label: '订单类型',
type: 1,
values: '',
width: '150',
checkarr: [],
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: 'systemTotalFee',
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: 'warehouseManagementFee',
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: 'warehouseOprationFee',
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: 'deliveryHandlingFee',
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',
checkarr: [],
fixed: false,
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: 'deliveryLineFee',
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: 'shipperName',
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: 'consigneeName',
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 },
{ label: '未签收', value: 0 },
{ label: '部分签收', value: 1 },
{ label: '已签收', value: 2 },
],
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: [],
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,
},
];
// toC
export const columnListByToC = [
{
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: 1,
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: 1,
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: 1,
values: '',
width: '150',
checkarr: [],
fixed: false,
sortable: true,
head: false,
},
{
prop: 'departureWarehouseName',
label: '发站仓',
type: 1,
values: '',
width: '150',
checkarr: [],
fixed: false,
sortable: true,
head: false,
},
{
prop: 'signStatusName',
label: '签收状态',
type: 1,
values: '',
width: '150',
checkarr: [],
fixed: false,
sortable: true,
head: false,
},
{
prop: 'typeServiceName',
label: '订单类型',
@ -764,7 +173,7 @@ export const columnListByToC = [
head: false,
},
{
prop: 'systemTotalFee',
prop: 'sysTotalFee',
label: '订单开单价',
type: 1,
values: '',
@ -852,7 +261,7 @@ export const columnListByToC = [
head: false,
},
{
prop: 'warehouseManagementFee',
prop: 'warehouseManageFee',
label: '仓储管理费',
type: 1,
values: '',
@ -874,7 +283,7 @@ export const columnListByToC = [
head: false,
},
{
prop: 'warehouseOprationFee',
prop: 'warehouseOperatingFee',
label: '仓储操作费',
type: 1,
values: '',
@ -918,7 +327,7 @@ export const columnListByToC = [
head: false,
},
{
prop: 'deliveryHandlingFee',
prop: 'deliveryLoadingFee',
label: '配送装卸费',
type: 1,
values: '',
@ -973,7 +382,7 @@ export const columnListByToC = [
head: false,
},
{
prop: 'deliveryLineFee',
prop: 'deliveryCrossingFee',
label: '超区公里费',
type: 1,
values: '',
@ -1006,7 +415,7 @@ export const columnListByToC = [
head: false,
},
{
prop: 'shipperName',
prop: 'shipperPerson',
label: '发货人',
type: 2,
values: '',
@ -1050,7 +459,7 @@ export const columnListByToC = [
head: false,
},
{
prop: 'consigneeName',
prop: 'consigneePerson',
label: '收货人',
type: 2,
values: '',
@ -1158,7 +567,10 @@ export const columnListByToC = [
type: 1,
values: '',
width: '150',
checkarr: [],
checkarr: [
{ label: '是', value: 1 },
{ label: '否', value: 0 },
],
fixed: false,
sortable: true,
head: false,

1
src/views/distribution/artery/TripartiteTransfer.vue

@ -948,6 +948,7 @@ const handleShowTruckLoadingDetails = ({ row }) => {
loadId: row.id,
name: row.carsNo + '--' + '装车明细',
type: 'TripartiteTransfer',
deliveryType: row.deliveryType,
},
});
};

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

@ -1480,6 +1480,10 @@ const handleBatchSigin = async () => {
for (let i = 0; i < details.selectionList.length; i++) {
const value = details.selectionList[i];
if (Number($route.query.deliveryType) === 1 && Number(value.scanStatus) === 1) {
return ElMessage.warning('存在未卸车数据,请卸车后再签收')
}
//
if (Number(value.scanStatus) === 3) continue;
loadScanIds.push(value.id);

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

@ -4395,11 +4395,17 @@ const handleAssignmentItemPrice = (value, isOnload = false, chargeType?: number
//
if (pickup && template) {
handleAssignmentItemPricePickUp(value, pickup, template);
} else value.pickupPrice = 0;
} else{
value.pickupPrice = 0;
value.systemPickupChargeType = 1;
}
//
if (dispatch && template) handleAssignmentItemPriceDispatch(value, dispatch, template);
else value.deliveryPrice = 0;
else{
value.deliveryPrice = 0;
value.systemDeliveryChargeType = 1;
}
//
handleAssignmentItemPriceWarehouseManagementPrice(value, warehouse, template);
@ -4705,6 +4711,8 @@ const handleSubmitPackage = () => {
goodsListOptions: [],
};
console.log('_obj :>> ', _obj);
_goodsArr.push(_obj);
handleAssignmentItemPrice(_obj);

94
src/views/finance/ReconciliationDepositSlip.vue

@ -152,7 +152,7 @@ import dayjs from 'dayjs';
import { mapGetters } from 'vuex';
/** 获取字典 */
import { getDictionaryBiz } from '@/api/system/dict';
import { postPageList, postCheckBalance, postReal,postOrderInfoListExport } from '@/api/finance/ReconciliationDepositSlip';
import { postPageList, postCheckBalance, postReal,postOrderInfoListExport, postCreateReconciliationOrder } from '@/api/finance/ReconciliationDepositSlip';
import {
downloadXls,
setNodeHeight,
@ -163,7 +163,7 @@ import {
handleTranslationDataSeclect,
getObjType
} from '@/utils/util';
import { columnListByToB, columnListByToC,confirmColumnList } from '@/option/finance/ReconciliationDepositSlip';
import { columnList, confirmColumnList } from '@/option/finance/ReconciliationDepositSlip';
import { useRouter } from 'vue-router';
import { deepClone } from '@/utils/util';
import { ElMessage, ElMessageBox } from 'element-plus';
@ -176,19 +176,21 @@ const details = reactive<any>({
search: true,
pageInfo: [
{
title: 'toB',
columnList: deepClone(columnListByToB),
//
title: 'toB订单对账',
//
columnList: deepClone(columnList),
//
query: {},
name: 1
},
{
title: 'toC',
columnList: deepClone(columnListByToC),
title: 'toC订单对账',
columnList: deepClone(columnList),
query: {},
name: 2
}
],
/** 表格搜索条件 */
/** 时间快捷选择设置 */
shortcuts: [
{
@ -287,6 +289,7 @@ const onLoad = async () => {
if (code !== 200) return;
details.data = data.records;
details.page.total = data.total;
console.log('columnList :>> ', columnList);
handleTranslationDataSeclect(
details.data,
columnList
@ -300,13 +303,65 @@ const onLoad = async () => {
}
};
const handleData = (key, res) => {
const { code, data } = res.data;
if (code !== 200) return;
for (let i = 0; i < details.pageInfo[0].columnList.length; i++) {
const value = details.pageInfo[0].columnList[i];
if (value.label === key)
return (value.checkarr =
getObjType(data) === 'array'
? data.map(val => {
val.label = val.dictValue;
val.value = val.dictKey;
return val;
})
: []);
}
for (let i = 0; i < details.pageInfo[1].columnList.length; i++) {
const value = details.pageInfo[1].columnList[i];
if (value.label === key)
return (value.checkarr =
getObjType(data) === 'array'
? data.map(val => {
val.label = val.dictValue;
val.value = val.dictKey;
return val;
})
: []);
}
};
const initData = async ()=>{
await Promise.all([
//
getDictionaryBiz('distribution_type').then(res => handleData('订单类型', res)),
//
getDictionaryBiz('open_order_pay_type').then(res => handleData('支付方式', res)),
//
getDictionaryBiz('open_order_pay_way').then(res => handleData('付款方式', res)),
initOnLoad()
])
await nextTick();
const {columnList} = ( details.pageStatus === 1 ?details.pageInfo[0]: details.pageInfo[1])
handleTranslationDataSeclect(
details.data,
columnList
);
}
/** 初始化请求 */
const initOnLoad = () => {
details.page.pageNum = 1;
details.page.total = 0;
onLoad();
return onLoad()
};
initOnLoad();
initData();
/** 搜索 */
const searchChange = () => {
@ -421,18 +476,24 @@ const handleConfirm = async () => {
if (details.selectionList.length === 0) return ElMessage.warning('请选择需要确认的数据');
const _errorArr = [];
const _arr = [];
//
let _destinationWarehouseName = ''
//
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
}
if (Number(value.confirmStatisticsOrder) === 1) _errorArr.push(value.orderNo);
_arr.push(value.orderInfoId);
if (value.consignee !== _consignee) return ElMessage.warning(`收货单位不一致,请移除不一致数据`)
if (value.destinationWarehouseName !== _destinationWarehouseName) return ElMessage.warning(`目的仓不一致,请移除不一致数据`)
if (Number(value.signStatus) !== 2) return ElMessage.warning(`存在未签收完成的数据`)
}
if (_errorArr.length > 0)
return ElMessage.warning(`订单【 ${_errorArr.join('、')} 】-- 已确认,请勿重复确认`);
details.popUpShow.confirmVisited = true
await nextTick()
const _node = document.querySelector(`.confirmVisited .maboxhi`);
@ -445,6 +506,7 @@ const handleSubmitConfrim= ()=>{
cancelButtonText: '取消',
type: 'warning',
}).then(async () => {
details.popUpShow.confirmVisited = false
try {
details.loadingObj.pageLoading = true;
@ -452,7 +514,7 @@ const handleSubmitConfrim= ()=>{
orderInfoIds: details.selectionList.map(val => val.orderInfoId),
};
const res = await postCheckBalance(submitData);
const res = await postCreateReconciliationOrder(submitData);
const { code, msg } = res.data;
if (code !== 200) return msg && ElMessage.warning(msg);

2
src/views/finance/WaybillAudit.vue

@ -378,7 +378,7 @@ const handleData = (key, res) => {
};
const initData = async()=>{
await new Promise.all([
await Promise.all([
//
getDictionaryBiz('distribution_type').then(res => handleData('服务类型', res)),
//

Loading…
Cancel
Save