From e7e6d39b095b6a763e54ab34631171c3de32ec9e Mon Sep 17 00:00:00 2001
From: 李白 <7387820+wjli_13439841639@user.noreply.gitee.com>
Date: 星期五, 15 五月 2026 08:33:50 +0800
Subject: [PATCH] Merge remote-tracking branch 'origin/master'

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

diff --git a/platformx-business-finance-biz/src/main/java/com/by4cloud/platformx/business/service/impl/ContractPaymentScheduleProcessServiceImpl.java b/platformx-business-finance-biz/src/main/java/com/by4cloud/platformx/business/service/impl/ContractPaymentScheduleProcessServiceImpl.java
index 4e6bf29..dcc0047 100644
--- a/platformx-business-finance-biz/src/main/java/com/by4cloud/platformx/business/service/impl/ContractPaymentScheduleProcessServiceImpl.java
+++ b/platformx-business-finance-biz/src/main/java/com/by4cloud/platformx/business/service/impl/ContractPaymentScheduleProcessServiceImpl.java
@@ -121,37 +121,51 @@
 		if (ArrayUtil.isNotEmpty(afterSchedule.toArray())&&afterSchedule.size()==1){
 			//鏈�鍚庨樁娈电敓鏁堟椂闂�
 			ContractPaymentSchedule endSchedule = afterSchedule.get(0);
-			endSchedule.setEffectiveDate(DateUtil.offsetDay(addDTO.getProcessDate(),endSchedule.getAgreedDays()));
-			endSchedule.setEffectiveEndDate(contract.getExpirationDate());
-			contractPaymentScheduleMapper.updateById(endSchedule);
-			//褰撳墠闃舵鐢熸晥鏃堕棿
-			schedule.setEffectiveDate(DateUtil.offsetDay(addDTO.getProcessDate(),schedule.getAgreedDays()));
-			schedule.setEffectiveEndDate(endSchedule.getEffectiveDate());
-			contractPaymentScheduleMapper.updateById(schedule);
-			//鏈�鍚庨樁娈靛簲鏀�
-			PaymentConfirm newConfim = new PaymentConfirm();
-			newConfim.setBusinessType(endSchedule.getStageName()+"搴旀敹");
-			newConfim.setBusGuestId(contract.getPartyAId());
-			newConfim.setBusGuestName(contract.getPartyA());
-			newConfim.setContractId(contract.getId());
-			newConfim.setContractName(contract.getContractName());
-			newConfim.setContractNo(contract.getContractNo());
-			newConfim.setScheduleId(endSchedule.getId());
-			newConfim.setScheduleName(schedule.getStageName());
-			newConfim.setConfirmTime(addDTO.getProcessDate());
-			newConfim.setTransationAmount(endSchedule.getPlannedAmount());
-			newConfim.setReceivableAmount(endSchedule.getPlannedAmount());
-			PaymentConfirm lastNewConfirm = paymentConfirmMapper.selectOne(Wrappers.<PaymentConfirm>lambdaQuery().eq(PaymentConfirm::getContractId,contract.getId())
-					.orderByDesc(PaymentConfirm::getCreateTime).last("limit 1"));
-			BigDecimal lastNewTotal = new BigDecimal("0");
-			if(ObjUtil.isNotNull(lastNewConfirm)){
-				lastNewTotal = lastNewConfirm.getTotalAmount();
+			if (StrUtil.equals(endSchedule.getStageName(),"璐ㄤ繚閲�")) {
+				endSchedule.setEffectiveDate(DateUtil.offsetDay(addDTO.getProcessDate(), endSchedule.getAgreedDays()));
+				endSchedule.setEffectiveEndDate(contract.getExpirationDate());
+				contractPaymentScheduleMapper.updateById(endSchedule);
+				//褰撳墠闃舵鐢熸晥鏃堕棿
+				schedule.setEffectiveDate(DateUtil.offsetDay(addDTO.getProcessDate(), schedule.getAgreedDays()));
+				schedule.setEffectiveEndDate(endSchedule.getEffectiveDate());
+				contractPaymentScheduleMapper.updateById(schedule);
+				//鏈�鍚庨樁娈靛簲鏀�
+				PaymentConfirm newConfim = new PaymentConfirm();
+				newConfim.setBusinessType(endSchedule.getStageName() + "搴旀敹");
+				newConfim.setBusGuestId(contract.getPartyAId());
+				newConfim.setBusGuestName(contract.getPartyA());
+				newConfim.setContractId(contract.getId());
+				newConfim.setContractName(contract.getContractName());
+				newConfim.setContractNo(contract.getContractNo());
+				newConfim.setScheduleId(endSchedule.getId());
+				newConfim.setScheduleName(schedule.getStageName());
+				newConfim.setConfirmTime(addDTO.getProcessDate());
+				newConfim.setTransationAmount(endSchedule.getPlannedAmount());
+				newConfim.setReceivableAmount(endSchedule.getPlannedAmount());
+				PaymentConfirm lastNewConfirm = paymentConfirmMapper.selectOne(Wrappers.<PaymentConfirm>lambdaQuery().eq(PaymentConfirm::getContractId, contract.getId())
+						.orderByDesc(PaymentConfirm::getCreateTime).last("limit 1"));
+				BigDecimal lastNewTotal = new BigDecimal("0");
+				if (ObjUtil.isNotNull(lastNewConfirm)) {
+					lastNewTotal = lastNewConfirm.getTotalAmount();
+				}
+				newConfim.setTotalAmount(lastNewTotal.subtract(newConfim.getReceivableAmount()));
+				paymentConfirmMapper.insert(newConfim);
 			}
-			newConfim.setTotalAmount(lastNewTotal.subtract(newConfim.getReceivableAmount()));
-			paymentConfirmMapper.insert(newConfim);
-		}else {
+			//鏇存柊鍚堝悓涓嬩釜闃舵
+			contract.setNextScheduleName(endSchedule.getStageName());
+			contractMapper.updateById(contract);
+		}
+		if(ArrayUtil.isNotEmpty(afterSchedule.toArray())&&afterSchedule.size()>1){
+			//鏇存柊鍚堝悓涓嬩釜闃舵
+			contract.setNextScheduleName(afterSchedule.get(0).getStageName());
+			contractMapper.updateById(contract);
+		}
+		if(ArrayUtil.isEmpty(afterSchedule.toArray())){
 			schedule.setEffectiveEndDate(contract.getExpirationDate());
 			contractPaymentScheduleMapper.updateById(schedule);
+			//鏇存柊鍚堝悓涓嬩釜闃舵
+			contract.setNextScheduleName("鏃�");
+			contractMapper.updateById(contract);
 		}
 		return R.ok();
 	}

--
Gitblit v1.9.1