From c5f7cf883c94d92cf7ef575b1f73df1f810da7b6 Mon Sep 17 00:00:00 2001
From: 陈昶聿 <chychen@nbjetron.com>
Date: 星期二, 16 十二月 2025 10:59:50 +0800
Subject: [PATCH] 【丽水】writeInSubTask 增加回滚事务

---
 smartor/src/main/java/com/smartor/service/impl/PatMedInhospServiceImpl.java |  411 +++++++++++++++++++++++++++++++++++++++++----------------
 1 files changed, 293 insertions(+), 118 deletions(-)

diff --git a/smartor/src/main/java/com/smartor/service/impl/PatMedInhospServiceImpl.java b/smartor/src/main/java/com/smartor/service/impl/PatMedInhospServiceImpl.java
index 8fd0c47..b0d1cef 100644
--- a/smartor/src/main/java/com/smartor/service/impl/PatMedInhospServiceImpl.java
+++ b/smartor/src/main/java/com/smartor/service/impl/PatMedInhospServiceImpl.java
@@ -1,5 +1,8 @@
 package com.smartor.service.impl;
 
+import com.fasterxml.jackson.core.JsonProcessingException;
+import com.fasterxml.jackson.core.type.TypeReference;
+import com.fasterxml.jackson.databind.ObjectMapper;
 import com.ruoyi.common.core.domain.entity.SysDept;
 import com.ruoyi.common.utils.DateUtils;
 import com.ruoyi.common.utils.DtoConversionUtils;
@@ -14,6 +17,9 @@
 import org.springframework.beans.factory.annotation.Value;
 import org.springframework.stereotype.Service;
 
+import java.io.IOException;
+import java.time.Instant;
+import java.time.temporal.ChronoUnit;
 import java.util.*;
 import java.util.stream.Collectors;
 
@@ -28,13 +34,10 @@
 public class PatMedInhospServiceImpl implements IPatMedInhospService {
     @Autowired
     private PatMedInhospMapper patMedInhospMapper;
-
     @Autowired
     private ServiceTaskdeptMapper serviceTaskdeptMapper;
-
     @Autowired
     private ServiceTaskdiagMapper serviceTaskdiagMapper;
-
     @Autowired
     private PatArchiveMapper patArchiveMapper;
     @Autowired
@@ -44,10 +47,10 @@
     @Autowired
     private ServiceSubtaskMapper serviceSubtaskMapper;
     @Autowired
-    private SysUserDeptMapper sysUserDeptMapper;
+    private ServiceSubtaskPreachformMapper serviceSubtaskPreachformMapper;
+    @Value("${spring.profiles.active}")
+    private String active;
 
-    @Value("${visitHosp}")
-    private Integer visitHosp;
 
     /**
      * 鏌ヨ鎮h�呬綇闄㈣褰�
@@ -58,6 +61,11 @@
     @Override
     public PatMedInhosp selectPatMedInhospByInhospid(Long inhospid) {
         return patMedInhospMapper.selectPatMedInhospByInhospid(inhospid);
+    }
+
+    @Override
+    public List<PatMedInhosp> selectPatMedInhosp(PatMedInhosp patMedInhosp) {
+        return patMedInhospMapper.selectPatMedInhosp(patMedInhosp);
     }
 
     /**
@@ -74,6 +82,19 @@
             patMedInhosp1.setTagname(tagname);
         }
         return patMedInhospList;
+    }
+
+    @Override
+    public Map<String, Integer> queryPersonCount(PatServiceCount patServiceCount) {
+        if (patServiceCount.getInterval() == 1) {
+            //鍛�
+        } else if (patServiceCount.getInterval() == 2) {
+            //鏈�
+        } else if (patServiceCount.getInterval() == 3) {
+            //骞�
+        }
+
+        return null;
     }
 
     /**
@@ -117,15 +138,16 @@
         PatMedRes patMedRes = null;
         // 鑾峰彇褰撳墠鐧婚檰浜虹殑閮ㄩ棬鏉冮檺
         if (org.springframework.util.CollectionUtils.isEmpty(patMedReq.getDeptcodeList())) {
-            Long userId = SecurityUtils.getUserId();
-            List<SysDept> sysDepts = sysUserDeptMapper.selectDeptListByUserId(userId);
-            List<String> deptCode = new ArrayList<>();
-            for (SysDept sysDept : sysDepts) {
-                deptCode.add(sysDept.getDeptId().toString());
-            }
-            patMedReq.setDeptcodeList(deptCode);
-            patMedRes = patMedInhospMapper.selectPatMedInhospCount(patMedReq);
+//            Long userId = SecurityUtils.getUserId();
+//            List<SysDept> sysDepts = sysUserDeptMapper.selectDeptListByUserId(userId);
+//            List<String> deptCode = new ArrayList<>();
+//            for (SysDept sysDept : sysDepts) {
+//                deptCode.add(sysDept.getDeptId().toString());
+//            }
+//            patMedReq.setDeptcodeList(deptCode);
+//            patMedRes = patMedInhospMapper.selectPatMedInhospCount(patMedReq);
         }
+        patMedRes = patMedInhospMapper.selectPatMedInhospCount(patMedReq);
         return patMedRes;
     }
 
@@ -188,7 +210,7 @@
     }
 
     @Override
-    public int dealOutHospInfo() {
+    public int dealOutHospInfo(String config) {
 
         PatMedInhosp pmks = new PatMedInhosp();
         //鑾峰彇闇�瑕佸嚭闄㈤儴闂ㄩ殢璁匡紝鏈鐞嗙殑鏁版嵁
@@ -196,7 +218,7 @@
         pmks.setInhospstate("1");
         pmks.setFuflag("1");
         List<PatMedInhosp> patMedInhosps = patMedInhospMapper.selectPatMedInhospList(pmks);
-        log.error("dealOutHospInfo闇�瑕佸鐞嗙殑鍑洪櫌閮ㄩ棬鎮h�呬俊鎭細{}", patMedInhosps);
+        log.info("dealOutHospInfo闇�瑕佸鐞嗙殑鍑洪櫌閮ㄩ棬鎮h�呬俊鎭細{}", CollectionUtils.isNotEmpty(patMedInhosps) ? patMedInhosps.size() : null);
         for (PatMedInhosp patMedInhosp1 : patMedInhosps) {
             String tagname = patMedInhospMapper.getTagnameBypatid(patMedInhosp1.getPatid());
             patMedInhosp1.setTagname(tagname);
@@ -228,7 +250,7 @@
                     patMedInhospMapper.updatePatMedInhosp(patMedInhosp1);
                 } else {
                     for (ServiceTaskdept serviceTaskdept1 : serviceTaskdepts) {
-                        writeInSubTask(serviceTaskdept1.getTaskId(), true, patMedInhosp1, patArchive, 1);
+                        writeInSubTask(serviceTaskdept1.getTaskId(), true, patMedInhosp1, patArchive, 1, config);
                     }
                     patMedInhosp1.setDeptcheckFlag("1");
                     patMedInhospMapper.updatePatMedInhosp(patMedInhosp1);
@@ -241,15 +263,14 @@
         }
 
         //鏍规嵁鎮h�呮墍鍦ㄧ梾鍖猴紝鑾峰彇璇ョ梾鍖虹殑闀挎湡浠诲姟,鏂板崕鍖婚櫌鍙互鍏堜笉鐢ㄦ牴鎹梾鍖哄拰鐤剧梾鏉ュ仛
-        if (visitHosp != 1) {
-
+        if (!active.equals("xh")) {
             PatMedInhosp pmbq = new PatMedInhosp();
             //鑾峰彇闇�瑕佸嚭闄㈤儴闂ㄩ殢璁匡紝鏈鐞嗙殑鏁版嵁
             pmbq.setWardcheckFlag("0");
             pmbq.setInhospstate("1");
             pmbq.setFuflag("1");
             List<PatMedInhosp> patMedInhospBQs = patMedInhospMapper.selectPatMedInhospList(pmbq);
-            log.error("dealOutHospInfo闇�瑕佸鐞嗙殑鍑洪櫌鐥呭尯鎮h�呬俊鎭細{}", patMedInhosps);
+            log.info("dealOutHospInfo闇�瑕佸鐞嗙殑鍑洪櫌鐥呭尯鎮h�呬俊鎭細{}", CollectionUtils.isNotEmpty(patMedInhospBQs) ? patMedInhospBQs.size() : null);
             for (PatMedInhosp patMedInhosp1 : patMedInhospBQs) {
                 String tagname = patMedInhospMapper.getTagnameBypatid(patMedInhosp1.getPatid());
                 patMedInhosp1.setTagname(tagname);
@@ -280,7 +301,7 @@
                         patMedInhospMapper.updatePatMedInhosp(pmiBQ1);
                     } else {
                         for (ServiceTaskdept serviceTaskdept1 : serviceTaskdeptList) {
-                            writeInSubTask(serviceTaskdept1.getTaskId(), true, pmiBQ1, patArchive, 2);
+                            writeInSubTask(serviceTaskdept1.getTaskId(), true, pmiBQ1, patArchive, 2, config);
                         }
                         pmiBQ1.setWardcheckFlag("1");
                         patMedInhospMapper.updatePatMedInhosp(pmiBQ1);
@@ -299,7 +320,7 @@
             pmjb.setInhospstate("1");
             pmjb.setFuflag("1");
             List<PatMedInhosp> patMedInhospJBs = patMedInhospMapper.selectPatMedInhospList(pmjb);
-            log.error("dealOutHospInfo闇�瑕佸鐞嗙殑鍑洪櫌鐤剧梾鎮h�呬俊鎭細{}", patMedInhosps);
+            log.info("dealOutHospInfo闇�瑕佸鐞嗙殑鍑洪櫌鐤剧梾鎮h�呬俊鎭細{}", CollectionUtils.isNotEmpty(patMedInhospJBs) ? patMedInhospJBs.size() : null);
             for (PatMedInhosp patMedInhosp1 : patMedInhospJBs) {
                 String tagname = patMedInhospMapper.getTagnameBypatid(patMedInhosp1.getPatid());
                 patMedInhosp1.setTagname(tagname);
@@ -315,6 +336,9 @@
                     continue;
                 }
                 try {
+                    if (StringUtils.isEmpty(pmiJB.getLeaveicd10code())) {
+                        continue;
+                    }
                     // 鏍规嵁鎮h�呯殑鐤剧梾锛岃幏鍙栬鐤剧梾鐨勯暱鏈熶换鍔�
                     ServiceTaskdiag serviceTaskdiag = new ServiceTaskdiag();
                     serviceTaskdiag.setLongtask(1L);
@@ -330,7 +354,7 @@
                         patMedInhospMapper.updatePatMedInhosp(pmiJB);
                     } else {
                         for (ServiceTaskdiag serviceTaskdept1 : serviceTaskdiags) {
-                            writeInSubTask(serviceTaskdept1.getTaskId(), true, pmiJB, patArchive, 3);
+                            writeInSubTask(serviceTaskdept1.getTaskId(), true, pmiJB, patArchive, 3, config);
                         }
                         pmiJB.setDiagcheckFlag("1");
                         patMedInhospMapper.updatePatMedInhosp(pmiJB);
@@ -342,7 +366,6 @@
                 }
             }
         }
-
 
         //鑾峰彇鏈鐞嗗湪闄㈢殑鏁版嵁(濡傛灉鍒氬垰鍑洪櫌鐨勬偅鑰呮暟鎹殑鍑洪櫌鏃堕棿,鍦ㄤ笅闈㈡煡璇㈠嚭鐨勫叆闄㈡椂闂翠箣鍓�,閭d箣鍓嶇殑鍑洪櫌鎮h�呯殑鏁版嵁,涔熷緱鍋滄帀,鍥犱负鍙堝叆闄簡)
         PatMedInhosp patMedInhosp = new PatMedInhosp();
@@ -467,7 +490,7 @@
     @Override
     public List<PatMedRes> getDeptRanking(PatMedReq patMedReq) {
 
-        return patMedInhospMapper.getDeptRanking(patMedReq);
+        return serviceSubtaskMapper.getDeptRanking(patMedReq);
     }
 
     @Override
@@ -515,122 +538,230 @@
     }
 
     //灏嗘偅鑰呮斁鍒皊ubtask涓�
-    private void writeInSubTask(Long taskid, Boolean check, PatMedInhosp patMedInhosp1, PatArchive patArchive, Integer type) {
+    private void writeInSubTask(Long taskid, Boolean check, PatMedInhosp patMedInhosp1, PatArchive patArchive, Integer type, String config) {
         String longTaskReason = patMedInhosp1.getLongTaskReason();
         if (StringUtils.isEmpty(longTaskReason)) longTaskReason = "";
         ServiceTask st = new ServiceTask();
         st.setTaskid(taskid);
         st.setSendState(2L);
         List<ServiceTask> serviceTasks = serviceTaskMapper.selectServiceTaskList(st);
-        if (CollectionUtils.isEmpty(serviceTasks)) {
-            log.error("璇ユ偅鑰呭嚭闄㈤殢璁块暱鏈熶换鍔′笉瀛樺湪,浠诲姟ID涓猴細{}", taskid);
-            patMedInhosp1.setDeptcheckFlag("2");
-            patMedInhosp1.setLongTaskReason(longTaskReason + " & 璇ユ偅鑰呭嚭闄㈤殢璁块暱鏈熶换鍔′笉瀛樺湪,浠诲姟ID涓�:" + taskid);
-            patMedInhospMapper.updatePatMedInhosp(patMedInhosp1);
+        ServiceTask serviceTask = null;
+        if(CollectionUtils.isEmpty(serviceTasks)){
+            if (type == 1) {
+                log.info("璇ユ偅鑰呭嚭闄㈤殢璁块暱鏈熶换鍔′笉瀛樺湪,浠诲姟ID涓猴細{}", taskid);
+                patMedInhosp1.setDeptcheckFlag("2");
+                patMedInhosp1.setLongTaskReason(longTaskReason + " & 璇ユ偅鑰呯闄㈢瀹ら暱鏈熶换鍔′笉瀛樺湪,浠诲姟ID涓�:" + taskid);
+                patMedInhospMapper.updatePatMedInhosp(patMedInhosp1);
+                return;
+            } else if (type == 2) {
+                patMedInhosp1.setWardcheckFlag("2");
+                patMedInhosp1.setLongTaskReason(longTaskReason + " & 璇ユ偅鑰呯闄㈢梾鍖洪暱鏈熶换鍔′笉瀛樺湪,浠诲姟ID涓�:" + taskid);
+                patMedInhospMapper.updatePatMedInhosp(patMedInhosp1);
+                return;
+            } else if (type == 3) {
+                patMedInhosp1.setDiagcheckFlag("2");
+                patMedInhosp1.setLongTaskReason(longTaskReason + " & 璇ユ偅鑰呯柧鐥呴暱鏈熶换鍔′笉瀛樺湪,浠诲姟ID涓�:" + taskid);
+                patMedInhospMapper.updatePatMedInhosp(patMedInhosp1);
+                return;
+            }
+        }else {
+            serviceTask = serviceTasks.get(0);
+        }
+        if (Objects.isNull(patMedInhosp1.getEndtime())) {
             return;
         }
-        ServiceTask serviceTask = serviceTasks.get(0);
         //灏佽serviceSubtask
-        ServiceSubtask serviceSubtask = boxedServiceSubtask(serviceTask, patMedInhosp1, patArchive);
+        ServiceSubtask serviceSubtask = boxedServiceSubtask(serviceTask, patMedInhosp1, patArchive, config);
+        if (type != 2) {
+            //绉戝鍜岀柧鐥� 閮界敤 绉戝濉厖
+            serviceSubtask.setVisitDeptCode(patMedInhosp1.getLeaveldeptcode());
+            serviceSubtask.setVisitDeptName(patMedInhosp1.getLeaveldeptname());
+        } else if (type == 2) {
+            serviceSubtask.setVisitDeptCode(patMedInhosp1.getLeavehospitaldistrictcode());
+            serviceSubtask.setVisitDeptName(patMedInhosp1.getLeavehospitaldistrictname());
+        }
         Integer i = 0;
-        //鍏堝垽鏂竴涓嬶紝鏄惁闇�瑕佹牎楠�
-        if (check) {
-            //鍦ㄦ柊澧炰箣鍓嶏紝鍏堥�氳繃鎮h�匢D锛宻endstate=2鏌ヨ涓�涓嬶紝鍦ㄦ墍鏈夐暱鏈熶换鍔′腑锛屾槸涓嶆槸杩樻湁璇ユ偅鑰呭緟鎵ц鐨勪换鍔★紝鏈夌殑璇�,姣旇緝涔嬪墠鐨別ndtime鏄惁灏忎簬褰撳墠鐨別ndtaime,濡傛灉涔嬪墠鐨勫皬浜庣幇鍦ㄧ殑锛屽垯鐩存帴灏嗕箣鍓嶇殑鍋滄帀锛堝師鍥犲啀鍏ラ櫌锛�
-            ServiceSubtaskVO subtask = new ServiceSubtaskVO();
-            subtask.setPatid(patArchive.getId());
-            subtask.setSendstate(2L);
-            subtask.setTaskid(taskid);
-            List<ServiceSubtask> selectServiceSubtaskList = serviceSubtaskMapper.selectServiceSubtaskList(subtask);
-            log.error("璇ユ偅鑰呭緟鎵ц鐨勪换鍔�:{}", selectServiceSubtaskList);
-            if (CollectionUtils.isNotEmpty(selectServiceSubtaskList) && selectServiceSubtaskList.size() > 0) {
-                for (ServiceSubtask serviceSubtask1 : selectServiceSubtaskList) {
-                    if (Objects.isNull(serviceSubtask1.getLongSendTime())) {
-                        //涓嶆槸闀挎湡浠诲姟锛屼笉澶勭悊
-                        continue;
-                    }
-                    //type = 1鎴�2 琛ㄧず 鈥濈瀹ゃ�佺梾鍖衡��
-                    if (type == 1 || type == 2) {
-                        if (serviceSubtask1.getEndtime().before(serviceSubtask.getEndtime()) && serviceSubtask1.getServiceType().equals("2")) {
-                            //濡傛灉褰撳墠寰幆鐨勫瓙浠诲姟鐨勫嚭闄㈡椂闂村湪鈥滃噯澶囨柊澧炵殑瀛愪换鍔♀�濈殑鍑洪櫌鏃堕棿涔嬪墠锛屽垯灏嗗惊鐜殑瀛愪换鍔″仠鎺�
-                            serviceSubtask1.setSendstate(4L);
-                            serviceSubtask1.setRemark("鎮h�呭啀鍏ラ櫌");
-                            serviceSubtask1.setResult("error");
-                            serviceSubtask1.setFinishtime(new Date());
-                            serviceSubtask1.setUpdateBy(serviceTask.getUpdateBy());
-                            serviceSubtask1.setUpdateTime(new Date());
-                            Boolean aBoolean = serviceSubtaskMapper.updateServiceSubtask(serviceSubtask1);
-                            if (aBoolean) i = 1;
-                        } else {
-                            //鐩稿弽,鍒欏皢褰撴湁鐨勬暟鎹仠鎺�
-                            serviceSubtask.setResult("error");
-                            serviceSubtask.setFinishtime(new Date());
-                            serviceSubtask.setSendstate(4L);
-                            serviceSubtask.setRemark("褰撳墠鎮h�呭嚭闄㈡椂闂村悗鏈夊緟鎵ц鐨勫嚭闄㈤殢璁块暱鏈熶换鍔�");
-                            serviceSubtask.setCreateBy(serviceTask.getCreateBy());
-                            serviceSubtask.setCreateTime(new Date());
-                            i = serviceSubtaskMapper.insertServiceSubtask(serviceSubtask);
+        try {
+            //鍏堝垽鏂竴涓嬶紝鏄惁闇�瑕佹牎楠�
+            if (check && (Objects.isNull(serviceSubtask.getTaskSituation()) || serviceSubtask.getTaskSituation() != 6)) {
+                //鍦ㄦ柊澧炰箣鍓嶏紝鍏堥�氳繃鎮h�匢D锛宻endstate=2鏌ヨ涓�涓嬶紝鍦ㄦ墍鏈夐暱鏈熶换鍔′腑锛屾槸涓嶆槸杩樻湁璇ユ偅鑰呭緟鎵ц鐨勪换鍔★紝鏈夌殑璇�,姣旇緝涔嬪墠鐨別ndtime鏄惁灏忎簬褰撳墠鐨別ndtaime,濡傛灉涔嬪墠鐨勫皬浜庣幇鍦ㄧ殑锛屽垯鐩存帴灏嗕箣鍓嶇殑鍋滄帀锛堝師鍥犲啀鍏ラ櫌锛�
+                ServiceSubtaskVO subtask = new ServiceSubtaskVO();
+                subtask.setPatid(patArchive.getId());
+                subtask.setSendstate(2L);
+                subtask.setTaskid(taskid);
+                List<ServiceSubtask> selectServiceSubtaskList = serviceSubtaskMapper.selectServiceSubtaskList(subtask);
+                log.info("璇ユ偅鑰呭緟鎵ц鐨勪换鍔�:{}", CollectionUtils.isNotEmpty(selectServiceSubtaskList) ? selectServiceSubtaskList.size() : null);
+                if (CollectionUtils.isNotEmpty(selectServiceSubtaskList) && selectServiceSubtaskList.size() > 0) {
+                    for (ServiceSubtask serviceSubtask1 : selectServiceSubtaskList) {
+                        if (Objects.isNull(serviceSubtask1.getLongSendTime())) {
+                            //涓嶆槸闀挎湡浠诲姟锛屼笉澶勭悊
+                            continue;
                         }
-                    } else if (type == 3) {
-                        //type=3 琛ㄧず鐤剧梾
-                        //灏嗕箣鍓嶇殑鍋滄帀
-                        serviceSubtask1.setSendstate(4L);
-                        serviceSubtask1.setRemark("鐤剧梾鎮h�呭啀鍏ラ櫌");
-                        serviceSubtask1.setResult("error");
-                        serviceSubtask1.setFinishtime(new Date());
-                        serviceSubtask1.setUpdateBy(serviceTask.getUpdateBy());
-                        serviceSubtaskMapper.updateServiceSubtask(serviceSubtask1);
-                        //閲嶆柊鏂板瀛愪换鍔�
-                        i = serviceSubtaskMapper.insertServiceSubtask(serviceSubtask);
+                        //type = 1鎴�2 琛ㄧず 鈥濈瀹ゃ�佺梾鍖衡��
+                        if (type == 1 || type == 2) {
+                            Date endTime = serviceSubtask.getEndtime();
+                            Date endTime1 = serviceSubtask1.getEndtime();
+                            //鍑洪櫌鏃堕棿鍒ょ┖锛屽鏋滀负绌鸿烦杩�
+                            if(Objects.isNull(endTime)){
+                                serviceSubtask.setResult("error");
+                                serviceSubtask.setRemark("鍑洪櫌鏃堕棿涓虹┖锛宻erviceSubtask鐨処d涓�" + serviceSubtask.getId());
+                                serviceSubtask.setUpdateBy(serviceTask.getUpdateBy());
+                                serviceSubtask.setUpdateTime(new Date());
+                                Boolean aBoolean = serviceSubtaskMapper.updateServiceSubtask(serviceSubtask1);
+                                if (aBoolean) i = 1;
+                                continue;
+                            }
+                            if(Objects.isNull(endTime1)){
+                                serviceSubtask1.setResult("error");
+                                serviceSubtask1.setRemark("鍑洪櫌鏃堕棿涓虹┖锛宻erviceSubtask鐨処d涓�" + serviceSubtask1.getId());
+                                serviceSubtask1.setUpdateBy(serviceTask.getUpdateBy());
+                                serviceSubtask1.setUpdateTime(new Date());
+                                Boolean aBoolean = serviceSubtaskMapper.updateServiceSubtask(serviceSubtask1);
+                                if (aBoolean) i = 1;
+                                continue;
+                            }
+                            if (endTime1.before(endTime) && serviceSubtask1.getServiceType().equals("2")) {
+                                //濡傛灉褰撳墠寰幆鐨勫瓙浠诲姟鐨勫嚭闄㈡椂闂村湪鈥滃噯澶囨柊澧炵殑瀛愪换鍔♀�濈殑鍑洪櫌鏃堕棿涔嬪墠锛屽垯灏嗗惊鐜殑瀛愪换鍔″仠鎺�
+                                serviceSubtask1.setSendstate(4L);
+                                if (StringUtils.isNotEmpty(serviceSubtask.getRemark()))
+                                    serviceSubtask.setRemark(serviceSubtask.getRemark() + ",鐤剧梾鎮h�呭啀鍏ラ櫌");
+                                else serviceSubtask.setRemark("鐤剧梾鎮h�呭啀鍏ラ櫌");
+                                serviceSubtask1.setResult("error");
+//                            serviceSubtask1.setFinishtime(new Date());
+                                serviceSubtask1.setUpdateBy(serviceTask.getUpdateBy());
+                                serviceSubtask1.setUpdateTime(new Date());
+                                Boolean aBoolean = serviceSubtaskMapper.updateServiceSubtask(serviceSubtask1);
+                                if (aBoolean) i = 1;
+                            } else {
+                                //鐩稿弽,鍒欏皢褰撴湁鐨勬暟鎹仠鎺�
+                                serviceSubtask.setResult("error");
+//                            serviceSubtask.setFinishtime(new Date());
+                                serviceSubtask.setSendstate(4L);
+                                if (StringUtils.isNotEmpty(serviceSubtask.getRemark()))
+                                    serviceSubtask.setRemark(serviceSubtask.getRemark() + ",褰撳墠鎮h�呭嚭闄㈡椂闂村悗鏈夊緟鎵ц鐨勫嚭闄㈤殢璁块暱鏈熶换鍔�");
+                                else serviceSubtask.setRemark("褰撳墠鎮h�呭嚭闄㈡椂闂村悗鏈夊緟鎵ц鐨勫嚭闄㈤殢璁块暱鏈熶换鍔�");
+                                serviceSubtask.setCreateBy(serviceTask.getCreateBy());
+                                serviceSubtask.setCreateTime(new Date());
+                                i = serviceSubtaskMapper.insertServiceSubtask(serviceSubtask);
+                            }
+                        } else if (type == 3) {
+                            //type=3 琛ㄧず鐤剧梾
+                            //灏嗕箣鍓嶇殑鍋滄帀
+                            serviceSubtask1.setSendstate(4L);
+                            if (StringUtils.isNotEmpty(serviceSubtask.getRemark()))
+                                serviceSubtask.setRemark(serviceSubtask.getRemark() + ",鐤剧梾鎮h�呭啀鍏ラ櫌");
+                            else serviceSubtask.setRemark("鐤剧梾鎮h�呭啀鍏ラ櫌");
+                            serviceSubtask1.setResult("error");
+//                        serviceSubtask1.setFinishtime(new Date());
+                            serviceSubtask1.setUpdateBy(serviceTask.getUpdateBy());
+                            serviceSubtaskMapper.updateServiceSubtask(serviceSubtask1);
+                            //閲嶆柊鏂板瀛愪换鍔�
+                            i = serviceSubtaskMapper.insertServiceSubtask(serviceSubtask);
+                            //杩欓噷闇�瑕佸叏澶辫触
+                            addServiceSubtaskPreachform(serviceSubtask, "5");
 
+                        }
                     }
+                } else {
+                    if (StringUtils.isEmpty(serviceSubtask.getPhone())) {
+                        if (StringUtils.isNotEmpty(serviceSubtask.getRemark()))
+                            serviceSubtask.setRemark(serviceSubtask.getRemark() + ",鎵嬫満鍙蜂负绌�");
+                        else serviceSubtask.setRemark("鎵嬫満鍙蜂负绌�");
+                        serviceSubtask.setSendstate(4L);
+                        serviceSubtask.setResult("error");
+                    }
+                    serviceSubtask.setCreateBy(serviceTask.getCreateBy());
+                    serviceSubtask.setCreateTime(new Date());
+                    i = serviceSubtaskMapper.insertServiceSubtask(serviceSubtask);
+                    addServiceSubtaskPreachform(serviceSubtask, null);
                 }
+            } else if (serviceSubtask.getTaskSituation() == 6) {
+                //璇存槑璇ユ偅鑰呮槸琚繃婊ょ殑锛屼笉鐢ㄥ啀鎵ц浜�
+                serviceSubtask.setCreateBy(serviceTask.getCreateBy());
+                serviceSubtask.setCreateTime(new Date());
+                i = serviceSubtaskMapper.insertServiceSubtask(serviceSubtask);
             } else {
                 if (StringUtils.isEmpty(serviceSubtask.getPhone())) {
-                    serviceSubtask.setRemark("鎵嬫満鍙蜂负绌�");
+                    if (StringUtils.isNotEmpty(serviceSubtask.getRemark()))
+                        serviceSubtask.setRemark(serviceSubtask.getRemark() + ",鎵嬫満鍙蜂负绌�");
+                    else serviceSubtask.setRemark("鎵嬫満鍙蜂负绌�");
                     serviceSubtask.setSendstate(4L);
                     serviceSubtask.setResult("error");
-                    serviceSubtask.setFinishtime(new Date());
                 }
                 serviceSubtask.setCreateBy(serviceTask.getCreateBy());
                 serviceSubtask.setCreateTime(new Date());
                 i = serviceSubtaskMapper.insertServiceSubtask(serviceSubtask);
+                addServiceSubtaskPreachform(serviceSubtask, null);
             }
-        } else {
-            if (StringUtils.isEmpty(serviceSubtask.getPhone())) {
-                serviceSubtask.setRemark("鎵嬫満鍙蜂负绌�");
-                serviceSubtask.setSendstate(4L);
-                serviceSubtask.setResult("error");
-                serviceSubtask.setFinishtime(new Date());
 
-            }
-            serviceSubtask.setCreateBy(serviceTask.getCreateBy());
-            serviceSubtask.setCreateTime(new Date());
-            i = serviceSubtaskMapper.insertServiceSubtask(serviceSubtask);
-        }
-        if (i == 1) {
             //灏哻heck_flag鏀规垚1锛堝凡澶勭悊锛�
-            PatMedInhosp patMedInhosp2 = new PatMedInhosp();
-            patMedInhosp2.setInhospid(patMedInhosp1.getInhospid());
-            if (type == 1) patMedInhosp2.setDeptcheckFlag("1");
-            if (type == 2) patMedInhosp2.setWardcheckFlag("1");
-            if (type == 3) patMedInhosp2.setDiagcheckFlag("1");
-
-            patMedInhospMapper.updatePatMedInhosp(patMedInhosp2);
-        } else {
-            //鐢熸垚瀛愪换鍔″け璐ワ紝
-            log.error("鐢熸垚瀛愪换鍔″け璐erviceSubtask涓猴細{}", serviceSubtask);
-            PatMedInhosp patMedInhosp2 = new PatMedInhosp();
-            patMedInhosp2.setInhospid(patMedInhosp1.getInhospid());
-            if (type == 1) patMedInhosp2.setDeptcheckFlag("2");
-            if (type == 2) patMedInhosp2.setWardcheckFlag("2");
-            if (type == 3) patMedInhosp2.setDiagcheckFlag("2");
-            patMedInhosp2.setRemark("鐢熸垚瀛愪换鍔″け璐� " + type);
-            patMedInhospMapper.updatePatMedInhosp(patMedInhosp2);
+            if(i == 1){
+                PatMedInhosp patMedInhosp2 = new PatMedInhosp();
+                patMedInhosp2.setInhospid(patMedInhosp1.getInhospid());
+                if (type == 1) patMedInhosp2.setDeptcheckFlag("1");
+                if (type == 2) patMedInhosp2.setWardcheckFlag("1");
+                if (type == 3) patMedInhosp2.setDiagcheckFlag("1");
+                patMedInhospMapper.updatePatMedInhosp(patMedInhosp2);
+            }else {
+                //鐢熸垚瀛愪换鍔″け璐ワ紝
+                log.info("鐢熸垚瀛愪换鍔″け璐erviceSubtask鐨則askid涓猴細{},patid涓猴細{}", serviceSubtask.getTaskid(), serviceSubtask.getPatid());
+                PatMedInhosp patMedInhosp2 = new PatMedInhosp();
+                patMedInhosp2.setInhospid(patMedInhosp1.getInhospid());
+                if (type == 1) patMedInhosp2.setDeptcheckFlag("2");
+                if (type == 2) patMedInhosp2.setWardcheckFlag("2");
+                if (type == 3) patMedInhosp2.setDiagcheckFlag("2");
+                patMedInhosp2.setRemark("鐢熸垚瀛愪换鍔″け璐� " + type);
+                patMedInhospMapper.updatePatMedInhosp(patMedInhosp2);
+            }
+        } catch (Exception e) {
+            //鍑洪敊鍥炴粴浜嬪姟
+            log.info("鐢熸垚瀛愪换鍔℃姤閿欏洖婊歴erviceSubtask鐨則askid涓猴細{},patid涓猴細{}", serviceSubtask.getTaskid(), serviceSubtask.getPatid());
+            e.printStackTrace();
         }
     }
 
+    private Integer addServiceSubtaskPreachform(ServiceSubtask serviceSubtask, String sendstate) {
+        //灏唒reachformDesc鐨刯son瀵硅薄锛屾斁鍒發ist闆嗗悎涓�
+        ServiceTask serviceTask = serviceTaskMapper.selectServiceTaskByTaskid(serviceSubtask.getTaskid());
+        String preachformDesc = serviceTask.getPreachformDesc();
+
+        ObjectMapper objectMapper = new ObjectMapper();
+        if (org.apache.commons.lang3.StringUtils.isNotEmpty(preachformDesc)) {
+            List<ServiceSubtaskPreachform> serviceSubtaskPreachformList = null;
+            try {
+                serviceSubtaskPreachformList = objectMapper.readValue(preachformDesc, new TypeReference<List<ServiceSubtaskPreachform>>() {
+                });
+            } catch (JsonProcessingException e) {
+                log.error("preachform杞琇ist<ServiceSubtaskPreachform>鎶ラ敊浜嗭細{}", e.getMessage());
+            }
+            for (ServiceSubtaskPreachform serviceSubtaskPreachform : serviceSubtaskPreachformList) {
+                serviceSubtaskPreachform.setTaskid(serviceSubtask.getTaskid());
+                serviceSubtaskPreachform.setSubid(serviceSubtask.getId());
+
+                //鍏堟煡璇竴涓嬶紝鏄惁瀛樺湪锛屽鏋滃凡缁忓瓨鍦紝灏变笉鏂板浜�
+                List<ServiceSubtaskPreachform> serviceSubtaskPreachformList1 = serviceSubtaskPreachformMapper.selectServiceSubtaskPreachformList(serviceSubtaskPreachform);
+                if (CollectionUtils.isNotEmpty(serviceSubtaskPreachformList1)) continue;
+
+                //杩欎釜sendstate闇�瑕佸湪鏁版嵁搴撹缃竴涓粯璁ゅ�间负鈥�1鈥�
+                serviceSubtaskPreachform.setSendstate("1");
+                if (StringUtils.isNotEmpty(sendstate)) serviceSubtaskPreachform.setSendstate(sendstate);
+
+                serviceSubtaskPreachform.setOrgid(serviceSubtask.getOrgid());
+                serviceSubtaskPreachformMapper.insertServiceSubtaskPreachform(serviceSubtaskPreachform);
+            }
+
+        }
+
+        return 0;
+    }
+
+
     //灏佽serviceSubtask
-    private ServiceSubtask boxedServiceSubtask(ServiceTask serviceTask, PatMedInhosp patMedInhosp1, PatArchive patArchive) {
+    private ServiceSubtask boxedServiceSubtask(ServiceTask serviceTask, PatMedInhosp patMedInhosp1, PatArchive patArchive, String config) {
+        //澧炲姞serviceTask鍒ょ┖
+//        if(Objects.isNull(serviceTask)){
+//            return null;
+//        }
         ServiceSubtask serviceSubtask = DtoConversionUtils.sourceToTarget(serviceTask, ServiceSubtask.class);
         serviceSubtask.setTaskid(serviceTask.getTaskid());
         if (StringUtils.isNotEmpty(serviceTask.getLibtemplateid()))
@@ -642,6 +773,8 @@
         serviceSubtask.setDrname(patMedInhosp1.getDrname());
         serviceSubtask.setDeptcode(patMedInhosp1.getLeaveldeptcode());
         serviceSubtask.setDeptname(patMedInhosp1.getLeaveldeptname());
+        serviceSubtask.setLeaveicd10code(patMedInhosp1.getLeaveicd10code());
+        serviceSubtask.setLeavediagname(patMedInhosp1.getDiagname());
         serviceSubtask.setTemplateid(serviceTask.getTemplateid());
         serviceSubtask.setTemplatename(serviceTask.getTemplatename());
         serviceSubtask.setPatid(patArchive.getId());
@@ -652,6 +785,8 @@
         serviceSubtask.setSex(patArchive.getSex());
         serviceSubtask.setAge(patArchive.getAge());
         serviceSubtask.setSendstate(2L);
+        serviceSubtask.setManagementDoctor(patMedInhosp1.getManagementDoctor());
+        serviceSubtask.setManagementDoctorCode(patMedInhosp1.getManagementDoctorCode());
         serviceSubtask.setStarttime(patMedInhosp1.getStarttime());
         serviceSubtask.setEndtime(patMedInhosp1.getEndtime());
         serviceSubtask.setServiceType(serviceTask.getServiceType());
@@ -666,18 +801,57 @@
         serviceSubtask.setUpdateTime(new Date());
         //璁剧疆鍙戦�佹椂闂�
         if (serviceTask.getSendDay() == null) serviceTask.setSendDay(1L);
-        Date newDate = addDays(patMedInhosp1.getEndtime(), serviceTask.getSendDay().intValue());
+        Date newDate = null;
+        if (!Objects.isNull(patMedInhosp1.getEndtime())) {
+            newDate = addDays(patMedInhosp1.getEndtime(), serviceTask.getSendDay().intValue());
+        } else {
+            //濡傛灉鍑洪櫌鏃堕棿涓虹┖锛屽垯杩斿洖涓�涓柊瀵硅薄
+            return new ServiceSubtask();
+        }
         serviceSubtask.setLongSendTime(newDate);
+        serviceSubtask.setVisitTime(newDate);
+
+        if (patMedInhosp1.getFudate() != null) serviceSubtask.setVisitTime(patMedInhosp1.getFudate());
+        //濡傛灉鏄�氱煡鐨勮瘽锛岄渶瑕佹彁鍓嶅嚑澶╁皢閫氳繃鐭俊鍙戝嚭鍘伙紙鍏蜂綋鍑犲ぉ锛岃繖涓彲浠ラ厤缃湪sys_conf琛ㄤ腑锛�
+        if ("3".equals(serviceTask.getType())) {
+            serviceSubtask.setVisitTime(minusDay(newDate, StringUtils.isNotEmpty(config) ? Integer.parseInt(config) : 0));
+            //鍒ゆ柇鏄笉鏄櫙瀹�
+            if (patMedInhosp1.getOrgid().equals("47255004333112711A1001"))
+                serviceSubtask.setVisitTime(null);
+
+            //濡傛灉璇ュ嚭闄㈣褰曟湁闅忚鏃堕棿锛屽垯鐢ㄤ粬鑷繁鐨勯殢璁挎椂闂�
+            if (patMedInhosp1.getFudate() != null)
+                serviceSubtask.setVisitTime(minusDay(patMedInhosp1.getFudate(), StringUtils.isNotEmpty(config) ? Integer.parseInt(config) : 0));
+        }
+
         //鎮h�呭彂閫佹椂闂�
         if (StringUtils.isNotEmpty(patArchive.getNotrequiredFlag()) && patArchive.getNotrequiredFlag().equals("1")) {
             String remark = patArchive.getNotrequiredreason();
             serviceSubtask.setRemark(remark);
             serviceSubtask.setResult("error");
-            serviceSubtask.setFinishtime(new Date());
+            serviceSubtask.setTaskSituation(6);
             //涓嶆墽琛�
             serviceSubtask.setSendstate(4L);
         }
         return serviceSubtask;
+    }
+
+    /**
+     * 鍑忓幓鐩稿簲澶╂暟
+     *
+     * @param originalDate
+     * @param day
+     * @return
+     */
+    public Date minusDay(Date originalDate, Integer day) {
+        // 1. 灏� Date 杞崲涓� Instant
+        Instant instant = originalDate.toInstant();
+
+        // 2. 鍦� Instant 涓婂噺鍘�2澶�
+        Instant twoDaysAgoInstant = instant.minus(2, ChronoUnit.DAYS);
+
+        // 3. 灏嗚绠楀悗鐨� Instant 杞洖 Date
+        return Date.from(twoDaysAgoInstant);
     }
 
     //澶勭悊鍏ラ櫌淇℃伅
@@ -689,7 +863,7 @@
                 subtask.setPatid(patMedInhosp1.getPatid());
                 subtask.setSendstate(2L);
                 List<ServiceSubtask> selectServiceSubtaskList = serviceSubtaskMapper.selectServiceSubtaskList(subtask);
-                log.error("鍏ラ櫌鐨勬偅鑰呭緟鎵ц鐨勪换鍔�:{}", selectServiceSubtaskList);
+//                log.error("鍏ラ櫌鐨勬偅鑰呭緟鎵ц鐨勪换鍔�:{}", selectServiceSubtaskList);
                 if (CollectionUtils.isNotEmpty(selectServiceSubtaskList) && selectServiceSubtaskList.size() > 0) {
                     for (ServiceSubtask serviceSubtask1 : selectServiceSubtaskList) {
                         if (Objects.isNull(serviceSubtask1.getLongSendTime())) {
@@ -698,17 +872,18 @@
                         }
                         if (serviceSubtask1.getEndtime().before(patMedInhosp1.getStarttime())) {
                             //濡傛灉褰撳墠寰幆鐨勫瓙浠诲姟鐨勫嚭闄㈡椂闂村湪鈥滃噯澶囨柊澧炵殑瀛愪换鍔♀�濈殑鍑洪櫌鏃堕棿涔嬪墠锛屽垯灏嗗惊鐜殑瀛愪换鍔″仠鎺�
-                            log.error("鎮h�呭啀鍏ラ櫌鐨剆erviceSubtask1涓�:{}", serviceSubtask1);
+//                            log.error("鎮h�呭啀鍏ラ櫌鐨剆erviceSubtask1涓�:{}", serviceSubtask1);
                             serviceSubtask1.setSendstate(4L);
                             serviceSubtask1.setRemark("鎮h�呭啀鍏ラ櫌");
                             serviceSubtask1.setResult("error");
-                            serviceSubtask1.setFinishtime(new Date());
+//                            serviceSubtask1.setFinishtime(new Date());
                             serviceSubtaskMapper.updateServiceSubtask(serviceSubtask1);
                         }
                     }
                 }
                 //灏嗘偅鍏ョ殑鍏ラ櫌鏁版嵁璁剧疆涓哄凡澶勭悊
-                patMedInhospMapper.updatePatMedInhosp(patMedInhosp1);
+                //鏇存柊鐘舵�佸�� patMedInhosp1.setDeptcheckFlag("0");
+                //patMedInhospMapper.updatePatMedInhosp(patMedInhosp1);
             } catch (Exception e) {
                 log.error("鍏ラ櫌鏁版嵁淇℃伅鍑哄紓甯镐簡锛歿},{}", patMedInhosp1, e.getMessage());
             }

--
Gitblit v1.9.3