From a422a984cfa2a5a2bbe89c6fa6947363e559bb4f Mon Sep 17 00:00:00 2001
From: shiyunteng <shiyunteng@example.com>
Date: 星期五, 22 五月 2026 09:29:14 +0800
Subject: [PATCH] feat:faet:出库加批次号,合同履约加销方购方履约,到货单据必填校验,验收单据必填校验,单位新增法人、委托代理人字段 、合同出库新增erp出库ID

---
 platformx-business-finance-biz/src/main/java/com/by4cloud/platformx/business/service/impl/OutBoundServiceImpl.java |   70 ++++++++++++++++++++++++++++++-----
 1 files changed, 60 insertions(+), 10 deletions(-)

diff --git a/platformx-business-finance-biz/src/main/java/com/by4cloud/platformx/business/service/impl/OutBoundServiceImpl.java b/platformx-business-finance-biz/src/main/java/com/by4cloud/platformx/business/service/impl/OutBoundServiceImpl.java
index 0ec467d..ba953e1 100644
--- a/platformx-business-finance-biz/src/main/java/com/by4cloud/platformx/business/service/impl/OutBoundServiceImpl.java
+++ b/platformx-business-finance-biz/src/main/java/com/by4cloud/platformx/business/service/impl/OutBoundServiceImpl.java
@@ -1,6 +1,7 @@
 package com.by4cloud.platformx.business.service.impl;
 
 import cn.hutool.core.bean.BeanUtil;
+import cn.hutool.core.date.DatePattern;
 import cn.hutool.core.date.DateUtil;
 import cn.hutool.core.util.ArrayUtil;
 import cn.hutool.core.util.ObjUtil;
@@ -13,6 +14,7 @@
 import com.by4cloud.platformx.business.mapper.*;
 import com.by4cloud.platformx.business.service.OutBoundService;
 import com.by4cloud.platformx.common.core.util.R;
+import com.by4cloud.platformx.common.security.util.SecurityUtils;
 import com.github.yulichang.wrapper.MPJLambdaWrapper;
 import lombok.RequiredArgsConstructor;
 import org.springframework.stereotype.Service;
@@ -73,8 +75,16 @@
 		}
 		//褰撳墠鍏ュ簱鏍囩殑鐗�
 		Map<Long, Object> currentOutMap = new HashMap<>();
+		//鍑哄簱鎵规
+		String batchNumber = DateUtil.format(new Date(), DatePattern.PURE_DATETIME_MS_PATTERN);
 		//鍑哄簱
 		addDTO.getSubjectMatterList().stream().forEach(outSubjectMatterAddDTO -> {
+			OutBound outBound = BeanUtil.copyProperties(outSubjectMatterAddDTO, OutBound.class);
+			outBound.setBatchNumber(batchNumber);
+			outBound.setBusGuestName(addDTO.getBusGuestName());
+			outBound.setBusGuestId(addDTO.getBusGuestId());
+			outBound.setOutBoundTime(addDTO.getOutBoundTime());
+			baseMapper.insert(outBound);
 			BigDecimal remainNum = outSubjectMatterAddDTO.getOutBoundNum();
 			for (ContractSubjectMatter subjectMatter : subjectMatterList) {
 				if (outSubjectMatterAddDTO.getSubjectMatterCode().equals(subjectMatter.getMaterialCode())) {
@@ -92,7 +102,7 @@
 							contractSubjectMatterMapper.updateById(subjectMatter);
 							currentOutMap.put(subjectMatter.getContractId(), subjectMatter);
 							//鏂板鍚堝悓鍑哄簱鍘嗗彶
-							saveContractOutBound(contract, addDTO, subjectMatter);
+							saveContractOutBound(contract, addDTO, subjectMatter,outBound.getId());
 						} else {
 							BigDecimal currentOut = remainNum.add(subjectMatter.getRemainingQuantity());
 							subjectMatter.setDeliveredQuantity(subjectMatter.getQuantity().add(remainNum));
@@ -103,7 +113,7 @@
 							contractSubjectMatterMapper.updateById(subjectMatter);
 							currentOutMap.put(subjectMatter.getContractId(), subjectMatter);
 							//鏂板鍚堝悓鍑哄簱鍘嗗彶
-							saveContractOutBound(contract, addDTO, subjectMatter);
+							saveContractOutBound(contract, addDTO, subjectMatter,outBound.getId());
 							break;
 						}
 
@@ -119,7 +129,7 @@
 							contractSubjectMatterMapper.updateById(subjectMatter);
 							currentOutMap.put(subjectMatter.getContractId(), subjectMatter);
 							//鏂板鍚堝悓鍑哄簱鍘嗗彶
-							saveContractOutBound(contract, addDTO, subjectMatter);
+							saveContractOutBound(contract, addDTO, subjectMatter,outBound.getId());
 						} else {
 							BigDecimal currentOut = remainNum.add(subjectMatter.getQuantity());
 							subjectMatter.setDeliveredQuantity(subjectMatter.getQuantity().add(remainNum));
@@ -130,17 +140,13 @@
 							contractSubjectMatterMapper.updateById(subjectMatter);
 							currentOutMap.put(subjectMatter.getContractId(), subjectMatter);
 							//鏂板鍚堝悓鍑哄簱鍘嗗彶
-							saveContractOutBound(contract, addDTO, subjectMatter);
+							saveContractOutBound(contract, addDTO, subjectMatter,outBound.getId());
 							break;
 						}
 					}
 				}
 			}
-			OutBound outBound = BeanUtil.copyProperties(outSubjectMatterAddDTO, OutBound.class);
-			outBound.setBusGuestName(addDTO.getBusGuestName());
-			outBound.setBusGuestId(addDTO.getBusGuestId());
-			outBound.setOutBoundTime(addDTO.getOutBoundTime());
-			baseMapper.insert(outBound);
+
 		});
 
 		//鍑哄簱搴旀敹娆炬槑缁�
@@ -215,6 +221,49 @@
 						paymentConfirm.setTotalAmount(paymentConfirm.getTransationAmount().multiply(new BigDecimal("-1")));
 						if(schedule.getPaymentRatio().compareTo(new BigDecimal("0"))>0) {
 							paymentConfirmMapper.insert(paymentConfirm);
+							//瀹㈡埛浠樻瀹屾垚鍚堝悓
+							List<Contract> customerCompleteContractList = contractMapper.selectList(Wrappers.<Contract>lambdaQuery().eq(Contract::getPartyAId, contract.getPartyAId())
+									.eq(Contract::getPartyBId, SecurityUtils.getUser().getCompId()).apply(" amount = paid_amount"));
+							if (ArrayUtil.isNotEmpty(customerCompleteContractList)){
+								List<BigDecimal> outAmountList = new ArrayList<>();
+								for (Contract completeContract:customerCompleteContractList
+								) {
+									PaymentConfirm contractLastConfirm = paymentConfirmMapper.selectOne(Wrappers.<PaymentConfirm>lambdaQuery().eq(PaymentConfirm::getContractId,completeContract.getId())
+											.orderByDesc(PaymentConfirm::getCreateTime).last("limit 1"));
+									//鏌ヨ瀹㈡埛浠樻瀹屾垚鍚堝悓涓渶鍚庢槑缁嗛噾棰� 鏈夐鏀惰浆鍏ュ綋鍓嶅悎鍚�
+									if (contractLastConfirm.getTotalAmount().compareTo(new BigDecimal("0"))>0){
+										//鏂板瀹屾垚浠樻鍚堝悓 璧勯噾杞嚭
+										PaymentConfirm outConfirm = BeanUtil.copyProperties(contractLastConfirm,PaymentConfirm.class,"id","transationAmount",
+												"advanceAmount","receivableAmount","overdueAmount","totalAmount");
+										outConfirm.setBusinessType("璧勯噾杞嚭");
+										outConfirm.setConfirmTime(new Date());
+										outConfirm.setTransationAmount(contractLastConfirm.getTotalAmount());
+										outConfirm.setTotalAmount(new BigDecimal("0"));
+										paymentConfirmMapper.insert(outConfirm);
+										outAmountList.add(outConfirm.getTransationAmount());
+									}
+								}
+								if (ArrayUtil.isNotEmpty(outAmountList.toArray())){
+									BigDecimal currentSum = new BigDecimal("0");
+									for (BigDecimal currentAmount:outAmountList
+									) {
+										currentSum=currentSum.add(currentAmount);
+										//鏂板褰撳墠鍚堝悓 璧勯噾杞叆
+										PaymentConfirm inConfirm = BeanUtil.copyProperties(paymentConfirm,PaymentConfirm.class,"id","transationAmount",
+												"advanceAmount","receivableAmount","overdueAmount","totalAmount");
+										inConfirm.setBusinessType("璧勯噾杞叆");
+										inConfirm.setConfirmTime(new Date());
+										inConfirm.setTransationAmount(currentSum.subtract(currentAmount));
+										inConfirm.setTotalAmount(paymentConfirm.getTotalAmount().add(currentSum));
+										if (inConfirm.getTotalAmount().compareTo(new BigDecimal("0"))>0){
+											inConfirm.setAdvanceAmount(inConfirm.getTotalAmount());
+										}else if (inConfirm.getTotalAmount().compareTo(new BigDecimal("0"))<0){
+											inConfirm.setReceivableAmount(inConfirm.getTotalAmount().multiply(new BigDecimal("-1")));
+										}
+										paymentConfirmMapper.insert(inConfirm);
+									}
+								}
+							}
 						}
 					}
 
@@ -316,7 +365,7 @@
 		return R.ok();
 	}
 
-	private void saveContractOutBound(Contract contract, OutBoundAddDTO addDTO, ContractSubjectMatter subjectMatter) {
+	private void saveContractOutBound(Contract contract, OutBoundAddDTO addDTO, ContractSubjectMatter subjectMatter,Long outBoundId) {
 		ContractOutBound contractOutBound = new ContractOutBound();
 		contractOutBound.setContractId(contract.getId());
 		contractOutBound.setContractName(contract.getContractName());
@@ -328,6 +377,7 @@
 		contractOutBound.setOutBoundNum(subjectMatter.getLastDeliveredQuantity());
 		contractOutBound.setOutBoundAttNames(addDTO.getOutBoundAttNames());
 		contractOutBound.setOutBoundAttPaths(addDTO.getOutBoundAttPaths());
+		contractOutBound.setOutBoundId(outBoundId);
 		contractOutBoundMapper.insert(contractOutBound);
 	}
 }
\ No newline at end of file

--
Gitblit v1.9.1