From c10b1e130ccbc94e6481a43e8e2d35cfc8fcf83b Mon Sep 17 00:00:00 2001
From: wlzboy <66905212@qq.com>
Date: 星期五, 26 十二月 2025 18:05:06 +0800
Subject: [PATCH] feat:显示问题

---
 ruoyi-system/src/main/java/com/ruoyi/system/service/impl/SysTaskServiceImpl.java |  175 +++++++++++++++++++++++++++++++++++++++++-----------------
 1 files changed, 124 insertions(+), 51 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 0159840..51f3800 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
@@ -101,6 +101,10 @@
     @Autowired
     private ISysTaskVehicleService sysTaskVehicleService;
 
+    @Autowired
+    private ISysTaskAssigneeService assigneeService;
+
+
     @Override
     public Boolean dispatchSyncEvent(Long taskId) {
         SysTask task= sysTaskMapper.selectSysTaskByTaskId(taskId);
@@ -124,7 +128,7 @@
     public SysTask selectSysTaskByTaskId(Long taskId) {
         SysTask task = sysTaskMapper.selectSysTaskByTaskId(taskId);
         if (task != null) {
-
+            bindTaskAssign(task);
             // 鍔犺浇鎬ユ晳杞繍鎵╁睍淇℃伅
             if ("EMERGENCY_TRANSFER".equals(task.getTaskType())) {
                 SysTaskEmergency emergencyInfo = sysTaskEmergencyMapper.selectSysTaskEmergencyByTaskId(taskId);
@@ -139,6 +143,13 @@
         return task;
     }
 
+
+    private void bindTaskAssign(SysTask task){
+       List<SysTaskAssignee> assignees= assigneeService.getAssigneesByTaskId(task.getTaskId());
+       if(assignees!=null && !assignees.isEmpty()) {
+           task.setAssignees(assignees);
+       }
+    }
     /**
      * 鏌ヨ浠诲姟绠$悊鍒楄〃
      * 
@@ -149,7 +160,7 @@
     public List<SysTask> selectSysTaskList(TaskQueryVO queryVO) {
         List<SysTask> tasks= sysTaskMapper.selectSysTaskList(queryVO);
         tasks.forEach(task -> {
-
+            bindTaskAssign( task);
             if ("EMERGENCY_TRANSFER".equals(task.getTaskType())) {
                 SysTaskEmergency emergencyInfo = sysTaskEmergencyMapper.selectSysTaskEmergencyByTaskId(task.getTaskId());
                 task.setEmergencyInfo(emergencyInfo);
@@ -220,6 +231,7 @@
             if (task.getTaskCode() != null && task.getTaskCode().contains(taskCode)) {
                 return true;
             }
+            bindTaskAssign(task);
 
             if ("EMERGENCY_TRANSFER".equals(task.getTaskType()) && task.getEmergencyInfo() != null) {
                 String dispatchCode = task.getEmergencyInfo().getDispatchCode();
@@ -240,23 +252,29 @@
      * @return 缁撴灉
      */
     @Override
-    @Transactional
     public int insertSysTask(TaskCreateVO createVO) {
+    // 鑾峰彇褰撳墠鐢ㄦ埛鍚嶅拰鐢ㄦ埛ID
         String username = SecurityUtils.getUsername();
         Long userId = SecurityUtils.getUserId();
+    // 鏍¢獙鐢ㄦ埛ID鏄惁涓虹┖鎴栦负0
         if(userId==null || userId==0){
             log.error("insertSysTask 鐢ㄦ埛ID涓虹┖ userName:{}",username);
             return 0;
         }
         SysTask task = new SysTask();
+    // 鍒涘缓鏂扮殑浠诲姟瀵硅薄
         task.setTaskCode(generateTaskCode());
-        task.setTaskType(createVO.getTaskType());
-        task.setTaskStatus(TaskStatus.PENDING.getCode());
-        task.setTaskDescription(createVO.getTaskDescription());
-        task.setPlannedStartTime(createVO.getPlannedStartTime());
-        task.setPlannedEndTime(createVO.getPlannedEndTime());
-        task.setAssigneeId(createVO.getAssigneeId());
+
+    // 璁剧疆浠诲姟鍩烘湰淇℃伅
+        task.setTaskType(createVO.getTaskType()); // 鐢熸垚浠诲姟缂栫爜
+        task.setTaskStatus(TaskStatus.PENDING.getCode()); // 璁剧疆浠诲姟绫诲瀷
+        task.setTaskDescription(createVO.getTaskDescription()); // 璁剧疆浠诲姟鐘舵�佷负寰呭鐞�
+        task.setPlannedStartTime(createVO.getPlannedStartTime()); // 璁剧疆浠诲姟鎻忚堪
+        task.setPlannedEndTime(createVO.getPlannedEndTime()); // 璁剧疆璁″垝寮�濮嬫椂闂�
+        task.setAssigneeId(createVO.getAssigneeId()); // 璁剧疆璁″垝缁撴潫鏃堕棿
+ // 璁剧疆鎸囨淳浜篒D
         task.setCreatorId(userId);
+    // 璁剧疆鍒涘缓浜轰俊鎭�
         // 浼樺厛浣跨敤鍓嶇浼犲叆鐨勯儴闂↖D锛屽鏋滄病鏈夊垯浣跨敤褰撳墠鐢ㄦ埛鐨勯儴闂↖D
         task.setDeptId(createVO.getDeptId() != null ? createVO.getDeptId() : SecurityUtils.getDeptId());
         task.setCreateBy(username);
@@ -266,7 +284,6 @@
         task.setRemark(createVO.getRemark());
         task.setDelFlag("0");
 
-        task.setIsHeadPush(isTaskHeaderPush(userId,task.getDeptId())?"1":"0");
         
         // 璁剧疆鍦板潃鍜屽潗鏍囦俊鎭�
         setAddressAndCoordinatesFromVO(task, createVO);
@@ -344,7 +361,6 @@
      * @return 缁撴灉
      */
     @Override
-    @Transactional
     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){
@@ -370,15 +386,6 @@
         task.setUpdateBy(userName);
         task.setRemark(createVO.getRemark());
         task.setDelFlag("0");
-
-        Boolean isHeadPush=this.isTaskHeaderPush(userId, deptId);
-        if(isHeadPush){
-            task.setIsHeadPush("1");
-        }else{
-            task.setIsHeadPush("0");
-        }
-
-
         
         // 璁剧疆鍦板潃鍜屽潗鏍囦俊鎭�
         setAddressAndCoordinatesFromVO(task, createVO);
@@ -386,8 +393,8 @@
         if (createVO.getTransferTime() != null) {
             task.setPlannedStartTime(createVO.getTransferTime());
         }
-        if (createVO.getDistance() != null) {
-            task.setEstimatedDistance(createVO.getDistance());
+        if (createVO.getTransferDistance() != null) {
+            task.setEstimatedDistance(createVO.getTransferDistance());
         }
         if (createVO.getPlannedStartTime() != null) {
             task.setPlannedStartTime(createVO.getPlannedStartTime());
@@ -398,9 +405,7 @@
         if (createVO.getEndAddress() != null) {
             task.setDestinationAddress(createVO.getEndAddress());
         }
-        if (createVO.getDistance() != null) {
-            task.setEstimatedDistance(createVO.getDistance());
-        }
+
         // 鑷姩濉厖缂哄け鐨凣PS鍧愭爣
         autoFillMissingGpsCoordinates(task);
         
@@ -455,10 +460,10 @@
 
     private void sendTaskAssigneeEvent(TaskCreateVO createVO,SysTask task,Long userId,String userName){
         List<Long> assigneeIds = createVO.getAssignees().stream()
-                .map(assignee -> assignee.getUserId())
+                .map(TaskCreateVO.AssigneeInfo::getUserId)
                 .collect(Collectors.toList());
         List<String> assigneeNames = createVO.getAssignees().stream()
-                .map(assignee -> assignee.getUserName())
+                .map(TaskCreateVO.AssigneeInfo::getUserName)
                 .collect(Collectors.toList());
 
         eventPublisher.publishEvent(new TaskAssignedEvent(
@@ -479,7 +484,6 @@
      * @return 缁撴灉
      */
     @Override
-    @Transactional
     public int updateSysTask(TaskUpdateVO updateVO, Boolean updateFromLegacy) {
         SysTask task = sysTaskMapper.selectSysTaskByTaskId(updateVO.getTaskId());
         if (task == null) {
@@ -502,11 +506,8 @@
 
         
         // 璁剧疆棰勮璺濈
-        if (updateVO.getEstimatedDistance() != null) {
-            task.setEstimatedDistance(updateVO.getEstimatedDistance());
-        } else if (updateVO.getDistance() != null) {
-            // 鍏煎鎬ユ晳杞繍瀛楁
-            task.setEstimatedDistance(updateVO.getDistance());
+        if (updateVO.getTransferDistance() != null) {
+            task.setEstimatedDistance(updateVO.getTransferDistance());
         }
         
         // 濡傛灉鏇存柊浜嗛儴闂↖D
@@ -519,7 +520,7 @@
         }
         Boolean hasSetDepartureFlag=false;
         //璁剧疆鎬婚儴鎺ㄩ��
-        task.setIsHeadPush(this.isTaskHeaderPush(task.getCreatorId(), task.getDeptId())?"1":"0");
+
         // 鑷姩鑾峰彇鍑哄彂鍦癎PS鍧愭爣锛堝鏋滄洿鏂颁簡鍦板潃浣嗙己澶卞潗鏍囷級
         if (updateVO.getDepartureAddress() != null && 
             (updateVO.getDepartureLongitude() == null || updateVO.getDepartureLatitude() == null) && 
@@ -722,13 +723,6 @@
             task.setTaskCode(updateVO.getTaskCode());
         }
 
-
-
-
-//        task.setDepartureLongitude(updateVO.getDepartureLongitude());
-//        task.setDepartureLatitude(updateVO.getDepartureLatitude());
-//        task.setDestinationLongitude(updateVO.getDestinationLongitude());
-//        task.setDestinationLatitude(updateVO.getDestinationLatitude());
         Boolean modifyOutLongLat = false;
         // 鑷姩鑾峰彇鍑哄彂鍦癎PS鍧愭爣锛堝鏋滃湴鍧�鍙樻洿涓旂己澶卞潗鏍囷級
         if (task != null && updateVO.getDepartureAddress() != null
@@ -818,8 +812,9 @@
             taskEmergency.setUpdateTime(DateUtils.getNowDate());
 
             Boolean hasEmergencyInfo = updateVO.getHospitalOut() != null || updateVO.getHospitalIn() != null || updateVO.getPatient() != null
-                    || updateVO.getPrice() != null || updateVO.getDistance() != null;
-
+                    || updateVO.getPrice() != null || updateVO.getTransferDistance() != null;
+//            Boolean isHeadPush=isTaskHeaderPush(task.getCreatorId(),task.getDeptId());
+//            updateVO.setFromHQ2_is(isHeadPush?"1":"0");
 
             // 浣跨敤TaskCreateVO鐨勫瓧娈垫潵鏇存柊鎬ユ晳杞繍淇℃伅
             if (hasEmergencyInfo) {
@@ -1021,6 +1016,71 @@
     }
 
     /**
+     * 淇濆瓨浠诲姟鍙栨秷淇℃伅锛堜粎闄愯浆杩愪换鍔★級
+     * 
+     * @param taskId 浠诲姟ID
+     * @param cancelReason 鍙栨秷鍘熷洜锛堟暟鎹瓧鍏竧ask_cancel_reason鐨剉alue锛�
+     * @return 缁撴灉
+     */
+    @Override
+    public int saveCancelInfo(Long taskId, String cancelReason) {
+        // 鑾峰彇浠诲姟淇℃伅
+        SysTask task = sysTaskMapper.selectSysTaskByTaskId(taskId);
+        if (task == null) {
+            throw new RuntimeException("浠诲姟涓嶅瓨鍦�");
+        }
+        
+        // 鍙湁杞繍浠诲姟鎵嶄繚瀛樺彇娑堜俊鎭�
+        if (!"EMERGENCY_TRANSFER".equals(task.getTaskType())) {
+            return 0;
+        }
+        
+        // 鑾峰彇杞繍浠诲姟鎵╁睍淇℃伅
+        SysTaskEmergency emergency = sysEmergencyTaskService.selectSysTaskEmergencyByTaskId(taskId);
+        if (emergency == null) {
+            return 0;
+        }
+        
+        // 璁剧疆鍙栨秷淇℃伅
+        emergency.setCancelReason(cancelReason);
+        emergency.setCancelBy(SecurityUtils.getNickName());
+        emergency.setCancelTime(DateUtils.getNowDate());
+        emergency.setUpdateBy(SecurityUtils.getUsername());
+        emergency.setUpdateTime(DateUtils.getNowDate());
+        
+        // 鏇存柊鏁版嵁搴�
+        return sysTaskEmergencyMapper.updateSysTaskEmergency(emergency);
+    }
+
+    @Override
+    public int saveCancel(Long taskId, String cancelReason, String cancelBy,Date cancelTime) {
+        SysTask task = sysTaskMapper.selectSysTaskByTaskId(taskId);
+        if (task == null) {
+            throw new RuntimeException("浠诲姟涓嶅瓨鍦�");
+        }
+
+        // 鍙湁杞繍浠诲姟鎵嶄繚瀛樺彇娑堜俊鎭�
+        if (!"EMERGENCY_TRANSFER".equals(task.getTaskType())) {
+            return 0;
+        }
+
+        // 鑾峰彇杞繍浠诲姟鎵╁睍淇℃伅
+        SysTaskEmergency emergency = sysEmergencyTaskService.selectSysTaskEmergencyByTaskId(taskId);
+        if (emergency == null) {
+            return 0;
+        }
+
+        // 璁剧疆鍙栨秷淇℃伅
+        emergency.setCancelReason(cancelReason);
+        emergency.setCancelBy(cancelBy);
+        emergency.setCancelTime(cancelTime);
+        emergency.setUpdateTime(DateUtils.getNowDate());
+
+        // 鏇存柊鏁版嵁搴�
+        return sysTaskEmergencyMapper.updateSysTaskEmergency(emergency);
+    }
+
+    /**
      * 涓婁紶浠诲姟闄勪欢
      * 
      * @param taskId 浠诲姟ID
@@ -1199,7 +1259,7 @@
     public List<SysTask> selectMyTasks(Long userId) {
         List<SysTask> list = sysTaskMapper.selectMyTasks(userId);
         list.stream().forEach(task -> {
-
+            bindTaskAssign(task);
             if(task.getTaskType().equals("EMERGENCY_TRANSFER")){
                 task.setEmergencyInfo(sysTaskEmergencyMapper.selectSysTaskEmergencyByTaskId(task.getTaskId()));
             }
@@ -1425,8 +1485,8 @@
         if (createVO.getDestinationLatitude() != null) {
             task.setDestinationLatitude(createVO.getDestinationLatitude());
         }
-        if (createVO.getEstimatedDistance() != null) {
-            task.setEstimatedDistance(createVO.getEstimatedDistance());
+        if (createVO.getTransferDistance() != null) {
+            task.setEstimatedDistance(createVO.getTransferDistance());
         }
     }
 
@@ -1441,8 +1501,8 @@
         if (createVO.getTransferTime() != null) {
             task.setPlannedStartTime(createVO.getTransferTime());
         }
-        if (createVO.getDistance() != null) {
-            task.setEstimatedDistance(createVO.getDistance());
+        if (createVO.getTransferDistance() != null) {
+            task.setEstimatedDistance(createVO.getTransferDistance());
         }
         
         // 璁剧疆绂忕杞︾壒瀹氫俊鎭�
@@ -1455,9 +1515,7 @@
         if (createVO.getEndAddress() != null) {
             task.setDestinationAddress(createVO.getEndAddress());
         }
-        if (createVO.getDistance() != null) {
-            task.setEstimatedDistance(createVO.getDistance());
-        }
+
     }
 
     /**
@@ -1659,5 +1717,20 @@
     public AjaxResult cancelAssigneeReady(Long taskId, Long userId) {
         return sysTaskAssigneeService.cancelAssigneeReady(taskId, userId);
     }
+    
+    /**
+     * 妫�鏌ヤ换鍔℃槸鍚﹂噸澶嶏紙鏍规嵁鑱旂郴浜虹數璇濆拰鍒涘缓鏃ユ湡锛�
+     * 
+     * @param phone 鑱旂郴浜虹數璇�
+     * @param createDate 浠诲姟鍒涘缓鏃ユ湡锛堟牸寮忥細YYYY-MM-DD锛�
+     * @return true-瀛樺湪閲嶅锛宖alse-涓嶉噸澶�
+     */
+    @Override
+    public boolean checkTaskDuplicate(String phone, String createDate) {
+        int count = sysTaskMapper.countTaskByPhoneAndDate(phone, createDate);
+        return count > 0;
+    }
+
+
    
 }

--
Gitblit v1.9.1