From 1b998cdf41ac4f1e4fec4d9bf076d7da700619c4 Mon Sep 17 00:00:00 2001
From: 陈昶聿 <chychen@nbjetron.com>
Date: 星期四, 07 五月 2026 17:41:18 +0800
Subject: [PATCH] 【市一】短信标题调整

---
 smartor/src/main/java/com/smartor/service/impl/PatMedInhospServiceImpl.java |  372 +++++++++++++++++++++++++++++++++++++++--------------
 1 files changed, 273 insertions(+), 99 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 c0797bb..5db97f8 100644
--- a/smartor/src/main/java/com/smartor/service/impl/PatMedInhospServiceImpl.java
+++ b/smartor/src/main/java/com/smartor/service/impl/PatMedInhospServiceImpl.java
@@ -3,9 +3,11 @@
 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.core.service.IConfigService;
 import com.ruoyi.common.utils.DateUtils;
 import com.ruoyi.common.utils.DtoConversionUtils;
+import com.ruoyi.common.utils.SecurityUtils;
 import com.ruoyi.common.utils.StringUtils;
 import com.smartor.domain.*;
 import com.smartor.domain.entity.ServiceSubtaskEntity;
@@ -18,6 +20,7 @@
 import org.springframework.stereotype.Service;
 import org.springframework.util.ObjectUtils;
 
+import java.io.IOException;
 import java.time.Instant;
 import java.time.temporal.ChronoUnit;
 import java.util.*;
@@ -39,6 +42,8 @@
     @Autowired
     private ServiceTaskdiagMapper serviceTaskdiagMapper;
     @Autowired
+    private ServiceTaskoperMapper serviceTaskoperMapper;
+    @Autowired
     private PatArchiveMapper patArchiveMapper;
     @Autowired
     private PatArchiveImportMapper patArchiveImportMapper;
@@ -48,6 +53,11 @@
     private ServiceSubtaskMapper serviceSubtaskMapper;
     @Autowired
     private ServiceSubtaskPreachformMapper serviceSubtaskPreachformMapper;
+    @Autowired
+    private PatMedOperationMapper patMedOperationMapper;
+    @Autowired
+    private PatMedOperationItemMapper patMedOperationItemMapper;
+
     @Value("${spring.profiles.active}")
     private String active;
     @Autowired
@@ -491,59 +501,47 @@
                 }
             }
 //            鎵嬫湳闅忚
-//            PatMedInhosp pmss = new PatMedInhosp();
-//            //鑾峰彇闇�瑕佸嚭闄㈢柧鐥呴殢璁匡紝鏈鐞嗙殑鏁版嵁
-//            pmss.setOpercheckFlag("0");
-//            pmss.setInhospstate("1");
-//            pmss.setFuflag("1");
-//            List<PatMedInhosp> patMedInhospSSs = patMedInhospMapper.selectPatMedInhospList(pmss);
-//            log.info("dealOutHospInfo闇�瑕佸鐞嗙殑鍑洪櫌鐤剧梾鎮h�呬俊鎭細{}", CollectionUtils.isNotEmpty(patMedInhospSSs) ? patMedInhospSSs.size() : null);
-//            for (PatMedInhosp patMedInhosp1 : patMedInhospSSs) {
-//                String tagname = patMedInhospMapper.getTagnameBypatid(patMedInhosp1.getPatid());
-//                patMedInhosp1.setTagname(tagname);
-//            }
-//
-//            for (PatMedInhosp pmiSS : patMedInhospSSs) {
-//                //鑾峰彇鎮h�呬俊鎭�
-//                PatArchive patArchive = patArchiveMapper.selectPatArchiveByPatid(pmiSS.getPatid());
-//                if (Objects.isNull(patArchive)) {
-//                    pmiSS.setDiagcheckFlag("2");
-//                    pmiSS.setLongTaskReason("鎮h�呭熀鏈俊鎭负绌�");
-//                    patMedInhospMapper.updatePatMedInhosp(pmiSS);
-//                    continue;
-//                }
-//                try {
-////                    if (StringUtils.isEmpty(pmiSS.getLeaveicd10code())) {
-////                        continue;
-////                    }
-//                    // 鏍规嵁鎮h�呯殑鐤剧梾锛岃幏鍙栬鐤剧梾鐨勯暱鏈熶换鍔�
-//                    ServiceTaskoper serviceTaskoper = new ServiceTaskoper();
-//                    serviceTaskoper.setLongtask(1L);
-//                    serviceTaskoper.setOrgid(pmiSS.getOrgid());
-//                    //todo
-//                    serviceTaskoper.setOplevelcode("");
-//
-//                    List<ServiceTaskoper> serviceTaskopers = serviceTaskoperMapper.selectServiceTaskoperList(serviceTaskoper);
-//                    //濡傛灉閮ㄩ棬妯℃澘涓虹┖锛堝皢deptIsNull璁剧疆涓簍rue锛�
-//                    if (CollectionUtils.isEmpty(serviceTaskopers) || serviceTaskopers.size() == 0) {
-//                        PatMedInhosp patMedInhosp = patMedInhospMapper.selectPatMedInhospByInhospid(pmiSS.getInhospid());
-//                        pmiSS.setOpercheckFlag("2");
-//                        pmiSS.setLongTaskReason(patMedInhosp.getLongTaskReason() + "鎵�鎮g殑鎵嬫湳鏈厤缃暱鏈熶换鍔�;");
-//                        patMedInhospMapper.updatePatMedInhosp(pmiSS);
-//                    } else {
-//                        for (ServiceTaskoper serviceTaskoper1 : serviceTaskopers) {
-//                            writeInSubTask(serviceTaskoper1.getTaskId(), true, pmiSS, patArchive, 3, config);
-//                        }
-//                    }
-//
-//                } catch (Exception e) {
-//                    e.printStackTrace();
-//                    log.error("浜哄憳鎵嬫湳澶勭悊鍑哄紓甯镐簡锛歿}", e.getMessage());
-//                    pmiSS.setOpercheckFlag("2");
-//                    pmiSS.setLongTaskReason("浜哄憳鎵嬫湳澶勭悊寮傚父锛�" + e.getMessage());
-//                    patMedInhospMapper.updatePatMedInhosp(pmiSS);
-//                }
-//            }
+            PatMedOperationItem pmoi = new PatMedOperationItem();
+            //鑾峰彇闇�瑕佸嚭闄㈢柧鐥呴殢璁匡紝鏈鐞嗙殑鏁版嵁
+            pmoi.setOpercheckFlag("0");
+            pmoi.setMainFlag("1");
+
+            List<PatMedOperationItem> patMedOperationItems = patMedOperationItemMapper.selectPatMedOperationItemList(pmoi);
+            log.info("dealOutHospInfo闇�瑕佸鐞嗙殑鍑洪櫌鎵嬫湳鎮h�呬俊鎭細{}", CollectionUtils.isNotEmpty(patMedOperationItems) ? patMedOperationItems.size() : null);
+
+            for (PatMedOperationItem opItem : patMedOperationItems) {
+
+                try {
+                    if (StringUtils.isEmpty(opItem.getOplevelcode())) {
+                        continue;
+                    }
+                    // 鏍规嵁鎮h�呯殑鐤剧梾锛岃幏鍙栬鐤剧梾鐨勯暱鏈熶换鍔�
+                    ServiceTaskoper serviceTaskoper = new ServiceTaskoper();
+                    serviceTaskoper.setLongtask(1L);
+                    serviceTaskoper.setOrgid(opItem.getOrgid());
+                    serviceTaskoper.setOplevelcode(opItem.getOplevelcode());
+
+                    List<ServiceTaskoper> serviceTaskopers = serviceTaskoperMapper.selectServiceTaskoperList(serviceTaskoper);
+                    //濡傛灉閮ㄩ棬妯℃澘涓虹┖锛堝皢deptIsNull璁剧疆涓簍rue锛�
+                    if (CollectionUtils.isEmpty(serviceTaskopers) || serviceTaskopers.size() == 0) {
+                        PatMedOperationItem patMedOperationItem = patMedOperationItemMapper.selectPatMedOperationItemById(opItem.getId());
+                        patMedOperationItem.setOpercheckFlag("2");
+                        patMedOperationItem.setLongTaskReason(patMedOperationItem.getLongTaskReason() + "鎵�鎮g殑鎵嬫湳鏈厤缃暱鏈熶换鍔�;");
+                        patMedOperationItemMapper.updatePatMedOperationItem(patMedOperationItem);
+                    } else {
+                        for (ServiceTaskoper serviceTaskoper1 : serviceTaskopers) {
+                            writeInSubTaskForOp(serviceTaskoper1.getTaskId(), true, opItem, config);
+                        }
+                    }
+
+                } catch (Exception e) {
+                    e.printStackTrace();
+                    log.error("浜哄憳鎵嬫湳澶勭悊鍑哄紓甯镐簡锛歿}", e.getMessage());
+                    opItem.setOpercheckFlag("2");
+                    opItem.setLongTaskReason("浜哄憳鎵嬫湳澶勭悊寮傚父锛�" + e.getMessage());
+                    patMedOperationItemMapper.updatePatMedOperationItem(opItem);
+                }
+            }
         }
 
         //鑾峰彇鏈鐞嗗湪闄㈢殑鏁版嵁(濡傛灉鍒氬垰鍑洪櫌鐨勬偅鑰呮暟鎹殑鍑洪櫌鏃堕棿,鍦ㄤ笅闈㈡煡璇㈠嚭鐨勫叆闄㈡椂闂翠箣鍓�,閭d箣鍓嶇殑鍑洪櫌鎮h�呯殑鏁版嵁,涔熷緱鍋滄帀,鍥犱负鍙堝叆闄簡)
@@ -858,7 +856,7 @@
      * @param check         鏄惁闇�瑕佹牎楠�
      * @param patMedInhosp1 鐥呬汉鍑哄叆闄俊鎭�
      * @param patArchive    鐥呬汉淇℃伅
-     * @param type          闅忚绫诲瀷(1-绉戝锛�2-鐥呭尯锛�3-鐤剧梾 4-鍏ラ櫌绉戝 5-鍏ラ櫌鐥呭尯)
+     * @param type          闅忚绫诲瀷(1-绉戝锛�2-鐥呭尯锛�3-鐤剧梾锛�
      * @param config        閰嶇疆淇℃伅 visit.early.day
      */
     //灏嗘偅鑰呮斁鍒皊ubtask涓�
@@ -888,16 +886,6 @@
                 patMedInhosp1.setLongTaskReason(longTaskReason + " & 璇ユ偅鑰呯柧鐥呴暱鏈熶换鍔′笉瀛樺湪,浠诲姟ID涓�:" + taskid);
                 patMedInhospMapper.updatePatMedInhosp(patMedInhosp1);
                 return;
-            } else if (type == 4) {
-                patMedInhosp1.setInDeptcheckFlag("2");
-                patMedInhosp1.setLongTaskReason(longTaskReason + " & 璇ユ偅鑰呭叆闄㈢瀹ら暱鏈熶换鍔′笉瀛樺湪,浠诲姟ID涓�:" + taskid);
-                patMedInhospMapper.updatePatMedInhosp(patMedInhosp1);
-                return;
-            } else if (type == 5) {
-                patMedInhosp1.setInWardcheckFlag("2");
-                patMedInhosp1.setLongTaskReason(longTaskReason + " & 璇ユ偅鑰呭叆闄㈢梾鍖洪暱鏈熶换鍔′笉瀛樺湪,浠诲姟ID涓�:" + taskid);
-                patMedInhospMapper.updatePatMedInhosp(patMedInhosp1);
-                return;
             }
         } else {
             serviceTask = serviceTasks.get(0);
@@ -906,19 +894,14 @@
             return;
         }
         //灏佽serviceSubtask
-        ServiceSubtask serviceSubtask = boxedServiceSubtask(serviceTask, patMedInhosp1, patArchive, config, type);
+        ServiceSubtask serviceSubtask = boxedServiceSubtask(serviceTask, patMedInhosp1, patArchive, config);
         if (ObjectUtils.isEmpty(serviceSubtask)) {
             return;
         }
         if (type != 2) {
             //绉戝鍜岀柧鐥� 閮界敤 绉戝濉厖
-            if (patMedInhosp1.getInhospstate().equals("1")) {
-                serviceSubtask.setVisitDeptCode(patMedInhosp1.getLeaveldeptcode());
-                serviceSubtask.setVisitDeptName(patMedInhosp1.getLeaveldeptname());
-            } else if (patMedInhosp1.getInhospstate().equals("0")) {
-                serviceSubtask.setVisitDeptCode(patMedInhosp1.getDeptcode());
-                serviceSubtask.setVisitDeptName(patMedInhosp1.getDeptname());
-            }
+            serviceSubtask.setVisitDeptCode(patMedInhosp1.getLeaveldeptcode());
+            serviceSubtask.setVisitDeptName(patMedInhosp1.getLeaveldeptname());
         } else if (type == 2) {
             serviceSubtask.setVisitDeptCode(patMedInhosp1.getLeavehospitaldistrictcode());
             serviceSubtask.setVisitDeptName(patMedInhosp1.getLeavehospitaldistrictname());
@@ -1052,8 +1035,6 @@
                 if (type == 1) patMedInhosp2.setDeptcheckFlag("1");
                 if (type == 2) patMedInhosp2.setWardcheckFlag("1");
                 if (type == 3) patMedInhosp2.setDiagcheckFlag("1");
-                if (type == 4) patMedInhosp2.setInDeptcheckFlag("1");
-                if (type == 5) patMedInhosp2.setInWardcheckFlag("1");
                 patMedInhospMapper.updatePatMedInhosp(patMedInhosp2);
             } else {
                 //鐢熸垚瀛愪换鍔″け璐ワ紝
@@ -1063,8 +1044,6 @@
                 if (type == 1) patMedInhosp2.setDeptcheckFlag("2");
                 if (type == 2) patMedInhosp2.setWardcheckFlag("2");
                 if (type == 3) patMedInhosp2.setDiagcheckFlag("2");
-                if (type == 4) patMedInhosp2.setInDeptcheckFlag("2");
-                if (type == 5) patMedInhosp2.setInWardcheckFlag("2");
                 patMedInhosp2.setRemark("鐢熸垚瀛愪换鍔″け璐� " + type);
                 patMedInhospMapper.updatePatMedInhosp(patMedInhosp2);
             }
@@ -1078,6 +1057,143 @@
             if (type == 3) patMedInhosp2.setDiagcheckFlag("2");
             patMedInhosp2.setRemark("鐢熸垚瀛愪换鍔℃姤閿欏洖婊� " + type);
             patMedInhospMapper.updatePatMedInhosp(patMedInhosp2);
+            e.printStackTrace();
+        }
+    }
+
+
+    /**
+     *
+     * @param taskid 浠诲姟id
+     * @param check 鏄惁闇�瑕佹牎楠�
+     * @param patMedOperationItem 鎵嬫湳璁板綍
+     * @param config 閰嶇疆淇℃伅 visit.early.day
+     */
+    //灏嗘偅鑰呮斁鍒皊ubtask涓� 鎵嬫湳涓撶敤
+    private void writeInSubTaskForOp(Long taskid, Boolean check, PatMedOperationItem patMedOperationItem, String config) {
+        String longTaskReason = patMedOperationItem.getLongTaskReason();
+        String orgId = patMedOperationItem.getOrgid();
+        if (StringUtils.isEmpty(longTaskReason)) longTaskReason = "";
+        ServiceTask st = new ServiceTask();
+        st.setTaskid(taskid);
+        st.setSendState(2L);
+        List<ServiceTask> serviceTasks = serviceTaskMapper.selectServiceTaskList(st);
+        ServiceTask serviceTask = null;
+        if (CollectionUtils.isEmpty(serviceTasks)) {
+            log.info("璇ユ墜鏈搴旀墜鏈瓑绾х殑闀挎湡浠诲姟涓嶅瓨鍦�,浠诲姟ID涓猴細{}", taskid);
+            patMedOperationItem.setOpercheckFlag("2");
+            patMedOperationItem.setLongTaskReason(longTaskReason + " & 璇ユ墜鏈搴旀墜鏈瓑绾х殑闀挎湡浠诲姟涓嶅瓨鍦�,浠诲姟ID涓�:" + taskid);
+            patMedOperationItemMapper.insertPatMedOperationItem(patMedOperationItem);
+            return;
+        } else {
+            serviceTask = serviceTasks.get(0);
+        }
+        if (Objects.isNull(patMedOperationItem.getOpid())) {
+            return;
+        }
+        if (Objects.isNull(patMedOperationItem.getOplevelcode())) {
+            return;
+        }
+        PatMedOperation patMedOperation = patMedOperationMapper.selectPatMedOperationById(patMedOperationItem.getOpid());
+        if (Objects.isNull(patMedOperation)) {
+            return;
+        }
+        PatArchive patArchive = patArchiveMapper.selectPatArchiveByPatid(patMedOperation.getPatid());
+        if (Objects.isNull(patArchive)) {
+            return;
+        }
+        PatMedInhosp patMedInhosp = new PatMedInhosp();
+        patMedInhosp.setPatid(patMedOperation.getPatid());
+        patMedInhosp.setInhospstate("1");
+        patMedInhosp.setFuflag("1");
+        List<PatMedInhosp> patMedInhospList = patMedInhospMapper.selectPatMedInhospList(patMedInhosp);
+
+        if (CollectionUtils.isEmpty(patMedInhospList)) {
+            return;
+        }
+
+        //灏佽serviceSubtask
+        ServiceSubtask serviceSubtask = boxedServiceSubtaskForOp(serviceTask, patMedInhospList.get(0), patMedOperation, patMedOperationItem, patArchive, config);
+        if (ObjectUtils.isEmpty(serviceSubtask)) {
+            return;
+        }
+        serviceSubtask.setVisitDeptCode(patMedOperation.getReqdeptcode());
+        serviceSubtask.setVisitDeptName(patMedOperation.getReqdeptname());
+        //璁板綍insertServiceSubtask璇彞杩斿洖鐘舵��
+        Integer i = 0;
+        try {
+            //鍏堝垽鏂竴涓嬶紝鏄惁闇�瑕佹牎楠�
+            if (check && (Objects.isNull(serviceSubtask.getTaskSituation()) || serviceSubtask.getTaskSituation() != 6)) {
+                //鍦ㄦ柊澧炰箣鍓嶏紝鍏堥�氳繃鎮h�匢D锛宻endstate=2鏌ヨ涓�涓嬶紝鍦ㄦ墍鏈夐暱鏈熶换鍔′腑锛屾槸涓嶆槸杩樻湁璇ユ偅鑰呭緟鎵ц鐨勪换鍔★紝鏈夌殑璇�,姣旇緝涔嬪墠鐨別ndtime鏄惁灏忎簬褰撳墠鐨別ndtaime,濡傛灉涔嬪墠鐨勫皬浜庣幇鍦ㄧ殑锛屽垯鐩存帴灏嗕箣鍓嶇殑鍋滄帀锛堝師鍥犲啀鍏ラ櫌锛�
+                ServiceSubtaskEntity subtask = new ServiceSubtaskEntity();
+                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 (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())) {
+                    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);
+            }
+
+            //灏哻heck_flag鏀规垚1锛堝凡澶勭悊锛�
+            if (i == 1) {
+                PatMedOperationItem patMedOperationItem2 = new PatMedOperationItem();
+                patMedOperationItem2.setId(patMedOperationItem.getId());
+                patMedOperationItem2.setOpercheckFlag("1");
+                patMedOperationItemMapper.updatePatMedOperationItem(patMedOperationItem2);
+            } else {
+                //鐢熸垚瀛愪换鍔″け璐ワ紝
+                log.info("鐢熸垚瀛愪换鍔″け璐erviceSubtask鐨則askid涓猴細{},patid涓猴細{}", serviceSubtask.getTaskid(), serviceSubtask.getPatid());
+                PatMedOperationItem patMedOperationItem2 = new PatMedOperationItem();
+                patMedOperationItem2.setId(patMedOperationItem.getId());
+                patMedOperationItem2.setOpercheckFlag("2");
+                patMedOperationItem2.setRemark("鐢熸垚瀛愪换鍔″け璐� 4");
+                patMedOperationItemMapper.updatePatMedOperationItem(patMedOperationItem2);
+            }
+        } catch (Exception e) {
+            //鍑洪敊鍥炴粴浜嬪姟
+
+            log.info("鐢熸垚瀛愪换鍔℃姤閿欏洖婊歴serviceSubtask鐨則askid涓猴細{},patid涓猴細{}", serviceSubtask.getTaskid(), serviceSubtask.getPatid());
+            PatMedOperationItem patMedOperationItem2 = new PatMedOperationItem();
+            patMedOperationItem2.setId(patMedOperationItem.getId());
+            patMedOperationItem2.setOpercheckFlag("2");
+            patMedOperationItem2.setRemark("鐢熸垚瀛愪换鍔℃姤閿欏洖婊� 4");
+            patMedOperationItemMapper.updatePatMedOperationItem(patMedOperationItem2);
             e.printStackTrace();
         }
     }
@@ -1119,7 +1235,7 @@
 
 
     //灏佽serviceSubtask
-    private ServiceSubtask boxedServiceSubtask(ServiceTask serviceTask, PatMedInhosp patMedInhosp1, PatArchive patArchive, String config, Integer type) {
+    private ServiceSubtask boxedServiceSubtask(ServiceTask serviceTask, PatMedInhosp patMedInhosp1, PatArchive patArchive, String config) {
         //澧炲姞serviceTask鍒ょ┖
 //        if(Objects.isNull(serviceTask)){
 //            return null;
@@ -1135,15 +1251,6 @@
         serviceSubtask.setDrname(patMedInhosp1.getDrname());
         serviceSubtask.setDeptcode(patMedInhosp1.getLeaveldeptcode());
         serviceSubtask.setDeptname(patMedInhosp1.getLeaveldeptname());
-        serviceSubtask.setLeavehospitaldistrictcode(patMedInhosp1.getLeavehospitaldistrictcode());
-        serviceSubtask.setLeavehospitaldistrictname(patMedInhosp1.getLeavehospitaldistrictname());
-        if(type == 4||type == 5){
-            //璁剧疆鍏ラ櫌鐨�
-            serviceSubtask.setDeptcode(patMedInhosp1.getDeptcode());
-            serviceSubtask.setDeptname(patMedInhosp1.getDeptname());
-            serviceSubtask.setLeavehospitaldistrictcode(patMedInhosp1.getHospitaldistrictcode());
-            serviceSubtask.setLeavehospitaldistrictname(patMedInhosp1.getHospitaldistrictname());
-        }
         serviceSubtask.setLeaveicd10code(patMedInhosp1.getLeaveicd10code());
         serviceSubtask.setLeavediagname(patMedInhosp1.getDiagname());
         serviceSubtask.setTemplateid(serviceTask.getTemplateid());
@@ -1163,30 +1270,24 @@
         serviceSubtask.setServiceType(serviceTask.getServiceType());
         serviceSubtask.setPreachform(serviceTask.getPreachform());
         serviceSubtask.setHospType("2");
-        if (type == 4 || type == 5) serviceSubtask.setHospType("6");
         serviceSubtask.setCreateTime(new Date());
         serviceSubtask.setUpdateTime(new Date());
         serviceSubtask.setCreateBy(patMedInhosp1.getNurseName());
+        serviceSubtask.setLeavehospitaldistrictcode(patMedInhosp1.getLeavehospitaldistrictcode());
+        serviceSubtask.setLeavehospitaldistrictname(patMedInhosp1.getLeavehospitaldistrictname());
         serviceSubtask.setUpdateBy(serviceTask.getUpdateBy());
         serviceSubtask.setUpdateTime(new Date());
-        //濡傛灉鏄鏁欏氨璁剧疆涓�7
-        if (serviceTask.getServiceType().equals("17")) serviceSubtask.setTaskSituation(7);
         //璁剧疆鍙戦�佹椂闂�
         if (serviceTask.getSendDay() == null) serviceTask.setSendDay(1L);
         Date newDate = null;
         if (!Objects.isNull(patMedInhosp1.getEndtime())) {
             newDate = addDays(patMedInhosp1.getEndtime(), serviceTask.getSendDay().intValue());
         } else {
-            //濡傛灉绛変簬4,璇存槑鏄叆闄㈠鏁欙紝鍏ラ櫌涓嶅彲鑳芥湁endTime
-            if (type != 4 && type != 5) {
-                patMedInhosp1.setDeptcheckFlag("2");
-                patMedInhosp1.setRemark(patMedInhosp1.getRemark() + "& 璇ユ偅鑰呯柧鐥呭嚭闄㈡椂闂翠负绌�,鍑洪櫌璁板綍ID涓�:" + patMedInhosp1.getInhospid());
-                patMedInhospMapper.updatePatMedInhosp(patMedInhosp1);
-                //濡傛灉鍑洪櫌鏃堕棿涓虹┖锛屽垯杩斿洖涓�涓柊瀵硅薄
-                return new ServiceSubtask();
-            }
-            //鍏ラ櫌瀹f暀锛屽熀鏈綋澶╂垨闅斿ぉ灏辫鍙戝嚭
-            newDate = addDays(new Date(), serviceTask.getSendDay().intValue());
+            patMedInhosp1.setDeptcheckFlag("2");
+            patMedInhosp1.setRemark(patMedInhosp1.getRemark() + "& 璇ユ偅鑰呯柧鐥呭嚭闄㈡椂闂翠负绌�,鍑洪櫌璁板綍ID涓�:" + patMedInhosp1.getInhospid());
+            patMedInhospMapper.updatePatMedInhosp(patMedInhosp1);
+            //濡傛灉鍑洪櫌鏃堕棿涓虹┖锛屽垯杩斿洖涓�涓柊瀵硅薄
+            return new ServiceSubtask();
         }
         serviceSubtask.setLongSendTime(newDate);
         serviceSubtask.setVisitTime(newDate);
@@ -1222,6 +1323,79 @@
         return serviceSubtask;
     }
 
+    //灏佽serviceSubtask
+    private ServiceSubtask boxedServiceSubtaskForOp(ServiceTask serviceTask, PatMedInhosp patMedInhosp1, PatMedOperation patMedOperation, PatMedOperationItem patMedOperationItem, PatArchive patArchive, String config) {
+        ServiceSubtask serviceSubtask = DtoConversionUtils.sourceToTarget(serviceTask, ServiceSubtask.class);
+        serviceSubtask.setTaskid(serviceTask.getTaskid());
+        if (StringUtils.isNotEmpty(serviceTask.getLibtemplateid()))
+            serviceSubtask.setLibtemplateid(Long.valueOf(serviceTask.getLibtemplateid()));
+        serviceSubtask.setNurseId(patMedOperation.getNurseId());
+        serviceSubtask.setNurseName(patMedOperation.getNurseName());
+//        serviceSubtask.setInhospid(patMedInhosp.getInhospid());
+        serviceSubtask.setDrcode(patMedOperation.getDrcode());
+        serviceSubtask.setDrname(patMedOperation.getDrname());
+        serviceSubtask.setDeptcode(patMedOperation.getDeptcode());
+        serviceSubtask.setDeptname(patMedOperation.getDeptname());
+
+        serviceSubtask.setTemplateid(serviceTask.getTemplateid());
+        serviceSubtask.setTemplatename(serviceTask.getTemplatename());
+        serviceSubtask.setPatid(patArchive.getId());
+        serviceSubtask.setSendname(patArchive.getName());
+        serviceSubtask.setSfzh(patArchive.getIdcardno());
+        serviceSubtask.setPhone(patArchive.getTelcode());
+        if (StringUtils.isBlank(patArchive.getTelcode())) serviceSubtask.setPhone(patArchive.getRelativetelcode());
+        serviceSubtask.setSex(patArchive.getSex());
+        serviceSubtask.setAge(patArchive.getAge());
+        serviceSubtask.setSendstate(2L);
+        serviceSubtask.setManagementDoctor(patMedOperation.getDrname());
+        serviceSubtask.setManagementDoctorCode(patMedOperation.getDrcode());
+//        serviceSubtask.setStarttime(patMedInhosp.getStarttime());
+//        serviceSubtask.setEndtime(patMedInhosp.getEndtime());
+
+        serviceSubtask.setServiceType(serviceTask.getServiceType());
+        serviceSubtask.setPreachform(serviceTask.getPreachform());
+        serviceSubtask.setHospType("2");
+        serviceSubtask.setCreateTime(new Date());
+        serviceSubtask.setUpdateTime(new Date());
+        serviceSubtask.setCreateBy(patMedOperation.getNurseName());
+//        serviceSubtask.setLeavehospitaldistrictcode(patArchive.getLeavehospitaldistrictcode());
+//        serviceSubtask.setLeavehospitaldistrictname(patArchive.getLeavehospitaldistrictname());
+        serviceSubtask.setOperationItemId(patMedOperationItem.getId());
+        serviceSubtask.setUpdateBy(serviceTask.getUpdateBy());
+        serviceSubtask.setUpdateTime(new Date());
+
+        //todo
+        //璁剧疆鍙戦�佹椂闂�
+        if (serviceTask.getSendDay() == null) serviceTask.setSendDay(1L);
+        Date newDate = null;
+        if (!Objects.isNull(patMedInhosp1.getEndtime())) {
+            newDate = addDays(patMedInhosp1.getEndtime(), serviceTask.getSendDay().intValue());
+        } else {
+            patMedInhosp1.setDeptcheckFlag("2");
+            patMedInhosp1.setRemark(patMedInhosp1.getRemark() + "& 璇ユ偅鑰呮墜鏈嚭闄㈡椂闂翠负绌�,鍑洪櫌璁板綍ID涓�:" + patMedInhosp1.getInhospid());
+            patMedInhospMapper.updatePatMedInhosp(patMedInhosp1);
+            //濡傛灉鍑洪櫌鏃堕棿涓虹┖锛屽垯杩斿洖涓�涓柊瀵硅薄
+            return new ServiceSubtask();
+        }
+        serviceSubtask.setLongSendTime(newDate);
+        serviceSubtask.setVisitTime(newDate);
+
+        //濡傛灉鏄�氱煡鐨勮瘽锛岄渶瑕佹彁鍓嶅嚑澶╁皢閫氳繃鐭俊鍙戝嚭鍘伙紙鍏蜂綋鍑犲ぉ锛岃繖涓彲浠ラ厤缃湪sys_conf琛ㄤ腑锛�
+        if ("3".equals(serviceTask.getType())) {
+            serviceSubtask.setVisitTime(minusDay(newDate, 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.setTaskSituation(6);
+            //涓嶆墽琛�
+            serviceSubtask.setSendstate(4L);
+        }
+        return serviceSubtask;
+    }
+
     /**
      * 鍑忓幓鐩稿簲澶╂暟
      *

--
Gitblit v1.9.3