From 0dc15775095a25797daf376e47999f0c11486e75 Mon Sep 17 00:00:00 2001 From: luofl <1442745593@qq.com> Date: 星期一, 07 四月 2025 22:17:13 +0800 Subject: [PATCH] 修改bug --- ruoyi-admin/src/main/java/com/ruoyi/web/controller/api/TContractController.java | 37 ++++++++++++++++++++++++++++--------- 1 files changed, 28 insertions(+), 9 deletions(-) diff --git a/ruoyi-admin/src/main/java/com/ruoyi/web/controller/api/TContractController.java b/ruoyi-admin/src/main/java/com/ruoyi/web/controller/api/TContractController.java index bc2be5a..a140353 100644 --- a/ruoyi-admin/src/main/java/com/ruoyi/web/controller/api/TContractController.java +++ b/ruoyi-admin/src/main/java/com/ruoyi/web/controller/api/TContractController.java @@ -14,6 +14,7 @@ import com.ruoyi.common.constant.DictConstants; import com.ruoyi.common.core.domain.R; import com.ruoyi.common.enums.BusinessType; +import com.ruoyi.common.enums.DisabledEnum; import com.ruoyi.common.enums.ProcessCategoryEnum; import com.ruoyi.common.exception.ServiceException; import com.ruoyi.common.utils.DateUtils; @@ -134,6 +135,8 @@ if (Objects.isNull(house)) { throw new ServiceException("房产信息不存在"); } + house.setRentalReturnStatus("1"); + houseService.updateById(house); dto.setBusinessDeptId(house.getBusinessDeptId()); contractService.save(dto); if (dto.getStatus().equals("2")){ @@ -370,6 +373,18 @@ return R.ok(res); } + // 计算两个日期相差天数的方法实现: + public static long calculateDaysBetween(LocalDateTime start, LocalDateTime end) { + return ChronoUnit.DAYS.between(start, end); + } + + public static void main(String[] args) { + LocalDateTime start = LocalDateTime.of(2024, 1, 1, 0, 0); + LocalDateTime end = LocalDateTime.of(2024, 1, 5, 12, 0); + long days = calculateDaysBetween(start, end); // 返回4天(不满一天不计) + + } + private String generateContract(TContract contract) { String templateFileName = "1_yzj_租赁合同_个人.docx"; String contractId = contract.getId(); @@ -379,7 +394,9 @@ if (StringUtils.isNotEmpty(contractId)) { firstBill = billService.lambdaQuery() .eq(TBill::getContractId, contractId) + .eq(TBill::getBillType, 1) .orderByAsc(TBill::getStartTime) + .ne(TBill::getManualAddition, DisabledEnum.YES.getCode()) .last("limit 1") .one(); tCheckAcceptRecord = checkAcceptRecordService.lambdaQuery() @@ -477,19 +494,21 @@ ? contract.getMonthRent().multiply(new BigDecimal("3")) : contract.getMonthRent().multiply(new BigDecimal("12"))) .setScale(2, RoundingMode.DOWN).doubleValue(); - fill(templateParam, "firstRent", "¥" + firstRent + "元"); + fill(templateParam, "firstRent", "¥" + firstBill.getPayableFeesMoney() + "元"); + // 其他财务字段 + fill(templateParam, "firstRentString", "人民币" + NumberToChineseUtils.numberToChinese(firstBill.getPayableFeesMoney().doubleValue())); } else { - fill(templateParam, "firstRent", ""); +// fill(templateParam, "firstRent", ""); } - // 其他财务字段 - fill(templateParam, "firstRentString", "人民币" + NumberToChineseUtils.numberToChinese( - (contract.getPayType().equals("1") + fill(templateParam, "firstRent", + "¥"+(contract.getPayType().equals("1") ? contract.getMonthRent() - : contract.getPayType().equals("2") - ? contract.getMonthRent().multiply(new BigDecimal("3")) - : contract.getMonthRent().multiply(new BigDecimal("12"))) - .setScale(2, RoundingMode.DOWN).doubleValue())); + :contract.getPayType().equals("2") + ?contract.getMonthRent().multiply(new BigDecimal("3")) + :contract.getMonthRent().multiply(new BigDecimal("12")) + .setScale(2, RoundingMode.DOWN)).doubleValue()+"元"); + fill(templateParam, "firstRentString", "人民币"+NumberToChineseUtils.numberToChinese( -- Gitblit v1.7.1