From 8cb5d3440208a3be3e772e65f1bd0ec63031ba62 Mon Sep 17 00:00:00 2001
From: wlzboy <66905212@qq.com>
Date: 星期三, 17 十二月 2025 08:37:14 +0800
Subject: [PATCH] feat: 增加服务单派发通知

---
 ruoyi-system/src/main/java/com/ruoyi/system/service/impl/SysTaskServiceImpl.java |   64 ++++++++++++++++++++-----------
 1 files changed, 41 insertions(+), 23 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 0644f40..3caf8c5 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
@@ -9,8 +9,9 @@
 
 import com.ruoyi.common.core.domain.AjaxResult;
 import com.ruoyi.common.core.domain.entity.SysUser;
+import com.ruoyi.common.utils.*;
 import com.ruoyi.system.domain.vo.*;
-import com.ruoyi.system.event.TaskDispatchSyncEvent;
+import com.ruoyi.system.event.*;
 import com.ruoyi.system.mapper.*;
 import com.ruoyi.system.service.*;
 import com.ruoyi.system.utils.TaskCodeGenerator;
@@ -19,10 +20,6 @@
 import org.springframework.stereotype.Service;
 import org.springframework.transaction.annotation.Transactional;
 import org.springframework.web.multipart.MultipartFile;
-import com.ruoyi.common.utils.DateUtils;
-import com.ruoyi.common.utils.SecurityUtils;
-import com.ruoyi.common.utils.StringUtils;
-import com.ruoyi.common.utils.GpsDistanceUtils;
 import com.ruoyi.common.utils.file.FileUploadUtils;
 import com.ruoyi.common.utils.file.FileUtils;
 import com.ruoyi.system.domain.SysTask;
@@ -34,9 +31,6 @@
 import com.ruoyi.system.domain.SysTaskAssignee;
 import com.ruoyi.system.domain.enums.TaskStatus;
 import com.ruoyi.system.domain.VehicleInfo;
-import com.ruoyi.system.event.TaskCreatedEvent;
-import com.ruoyi.system.event.TaskAssignedEvent;
-import com.ruoyi.system.event.TaskStatusChangedEvent;
 import org.slf4j.Logger;
 import org.slf4j.LoggerFactory;
 import org.springframework.beans.factory.annotation.Autowired;
@@ -317,7 +311,7 @@
      */
     @Override
     @Transactional
-    public int insertTask(TaskCreateVO createVO,String serviceOrderId,String dispatchOrderId, String serviceOrdNo, Long userId,String userName, Long deptId, Date createTime, Date updateTime) {
+    public int insertTask(TaskCreateVO createVO,Long serviceOrderId,Long dispatchOrderId, String serviceOrdNo, Long userId,String userName, Long deptId, Date createTime, Date updateTime) {
         SysTask task = new SysTask();
         if(createVO.getTaskCode()!=null){
             task.setTaskCode(createVO.getTaskCode());
@@ -411,8 +405,9 @@
         }
         
 
-        
-
+        if(result>0) {
+            this.sendEmeryTaskProcess(task, dispatchOrderId);
+        }
         
         return result;
     }
@@ -532,6 +527,11 @@
                 }
             }
         }
+        if(updateVO.getAssignees()!=null && !updateVO.getAssignees().isEmpty()){
+           TaskCreateVO.AssigneeInfo assigneeInfo= updateVO.getAssignees().get(0);
+            task.setAssigneeId(assigneeInfo.getUserId());
+            task.setAssigneeName(assigneeInfo.getUserName());
+        }
         // 鐢ㄤ簬璺熻釜鏄惁闇�瑕侀噸鏂板悓姝ワ紙杞﹁締銆佷汉鍛樸�佸湴鍧�銆佹垚浜や环鍙樻洿锛�
         boolean needResync = false;
         int result = sysTaskMapper.updateSysTask(task);
@@ -608,11 +608,11 @@
      * @return 缁撴灉
      */
     @Override
-    public int updateTask(TaskUpdateVO updateVO, String serviceOrderId, String dispatchOrderId, String serviceOrdNo,
+    public int updateTask(TaskUpdateVO updateVO, Long serviceOrderId, Long dispatchOrderId, String serviceOrdNo,
                          Long userId, String userName, Long deptId, Date createTime, Date updateTime) {
 //        log.info("寮�濮嬫洿鏂颁换鍔� ServiceOrdID: {} , dispatchOrdId:{}", serviceOrderId,dispatchOrderId);
         // 閫氳繃鏃х郴缁熸湇鍔″崟ID鏌ユ壘浠诲姟
-        SysTaskEmergency taskEmergency = sysTaskEmergencyMapper.selectByLegacyServiceOrdId(Long.parseLong(serviceOrderId));
+        SysTaskEmergency taskEmergency = sysTaskEmergencyMapper.selectByLegacyServiceOrdId(serviceOrderId);
         Long taskId = taskEmergency.getTaskId();
         updateVO.setTaskId(taskId);
         SysTask task = new SysTask();
@@ -629,7 +629,7 @@
         if(updateVO.getActualEndTime() != null) {
             task.setActualEndTime(updateVO.getActualEndTime());
         }
-        task.setAssigneeId(updateVO.getAssigneeId());
+//        task.setAssigneeId(updateVO.getAssigneeId());
         task.setUpdateBy(userName);
         task.setUpdateTime(DateUtils.getNowDate());
         task.setRemark(updateVO.getRemark());
@@ -642,7 +642,11 @@
         task.setDepartureLatitude(updateVO.getDepartureLatitude());
         task.setDestinationLongitude(updateVO.getDestinationLongitude());
         task.setDestinationLatitude(updateVO.getDestinationLatitude());
-        
+        if(updateVO.getAssignees()!=null && !updateVO.getAssignees().isEmpty()){
+            TaskCreateVO.AssigneeInfo assigneeInfo= updateVO.getAssignees().get(0);
+            task.setAssigneeId(assigneeInfo.getUserId());
+            task.setAssigneeName(assigneeInfo.getUserName());
+        }
         // 濡傛灉鏇存柊浜嗛儴闂↖D
         if (updateVO.getDeptId() != null) {
             task.setDeptId(updateVO.getDeptId());
@@ -713,14 +717,14 @@
 //            log.info("鏇存柊鎵ц浜哄憳 ServiceOrdID:{},dispatchOrderId:{}",serviceOrderId,dispatchOrderId);
             sysTaskAssigneeService.updateTaskAssignees(taskId, updateVO.getAssignees(), userName);
         }
-        Long dispatchOrderIdLong = 0L;
+
         // 鏇存柊鎬ユ晳杞繍鎵╁睍淇℃伅
         if (result > 0) {
             // 鏇存柊鏃х郴缁烮D
-            taskEmergency.setLegacyServiceOrdId(Long.parseLong(serviceOrderId));
-            if (dispatchOrderId != null) {
-                dispatchOrderIdLong = Long.parseLong(dispatchOrderId);
-                taskEmergency.setLegacyDispatchOrdId(dispatchOrderIdLong);
+            taskEmergency.setLegacyServiceOrdId(serviceOrderId);
+            if (LongUtil.isNotEmpty(dispatchOrderId)) {
+
+                taskEmergency.setLegacyDispatchOrdId(dispatchOrderId);
                 taskEmergency.setDispatchSyncStatus(2);
                 taskEmergency.setDispatchSyncTime(new Date());
                 taskEmergency.setDispatchSyncErrorMsg("鏃х郴缁熷悓姝ヨ繃鏉�");
@@ -738,16 +742,30 @@
                 sysEmergencyTaskService.updateEmergencyInfoFromCreateVO(taskEmergency, updateVO, userName);
             }
            SysTaskEmergency emergency= sysEmergencyTaskService.selectSysTaskEmergencyByTaskId(taskId);
-            dispatchOrderIdLong = emergency.getLegacyDispatchOrdId();
+            dispatchOrderId = emergency.getLegacyDispatchOrdId();
         }
 
-        if(updateVO.getTaskStatus()!=null && updateVO.getTaskStatus().equals(TaskStatus.PENDING.getCode()) && updateVO.getAssignees()!=null && !updateVO.getAssignees().isEmpty() && dispatchOrderIdLong>0L){
+        if(updateVO.getTaskStatus()!=null && updateVO.getTaskStatus().equals(TaskStatus.PENDING.getCode()) && updateVO.getAssignees()!=null && !updateVO.getAssignees().isEmpty() && dispatchOrderId>0L){
             this.sendTaskAssigneeEvent(updateVO,task,userId,userName);
         }
-        
+
         return result;
     }
 
+    private void sendEmeryTaskProcess(SysTask task,Long dispatchOrderId){
+        Long taskId = task.getTaskId();
+        String taskCode = task.getShowTaskCode();
+        if(task.getTaskStatus()!=null && task.getTaskStatus().equals(TaskStatus.PENDING.getCode())){
+            //濡傛灉娌℃湁鍒嗛厤浜哄憳锛屼笖娌℃湁璋冨害鍗曪紝涓嶆槸骞垮窞鎬诲叕鍙哥殑灏遍渶瑕佸彂閫侀�氱煡璺熻繘
+            if(LongUtil.isEmpty(dispatchOrderId)){
+                if(!task.getDeptId().equals(DeptUtil.GUANGZHOU_DEPT_ID) && task.getAssignees().isEmpty()){
+                    //鍙戦�侀�氱煡
+                    eventPublisher.publishEvent(new TaskOnlyServerOrderSyncEvent(this, taskId, taskCode));
+
+                }
+            }
+        }
+    }
     /**
      * 鎵归噺鍒犻櫎浠诲姟绠$悊
      * 

--
Gitblit v1.9.1