From 5b1c84423d590c7240209fa9a68d33c0116457af Mon Sep 17 00:00:00 2001
From: shiyunteng <shiyunteng@example.com>
Date: 星期二, 26 五月 2026 17:27:03 +0800
Subject: [PATCH] feat:测试调整

---
 platformx-business-finance-biz/src/main/java/com/by4cloud/platformx/business/service/impl/OutBoundServiceImpl.java |   83 +++++++++++++++++++++--------------------
 1 files changed, 43 insertions(+), 40 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 9507420..3b5e5e9 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
@@ -62,11 +62,11 @@
 			return R.failed("娌℃湁鏌ヨ鍒扮浉鍏冲悎鍚岃鍗�");
 		}
 		List<String> erpCodeList = subjectMatterList.stream().map(ContractSubjectMatter::getMaterialCode).collect(Collectors.toList());
-		BigDecimal orderNum = subjectMatterList.stream().filter(item ->item.getDeliveryStatus()!=2)
-				.map(item ->item.getDeliveryStatus()==0?item.getQuantity():item.getRemainingQuantity())
+		BigDecimal orderNum = subjectMatterList.stream().filter(item -> item.getDeliveryStatus() != 2)
+				.map(item -> item.getDeliveryStatus() == 0 ? item.getQuantity() : item.getRemainingQuantity())
 				.reduce(BigDecimal.ZERO, BigDecimal::add);
 		BigDecimal outTotal = addDTO.getSubjectMatterList().stream()
-				.filter(item->erpCodeList.contains(item.getSubjectMatterCode()))
+				.filter(item -> erpCodeList.contains(item.getSubjectMatterCode()))
 				.map(OutSubjectMatterAddDTO::getOutBoundNum)
 				.filter(num -> num != null) // 杩囨护鎺� null 鍊硷紝闃叉 NullPointerException
 				.reduce(BigDecimal.ZERO, BigDecimal::add);
@@ -102,7 +102,7 @@
 							contractSubjectMatterMapper.updateById(subjectMatter);
 							currentOutMap.put(subjectMatter.getContractId(), subjectMatter);
 							//鏂板鍚堝悓鍑哄簱鍘嗗彶
-							saveContractOutBound(contract, addDTO, subjectMatter,outBound.getId());
+							saveContractOutBound(contract, addDTO, subjectMatter, outBound.getId());
 						} else {
 							BigDecimal currentOut = remainNum.add(subjectMatter.getRemainingQuantity());
 							subjectMatter.setDeliveredQuantity(subjectMatter.getQuantity().add(remainNum));
@@ -113,7 +113,7 @@
 							contractSubjectMatterMapper.updateById(subjectMatter);
 							currentOutMap.put(subjectMatter.getContractId(), subjectMatter);
 							//鏂板鍚堝悓鍑哄簱鍘嗗彶
-							saveContractOutBound(contract, addDTO, subjectMatter,outBound.getId());
+							saveContractOutBound(contract, addDTO, subjectMatter, outBound.getId());
 							break;
 						}
 
@@ -129,7 +129,7 @@
 							contractSubjectMatterMapper.updateById(subjectMatter);
 							currentOutMap.put(subjectMatter.getContractId(), subjectMatter);
 							//鏂板鍚堝悓鍑哄簱鍘嗗彶
-							saveContractOutBound(contract, addDTO, subjectMatter,outBound.getId());
+							saveContractOutBound(contract, addDTO, subjectMatter, outBound.getId());
 						} else {
 							BigDecimal currentOut = remainNum.add(subjectMatter.getQuantity());
 							subjectMatter.setDeliveredQuantity(subjectMatter.getQuantity().add(remainNum));
@@ -140,7 +140,7 @@
 							contractSubjectMatterMapper.updateById(subjectMatter);
 							currentOutMap.put(subjectMatter.getContractId(), subjectMatter);
 							//鏂板鍚堝悓鍑哄簱鍘嗗彶
-							saveContractOutBound(contract, addDTO, subjectMatter,outBound.getId());
+							saveContractOutBound(contract, addDTO, subjectMatter, outBound.getId());
 							break;
 						}
 					}
@@ -200,41 +200,41 @@
 
 							//鏌ヨ涔嬪墠鎵�鏈夊彂璐у墠搴旀敹
 							List<PaymentConfirm> fhConfirmList = paymentConfirmMapper.selectList(Wrappers.<PaymentConfirm>lambdaQuery().eq(PaymentConfirm::getContractId, contract.getId())
-									.eq(PaymentConfirm::getScheduleId,schedule.getId()).orderByDesc(PaymentConfirm::getCreateTime));
-							BigDecimal fhTotalAmount = fhConfirmList.stream().map(item->item.getTransationAmount()).reduce(BigDecimal.ZERO,BigDecimal::add);
+									.eq(PaymentConfirm::getScheduleId, schedule.getId()).orderByDesc(PaymentConfirm::getCreateTime));
+							BigDecimal fhTotalAmount = fhConfirmList.stream().map(item -> item.getTransationAmount()).reduce(BigDecimal.ZERO, BigDecimal::add);
 							//鏈鍙戣揣鍓嶅簲鏀� 鍑哄簱鎬婚 - 鎵�鏈夊彂璐у墠搴旀敹
 							paymentConfirm.setTransationAmount(paymentConfirm.getTransationAmount().subtract(fhTotalAmount));
 							paymentConfirm.setReceivableAmount(paymentConfirm.getTransationAmount());
 							paymentConfirm.setTotalAmount(lastConfirm.getTotalAmount().subtract(paymentConfirm.getTransationAmount()));
-							if(schedule.getPaymentRatio().compareTo(new BigDecimal("0"))>0) {
+							if (schedule.getPaymentRatio().compareTo(new BigDecimal("0")) > 0) {
 								paymentConfirmMapper.insert(paymentConfirm);
 							}
 						} else {
 							//涓嶅瓨鍦ㄥ彂璐у簲鏀� 鍑哄簱鎬婚
 							paymentConfirm.setTotalAmount(lastConfirm.getTotalAmount().subtract(paymentConfirm.getTransationAmount()));
-							if(schedule.getPaymentRatio().compareTo(new BigDecimal("0"))>0) {
+							if (schedule.getPaymentRatio().compareTo(new BigDecimal("0")) > 0) {
 								paymentConfirmMapper.insert(paymentConfirm);
 							}
 						}
 					} else {
 						//鏃犱箣鍓嶉樁娈靛簲鏀�
 						paymentConfirm.setTotalAmount(paymentConfirm.getTransationAmount().multiply(new BigDecimal("-1")));
-						if(schedule.getPaymentRatio().compareTo(new BigDecimal("0"))>0) {
+						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)){
+							if (ArrayUtil.isNotEmpty(customerCompleteContractList)) {
 								List<BigDecimal> outAmountList = new ArrayList<>();
-								for (Contract completeContract:customerCompleteContractList
+								for (Contract completeContract : customerCompleteContractList
 								) {
-									PaymentConfirm contractLastConfirm = paymentConfirmMapper.selectOne(Wrappers.<PaymentConfirm>lambdaQuery().eq(PaymentConfirm::getContractId,completeContract.getId())
+									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){
+									if (contractLastConfirm.getTotalAmount().compareTo(new BigDecimal("0")) > 0) {
 										//鏂板瀹屾垚浠樻鍚堝悓 璧勯噾杞嚭
-										PaymentConfirm outConfirm = BeanUtil.copyProperties(contractLastConfirm,PaymentConfirm.class,"id","transationAmount",
-												"advanceAmount","receivableAmount","overdueAmount","totalAmount");
+										PaymentConfirm outConfirm = BeanUtil.copyProperties(contractLastConfirm, PaymentConfirm.class, "id", "transationAmount",
+												"advanceAmount", "receivableAmount", "overdueAmount", "totalAmount");
 										outConfirm.setBusinessType("璧勯噾杞嚭");
 										outConfirm.setConfirmTime(new Date());
 										outConfirm.setTransationAmount(contractLastConfirm.getTotalAmount());
@@ -243,25 +243,28 @@
 										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);
+								if (ArrayUtil.isNotEmpty(outAmountList.toArray())) {
+									BigDecimal currentInSum = outAmountList.stream().reduce(BigDecimal.ZERO, BigDecimal::add);
+									//鏂板褰撳墠鍚堝悓 璧勯噾杞叆
+									PaymentConfirm inConfirm = BeanUtil.copyProperties(paymentConfirm, PaymentConfirm.class, "id", "transationAmount",
+											"advanceAmount", "receivableAmount", "overdueAmount", "totalAmount");
+									inConfirm.setBusinessType("璧勯噾杞叆");
+									inConfirm.setConfirmTime(new Date());
+									inConfirm.setTransationAmount(currentInSum);
+									inConfirm.setTotalAmount(paymentConfirm.getTotalAmount().add(currentInSum));
+									//鏇存柊褰撳墠闃舵瀹為檯鏀舵 鍜� 鏀舵鐘舵��
+									schedule.setActualAmount(inConfirm.getTransationAmount());
+									schedule.setPaymentStatus(2);
+									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")));
+										schedule.setActualAmount(paymentConfirm.getTotalAmount().subtract(currentInSum));
+										schedule.setPaymentStatus(1);
 									}
+									paymentConfirmMapper.insert(inConfirm);
+									//鏇存柊褰撳墠闃舵瀹為檯鏀舵 鍜� 鏀舵鐘舵��
+									scheduleMapper.updateById(schedule);
 								}
 							}
 						}
@@ -332,7 +335,7 @@
 								lastNewTotal = lastNewConfirm.getTotalAmount();
 							}
 							newConfim.setTotalAmount(lastNewTotal.subtract(newConfim.getReceivableAmount()));
-							if(endSchedule.getPaymentRatio().compareTo(new BigDecimal("0"))>0) {
+							if (endSchedule.getPaymentRatio().compareTo(new BigDecimal("0")) > 0) {
 								paymentConfirmMapper.insert(newConfim);
 							}
 						}
@@ -352,9 +355,9 @@
 						contract.setNextScheduleName("鏃�");
 						contractMapper.updateById(contract);
 						//褰撳墠涓哄悎鍚屾渶鍚庨樁娈�
-						PaymentConfirm lastNewConfirm = paymentConfirmMapper.selectOne(Wrappers.<PaymentConfirm>lambdaQuery().eq(PaymentConfirm::getContractId,contract.getId())
+						PaymentConfirm lastNewConfirm = paymentConfirmMapper.selectOne(Wrappers.<PaymentConfirm>lambdaQuery().eq(PaymentConfirm::getContractId, contract.getId())
 								.orderByDesc(PaymentConfirm::getCreateTime).last("limit 1"));
-						if (lastNewConfirm.getTotalAmount().compareTo(new BigDecimal("0"))>=0){
+						if (lastNewConfirm.getTotalAmount().compareTo(new BigDecimal("0")) >= 0) {
 							//鏈夐浠樹笖瓒呰繃搴旀敹 鍏抽棴鍚堝悓鐘舵��
 							contract.setContractStatus(3);
 							contractMapper.updateById(contract);
@@ -367,7 +370,7 @@
 		return R.ok();
 	}
 
-	private void saveContractOutBound(Contract contract, OutBoundAddDTO addDTO, ContractSubjectMatter subjectMatter,Long outBoundId) {
+	private void saveContractOutBound(Contract contract, OutBoundAddDTO addDTO, ContractSubjectMatter subjectMatter, Long outBoundId) {
 		ContractOutBound contractOutBound = new ContractOutBound();
 		contractOutBound.setContractId(contract.getId());
 		contractOutBound.setContractName(contract.getContractName());

--
Gitblit v1.9.1