From 8a8a94d9a6de7d1d1a5720ce1f36d7b5bc6d7702 Mon Sep 17 00:00:00 2001
From: liusheng <337615773@qq.com>
Date: 星期五, 19 十二月 2025 20:13:16 +0800
Subject: [PATCH] 代码提交

---
 ruoyi-admin/src/main/java/com/ruoyi/web/controller/project/ServiceDonatebaseinfoController.java |  110 ++++++++++++++++++++++++++++++++++++++++--------------
 1 files changed, 81 insertions(+), 29 deletions(-)

diff --git a/ruoyi-admin/src/main/java/com/ruoyi/web/controller/project/ServiceDonatebaseinfoController.java b/ruoyi-admin/src/main/java/com/ruoyi/web/controller/project/ServiceDonatebaseinfoController.java
index f2ca5ea..d4488be 100644
--- a/ruoyi-admin/src/main/java/com/ruoyi/web/controller/project/ServiceDonatebaseinfoController.java
+++ b/ruoyi-admin/src/main/java/com/ruoyi/web/controller/project/ServiceDonatebaseinfoController.java
@@ -1,7 +1,7 @@
 package com.ruoyi.web.controller.project;
 
+import com.baomidou.mybatisplus.core.toolkit.ObjectUtils;
 import com.ruoyi.common.annotation.Log;
-import com.ruoyi.common.annotation.NotRepeatCommit;
 import com.ruoyi.common.annotation.RepeatSubmit;
 import com.ruoyi.common.config.RuoYiConfig;
 import com.ruoyi.common.constant.HttpStatus;
@@ -14,9 +14,12 @@
 import com.ruoyi.common.utils.SecurityUtils;
 import com.ruoyi.common.utils.poi.ExcelUtil;
 import com.ruoyi.framework.config.ServerConfig;
+import com.ruoyi.project.common.CalculateDateUtils;
 import com.ruoyi.project.domain.ServiceDonatebaseinfo;
+import com.ruoyi.project.domain.ServiceDonationwitness;
 import com.ruoyi.project.domain.vo.TimeVO;
 import com.ruoyi.project.service.IServiceDonatebaseinfoService;
+import com.ruoyi.project.service.IServiceDonationwitnessService;
 import com.ruoyi.project.service.IServiceExternalpersonService;
 import com.ruoyi.system.mapper.SysDeptMapper;
 import freemarker.template.Configuration;
@@ -26,13 +29,14 @@
 import io.swagger.annotations.ApiOperation;
 import lombok.extern.slf4j.Slf4j;
 import org.springframework.beans.factory.annotation.Autowired;
+import org.springframework.util.CollectionUtils;
 import org.springframework.web.bind.annotation.*;
 
 import java.io.*;
 import java.text.SimpleDateFormat;
+import java.time.LocalDate;
+import java.time.ZoneId;
 import java.util.*;
-
-//import javafx.scene.input.DataFormat;
 
 
 /**
@@ -50,10 +54,10 @@
     private IServiceDonatebaseinfoService serviceDonatebaseinfoService;
 
     @Autowired
-    private IServiceExternalpersonService serviceExternalpersonService;
+    private IServiceDonationwitnessService serviceDonationwitnessService;
 
     @Autowired
-    private ServerConfig serverConfig;
+    private IServiceExternalpersonService serviceExternalpersonService;
 
     @Autowired
     private SysDeptMapper sysDeptMapper;
@@ -70,13 +74,24 @@
      * 鏌ヨ鎹愮尞鍩虹鍒楄〃
      */
     @ApiOperation("娼滃湪鎹愮尞淇℃伅鍒楄〃")
-    //@PreAuthorize("@ss.hasPermi('project:donatebaseinfo:list')")
+    //// @PreAuthorize("@ss.hasPermi('project:donatebaseinfo:list')")
     @GetMapping("/list")
     public TableDataInfo list(ServiceDonatebaseinfo serviceDonatebaseinfo) {
         log.info("娼滃湪鎹愮尞淇℃伅鍒楄〃锛歿}", serviceDonatebaseinfo);
         startPage();
-        //List<ServiceDonatebaseinfo> list = serviceDonatebaseinfoService.queryList(serviceDonatebaseinfo);
         List<ServiceDonatebaseinfo> list = serviceDonatebaseinfoService.selectServiceDonatebaseinfoList(serviceDonatebaseinfo);
+        return getDataTable(list);
+    }
+
+    /**
+     * 鏌ヨ娼滃湪鎹愮尞鎮h�呬俊鎭垪琛ㄤ笉涓巄ase_organization鍏宠仈
+     */
+    @ApiOperation("娼滃湪鎹愮尞鎮h�呬俊鎭垪琛�")
+    //// @PreAuthorize("@ss.hasPermi('project:donatebaseinfo:list')")
+    @GetMapping("/getpatname")
+    public TableDataInfo getPatName(ServiceDonatebaseinfo serviceDonatebaseinfo) {
+        log.info("娼滃湪鎹愮尞鎮h�呬俊鎭垪琛細{}", serviceDonatebaseinfo);
+        List<ServiceDonatebaseinfo> list = serviceDonatebaseinfoService.getPatName(serviceDonatebaseinfo);
         return getDataTable(list);
     }
 
@@ -89,12 +104,11 @@
         return getDataTable(list);
     }
 
-
     /**
      * 瀵煎嚭鎹愮尞鍩虹鍒楄〃
      */
     @ApiOperation("瀵煎嚭娼滃湪鎹愮尞淇℃伅鍒楄〃")
-    //@PreAuthorize("@ss.hasPermi('project:donatebaseinfo:export')")
+    //// @PreAuthorize("@ss.hasPermi('project:donatebaseinfo:export')")
     @Log(title = "鎹愮尞鍩虹", businessType = BusinessType.EXPORT)
     @GetMapping("/export")
     public AjaxResult export(ServiceDonatebaseinfo serviceDonatebaseinfo) {
@@ -108,18 +122,50 @@
      * 鑾峰彇鎹愮尞鍩虹璇︾粏淇℃伅
      */
     @ApiOperation("閫氳繃id鑾峰緱娼滃湪鎹愮尞淇℃伅")
-    //@PreAuthorize("@ss.hasPermi('project:donatebaseinfo:query')")
+    //// @PreAuthorize("@ss.hasPermi('project:donatebaseinfo:query')")
     @GetMapping(value = "/{id}")
     public AjaxResult getInfo(@PathVariable("id") Long id) {
         log.info("閫氳繃id鑾峰緱娼滃湪鎹愮尞淇℃伅锛歿}", id);
-        return AjaxResult.success(serviceDonatebaseinfoService.getById(id));
+        ServiceDonatebaseinfo serviceDonatebaseinfo = serviceDonatebaseinfoService.getById(id);
+        if (serviceDonatebaseinfo.getBirthday() != null) {
+            Map<String, String> map = CalculateDateUtils.calculateAge(serviceDonatebaseinfo.getBirthday().toInstant().atZone(ZoneId.systemDefault()).toLocalDate(), LocalDate.now());
+            serviceDonatebaseinfo.setAge(org.apache.commons.lang3.ObjectUtils.isNotEmpty(map.get("age")) ? Long.valueOf(map.get("age")) : null);
+            serviceDonatebaseinfo.setAgeunit(map.get("ageUnit"));
+            serviceDonatebaseinfo.setAge2(org.apache.commons.lang3.ObjectUtils.isNotEmpty(map.get("age2")) ? Long.valueOf(map.get("age2")) : null);
+            serviceDonatebaseinfo.setAgeunit2(map.get("ageUnit2"));
+        }
+
+        serviceDonatebaseinfo.setAgeunit("-");
+        serviceDonatebaseinfo.setAge(null);
+        serviceDonatebaseinfo.setAge2(null);
+
+        //鑾峰彇姝讳骸鏃堕棿锛屽鏋滆幏鍙栬璇侀噷鏈夋浜℃椂闂达紝鍒欒繘琛岃绠椾粬鐨勫勾榫�
+        ServiceDonationwitness sdw = new ServiceDonationwitness();
+        sdw.setInfoid(serviceDonatebaseinfo.getId());
+        List<ServiceDonationwitness> serviceDonationwitnessList = serviceDonationwitnessService.selectServiceDonationwitnessList(sdw);
+        if (!CollectionUtils.isEmpty(serviceDonationwitnessList) && serviceDonatebaseinfo.getBirthday() != null) {
+            Date deathtime = serviceDonationwitnessList.get(0).getDeathtime();
+            if (ObjectUtils.isNotEmpty(deathtime)) {
+                Map<String, String> map = CalculateDateUtils.calculateAge(serviceDonatebaseinfo.getBirthday().toInstant().atZone(ZoneId.systemDefault()).toLocalDate(), deathtime.toInstant().atZone(ZoneId.systemDefault()).toLocalDate());
+                if (Objects.isNull(map)) {
+                    log.error("serviceDonatebaseinfo鍑虹敓鏃ユ湡锛歿},serviceDonatebaseinfo姝讳骸鏃ユ湡锛歿}", serviceDonatebaseinfo.getBirthday(), deathtime);
+                }
+                serviceDonatebaseinfo.setAge(org.apache.commons.lang3.ObjectUtils.isNotEmpty(map.get("age")) ? Long.valueOf(map.get("age")) : null);
+                serviceDonatebaseinfo.setAgeunit(map.get("ageUnit"));
+                serviceDonatebaseinfo.setAge2(org.apache.commons.lang3.ObjectUtils.isNotEmpty(map.get("age2")) ? Long.valueOf(map.get("age2")) : null);
+                serviceDonatebaseinfo.setAgeunit2(map.get("ageUnit2"));
+            }
+        }
+
+
+        return AjaxResult.success(serviceDonatebaseinfo);
     }
 
     /**
      * 鏂板鎹愮尞鍩虹
      */
     @ApiOperation("鏂板娼滃湪鎹愮尞淇℃伅")
-    //@PreAuthorize("@ss.hasPermi('project:donatebaseinfo:add')")
+    //// @PreAuthorize("@ss.hasPermi('project:donatebaseinfo:add')")
     @Log(title = "鎹愮尞鍩虹", businessType = BusinessType.INSERT)
     @PostMapping("/add")
     @RepeatSubmit
@@ -127,19 +173,6 @@
         log.info("鏂板娼滃湪鎹愮尞淇℃伅锛歿}", serviceDonatebaseinfo);
         SysUser user = SecurityUtils.getLoginUser().getUser();
 
-//        String bh = "";
-//        bh = serviceDonatebaseinfoService.getDonateNumber(serviceDonatebaseinfo);
-//        if (bh == "") {
-//            return AjaxResult.error("鏂板鏃剁敓鎴愮殑缂栧彿涓虹┖,鍒涘缓澶辫触!");
-//        } else {
-//            ServiceDonatebaseinfo serviceDonatebaseinfo1 = new ServiceDonatebaseinfo();
-//            serviceDonatebaseinfo1.setDonorno(bh);
-//            List<ServiceDonatebaseinfo> listrecord = serviceDonatebaseinfoService.queryList(serviceDonatebaseinfo1);
-//            if (listrecord.size() > 0) {
-//                return AjaxResult.error("鏂板鏃剁敓鎴愮殑缂栧彿" + bh + "宸插瓨鍦�,鏃犳硶淇濆瓨!");
-//            }
-//
-//        }
         String idcardno = serviceDonatebaseinfo.getIdcardno();
         ServiceDonatebaseinfo serviceDonatebaseinfo2 = new ServiceDonatebaseinfo();
         serviceDonatebaseinfo2.setIdcardno(idcardno);
@@ -161,7 +194,7 @@
      * 淇敼鎹愮尞鍩虹
      */
     @ApiOperation("淇敼娼滃湪鎹愮尞淇℃伅")
-    //@PreAuthorize("@ss.hasPermi('project:donatebaseinfo:edit')")
+    //// @PreAuthorize("@ss.hasPermi('project:donatebaseinfo:edit')")
     @Log(title = "鎹愮尞鍩虹", businessType = BusinessType.UPDATE)
     @PostMapping("/edit")
     @RepeatSubmit
@@ -174,7 +207,7 @@
      * 鍒犻櫎鎹愮尞鍩虹
      */
     @ApiOperation("鍒犻櫎娼滃湪鎹愮尞淇℃伅")
-    //@PreAuthorize("@ss.hasPermi('project:donatebaseinfo:remove')")
+    //// @PreAuthorize("@ss.hasPermi('project:donatebaseinfo:remove')")
     @Log(title = "鎹愮尞鍩虹", businessType = BusinessType.DELETE)
     @GetMapping("/remove/{ids}")
     public AjaxResult remove(@PathVariable Long[] ids) {
@@ -183,8 +216,8 @@
     }
 
     @ApiOperation("鑾峰彇鎹愮尞缂栧彿")
-    @GetMapping("/donatenumber")
-    public AjaxResult getDonateNumber(ServiceDonatebaseinfo serviceDonatebaseinfo) {
+    @PostMapping("/donatenumber")
+    public AjaxResult getDonateNumber(@RequestBody ServiceDonatebaseinfo serviceDonatebaseinfo) {
         log.info("鑾峰彇鎹愮尞缂栧彿锛歿}", serviceDonatebaseinfo);
         return AjaxResult.success(serviceDonatebaseinfoService.getDonateNumber(serviceDonatebaseinfo));
     }
@@ -848,6 +881,11 @@
             dataMap.put("YJXZGX", "鍏朵粬");
         }
         //淇℃伅鏉ユ簮
+        if (serviceDonatebaseinfo.getInfosources().contains("绾㈠崄瀛椾細")) {
+            dataMap.put("HSZH2", (char) 8730);  // 鍕鹃�夌鍙�
+        } else {
+            dataMap.put("HSZH2", "鈻�");  // 鏂规绗﹀彿
+        }
         if (serviceDonatebaseinfo.getInfosources().contains("鍖荤枟鏈烘瀯")) {
             dataMap.put("YLJG", (char) 8730);
             if (serviceDonatebaseinfo.getInfosources().contains("瀹跺睘")) {
@@ -935,6 +973,20 @@
         dataMap.put("BGR", serviceDonatebaseinfo.getReportername() == null ? "" : serviceDonatebaseinfo.getReportername());
         dataMap.put("BGRDH", serviceDonatebaseinfo.getReporterphone() == null ? "" : serviceDonatebaseinfo.getReporterphone());
 
+        //鑾峰彇鎶ュ憡鏃堕棿
+        String bgrq = null;
+        if (serviceDonatebaseinfo.getReporttime() != null) {
+            Date reportTime = serviceDonatebaseinfo.getReporttime();
+            LocalDate localDate = reportTime.toInstant().atZone(ZoneId.systemDefault()).toLocalDate();
+
+            int year = localDate.getYear();
+            int month = localDate.getMonthValue(); // 鐩存帴鑾峰彇鏈堜唤鍊硷紙1-12锛�
+            int day = localDate.getDayOfMonth();
+            bgrq = year + "骞�" + month + "鏈�" + day + "鏃�";
+        }
+
+        dataMap.put("BGRQ", bgrq);
+
     }
 
     @ApiOperation("鑾峰彇鐘舵�佽幏鍙栬鏁�")

--
Gitblit v1.9.3