From b1ffaa0bfbe610b16b64966965fe13b7e2a57d93 Mon Sep 17 00:00:00 2001
From: liusheng <337615773@qq.com>
Date: 星期二, 04 十一月 2025 19:06:30 +0800
Subject: [PATCH] 处理年龄问题

---
 ruoyi-project/src/main/java/com/ruoyi/project/service/impl/ServiceEthicalreviewopinionsServiceImpl.java |   86 +++++++++++++++++++++++++++++++-----------
 1 files changed, 63 insertions(+), 23 deletions(-)

diff --git a/ruoyi-project/src/main/java/com/ruoyi/project/service/impl/ServiceEthicalreviewopinionsServiceImpl.java b/ruoyi-project/src/main/java/com/ruoyi/project/service/impl/ServiceEthicalreviewopinionsServiceImpl.java
index 11cf764..1d5aaab 100644
--- a/ruoyi-project/src/main/java/com/ruoyi/project/service/impl/ServiceEthicalreviewopinionsServiceImpl.java
+++ b/ruoyi-project/src/main/java/com/ruoyi/project/service/impl/ServiceEthicalreviewopinionsServiceImpl.java
@@ -1,23 +1,35 @@
 package com.ruoyi.project.service.impl;
 
+import java.time.LocalDate;
+import java.time.ZoneId;
+import java.util.Date;
 import java.util.List;
 
+import com.baomidou.mybatisplus.core.toolkit.ObjectUtils;
 import com.ruoyi.common.core.domain.entity.SysRole;
 import com.ruoyi.common.core.domain.entity.SysUser;
 import com.ruoyi.common.utils.DateUtils;
 import com.ruoyi.common.utils.SecurityUtils;
+import com.ruoyi.project.common.CalculateDateUtils;
+import com.ruoyi.project.domain.ServiceDonationwitness;
 import com.ruoyi.project.domain.vo.EthicalReviewVO;
+import com.ruoyi.project.domain.vo.MedicalEvaluationVO;
+import com.ruoyi.project.mapper.ServiceDonationwitnessMapper;
+import lombok.extern.slf4j.Slf4j;
 import org.springframework.beans.factory.annotation.Autowired;
 import org.springframework.stereotype.Service;
 import com.baomidou.mybatisplus.core.conditions.query.LambdaQueryWrapper;
 import com.baomidou.mybatisplus.core.toolkit.Wrappers;
 import com.baomidou.mybatisplus.extension.service.impl.ServiceImpl;
+
 import java.util.ArrayList;
 import java.util.Map;
+
 import com.ruoyi.common.utils.StringUtils;
 import com.ruoyi.project.mapper.ServiceEthicalreviewopinionsMapper;
 import com.ruoyi.project.domain.ServiceEthicalreviewopinions;
 import com.ruoyi.project.service.IServiceEthicalreviewopinionsService;
+import org.springframework.util.CollectionUtils;
 
 /**
  * 浼︾悊瀹℃煡涓撳鎰忚Service涓氬姟灞傚鐞�
@@ -25,13 +37,15 @@
  * @author ruoyi
  * @date 2021-11-23
  */
+@Slf4j
 @Service
-public class ServiceEthicalreviewopinionsServiceImpl extends ServiceImpl<ServiceEthicalreviewopinionsMapper, ServiceEthicalreviewopinions> implements IServiceEthicalreviewopinionsService
-{
+public class ServiceEthicalreviewopinionsServiceImpl extends ServiceImpl<ServiceEthicalreviewopinionsMapper, ServiceEthicalreviewopinions> implements IServiceEthicalreviewopinionsService {
 
     @Autowired
     ServiceEthicalreviewopinionsMapper serviceEthicalreviewopinionsMapper;
 
+    @Autowired
+    ServiceDonationwitnessMapper serviceDonationwitnessMapper;
 
     /**
      * 鏌ヨ浼︾悊瀹℃煡涓撳鎰忚鍒楄〃
@@ -42,29 +56,29 @@
     @Override
     public List<ServiceEthicalreviewopinions> queryList(ServiceEthicalreviewopinions serviceEthicalreviewopinions) {
         LambdaQueryWrapper<ServiceEthicalreviewopinions> wrappers = Wrappers.lambdaQuery();
-        if (serviceEthicalreviewopinions.getInfoid() != null){
-            wrappers.eq(ServiceEthicalreviewopinions::getInfoid ,serviceEthicalreviewopinions.getInfoid());
+        if (serviceEthicalreviewopinions.getInfoid() != null) {
+            wrappers.eq(ServiceEthicalreviewopinions::getInfoid, serviceEthicalreviewopinions.getInfoid());
         }
-        if (StringUtils.isNotBlank(serviceEthicalreviewopinions.getDonorno())){
-            wrappers.eq(ServiceEthicalreviewopinions::getDonorno ,serviceEthicalreviewopinions.getDonorno());
+        if (StringUtils.isNotBlank(serviceEthicalreviewopinions.getDonorno())) {
+            wrappers.eq(ServiceEthicalreviewopinions::getDonorno, serviceEthicalreviewopinions.getDonorno());
         }
-        if (StringUtils.isNotBlank(serviceEthicalreviewopinions.getExpertopinion())){
-            wrappers.eq(ServiceEthicalreviewopinions::getExpertopinion ,serviceEthicalreviewopinions.getExpertopinion());
+        if (StringUtils.isNotBlank(serviceEthicalreviewopinions.getExpertopinion())) {
+            wrappers.eq(ServiceEthicalreviewopinions::getExpertopinion, serviceEthicalreviewopinions.getExpertopinion());
         }
-        if (serviceEthicalreviewopinions.getExpertconclusion() != null){
-            wrappers.eq(ServiceEthicalreviewopinions::getExpertconclusion ,serviceEthicalreviewopinions.getExpertconclusion());
+        if (serviceEthicalreviewopinions.getExpertconclusion() != null) {
+            wrappers.eq(ServiceEthicalreviewopinions::getExpertconclusion, serviceEthicalreviewopinions.getExpertconclusion());
         }
-        if (StringUtils.isNotBlank(serviceEthicalreviewopinions.getExpertname())){
-            wrappers.like(ServiceEthicalreviewopinions::getExpertname ,serviceEthicalreviewopinions.getExpertname());
+        if (StringUtils.isNotBlank(serviceEthicalreviewopinions.getExpertname())) {
+            wrappers.like(ServiceEthicalreviewopinions::getExpertname, serviceEthicalreviewopinions.getExpertname());
         }
-        if (serviceEthicalreviewopinions.getConclusiontime() != null){
-            wrappers.eq(ServiceEthicalreviewopinions::getConclusiontime ,serviceEthicalreviewopinions.getConclusiontime());
+        if (serviceEthicalreviewopinions.getConclusiontime() != null) {
+            wrappers.eq(ServiceEthicalreviewopinions::getConclusiontime, serviceEthicalreviewopinions.getConclusiontime());
         }
-        if (StringUtils.isNotBlank(serviceEthicalreviewopinions.getConclusionannex())){
-            wrappers.eq(ServiceEthicalreviewopinions::getConclusionannex ,serviceEthicalreviewopinions.getConclusionannex());
+        if (StringUtils.isNotBlank(serviceEthicalreviewopinions.getConclusionannex())) {
+            wrappers.eq(ServiceEthicalreviewopinions::getConclusionannex, serviceEthicalreviewopinions.getConclusionannex());
         }
-        if (serviceEthicalreviewopinions.getConclusionorder() != null){
-            wrappers.eq(ServiceEthicalreviewopinions::getConclusionorder ,serviceEthicalreviewopinions.getConclusionorder());
+        if (serviceEthicalreviewopinions.getConclusionorder() != null) {
+            wrappers.eq(ServiceEthicalreviewopinions::getConclusionorder, serviceEthicalreviewopinions.getConclusionorder());
         }
         return this.list(wrappers);
     }
@@ -73,18 +87,44 @@
     public List<EthicalReviewVO> selectVOList(EthicalReviewVO ethicalReviewVO) {
 
         SysUser user = SecurityUtils.getLoginUser().getUser();
-        List <SysRole> l = user.getRoles();
+        List<SysRole> l = user.getRoles();
         Boolean b = false;
-        for(SysRole r : l){
-            if(r.getRoleId().longValue() == 3){
+        for (SysRole r : l) {
+            if (r.getRoleId().longValue() == 3) {
                 b = true;
             }
         }
-        if(b){
+        if (b) {
             ethicalReviewVO.setReporterno(user.getUserName());
         }
+        List<EthicalReviewVO> ethicalReviewVOS = serviceEthicalreviewopinionsMapper.selectVOList(ethicalReviewVO);
 
-        return serviceEthicalreviewopinionsMapper.selectVOList(ethicalReviewVO);
+        for (EthicalReviewVO ethicalReviewVO1 : ethicalReviewVOS) {
+            //鍏堢粰涓勾榫勯粯璁ゅ�硷紙鍥犱负age鏄暟瀛楃被鍨嬶紝涓嶈兘鏀炬í鏉狅紝鎵�浠ュ氨鎵�妯墰鏀惧埌鍗曚綅涓婏級
+            ethicalReviewVO1.setAgeunit("-");
+            ethicalReviewVO1.setAge(null);
+            ethicalReviewVO1.setAge2(null);
+            //鑾峰彇姝讳骸鏃堕棿锛屽鏋滆幏鍙栬璇侀噷鏈夋浜℃椂闂达紝鍒欒繘琛岃绠椾粬鐨勫勾榫�
+            ServiceDonationwitness sdw = new ServiceDonationwitness();
+            sdw.setInfoid(ethicalReviewVO1.getId());
+            List<ServiceDonationwitness> serviceDonationwitnessList = serviceDonationwitnessMapper.selectServiceDonationwitnessList(sdw);
+            if (!CollectionUtils.isEmpty(serviceDonationwitnessList) && ethicalReviewVO1.getBirthday() != null) {
+                Date deathtime = serviceDonationwitnessList.get(0).getDeathtime();
+                if (ObjectUtils.isNotEmpty(deathtime)) {
+                    Map<String, String> map = CalculateDateUtils.calculateAge(ethicalReviewVO1.getBirthday().toInstant().atZone(ZoneId.systemDefault()).toLocalDate(), deathtime.toInstant().atZone(ZoneId.systemDefault()).toLocalDate());
+                    if (ObjectUtils.isEmpty(map)) {
+                        log.error("EthicalReviewVO鍑虹敓鏃ユ湡锛歿},EthicalReviewVO姝讳骸鏃ユ湡锛歿}", ethicalReviewVO1.getBirthday(), deathtime);
+                        continue;
+                    }
+                    ethicalReviewVO1.setAge(org.apache.commons.lang3.ObjectUtils.isNotEmpty(map.get("age")) ? Long.valueOf(map.get("age")) : null);
+                    ethicalReviewVO1.setAgeunit(map.get("ageUnit"));
+                    ethicalReviewVO1.setAge2(org.apache.commons.lang3.ObjectUtils.isNotEmpty(map.get("age2")) ? Long.valueOf(map.get("age2")) : null);
+                    ethicalReviewVO1.setAgeunit2(map.get("ageUnit2"));
+                }
+            }
+
+        }
+        return ethicalReviewVOS;
     }
 
 }

--
Gitblit v1.9.3