From c05ddf57634572b43869e00d426efe05d2df5077 Mon Sep 17 00:00:00 2001
From: shiyunteng <shiyunteng@example.com>
Date: 星期三, 10 六月 2026 08:16:23 +0800
Subject: [PATCH] feat:模版合同加备注、水电房屋租赁执行次数改为合同有效期、合同履约列表新增双方履约、开票新增拟开票数量

---
 platformx-business-finance-biz/src/main/java/com/by4cloud/platformx/business/service/impl/ContractServiceImpl.java |  195 ++++++++++++++++++++++++++++++++++++------------
 1 files changed, 145 insertions(+), 50 deletions(-)

diff --git a/platformx-business-finance-biz/src/main/java/com/by4cloud/platformx/business/service/impl/ContractServiceImpl.java b/platformx-business-finance-biz/src/main/java/com/by4cloud/platformx/business/service/impl/ContractServiceImpl.java
index bec5082..bf5f56e 100644
--- a/platformx-business-finance-biz/src/main/java/com/by4cloud/platformx/business/service/impl/ContractServiceImpl.java
+++ b/platformx-business-finance-biz/src/main/java/com/by4cloud/platformx/business/service/impl/ContractServiceImpl.java
@@ -8,19 +8,23 @@
 import cn.hutool.core.util.ObjUtil;
 import cn.hutool.core.util.StrUtil;
 import com.baomidou.mybatisplus.core.toolkit.Wrappers;
+import com.baomidou.mybatisplus.extension.plugins.pagination.Page;
 import com.baomidou.mybatisplus.extension.service.impl.ServiceImpl;
 import com.by4cloud.platformx.admin.api.entity.SysDept;
 import com.by4cloud.platformx.admin.api.feign.RemoteDeptService;
 import com.by4cloud.platformx.business.api.feign.RemoteFlowProcessService;
 import com.by4cloud.platformx.business.constant.FlowNameEnum;
+import com.by4cloud.platformx.business.dto.ContracQueryDTO;
 import com.by4cloud.platformx.business.dto.ContractAddDTO;
 import com.by4cloud.platformx.business.dto.ContractUpdateDTO;
+import com.by4cloud.platformx.business.dto.DelayOutApprovalDTO;
 import com.by4cloud.platformx.business.entity.*;
 import com.by4cloud.platformx.business.mapper.*;
 import com.by4cloud.platformx.business.service.ContractService;
 import com.by4cloud.platformx.business.utils.ContractNumberGenerator;
 import com.by4cloud.platformx.business.vo.ContractDetailVo;
 import com.by4cloud.platformx.common.core.util.R;
+import com.by4cloud.platformx.common.data.datascope.DataScope;
 import com.by4cloud.platformx.common.security.util.SecurityUtils;
 import com.by4cloud.platformx.flow.task.dto.ProcessInstanceParamDto;
 import com.deepoove.poi.XWPFTemplate;
@@ -61,9 +65,7 @@
 	private final RemoteFlowProcessService remoteFlowProcessService;
 	private final ProductMapper productMapper;
 	private final RemoteDeptService remoteDeptService;
-
-	@Value("${file.local.base-path}")
-	private String basePath;
+	private final ContractDelayOutMapper contractDelayOutMapper;
 
 	@Override
 	public R add(ContractAddDTO addDTO) {
@@ -74,8 +76,12 @@
 		contract.setPaidAmount(new BigDecimal("0"));
 		contract.setBillingStatus("0");
 		contract.setErpPushFlag("0");
-		List<Contract> contracts;
-		contracts = baseMapper.selectList(Wrappers.<Contract>lambdaQuery().eq(Contract::getContractNo, contract.getContractNo()));
+
+		if (StrUtil.isNotEmpty(addDTO.getContractCategory()) && (
+				StrUtil.equals(addDTO.getContractCategory(), "ymjgkcpmm")||StrUtil.equals(addDTO.getContractCategory(), "ymjgypmm"))) {
+			contract.setExpirationDate(DateUtil.offsetDay(contract.getSignDate(),contract.getDeliveryCycle()));
+		}
+		List<Contract> contracts = baseMapper.selectList(Wrappers.<Contract>lambdaQuery().eq(Contract::getContractNo, contract.getContractNo()));
 		while (ArrayUtil.isNotEmpty(contracts.toArray())) {
 			contract.setContractNo(ContractNumberGenerator.generateContractNumber());
 			contracts = baseMapper.selectList(Wrappers.<Contract>lambdaQuery().eq(Contract::getContractNo, contract.getContractNo()));
@@ -102,6 +108,12 @@
 					record.setBusGuestName(contract.getPartyA());
 					record.setMeterReadTime(new Date());
 					meterReadRecordMapper.insert(record);
+				}
+				if (StrUtil.isNotEmpty(addDTO.getContractCategory()) && StrUtil.equals(addDTO.getContractCategory(), "ymjcg")
+				&&ObjUtil.isNotNull(subjectMatter.getPlannedDeliveryDate())&&ObjUtil.isNotNull(contract.getExpirationDate())
+					&&DateUtil.compare(contract.getExpirationDate(),subjectMatter.getPlannedDeliveryDate())>0) {
+						contract.setExpirationDate(subjectMatter.getPlannedDeliveryDate());
+						baseMapper.updateById(contract);
 				}
 			});
 
@@ -144,9 +156,6 @@
 
 		}
 
-		if (StrUtil.isNotEmpty(addDTO.getContractCategory()) && StrUtil.equals(addDTO.getContractCategory(), "water_house")) {
-
-		}
 
 		return R.ok();
 	}
@@ -267,58 +276,111 @@
 		if (StrUtil.isNotEmpty(contract.getContractCategory()) && StrUtil.equals(contract.getContractCategory(), "water_house")) {
 			List<ContractSubjectMatter> subjectMatterList = contractSubjectMatterMapper.selectList(Wrappers.<ContractSubjectMatter>lambdaQuery()
 					.eq(ContractSubjectMatter::getContractId,id));
+
 			if (ArrayUtil.isNotEmpty(subjectMatterList.toArray())) {
 				subjectMatterList.stream().forEach(contractSubjectMatter -> {
-
-					//寰幆鏃ユ湡
-					Date execDate0 = DateUtil.offsetDay(contract.getSignDate(), contract.getExecDay());
-					for (int i = 0; i < contract.getExecTimes(); i++) {
-						if (StrUtil.equals(contract.getExecFrequency(), "1")) {
+					if (StrUtil.equals(contract.getExecFrequency(), "1")) {
+						Long weeksTrue = DateUtil.betweenWeek(DateUtil.beginOfWeek(contract.getEffectiveDate()),
+								DateUtil.endOfWeek(contract.getExpirationDate()), true);
+						//寰幆鏃ユ湡
+						Date execDate0 = DateUtil.offsetDay(DateUtil.beginOfWeek(contract.getEffectiveDate()), contract.getExecDay());
+						for (int i = 0; i < weeksTrue.intValue(); i++) {
 							Date execDatei = DateUtil.offsetWeek(execDate0, i);
 							ContractExecDate execDate = new ContractExecDate();
 							execDate.setContractId(contract.getId());
 							execDate.setMatterId(contractSubjectMatter.getId());
 							execDate.setExecDate(execDatei);
 							execDate.setGenFlag("0");
-							contractExecDateMapper.insert(execDate);
-						}
-						if (StrUtil.equals(contract.getExecFrequency(), "2")) {
-							Date execDatei = DateUtil.offsetMonth(execDate0, i );
-							ContractExecDate execDate = new ContractExecDate();
-							execDate.setContractId(contract.getId());
-							execDate.setMatterId(contractSubjectMatter.getId());
-							execDate.setExecDate(execDatei);
-							execDate.setGenFlag("0");
-							contractExecDateMapper.insert(execDate);
-						}
-						if (StrUtil.equals(contract.getExecFrequency(), "3")) {
-							Date execDatei = DateUtil.offsetMonth(execDate0, i * 3);
-							ContractExecDate execDate = new ContractExecDate();
-							execDate.setContractId(contract.getId());
-							execDate.setMatterId(contractSubjectMatter.getId());
-							execDate.setExecDate(execDatei);
-							execDate.setGenFlag("0");
-							contractExecDateMapper.insert(execDate);
-						}
-						if (StrUtil.equals(contract.getExecFrequency(), "4")) {
-							Date execDatei = DateUtil.offsetMonth(execDate0, i * 6);
-							ContractExecDate execDate = new ContractExecDate();
-							execDate.setContractId(contract.getId());
-							execDate.setMatterId(contractSubjectMatter.getId());
-							execDate.setExecDate(execDatei);
-							execDate.setGenFlag("0");
-							contractExecDateMapper.insert(execDate);
-						}
-						if (StrUtil.equals(contract.getExecFrequency(), "5")) {
-							Date execDatei = DateUtil.offsetYear(execDate0, i);
-							ContractExecDate execDate = new ContractExecDate();
-							execDate.setContractId(contract.getId());
-							execDate.setMatterId(contractSubjectMatter.getId());
-							execDate.setExecDate(execDatei);
-							execDate.setGenFlag("0");
-							contractExecDateMapper.insert(execDate);
+							if (DateUtil.isIn(execDatei,contract.getEffectiveDate(),contract.getExpirationDate())) {
+								contractExecDateMapper.insert(execDate);
+							}
 						}
 					}
+					if (StrUtil.equals(contract.getExecFrequency(), "2")) {
+						Long weeksTrue = DateUtil.betweenMonth(DateUtil.beginOfMonth(contract.getEffectiveDate()),
+								DateUtil.endOfMonth(contract.getExpirationDate()), true);
+						//寰幆鏃ユ湡
+						Date execDate0 = DateUtil.offsetDay(DateUtil.beginOfMonth(contract.getEffectiveDate()), contract.getExecDay());
+						for (int i = 0; i < weeksTrue.intValue(); i++) {
+							Date execDatei = DateUtil.offsetMonth(execDate0, i);
+							ContractExecDate execDate = new ContractExecDate();
+							execDate.setContractId(contract.getId());
+							execDate.setMatterId(contractSubjectMatter.getId());
+							execDate.setExecDate(execDatei);
+							execDate.setGenFlag("0");
+							if (DateUtil.isIn(execDatei,contract.getEffectiveDate(),contract.getExpirationDate())) {
+								contractExecDateMapper.insert(execDate);
+							}
+						}
+					}
+					if (StrUtil.equals(contract.getExecFrequency(), "3")) {
+						Long weeksTrue = DateUtil.betweenMonth(DateUtil.beginOfQuarter(contract.getEffectiveDate()),
+								DateUtil.endOfQuarter(contract.getExpirationDate()), true)/3;
+
+						//寰幆鏃ユ湡
+						Date execDate0 = DateUtil.offsetDay(DateUtil.beginOfWeek(contract.getExpirationDate()), contract.getExecDay());
+						for (int i = 0; i < weeksTrue.intValue(); i++) {
+							Date execDatei = DateUtil.offsetMonth(execDate0, i*3);
+							ContractExecDate execDate = new ContractExecDate();
+							execDate.setContractId(contract.getId());
+							execDate.setMatterId(contractSubjectMatter.getId());
+							execDate.setExecDate(execDatei);
+							execDate.setGenFlag("0");
+							if (DateUtil.isIn(execDatei,contract.getEffectiveDate(),contract.getExpirationDate())) {
+								contractExecDateMapper.insert(execDate);
+							}
+						}
+					}
+					if (StrUtil.equals(contract.getExecFrequency(), "4")) {
+						Date startDate = contract.getEffectiveDate();
+						Date endDate = contract.getExpirationDate();
+						Integer startMonth = DateUtil.month(contract.getEffectiveDate());
+						Integer endMonth = DateUtil.month(contract.getExpirationDate());
+						if (1<=startMonth&&startMonth<=6){
+							startDate = DateUtil.beginOfYear(startDate);
+						}
+						if (7<=startMonth&&startMonth<=12){
+							startDate = DateUtil.offsetMonth(DateUtil.beginOfYear(startDate),6);
+						}
+						if (1<=endMonth&&endMonth<=6){
+							endDate = DateUtil.offsetMonth(DateUtil.endOfYear(endDate),-6);
+						}
+						if (7<=endMonth&&endMonth<=12){
+							endDate = DateUtil.endOfYear(endDate);
+						}
+						Long weeksTrue = DateUtil.betweenMonth(startDate,endDate, true)/6;
+						//寰幆鏃ユ湡
+						Date execDate0 = DateUtil.offsetDay(DateUtil.beginOfWeek(contract.getExpirationDate()), contract.getExecDay());
+						for (int i = 0; i < weeksTrue.intValue(); i++) {
+							Date execDatei = DateUtil.offsetMonth(execDate0, i*6);
+							ContractExecDate execDate = new ContractExecDate();
+							execDate.setContractId(contract.getId());
+							execDate.setMatterId(contractSubjectMatter.getId());
+							execDate.setExecDate(execDatei);
+							execDate.setGenFlag("0");
+							if (DateUtil.isIn(execDatei,contract.getEffectiveDate(),contract.getExpirationDate())) {
+								contractExecDateMapper.insert(execDate);
+							}
+						}
+					}
+					if (StrUtil.equals(contract.getExecFrequency(), "5")) {
+						Long weeksTrue = DateUtil.betweenWeek(DateUtil.beginOfYear(contract.getEffectiveDate()),
+								DateUtil.endOfYear(contract.getExpirationDate()), true);
+						//寰幆鏃ユ湡
+						Date execDate0 = DateUtil.offsetDay(DateUtil.beginOfYear(contract.getEffectiveDate()), contract.getExecDay());
+						for (int i = 0; i < weeksTrue.intValue(); i++) {
+							Date execDatei = DateUtil.offsetWeek(execDate0, i);
+							ContractExecDate execDate = new ContractExecDate();
+							execDate.setContractId(contract.getId());
+							execDate.setMatterId(contractSubjectMatter.getId());
+							execDate.setExecDate(execDatei);
+							execDate.setGenFlag("0");
+							if (DateUtil.isIn(execDatei,contract.getEffectiveDate(),contract.getExpirationDate())) {
+								contractExecDateMapper.insert(execDate);
+							}
+						}
+					}
+
 				});
 			}
 		} else {
@@ -972,6 +1034,8 @@
 		map.put("court",contract.getCourt());
 		map.put("contractAttchment",contract.getContractAttchment());
 		map.put("invoiceNotice",contract.getInvoiceNotice());
+		map.put("city",contract.getCity());
+		map.put("region",contract.getRegion());
 
 		//鏍囩殑鐗�
 		List<Map<String, Object>> items = new ArrayList<>();
@@ -1073,4 +1137,35 @@
 			e.printStackTrace();
 		}
 	}
+
+	@Override
+	public R delayOutApproval(DelayOutApprovalDTO dto) {
+		Contract contract = baseMapper.selectById(dto.getContractId());
+		ContractDelayOut delayOut = BeanUtil.copyProperties(dto,ContractDelayOut.class);
+		delayOut.setApplyTime(new Date());
+		delayOut.setApplyName(SecurityUtils.getUser().getUsername());
+		delayOut.setDelayStatus("0");
+		Map<String,Object> map = new HashMap<>();
+		map.put("contractId",contract.getId());
+		map.put("contractName",contract.getContractName());
+		map.put("delayDay",dto.getDelayDay());
+		map.put("applyName",SecurityUtils.getUser().getUsername());
+		map.put("applyTime",DateUtil.format(delayOut.getApplyTime(),DatePattern.NORM_DATETIME_FORMAT));
+		//鍚姩娴佺▼
+		ProcessInstanceParamDto paramDto = new ProcessInstanceParamDto();
+		paramDto.setParamMap(map);
+		paramDto.setFlowName(FlowNameEnum.寤舵湡鍑鸿揣瀹℃壒.name());
+		R r1 = remoteFlowProcessService.startProcessInstance(paramDto);
+		if (r1.getCode() == 1) {
+			return R.failed("娴佺▼鍚姩澶辫触");
+		}
+		contractDelayOutMapper.insert(delayOut);
+		return R.ok();
+	}
+
+	@Override
+	public Page pageScope(Page page, ContracQueryDTO queryDTO) {
+
+		return baseMapper.pageScope(page,queryDTO, DataScope.of("comp_id"));
+	}
 }

--
Gitblit v1.9.1