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 |   51 ++++++++++++++++++++++++++++++---------------------
 1 files changed, 30 insertions(+), 21 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 8ea35df..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;
     }
@@ -613,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();
@@ -722,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("鏃х郴缁熷悓姝ヨ繃鏉�");
@@ -747,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