From a5b842f1f6ab32f1af39f4bcb7e45217e94db761 Mon Sep 17 00:00:00 2001
From: wlzboy <66905212@qq.com>
Date: 星期六, 25 十月 2025 18:14:44 +0800
Subject: [PATCH] fix:完成任务状态,任务同步,高度同步等工作

---
 ruoyi-system/src/main/java/com/ruoyi/system/service/impl/SysTaskServiceImpl.java |   90 ++++++++++++++++++++++++++++++++++++++++++++
 1 files changed, 89 insertions(+), 1 deletions(-)

diff --git a/ruoyi-system/src/main/java/com/ruoyi/system/service/impl/SysTaskServiceImpl.java b/ruoyi-system/src/main/java/com/ruoyi/system/service/impl/SysTaskServiceImpl.java
index baaece3..499b06f 100644
--- a/ruoyi-system/src/main/java/com/ruoyi/system/service/impl/SysTaskServiceImpl.java
+++ b/ruoyi-system/src/main/java/com/ruoyi/system/service/impl/SysTaskServiceImpl.java
@@ -4,6 +4,7 @@
 import java.util.Date;
 import java.util.List;
 import java.util.ArrayList;
+import java.util.stream.Collectors;
 import java.io.File;
 import java.io.IOException;
 
@@ -24,6 +25,7 @@
 import com.ruoyi.system.domain.SysTaskLog;
 import com.ruoyi.system.domain.SysTaskEmergency;
 import com.ruoyi.system.domain.SysTaskWelfare;
+import com.ruoyi.system.domain.SysTaskAssignee;
 import com.ruoyi.system.domain.vo.TaskQueryVO;
 import com.ruoyi.system.domain.vo.TaskCreateVO;
 import com.ruoyi.system.domain.vo.TaskUpdateVO;
@@ -35,9 +37,12 @@
 import com.ruoyi.system.mapper.SysTaskLogMapper;
 import com.ruoyi.system.mapper.SysTaskEmergencyMapper;
 import com.ruoyi.system.mapper.SysTaskWelfareMapper;
+import com.ruoyi.system.mapper.SysTaskAssigneeMapper;
 import com.ruoyi.system.mapper.VehicleInfoMapper;
 import com.ruoyi.system.domain.VehicleInfo;
 import com.ruoyi.system.service.ISysTaskService;
+import com.ruoyi.system.service.ILegacySystemSyncService;
+import org.springframework.beans.factory.annotation.Autowired;
 
 /**
  * 浠诲姟绠$悊Service涓氬姟灞傚鐞�
@@ -67,7 +72,13 @@
     private SysTaskWelfareMapper sysTaskWelfareMapper;
     
     @Autowired
+    private SysTaskAssigneeMapper sysTaskAssigneeMapper;
+    
+    @Autowired
     private VehicleInfoMapper vehicleInfoMapper;
+
+    @Autowired(required = false)
+    private ILegacySystemSyncService legacySystemSyncService;
 
     /**
      * 鏌ヨ浠诲姟绠$悊
@@ -122,7 +133,8 @@
         task.setPlannedEndTime(createVO.getPlannedEndTime());
         task.setAssigneeId(createVO.getAssigneeId());
         task.setCreatorId(SecurityUtils.getUserId());
-        task.setDeptId(SecurityUtils.getDeptId());
+        // 浼樺厛浣跨敤鍓嶇浼犲叆鐨勯儴闂↖D锛屽鏋滄病鏈夊垯浣跨敤褰撳墠鐢ㄦ埛鐨勯儴闂↖D
+        task.setDeptId(createVO.getDeptId() != null ? createVO.getDeptId() : SecurityUtils.getDeptId());
         task.setCreateBy(SecurityUtils.getUsername());
         task.setCreateTime(DateUtils.getNowDate());
         task.setUpdateBy(SecurityUtils.getUsername());
@@ -196,6 +208,11 @@
             }
         }
         
+        // 淇濆瓨鎵ц浜哄憳淇℃伅锛堝寘鍚鑹茬被鍨嬶級
+        if (result > 0 && createVO.getAssignees() != null && !createVO.getAssignees().isEmpty()) {
+            saveTaskAssignees(task.getTaskId(), createVO.getAssignees());
+        }
+        
         // 淇濆瓨鎬ユ晳杞繍鎵╁睍淇℃伅
         if (result > 0 && "EMERGENCY_TRANSFER".equals(createVO.getTaskType())) {
             saveEmergencyInfo(task.getTaskId(), createVO);
@@ -210,6 +227,19 @@
         if (result > 0) {
             recordTaskLog(task.getTaskId(), "CREATE", "鍒涘缓浠诲姟", null, 
                          "浠诲姟绫诲瀷锛�" + createVO.getTaskType(), SecurityUtils.getUserId(), SecurityUtils.getUsername());
+        }
+        
+        // 寮傛鍚屾鎬ユ晳杞繍浠诲姟鍒版棫绯荤粺
+        if (result > 0 && "EMERGENCY_TRANSFER".equals(createVO.getTaskType()) && legacySystemSyncService != null) {
+            final Long finalTaskId = task.getTaskId();
+            new Thread(() -> {
+                try {
+                    Thread.sleep(2000); // 绛夊緟2绉掞紝纭繚浜嬪姟宸叉彁浜�
+                    legacySystemSyncService.syncEmergencyTaskToLegacy(finalTaskId);
+                } catch (Exception e) {
+                    // 鍚屾澶辫触涓嶅奖鍝嶄富娴佺▼锛屼粎璁板綍鏃ュ織
+                }
+            }).start();
         }
         
         return result;
@@ -790,6 +820,46 @@
     }
 
     /**
+     * 淇濆瓨浠诲姟鎵ц浜哄憳淇℃伅锛堝寘鍚鑹茬被鍨嬶級
+     * 
+     * @param taskId 浠诲姟ID
+     * @param assignees 鎵ц浜哄憳淇℃伅鍒楄〃
+     */
+    private void saveTaskAssignees(Long taskId, java.util.List<TaskCreateVO.AssigneeInfo> assignees) {
+        if (assignees == null || assignees.isEmpty()) {
+            return;
+        }
+        
+        java.util.List<SysTaskAssignee> taskAssignees = new java.util.ArrayList<>();
+        Date now = DateUtils.getNowDate();
+        String currentUser = SecurityUtils.getUsername();
+        
+        for (int i = 0; i < assignees.size(); i++) {
+            TaskCreateVO.AssigneeInfo assigneeInfo = assignees.get(i);
+            
+            SysTaskAssignee taskAssignee = new SysTaskAssignee();
+            taskAssignee.setTaskId(taskId);
+            taskAssignee.setUserId(assigneeInfo.getUserId());
+            taskAssignee.setUserName(assigneeInfo.getUserName());
+            taskAssignee.setUserType(assigneeInfo.getUserType());
+            // 绗竴涓墽琛屼汉鍛樹负涓昏鎵ц浜�
+            taskAssignee.setIsPrimary(i == 0 ? "1" : "0");
+            taskAssignee.setSortOrder(i);
+            taskAssignee.setCreateTime(now);
+            taskAssignee.setCreateBy(currentUser);
+            taskAssignee.setUpdateTime(now);
+            taskAssignee.setUpdateBy(currentUser);
+            
+            taskAssignees.add(taskAssignee);
+        }
+        
+        // 鎵归噺淇濆瓨
+        if (!taskAssignees.isEmpty()) {
+            sysTaskAssigneeMapper.batchInsertSysTaskAssignee(taskAssignees);
+        }
+    }
+    
+    /**
      * 淇濆瓨鎬ユ晳杞繍浠诲姟鎵╁睍淇℃伅
      * 
      * @param taskId 浠诲姟ID
@@ -811,8 +881,10 @@
         
         // 璁剧疆杞嚭鍖婚櫌淇℃伅
         if (createVO.getHospitalOut() != null) {
+            emergencyInfo.setHospitalOutId(createVO.getHospitalOut().getId());
             emergencyInfo.setHospitalOutName(createVO.getHospitalOut().getName());
             emergencyInfo.setHospitalOutDepartment(createVO.getHospitalOut().getDepartment());
+            emergencyInfo.setHospitalOutDepartmentId(createVO.getHospitalOut().getDepartmentId());
             emergencyInfo.setHospitalOutBedNumber(createVO.getHospitalOut().getBedNumber());
             emergencyInfo.setHospitalOutAddress(createVO.getHospitalOut().getAddress());
             emergencyInfo.setHospitalOutLongitude(createVO.getHospitalOut().getLongitude());
@@ -821,8 +893,10 @@
         
         // 璁剧疆杞叆鍖婚櫌淇℃伅
         if (createVO.getHospitalIn() != null) {
+            emergencyInfo.setHospitalInId(createVO.getHospitalIn().getId());
             emergencyInfo.setHospitalInName(createVO.getHospitalIn().getName());
             emergencyInfo.setHospitalInDepartment(createVO.getHospitalIn().getDepartment());
+            emergencyInfo.setHospitalInDepartmentId(createVO.getHospitalIn().getDepartmentId());
             emergencyInfo.setHospitalInBedNumber(createVO.getHospitalIn().getBedNumber());
             emergencyInfo.setHospitalInAddress(createVO.getHospitalIn().getAddress());
             emergencyInfo.setHospitalInLongitude(createVO.getHospitalIn().getLongitude());
@@ -833,6 +907,20 @@
         emergencyInfo.setTransferDistance(createVO.getTransferDistance());
         emergencyInfo.setTransferPrice(createVO.getPrice());
         
+        // 璁剧疆鍗曟嵁绫诲瀷ID
+        emergencyInfo.setDocumentTypeId(createVO.getDocumentTypeId());
+        
+        // 璁剧疆浠诲姟绫诲瀷ID
+        emergencyInfo.setTaskTypeId(createVO.getTaskTypeId());
+        
+        // 璁剧疆鐥呮儏ID鍒楄〃锛堝皢List<Long>杞崲涓洪�楀彿鍒嗛殧鐨勫瓧绗︿覆锛�
+        if (createVO.getDiseaseIds() != null && !createVO.getDiseaseIds().isEmpty()) {
+            String diseaseIdsStr = createVO.getDiseaseIds().stream()
+                .map(String::valueOf)
+                .collect(Collectors.joining(","));
+            emergencyInfo.setDiseaseIds(diseaseIdsStr);
+        }
+        
         // 绯荤粺瀛楁
         emergencyInfo.setCreateTime(DateUtils.getNowDate());
         emergencyInfo.setUpdateTime(DateUtils.getNowDate());

--
Gitblit v1.9.1