From 304aa3427cc8233721d7023348c5d7b3fc4f784a Mon Sep 17 00:00:00 2001
From: luofl <1442745593@qq.com>
Date: 星期一, 24 三月 2025 09:42:50 +0800
Subject: [PATCH] 1.租户数量趋势统计

---
 ruoyi-admin/src/main/java/com/ruoyi/web/controller/api/TContractController.java |  145 +++++++++++++++++++++++++++++-------------------
 1 files changed, 88 insertions(+), 57 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 514ee6f..a89a5bd 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
@@ -3,6 +3,7 @@
 
 import cn.afterturn.easypoi.excel.ExcelExportUtil;
 import cn.afterturn.easypoi.excel.entity.ExportParams;
+import cn.hutool.core.bean.BeanUtil;
 import com.aizuda.bpm.engine.entity.FlwTask;
 import com.aizuda.bpm.mybatisplus.mapper.FlwTaskMapper;
 import com.baomidou.mybatisplus.core.conditions.query.LambdaQueryWrapper;
@@ -297,69 +298,99 @@
         List<TContract> list = contractService.lambdaQuery().in(TContract::getId, dto.getIds()).list();
         List<String> res = new ArrayList<>();
         for (TContract contract : list) {
-            String templateFileName = "1_yzj_租赁合同_个人.docx";
-            TBill firstBill = billService.lambdaQuery().eq(TBill::getContractId, contract.getId())
-                    .orderByDesc(TBill::getStartTime).last("limit 1").one();
-            TTenant tenant = tenantService.getById(contract.getTenantId());
-            THouse tHouse = houseService.getById(contract.getHouseId());
-            Map<String, Object> templateParam = new HashMap<>(5);
-            templateParam.put("${contractNumber}", contract.getContractNumber());
-            templateParam.put("${partyOneName}", contract.getPartyOneName());
-            templateParam.put("${partyTwoName}", contract.getPartyTwoName());
-            if (Objects.nonNull(tenant)) {
-                templateParam.put("${mailAddress}", StringUtils.isNotBlank(tenant.getMailAddress()) ? tenant.getMailAddress() : "");
-                templateParam.put("${idCard}", StringUtils.isNotBlank(tenant.getIdCard()) ? tenant.getIdCard() : "");
-                //企业、政府机构、国有企业
-                if (tenant.getTenantType().equals("2") || tenant.getTenantType().equals("5") || tenant.getTenantType().equals("7")){
-                    templateParam.put("${creditCode}", StringUtils.isNotBlank(tenant.getCreditCode()) ? tenant.getCreditCode() : "");
-                    templateParam.put("${legalPerson}", StringUtils.isNotBlank(tenant.getLegalPerson()) ? tenant.getLegalPerson() : "");
-                    templateFileName = "1_yzj_租赁合同_企业.docx";
-                }
-            }
-            templateParam.put("${houseAddress}", tHouse.getHouseAddress());
-            templateParam.put("${houseArea}", tHouse.getHouseArea()+"m²");
-            long between = ChronoUnit.DAYS.between(contract.getStartTime(), contract.getStartPayTime())+1;
-            templateParam.put("${day}", between);
-            templateParam.put("${endTimeFree}", DateUtils.localDateTimeToStringYear(contract.getStartPayTime().plusDays(1)));
-            templateParam.put("${startPayTime}", DateUtils.localDateTimeToStringYear(contract.getStartPayTime()));
-            templateParam.put("${startTime}", DateUtils.localDateTimeToStringYear(contract.getStartTime()));
-            templateParam.put("${endTime}", DateUtils.localDateTimeToStringYear(contract.getEndTime()));
-            templateParam.put("${monthRent}", "¥"+contract.getMonthRent()+"元");
-            templateParam.put("${monthRentString}", "人民币"+NumberToChineseUtils.numberToChinese(contract.getMonthRent().setScale(2, BigDecimal.ROUND_DOWN).doubleValue()));
-            String totalYear = Objects.nonNull(contract.getTotalYear())?contract.getTotalYear().toString():"";
-            templateParam.put("${totalYear}", "¥"+totalYear+"元");
-            String totalYearString = StringUtils.isNotEmpty(totalYear)?NumberToChineseUtils.numberToChinese(contract.getTotalYear().setScale(2, BigDecimal.ROUND_DOWN).doubleValue()):"";
-            templateParam.put("${totalYearString}", "人民币"+totalYearString);
-            templateParam.put("${payType}", contract.getPayType().equals("1")?"月":contract.getPayType().equals("2")?"季":"年");
-            if(firstBill!=null){
-                templateParam.put("${firstRent}", "¥"+(firstBill.getPayableFeesMoney())+"元");
-            }else{
-                templateParam.put("${firstRent}", "");
-
-            }
-            templateParam.put("${firstRentString}", "人民币"+NumberToChineseUtils.numberToChinese((contract.getPayType().equals("1")?contract.getMonthRent():contract.getPayType().equals("2")?contract.getMonthRent().multiply(new BigDecimal("3")):contract.getMonthRent().multiply(new BigDecimal("12")).setScale(2,BigDecimal.ROUND_DOWN)).doubleValue()));
-            templateParam.put("${nextPayTime}", contract.getPayType().equals("1")?"月":contract.getPayType().equals("2")?"季":"年");
-            templateParam.put("${deposit}", "¥"+contract.getDeposit()+"元");
-            templateParam.put("${depositString}", NumberToChineseUtils.numberToChinese(contract.getDeposit().setScale(2, BigDecimal.ROUND_DOWN).doubleValue()));
-            templateParam.put("${partyOnePerson}", contract.getPartyOnePerson());
-            templateParam.put("${partyOnePhone}", contract.getPartyOnePhone());
-            templateParam.put("${partyTwoPerson}", contract.getPartyTwoPerson());
-            templateParam.put("${partyTwoPhone}", contract.getPartyTwoPhone());
-            // 验收时间
-            TCheckAcceptRecord tCheckAcceptRecord = checkAcceptRecordService.lambdaQuery().eq(TCheckAcceptRecord::getContractId, contract.getId()).last("limit 1").one();
-            if (tCheckAcceptRecord!=null &&tCheckAcceptRecord.getCheckTime()!=null ){
-                templateParam.put("${checkTime}", DateUtils.localDateTimeToStringYear(tCheckAcceptRecord.getCheckTime()));
-            }else{
-                templateParam.put("${checkTime}", "");
-
-            }
-            String url = wordUtil.generatePdf("/usr/local/project/file/", templateFileName, templateParam, "租赁合同", "/usr/local/project/file/");
+            String url = generateContract(contract);
             res.add(url);
         }
 
         return R.ok(res);
     }
 
+    private String generateContract(TContract contract) {
+        String templateFileName = "1_yzj_租赁合同_个人.docx";
+        TBill firstBill = null;
+        TTenant tenant = null;
+        THouse tHouse = null;
+        TCheckAcceptRecord tCheckAcceptRecord = null;
+        if (StringUtils.isNotEmpty(contract.getId())){
+            firstBill = billService.lambdaQuery().eq(TBill::getContractId, contract.getId())
+                    .orderByDesc(TBill::getStartTime).last("limit 1").one();
+            tenant = tenantService.getById(contract.getTenantId());
+            tHouse = houseService.getById(contract.getHouseId());
+            // 验收时间
+            tCheckAcceptRecord = checkAcceptRecordService.lambdaQuery()
+                    .eq(TCheckAcceptRecord::getContractId, contract.getId())
+                    .last("limit 1").one();
+        }
+
+
+
+        Map<String, Object> templateParam = new HashMap<>(5);
+        templateParam.put("${contractNumber}", contract.getContractNumber());
+        templateParam.put("${partyOneName}", contract.getPartyOneName());
+        templateParam.put("${partyTwoName}", contract.getPartyTwoName());
+        if (Objects.nonNull(tenant)) {
+            templateParam.put("${mailAddress}", StringUtils.isNotBlank(tenant.getMailAddress()) ? tenant.getMailAddress() : "");
+            templateParam.put("${idCard}", StringUtils.isNotBlank(tenant.getIdCard()) ? tenant.getIdCard() : "");
+            //企业、政府机构、国有企业
+            if (tenant.getTenantType().equals("2") || tenant.getTenantType().equals("5") || tenant.getTenantType().equals("7")){
+                templateParam.put("${creditCode}", StringUtils.isNotBlank(tenant.getCreditCode()) ? tenant.getCreditCode() : "");
+                templateParam.put("${legalPerson}", StringUtils.isNotBlank(tenant.getLegalPerson()) ? tenant.getLegalPerson() : "");
+                templateFileName = "1_yzj_租赁合同_企业.docx";
+            }
+        }
+        templateParam.put("${houseAddress}", tHouse.getHouseAddress());
+        templateParam.put("${houseArea}", tHouse.getHouseArea()+"m²");
+        long between = ChronoUnit.DAYS.between(contract.getStartTime(), contract.getStartPayTime())+1;
+        templateParam.put("${day}", between);
+        templateParam.put("${endTimeFree}", DateUtils.localDateTimeToStringYear(contract.getStartPayTime().plusDays(1)));
+        templateParam.put("${startPayTime}", DateUtils.localDateTimeToStringYear(contract.getStartPayTime()));
+        templateParam.put("${startTime}", DateUtils.localDateTimeToStringYear(contract.getStartTime()));
+        templateParam.put("${endTime}", DateUtils.localDateTimeToStringYear(contract.getEndTime()));
+        templateParam.put("${monthRent}", "¥"+ contract.getMonthRent()+"元");
+        templateParam.put("${monthRentString}", "人民币"+NumberToChineseUtils.numberToChinese(contract.getMonthRent().setScale(2, BigDecimal.ROUND_DOWN).doubleValue()));
+        String totalYear = Objects.nonNull(contract.getTotalYear())? contract.getTotalYear().toString():"";
+        templateParam.put("${totalYear}", "¥"+totalYear+"元");
+        String totalYearString = StringUtils.isNotEmpty(totalYear)?NumberToChineseUtils.numberToChinese(contract.getTotalYear().setScale(2, BigDecimal.ROUND_DOWN).doubleValue()):"";
+        templateParam.put("${totalYearString}", "人民币"+totalYearString);
+        templateParam.put("${payType}", contract.getPayType().equals("1")?"月": contract.getPayType().equals("2")?"季":"年");
+        if(firstBill!=null){
+            templateParam.put("${firstRent}", "¥"+(firstBill.getPayableFeesMoney())+"元");
+        }else{
+            templateParam.put("${firstRent}", "");
+
+        }
+        templateParam.put("${firstRentString}", "人民币"+NumberToChineseUtils.numberToChinese((contract.getPayType().equals("1")? contract.getMonthRent(): contract.getPayType().equals("2")? contract.getMonthRent().multiply(new BigDecimal("3")): contract.getMonthRent().multiply(new BigDecimal("12")).setScale(2,BigDecimal.ROUND_DOWN)).doubleValue()));
+        templateParam.put("${nextPayTime}", contract.getPayType().equals("1")?"月": contract.getPayType().equals("2")?"季":"年");
+        templateParam.put("${deposit}", "¥"+ contract.getDeposit()+"元");
+        templateParam.put("${depositString}", NumberToChineseUtils.numberToChinese(contract.getDeposit().setScale(2, BigDecimal.ROUND_DOWN).doubleValue()));
+        templateParam.put("${partyOnePerson}", contract.getPartyOnePerson());
+        templateParam.put("${partyOnePhone}", contract.getPartyOnePhone());
+        templateParam.put("${partyTwoPerson}", contract.getPartyTwoPerson());
+        templateParam.put("${partyTwoPhone}", contract.getPartyTwoPhone());
+
+        if (tCheckAcceptRecord!=null &&tCheckAcceptRecord.getCheckTime()!=null ){
+            templateParam.put("${checkTime}", DateUtils.localDateTimeToStringYear(tCheckAcceptRecord.getCheckTime()));
+        }else{
+            templateParam.put("${checkTime}", "");
+
+        }
+        return wordUtil.generatePdf("/usr/local/project/file/", templateFileName, templateParam, "租赁合同", "/usr/local/project/file/");
+    }
+
+    /**
+     * 生成预览版合同附件
+     */
+    @ApiOperation(value = "生成预览版合同附件")
+    @PostMapping("/generateContractPreview")
+    public R<String> generateContractPreview(@RequestBody TContractDTO dto)
+    {
+        TContract contract = new TContract();
+        BeanUtil.copyProperties(dto,contract);
+        return R.ok(generateContract(contract));
+    }
+
+
+
     /**
      * 导出
      */

--
Gitblit v1.7.1