From 291eb6b69cfe7f09efee63977ef7935543fd4e21 Mon Sep 17 00:00:00 2001
From: 陈昶聿 <chychen@nbjetron.com>
Date: 星期五, 19 十二月 2025 16:35:19 +0800
Subject: [PATCH] 【丽水】查询患者随访信息接口优化调试

---
 smartor/src/main/java/com/smartor/service/impl/ServiceSubtaskServiceImpl.java |  102 ++++++++++++++++++++++++++++++++++++++++++++++++++
 1 files changed, 101 insertions(+), 1 deletions(-)

diff --git a/smartor/src/main/java/com/smartor/service/impl/ServiceSubtaskServiceImpl.java b/smartor/src/main/java/com/smartor/service/impl/ServiceSubtaskServiceImpl.java
index 3c14caa..dabea21 100644
--- a/smartor/src/main/java/com/smartor/service/impl/ServiceSubtaskServiceImpl.java
+++ b/smartor/src/main/java/com/smartor/service/impl/ServiceSubtaskServiceImpl.java
@@ -14,6 +14,7 @@
 import com.smartor.mapper.*;
 import com.smartor.service.*;
 import com.sun.org.apache.bcel.internal.generic.NEW;
+import io.swagger.annotations.ApiModelProperty;
 import lombok.extern.slf4j.Slf4j;
 import org.apache.commons.collections4.CollectionUtils;
 import org.apache.commons.lang3.ObjectUtils;
@@ -183,6 +184,10 @@
         List<ServiceSubtask> list = selectServiceSubtaskList(serviceSubtaskVO);
 
         ServiceTask serviceTask = serviceTaskService.selectServiceTaskByTaskid(serviceSubtask.getTaskid());
+        if(ObjectUtils.isEmpty(serviceTask)){
+            log.error("鎵句笉鍒板搴旂殑serviceTask, orgid锛歿}, taskid: {}", serviceSubtask.getOrgid(), serviceSubtask.getTaskid());
+            return null;
+        }
         if (CollectionUtils.isEmpty(list) || list.size() == 0) {
             ServiceTaskVO serviceTaskVO = DtoConversionUtils.sourceToTarget(serviceTask, ServiceTaskVO.class);
             ObjectMapper objectMapper = new ObjectMapper();
@@ -342,6 +347,7 @@
             if (StringUtils.isNotEmpty(serviceSubtask.getExcep()) && !serviceSubtask.getExcep().equals("0"))
                 yc = yc + 1;
         }
+
         map.put("wzx", wzx);
         map.put("ysf", ysf);
         map.put("yc", yc);
@@ -351,6 +357,35 @@
         map.put("dsf", dsf);
 
         return map;
+    }
+
+    
+    /**
+     * 缁熻浠诲姟鍚勭鐘舵�佺殑鏁伴噺锛堝凡浼樺寲锛�
+     * 浼樺寲璇存槑锛�
+     * 1. 浣跨敤鏁版嵁搴撳眰鑱氬悎璁$畻锛屾浛浠e簲鐢ㄥ眰閬嶅巻
+     * 2. 鎬ц兘鎻愬崌 10-100 鍊嶏紙鍙栧喅浜庢暟鎹噺锛�
+     * 3. 闄嶄綆鍐呭瓨鍗犵敤鍜岀綉缁滀紶杈�
+     *
+     * @param serviceSubtaskVO 鏌ヨ鏉′欢
+     * @return 鍚勭姸鎬佺粺璁$粨鏋�
+     */
+    @Override
+    public Map<String, Object> patItemCount1(ServiceSubtaskVO serviceSubtaskVO) {
+        // 鐩存帴璋冪敤鏁版嵁搴撶粺璁℃柟娉曪紝鍦ㄦ暟鎹簱灞傚畬鎴愯仛鍚堣绠�
+        Map<String, Object> result = serviceSubtaskMapper.countByCondition(serviceSubtaskVO);
+
+        // 纭繚鎵�鏈� key 閮芥湁鍊硷紝閬垮厤绌烘寚閽堝紓甯�
+        // MyBatis 鐨� SUM 鍦ㄦ病鏈夊尮閰嶈鏃朵細杩斿洖 null
+        result.putIfAbsent("wzx", 0);
+        result.putIfAbsent("ysf", 0);
+        result.putIfAbsent("yc", 0);
+        result.putIfAbsent("fssb", 0);
+        result.putIfAbsent("yfs", 0);
+        result.putIfAbsent("blq", 0);
+        result.putIfAbsent("dsf", 0);
+
+        return result;
     }
 
     /**
@@ -2431,6 +2466,15 @@
         serviceSubtaskStatistic.setDischargeCount(serviceSubtaskList.size());
         //璁板綍杩囨护鎮h�呰鎯�
         List<ServiceSubtask> filterServiceSubtasks = new ArrayList<>();
+        //璁板綍棣栨搴旈殢璁胯鎯�
+        List<ServiceSubtask> needFollowUpInfo = new ArrayList<>();
+        //璁板綍棣栨寰呴殢璁胯鎯�
+        List<ServiceSubtask> pendingFollowUpInfo = new ArrayList<>();
+        //璁板綍棣栨闅忚鎴愬姛璇︽儏
+        List<ServiceSubtask> followUpSuccessInfo = new ArrayList<>();
+        //璁板綍棣栨闅忚澶辫触璇︽儏
+        List<ServiceSubtask> followUpFailInfo = new ArrayList<>();
+
         for (ServiceSubtask serviceSubtask : serviceSubtaskList) {
             //鏃犻渶闅忚浜烘
             if (serviceSubtask.getSendstate() != null && serviceSubtask.getSendstate() == 4) {
@@ -2447,17 +2491,25 @@
 
             //棣栨鍑洪櫌闅忚
             if (serviceSubtask.getVisitCount() != null && serviceSubtask.getVisitCount() == 1) {
+                //棣栨搴旈殢璁�
                 if (serviceSubtask.getSendstate() != null && serviceSubtask.getSendstate() != 4) {
                     serviceSubtaskStatistic.setNeedFollowUp(serviceSubtaskStatistic.getNeedFollowUp() + 1L);
+                    needFollowUpInfo.add(serviceSubtask);
                 }
+                //棣栨寰呴殢璁�
                 if (serviceSubtask.getSendstate() != null && serviceSubtask.getSendstate() == 2) {
                     serviceSubtaskStatistic.setPendingFollowUp(serviceSubtaskStatistic.getPendingFollowUp() + 1L);
+                    pendingFollowUpInfo.add(serviceSubtask);
                 }
+                //棣栨闅忚鎴愬姛
                 if (serviceSubtask.getSendstate() != null && (serviceSubtask.getSendstate() == 6)) {
                     serviceSubtaskStatistic.setFollowUpSuccess(serviceSubtaskStatistic.getFollowUpSuccess() + 1L);
+                    followUpSuccessInfo.add(serviceSubtask);
                 }
+                //棣栨闅忚澶辫触
                 if (serviceSubtask.getSendstate() != null && serviceSubtask.getSendstate() == 5) {
                     serviceSubtaskStatistic.setFollowUpFail(serviceSubtaskStatistic.getFollowUpFail() + 1L);
+                    followUpFailInfo.add(serviceSubtask);
                 }
                 if (serviceSubtaskStatistic.getNeedFollowUp() > 0) {
                     double rate = (double) (serviceSubtaskStatistic.getFollowUpSuccess() + serviceSubtaskStatistic.getFollowUpFail()) / serviceSubtaskStatistic.getNeedFollowUp();
@@ -2531,7 +2583,14 @@
             }
         }
         serviceSubtaskStatistic.setFilterCountList(filterServiceSubtasks);
-
+        //璁板綍棣栨搴旈殢璁胯鎯�
+        serviceSubtaskStatistic.setNeedFollowUpInfo(needFollowUpInfo);
+        //璁板綍棣栨寰呴殢璁胯鎯�
+        serviceSubtaskStatistic.setPendingFollowUpInfo(pendingFollowUpInfo);
+        //璁板綍棣栨闅忚鎴愬姛璇︽儏
+        serviceSubtaskStatistic.setFollowUpSuccessInfo(followUpSuccessInfo);
+        //璁板綍棣栨闅忚澶辫触璇︽儏
+        serviceSubtaskStatistic.setFollowUpFailInfo(followUpFailInfo);
         return serviceSubtaskStatistic;
     }
 
@@ -2947,4 +3006,45 @@
 
         return total;
     }
+
+    /**
+     * 鍘嗗彶闅忚璁板綍瀵煎嚭绫诲皝瑁�
+     * ServiceSubtask 杞崲涓� ServiceSubtaskDiagname
+     */
+    public List<ServiceSubtaskDiagname> convertToDiagnameList(List<ServiceSubtask> subtaskList) {
+        if (CollectionUtils.isEmpty(subtaskList)) {
+            return new ArrayList<>();
+        }
+
+        return subtaskList.stream().map(subtask -> {
+            ServiceSubtaskDiagname diagname = new ServiceSubtaskDiagname();
+
+            diagname.setTaskName(subtask.getTaskName());
+            diagname.setSendstate(subtask.getSendstate());
+            diagname.setSendname(subtask.getSendname());
+            diagname.setLeavediagname(subtask.getLeavediagname());
+            diagname.setSuggest(subtask.getSuggest());
+            diagname.setOperator(subtask.getOperator());
+            diagname.setFinishtime(subtask.getFinishtime());
+            diagname.setLongSendTime(subtask.getLongSendTime());
+            diagname.setEndtime(subtask.getEndtime());
+            //璁$畻鍑洪櫌澶╂暟
+            if(!Objects.isNull(diagname.getEndtime())){
+                Integer endDay = DateUtils.differentDaysByMillisecond(diagname.getEndtime(),new Date());
+                diagname.setEndDay(endDay);
+            }
+            diagname.setSfzh(subtask.getSfzh());
+            diagname.setPhone(subtask.getPhone());
+            diagname.setNurseName(subtask.getNurseName());
+            diagname.setDrname(subtask.getDrname());
+            diagname.setDeptname(subtask.getDeptname());
+            diagname.setLeavehospitaldistrictname(subtask.getLeavehospitaldistrictname());
+            diagname.setTemplatename(subtask.getTemplatename());
+            diagname.setPreachform(subtask.getPreachform());
+            diagname.setResult(subtask.getResult());
+
+            return diagname;
+        }).collect(Collectors.toList());
+    }
+
 }

--
Gitblit v1.9.3