From 376ea5b60128cf28b2e529ca908623da0ef006b3 Mon Sep 17 00:00:00 2001
From: 陈昶聿 <chychen@nbjetron.com>
Date: 星期一, 15 十二月 2025 15:09:28 +0800
Subject: [PATCH] 【丽水】增加出院时间判空

---
 smartor/src/main/java/com/smartor/service/impl/PatMedInhospServiceImpl.java |   61 +++++++++++++++++++++---------
 1 files changed, 43 insertions(+), 18 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 0e49694..cff1ca9 100644
--- a/smartor/src/main/java/com/smartor/service/impl/PatMedInhospServiceImpl.java
+++ b/smartor/src/main/java/com/smartor/service/impl/PatMedInhospServiceImpl.java
@@ -536,6 +536,7 @@
         return calendar.getTime();
     }
 
+    //todo
     //灏嗘偅鑰呮斁鍒皊ubtask涓�
     private void writeInSubTask(Long taskid, Boolean check, PatMedInhosp patMedInhosp1, PatArchive patArchive, Integer type, String config) {
         String longTaskReason = patMedInhosp1.getLongTaskReason();
@@ -544,24 +545,27 @@
         st.setTaskid(taskid);
         st.setSendState(2L);
         List<ServiceTask> serviceTasks = serviceTaskMapper.selectServiceTaskList(st);
-        if (CollectionUtils.isEmpty(serviceTasks) && type == 1) {
-            log.info("璇ユ偅鑰呭嚭闄㈤殢璁块暱鏈熶换鍔′笉瀛樺湪,浠诲姟ID涓猴細{}", taskid);
-            patMedInhosp1.setDeptcheckFlag("2");
-            patMedInhosp1.setLongTaskReason(longTaskReason + " & 璇ユ偅鑰呯闄㈢瀹ら暱鏈熶换鍔′笉瀛樺湪,浠诲姟ID涓�:" + taskid);
-            patMedInhospMapper.updatePatMedInhosp(patMedInhosp1);
-            return;
-        } else if (CollectionUtils.isEmpty(serviceTasks) && type == 2) {
-            patMedInhosp1.setWardcheckFlag("2");
-            patMedInhosp1.setLongTaskReason(longTaskReason + " & 璇ユ偅鑰呯闄㈢梾鍖洪暱鏈熶换鍔′笉瀛樺湪,浠诲姟ID涓�:" + taskid);
-            patMedInhospMapper.updatePatMedInhosp(patMedInhosp1);
-            return;
-        } else if (CollectionUtils.isEmpty(serviceTasks) && type == 3) {
-            patMedInhosp1.setDiagcheckFlag("2");
-            patMedInhosp1.setLongTaskReason(longTaskReason + " & 璇ユ偅鑰呯柧鐥呴暱鏈熶换鍔′笉瀛樺湪,浠诲姟ID涓�:" + taskid);
-            patMedInhospMapper.updatePatMedInhosp(patMedInhosp1);
-            return;
+        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;
+            }
+            serviceTask = serviceTasks.get(0);
         }
-        ServiceTask serviceTask = serviceTasks.get(0);
 
         if (Objects.isNull(patMedInhosp1.getEndtime())) {
             return;
@@ -596,7 +600,28 @@
                     }
                     //type = 1鎴�2 琛ㄧず 鈥濈瀹ゃ�佺梾鍖衡��
                     if (type == 1 || type == 2) {
-                        if (serviceSubtask1.getEndtime().before(serviceSubtask.getEndtime()) && serviceSubtask1.getServiceType().equals("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()))

--
Gitblit v1.9.3