From 0e811615b93c04188ba520b2ba6b89b0d186f80b Mon Sep 17 00:00:00 2001
From: liusheng <337615773@qq.com>
Date: 星期一, 26 一月 2026 20:12:27 +0800
Subject: [PATCH] Merge remote-tracking branch 'origin/master'

---
 ruoyi-quartz/src/main/java/com/ruoyi/quartz/task/RyTask.java                             |   11 ++
 ruoyi-admin/src/main/java/com/ruoyi/web/controller/smartor/ServiceSubtaskController.java |    8 ++
 smartor/src/main/java/com/smartor/service/impl/ServiceSubtaskServiceImpl.java            |  169 ++++++++++++++++++++++++++++-------------
 smartor/src/main/java/com/smartor/domain/ServiceSubtaskCountReq.java                     |    7 +
 ruoyi-system/src/main/resources/mapper/system/SysConfigMapper.xml                        |    1 
 smartor/src/main/resources/mapper/smartor/ServiceSubtaskMapper.xml                       |   34 ++++++++
 6 files changed, 175 insertions(+), 55 deletions(-)

diff --git a/ruoyi-admin/src/main/java/com/ruoyi/web/controller/smartor/ServiceSubtaskController.java b/ruoyi-admin/src/main/java/com/ruoyi/web/controller/smartor/ServiceSubtaskController.java
index 2a5ff0d..857b8a6 100644
--- a/ruoyi-admin/src/main/java/com/ruoyi/web/controller/smartor/ServiceSubtaskController.java
+++ b/ruoyi-admin/src/main/java/com/ruoyi/web/controller/smartor/ServiceSubtaskController.java
@@ -22,6 +22,7 @@
 import com.ruoyi.common.utils.poi.ExcelUtil;
 import com.ruoyi.common.utils.reflect.ReflectUtils;
 import com.ruoyi.common.utils.uuid.IdUtils;
+import com.ruoyi.system.domain.SysConfig;
 import com.ruoyi.system.service.ISysConfigService;
 import com.smartor.domain.*;
 import com.smartor.mapper.PatMedInhospMapper;
@@ -487,6 +488,13 @@
         if (CollectionUtils.isEmpty(serviceSubtaskCountReq.getServiceType())) {
             return error("鏈嶅姟绫诲瀷涓嶈兘涓虹┖");
         }
+        String followUpCountStyle = configService.selectConfigByKey("followUpCountStyle",
+                serviceSubtaskCountReq.getOrgid());
+        if (ObjectUtils.isNotEmpty(followUpCountStyle)){
+            serviceSubtaskCountReq.setFollowUpCountStyle(followUpCountStyle);
+        }else {
+            serviceSubtaskCountReq.setFollowUpCountStyle("1");
+        }
         return success(serviceSubtaskService.getSfStatistics(serviceSubtaskCountReq));
     }
 
diff --git a/ruoyi-quartz/src/main/java/com/ruoyi/quartz/task/RyTask.java b/ruoyi-quartz/src/main/java/com/ruoyi/quartz/task/RyTask.java
index 0855f2b..03332f0 100644
--- a/ruoyi-quartz/src/main/java/com/ruoyi/quartz/task/RyTask.java
+++ b/ruoyi-quartz/src/main/java/com/ruoyi/quartz/task/RyTask.java
@@ -888,6 +888,17 @@
         Optional<Long> currentSort = serviceSubtaskPreachforms.stream().filter(item -> serviceSubtask.getCurrentPreachform().equals(item.getPreachform())).map(ServiceSubtaskPreachform::getSort).findFirst();
 
         if (currentSort.isPresent()) {
+            //寰俊宸插彂閫併�佸凡棰嗗彇瑙嗕负鍙戦�佹垚鍔燂紝涓嶅啀杩涜琛ュ伩 -涓芥按涓尰闄�
+            if(active.equals("47231022633110211A2101")){
+                //鑾峰彇褰撳墠鍙戦�佹柟寮�
+                ServiceSubtaskPreachform currentServiceSubtaskPreachform = serviceSubtaskPreachforms.stream().filter(item -> item.getSort().equals(currentSort.get())).findFirst().orElse(new ServiceSubtaskPreachform());
+                if(currentServiceSubtaskPreachform.getPreachform().equals("5")
+                        && (currentServiceSubtaskPreachform.getSendstate().equals("2")
+                        || currentServiceSubtaskPreachform.getSendstate().equals("3"))){
+                    return "-1";
+                }
+            }
+
             // 妫�鏌ユ槸鍚︽墍鏈塻endstate涓嶇瓑浜�9
             boolean allSendStateNot1AndNot9 = serviceSubtaskPreachforms.stream().allMatch(item -> !item.getSendstate().equals("9"));
             if (!allSendStateNot1AndNot9) {
diff --git a/ruoyi-system/src/main/resources/mapper/system/SysConfigMapper.xml b/ruoyi-system/src/main/resources/mapper/system/SysConfigMapper.xml
index 8ee3b05..fc59999 100644
--- a/ruoyi-system/src/main/resources/mapper/system/SysConfigMapper.xml
+++ b/ruoyi-system/src/main/resources/mapper/system/SysConfigMapper.xml
@@ -51,6 +51,7 @@
     <select id="selectConfig" parameterType="SysConfig" resultMap="SysConfigResult">
         <include refid="selectConfigVo"/>
         <include refid="sqlwhereSearch"/>
+        limit 1
     </select>
 
     <select id="selectConfigList" parameterType="SysConfig" resultMap="SysConfigResult">
diff --git a/smartor/src/main/java/com/smartor/domain/ServiceSubtaskCountReq.java b/smartor/src/main/java/com/smartor/domain/ServiceSubtaskCountReq.java
index 79c133a..15e7b38 100644
--- a/smartor/src/main/java/com/smartor/domain/ServiceSubtaskCountReq.java
+++ b/smartor/src/main/java/com/smartor/domain/ServiceSubtaskCountReq.java
@@ -103,6 +103,13 @@
      */
     @ApiModelProperty(value = "鍒嗙粍key")
     private String groupKey;
+
+    /**
+     * 闅忚缁熻鏂瑰紡 1-榛樿缁熻鏂瑰紡 2-缁熻鏃剁畻涓婁笉鍙戦�佺殑
+     */
+    @ApiModelProperty(value = "缁熻鏂瑰紡")
+    private String followUpCountStyle;
+
     /**
      * 鍒嗙粍code闆嗗悎
      */
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 068d985..0edb482 100644
--- a/smartor/src/main/java/com/smartor/service/impl/ServiceSubtaskServiceImpl.java
+++ b/smartor/src/main/java/com/smartor/service/impl/ServiceSubtaskServiceImpl.java
@@ -2272,7 +2272,7 @@
             if (CollectionUtils.isEmpty(serviceSubtaskList)) {
                 continue;
             }
-            ServiceSubtaskStatistic statistic = getStatistic(serviceSubtaskList);
+            ServiceSubtaskStatistic statistic = getStatistic(serviceSubtaskList, serviceSubtaskCountReq.getFollowUpCountStyle());
             if(ObjectUtils.isNotEmpty(jsRates)){
                 Map<String, Object> jsRateMap = jsRates.get(collectKey);
                 BigDecimal jsRate = new BigDecimal("0");
@@ -2519,7 +2519,7 @@
     }
 
 
-    private ServiceSubtaskStatistic getStatistic(List<ServiceSubtask> serviceSubtaskList) {
+    private ServiceSubtaskStatistic getStatistic(List<ServiceSubtask> serviceSubtaskList, String followUpCountStyle) {
         ServiceSubtaskStatistic serviceSubtaskStatistic = new ServiceSubtaskStatistic();
         //鏍煎紡鍖栦负涓や綅灏忔暟鐨勭櫨鍒嗘瘮
         DecimalFormat percentFormat = new DecimalFormat("##.##%");
@@ -2589,42 +2589,72 @@
                     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);
+                }
+                /**
+                 * 涓嶅悓缁熻鏂瑰紡涓嬩笉鍚岀殑闅忚鎴愬姛鏁� 鍙傛暟 followUpCountStyle 鎺у埗
+                 */
+                if(StringUtils.isNotEmpty(followUpCountStyle) && followUpCountStyle.equals("1")){
+                    //棣栨闅忚鎴愬姛
+                    if (serviceSubtask.getSendstate() != null && (serviceSubtask.getSendstate() == 6L)) {
+                        serviceSubtaskStatistic.setFollowUpSuccess(serviceSubtaskStatistic.getFollowUpSuccess() + 1L);
+                        followUpSuccessInfo.add(serviceSubtask);
+                    }
+                    //棣栨闅忚浜哄伐 (涓嶇粺璁′笉鎵ц)
+                    if (serviceSubtask.getSendstate() != null
+                            && !serviceSubtask.getSendstate().equals(4L)
+                            && serviceSubtask.getPreachform().equals("1")) {
+                        serviceSubtaskStatistic.setManual(serviceSubtaskStatistic.getManual() + 1L);
+                        manualInfo.add(serviceSubtask);
+                    }
+                    //棣栨闅忚鐭俊(涓嶇粺璁′笉鎵ц)
+                    if (serviceSubtask.getSendstate() != null
+                            && !serviceSubtask.getSendstate().equals(4L)
+                            && serviceSubtask.getPreachform().equals("4")) {
+                        serviceSubtaskStatistic.setSms(serviceSubtaskStatistic.getSms() + 1L);
+                        smsInfo.add(serviceSubtask);
+                    }
+                    //棣栨闅忚寰俊(涓嶇粺璁′笉鎵ц)
+                    if (serviceSubtask.getSendstate() != null
+                            && !serviceSubtask.getSendstate().equals(4L)
+                            && serviceSubtask.getPreachform().equals("5")) {
+                        serviceSubtaskStatistic.setWeChat(serviceSubtaskStatistic.getWeChat() + 1L);
+                        wechatInfo.add(serviceSubtask);
+                    }
+                }else {
+                    //棣栨闅忚鎴愬姛 - 缁熻鏃跺�欏姞涓婁笉鎵ц鐨勶紝宸插彂閫佺殑
+                    if (serviceSubtask.getSendstate() != null && (serviceSubtask.getSendstate().equals(6L)
+                            || serviceSubtask.getSendstate().equals(3L) || serviceSubtask.getSendstate().equals(4L))) {
+                        serviceSubtaskStatistic.setFollowUpSuccess(serviceSubtaskStatistic.getFollowUpSuccess() + 1L);
+                        followUpSuccessInfo.add(serviceSubtask);
+                    }
+                    //棣栨闅忚浜哄伐 (缁熻涓嶆墽琛�)
+                    if (serviceSubtask.getSendstate() != null
+                            && serviceSubtask.getPreachform().equals("1")) {
+                        serviceSubtaskStatistic.setManual(serviceSubtaskStatistic.getManual() + 1L);
+                        manualInfo.add(serviceSubtask);
+                    }
+                    //棣栨闅忚鐭俊(缁熻涓嶆墽琛�)
+                    if (serviceSubtask.getSendstate() != null
+                            && serviceSubtask.getPreachform().equals("4")) {
+                        serviceSubtaskStatistic.setSms(serviceSubtaskStatistic.getSms() + 1L);
+                        smsInfo.add(serviceSubtask);
+                    }
+                    //棣栨闅忚寰俊(缁熻涓嶆墽琛�)
+                    if (serviceSubtask.getSendstate() != null
+                            && serviceSubtask.getPreachform().equals("5")) {
+                        serviceSubtaskStatistic.setWeChat(serviceSubtaskStatistic.getWeChat() + 1L);
+                        wechatInfo.add(serviceSubtask);
+                    }
                 }
                 if (serviceSubtaskStatistic.getNeedFollowUp() > 0) {
                     double rate = (double) (serviceSubtaskStatistic.getFollowUpSuccess() + serviceSubtaskStatistic.getFollowUpFail()) / serviceSubtaskStatistic.getNeedFollowUp();
                     serviceSubtaskStatistic.setFollowUpRate(percentFormat.format(rate));
                 } else {
                     serviceSubtaskStatistic.setFollowUpRate("0.00%");
-                }
-                //棣栨闅忚浜哄伐 (涓嶇粺璁′笉鎵ц)
-                if (serviceSubtask.getSendstate() != null
-                        && !serviceSubtask.getSendstate().equals(4L)
-                        && serviceSubtask.getPreachform().equals("1")) {
-                    serviceSubtaskStatistic.setManual(serviceSubtaskStatistic.getManual() + 1L);
-                    manualInfo.add(serviceSubtask);
-                }
-                //棣栨闅忚鐭俊(涓嶇粺璁′笉鎵ц)
-                if (serviceSubtask.getSendstate() != null
-                        && !serviceSubtask.getSendstate().equals(4L)
-                        && serviceSubtask.getPreachform().equals("4")) {
-                    serviceSubtaskStatistic.setSms(serviceSubtaskStatistic.getSms() + 1L);
-                    smsInfo.add(serviceSubtask);
-                }
-                //棣栨闅忚寰俊(涓嶇粺璁′笉鎵ц)
-                if (serviceSubtask.getSendstate() != null
-                        && !serviceSubtask.getSendstate().equals(4L)
-                        && serviceSubtask.getPreachform().equals("5")) {
-                    serviceSubtaskStatistic.setWeChat(serviceSubtaskStatistic.getWeChat() + 1L);
-                    wechatInfo.add(serviceSubtask);
                 }
                 //缁撴灉寮傚父
                 if (serviceSubtask.getSendstate() != null && serviceSubtask.getExcep().equals("1")) {
@@ -2642,42 +2672,73 @@
                     serviceSubtaskStatistic.setPendingFollowUpAgain(serviceSubtaskStatistic.getPendingFollowUpAgain() + 1L);
                     pendingFollowUpAgainInfo.add(serviceSubtask);
                 }
-                //鍐嶆闅忚鎴愬姛
-                if (serviceSubtask.getSendstate() != null && (serviceSubtask.getSendstate() == 1 || serviceSubtask.getSendstate() == 3 || serviceSubtask.getSendstate() == 6)) {
-                    serviceSubtaskStatistic.setFollowUpSuccessAgain(serviceSubtaskStatistic.getFollowUpSuccessAgain() + 1L);
-                    followUpSuccessAgainInfo.add(serviceSubtask);
-                }
                 //鍐嶆闅忚澶辫触
                 if (serviceSubtask.getSendstate() != null && serviceSubtask.getSendstate() == 5) {
                     serviceSubtaskStatistic.setFollowUpFailAgain(serviceSubtaskStatistic.getFollowUpFailAgain() + 1L);
                     followUpFailAgainInfo.add(serviceSubtask);
+                }
+                /**
+                 * 涓嶅悓缁熻鏂瑰紡涓嬩笉鍚岀殑闅忚鎴愬姛鏁� 鍙傛暟 followUpCountStyle 鎺у埗
+                 */
+                if(StringUtils.isNotEmpty(followUpCountStyle) && followUpCountStyle.equals("1")){
+                    //鍐嶆闅忚鎴愬姛
+                    if (serviceSubtask.getSendstate() != null && (serviceSubtask.getSendstate() == 1 || serviceSubtask.getSendstate() == 3 || serviceSubtask.getSendstate() == 6)) {
+                        serviceSubtaskStatistic.setFollowUpSuccessAgain(serviceSubtaskStatistic.getFollowUpSuccessAgain() + 1L);
+                        followUpSuccessAgainInfo.add(serviceSubtask);
+                    }
+                    //鍐嶆闅忚浜哄伐(涓嶇粺璁′笉鎵ц)
+                    if (serviceSubtask.getSendstate() != null
+                            && !serviceSubtask.getSendstate().equals(4L)
+                            && serviceSubtask.getPreachform().equals("1")) {
+                        serviceSubtaskStatistic.setManualAgain(serviceSubtaskStatistic.getManualAgain() + 1L);
+                        manualAgainInfo.add(serviceSubtask);
+                    }
+                    //鍐嶆闅忚鐭俊(涓嶇粺璁′笉鎵ц)
+                    if (serviceSubtask.getSendstate() != null
+                            && !serviceSubtask.getSendstate().equals(4L)
+                            && serviceSubtask.getPreachform().equals("4")) {
+                        serviceSubtaskStatistic.setSmsAgain(serviceSubtaskStatistic.getSmsAgain() + 1L);
+                        smsAgainInfo.add(serviceSubtask);
+                    }
+                    //鍐嶆闅忚寰俊(涓嶇粺璁′笉鎵ц)
+                    if (serviceSubtask.getSendstate() != null
+                            && !serviceSubtask.getSendstate().equals(4L)
+                            && serviceSubtask.getPreachform().equals("5")) {
+                        serviceSubtaskStatistic.setWeChatAgain(serviceSubtaskStatistic.getWeChatAgain() + 1L);
+                        wechatAgainInfo.add(serviceSubtask);
+                    }
+                }else {
+                    //鍐嶆闅忚鎴愬姛
+                    if (serviceSubtask.getSendstate() != null &&
+                            (serviceSubtask.getSendstate().equals(1L) || serviceSubtask.getSendstate().equals(6L) ||
+                            serviceSubtask.getSendstate().equals(3L) || serviceSubtask.getSendstate().equals(4L))) {
+                        serviceSubtaskStatistic.setFollowUpSuccessAgain(serviceSubtaskStatistic.getFollowUpSuccessAgain() + 1L);
+                        followUpSuccessAgainInfo.add(serviceSubtask);
+                    }
+                    //鍐嶆闅忚浜哄伐(缁熻涓嶆墽琛�)
+                    if (serviceSubtask.getSendstate() != null
+                            && serviceSubtask.getPreachform().equals("1")) {
+                        serviceSubtaskStatistic.setManualAgain(serviceSubtaskStatistic.getManualAgain() + 1L);
+                        manualAgainInfo.add(serviceSubtask);
+                    }
+                    //鍐嶆闅忚鐭俊(缁熻涓嶆墽琛�)
+                    if (serviceSubtask.getSendstate() != null
+                            && serviceSubtask.getPreachform().equals("4")) {
+                        serviceSubtaskStatistic.setSmsAgain(serviceSubtaskStatistic.getSmsAgain() + 1L);
+                        smsAgainInfo.add(serviceSubtask);
+                    }
+                    //鍐嶆闅忚寰俊(缁熻涓嶆墽琛�)
+                    if (serviceSubtask.getSendstate() != null
+                            && serviceSubtask.getPreachform().equals("5")) {
+                        serviceSubtaskStatistic.setWeChatAgain(serviceSubtaskStatistic.getWeChatAgain() + 1L);
+                        wechatAgainInfo.add(serviceSubtask);
+                    }
                 }
                 if (serviceSubtaskStatistic.getNeedFollowUp() > 0) {
                     double rate = (double) (serviceSubtaskStatistic.getFollowUpSuccessAgain() + serviceSubtaskStatistic.getFollowUpFailAgain()) / serviceSubtaskStatistic.getNeedFollowUpAgain();
                     serviceSubtaskStatistic.setFollowUpRateAgain(percentFormat.format(rate));
                 } else {
                     serviceSubtaskStatistic.setFollowUpRateAgain("0.00%");
-                }
-                //鍐嶆闅忚浜哄伐(涓嶇粺璁′笉鎵ц)
-                if (serviceSubtask.getSendstate() != null
-                        && !serviceSubtask.getSendstate().equals(4L)
-                        && serviceSubtask.getPreachform().equals("1")) {
-                    serviceSubtaskStatistic.setManualAgain(serviceSubtaskStatistic.getManualAgain() + 1L);
-                    manualAgainInfo.add(serviceSubtask);
-                }
-                //鍐嶆闅忚鐭俊(涓嶇粺璁′笉鎵ц)
-                if (serviceSubtask.getSendstate() != null
-                        && !serviceSubtask.getSendstate().equals(4L)
-                        && serviceSubtask.getPreachform().equals("4")) {
-                    serviceSubtaskStatistic.setSmsAgain(serviceSubtaskStatistic.getSmsAgain() + 1L);
-                    smsAgainInfo.add(serviceSubtask);
-                }
-                //鍐嶆闅忚寰俊(涓嶇粺璁′笉鎵ц)
-                if (serviceSubtask.getSendstate() != null
-                        && !serviceSubtask.getSendstate().equals(4L)
-                        && serviceSubtask.getPreachform().equals("5")) {
-                    serviceSubtaskStatistic.setWeChatAgain(serviceSubtaskStatistic.getWeChatAgain() + 1L);
-                    wechatAgainInfo.add(serviceSubtask);
                 }
                 //鍐嶆寮傚父
                 if (serviceSubtask.getSendstate() != null && serviceSubtask.getExcep().equals("1")) {
diff --git a/smartor/src/main/resources/mapper/smartor/ServiceSubtaskMapper.xml b/smartor/src/main/resources/mapper/smartor/ServiceSubtaskMapper.xml
index a479da0..cf129d9 100644
--- a/smartor/src/main/resources/mapper/smartor/ServiceSubtaskMapper.xml
+++ b/smartor/src/main/resources/mapper/smartor/ServiceSubtaskMapper.xml
@@ -1216,7 +1216,39 @@
 
     <select id="getSfStatistics" parameterType="com.smartor.domain.ServiceSubtaskCountReq"
             resultMap="ServiceSubtaskResult">
-        <include refid="selectServiceSubtaskVo"/>
+        select id,
+        visit_count,
+        is_visit_again,
+        type,
+        orgid,
+        drcode,
+        drname,
+        leavehospitaldistrictcode,
+        leavehospitaldistrictname,
+        deptcode,
+        deptname,
+        sendstate,
+        preachform,
+        excep,
+        nurse_id,
+        nurse_name,
+        taskid,
+        task_name,
+        visit_time,
+        finishtime,
+        endtime,
+        senddate,
+        suggest,
+        result,
+        templateid,
+        templatename,
+        patid,
+        sendname,
+        send_type,
+        recordid,
+        exrecallcount,
+        task_situation
+        from service_subtask
         where 1=1
         and del_flag = 0
         <if test="orgid != null and orgid != ''">

--
Gitblit v1.9.3