From 6bab142343375e744e46f2042aa3b0fedea70b06 Mon Sep 17 00:00:00 2001
From: gongchunyi <deslre0381@gmail.com>
Date: 星期二, 19 五月 2026 23:32:55 +0800
Subject: [PATCH] fix: 设备巡检修改

---
 src/main/java/com/ruoyi/inspectiontask/service/impl/TimingTaskServiceImpl.java |  115 ++++++++++++++++++++++++++++++++++++++++++++++-----------
 1 files changed, 92 insertions(+), 23 deletions(-)

diff --git a/src/main/java/com/ruoyi/inspectiontask/service/impl/TimingTaskServiceImpl.java b/src/main/java/com/ruoyi/inspectiontask/service/impl/TimingTaskServiceImpl.java
index 33c815e..354f971 100644
--- a/src/main/java/com/ruoyi/inspectiontask/service/impl/TimingTaskServiceImpl.java
+++ b/src/main/java/com/ruoyi/inspectiontask/service/impl/TimingTaskServiceImpl.java
@@ -1,8 +1,10 @@
 package com.ruoyi.inspectiontask.service.impl;
 
+import com.baomidou.mybatisplus.core.conditions.query.LambdaQueryWrapper;
 import com.baomidou.mybatisplus.core.metadata.IPage;
 import com.baomidou.mybatisplus.extension.plugins.pagination.Page;
 import com.baomidou.mybatisplus.extension.service.impl.ServiceImpl;
+import com.ruoyi.common.exception.ServiceException;
 import com.ruoyi.common.utils.StringUtils;
 import com.ruoyi.common.utils.bean.BeanUtils;
 import com.ruoyi.inspectiontask.dto.TimingTaskDto;
@@ -13,7 +15,6 @@
 import com.ruoyi.project.system.domain.SysUser;
 import com.ruoyi.project.system.mapper.SysUserMapper;
 import lombok.extern.slf4j.Slf4j;
-import org.quartz.SchedulerException;
 import org.springframework.beans.factory.annotation.Autowired;
 import org.springframework.stereotype.Service;
 import org.springframework.transaction.annotation.Transactional;
@@ -47,7 +48,12 @@
     @Override
     public IPage<TimingTaskDto> selectTimingTaskList(Page<TimingTask> page, TimingTask timingTask) {
         // 1. 鍏堝垎椤垫煡璇㈠畾鏃朵换鍔℃暟鎹�
-        IPage<TimingTask> taskPage = timingTaskMapper.selectPage(page, null);
+        // 鏋勫缓鏌ヨ鏉′欢
+        LambdaQueryWrapper<TimingTask> queryWrapper = new LambdaQueryWrapper<>();
+        if (StringUtils.isNotBlank(timingTask.getTaskName())) {
+            queryWrapper.like(TimingTask::getTaskName, timingTask.getTaskName());
+        }
+        IPage<TimingTask> taskPage = timingTaskMapper.selectPage(page, queryWrapper);
 
         // 2. 濡傛灉娌℃湁鏁版嵁锛岀洿鎺ヨ繑鍥炵┖鍒嗛〉
         if (taskPage.getRecords().isEmpty()) {
@@ -66,11 +72,19 @@
 
         // 鏀堕泦宸℃浜篒D锛堝涓狪D浠ラ�楀彿鍒嗛殧锛�
         taskPage.getRecords().forEach(task -> {
+            task.setDateStr(task.getCreateTime().format(DateTimeFormatter.ofPattern("yyyy-MM-dd")));
             if (StringUtils.isNotBlank(task.getInspectorIds())) {
                 Arrays.stream(task.getInspectorIds().split(","))
                         .filter(StringUtils::isNotBlank)
                         .map(Long::valueOf)
                         .forEach(userIds::add);
+            }
+        });
+
+        // 鏀堕泦楠屾敹鍏D
+        taskPage.getRecords().forEach(task -> {
+            if (task.getInspectionAcceptorId() != null) {
+                userIds.add(task.getInspectionAcceptorId());
             }
         });
 
@@ -104,6 +118,11 @@
                 dto.setInspector(inspectorNickNames);
             }
 
+            // 璁剧疆楠屾敹浜烘樀绉�
+            if (task.getInspectionAcceptorId() != null) {
+                dto.setInspectionAcceptor(userNickNameMap.getOrDefault(task.getInspectionAcceptorId(), "鏈煡鐢ㄦ埛"));
+            }
+
             return dto;
         }).collect(Collectors.toList());
 
@@ -115,36 +134,65 @@
 
     @Override
     @Transactional
-    public int addOrEditTimingTask(TimingTaskDto timingTaskDto) throws SchedulerException {
+    public int addOrEditTimingTask(TimingTaskDto timingTaskDto) {
         TimingTask timingTask = new TimingTask();
         BeanUtils.copyProperties(timingTaskDto, timingTask);
+        DateTimeFormatter formatter = DateTimeFormatter.ofPattern("yyyy-MM-dd");
+        LocalDate localDate = LocalDate.now();
 
-        // 璁剧疆鍒涘缓浜轰俊鎭拰榛樿鍊�
+        if (StringUtils.isNotEmpty(timingTaskDto.getDateStr())) {
+            localDate = LocalDate.parse(timingTaskDto.getDateStr(), formatter);
+        }
+        LocalTime currentTime = LocalTime.now();
+        LocalDateTime localDateTime = LocalDateTime.of(localDate, currentTime);
+        timingTask.setCreateTime(localDateTime);
         if (Objects.isNull(timingTaskDto.getId())) {
             timingTask.setRegistrationDate(LocalDate.now());
-            timingTask.setActive(true);
-
             // 璁$畻棣栨鎵ц鏃堕棿
             LocalDateTime firstExecutionTime = calculateFirstExecutionTime(timingTask);
             timingTask.setNextExecutionTime(firstExecutionTime);
-
             int result = timingTaskMapper.insert(timingTask);
-            if (result > 0) {
-                // 鏂板鎴愬姛鍚庢坊鍔犲埌璋冨害鍣�
-                timingTaskScheduler.scheduleTimingTask(timingTask);
+            // 鏂板鎴愬姛鍚庝笖鍚敤鐘舵�佹墠娣诲姞鍒拌皟搴﹀櫒
+            if (result > 0 && Integer.valueOf(1).equals(timingTask.getIsActive())) {
+                try {
+                    timingTaskScheduler.scheduleTimingTask(timingTask);
+                } catch (Exception e) {
+                    log.error("娣诲姞宸℃浠诲姟澶辫触 : {}", e.getMessage(), e);
+                    throw new ServiceException("娣诲姞宸℃浠诲姟澶辫触");
+                }
             }
             return result;
         } else {
+            // 缂栬緫鏃讹紝淇濆瓨鏃х殑鐘舵��
+            TimingTask oldTask = timingTaskMapper.selectById(timingTaskDto.getId());
+            Integer oldIsActive = oldTask != null ? oldTask.getIsActive() : 0;
+            Integer newIsActive = timingTask.getIsActive();
             int result = timingTaskMapper.updateById(timingTask);
             if (result > 0) {
-                // 鏇存柊鎴愬姛鍚庨噸鏂拌皟搴︿换鍔�
-                timingTaskScheduler.rescheduleTimingTask(timingTask);
+                // 浠庡惎鐢ㄥ彉涓哄仠鐢紝绉婚櫎浠诲姟
+                if (Integer.valueOf(1).equals(oldIsActive)
+                        && !Integer.valueOf(1).equals(newIsActive)) {
+                    timingTaskScheduler.unscheduleTimingTask(timingTask.getId());
+                }
+                // 浠庡仠鐢ㄥ彉涓哄惎鐢紝娣诲姞浠诲姟
+                else if (!Integer.valueOf(1).equals(oldIsActive)
+                        && Integer.valueOf(1).equals(newIsActive)) {
+                    // 璁$畻棣栨鎵ц鏃堕棿
+                    LocalDateTime firstExecutionTime = calculateFirstExecutionTime(timingTask);
+                    timingTask.setNextExecutionTime(firstExecutionTime);
+                    try {
+                        timingTaskScheduler.scheduleTimingTask(timingTask);
+                    } catch (Exception e) {
+                        log.error("娣诲姞宸℃浠诲姟澶辫触 : {}", e.getMessage(), e);
+                        throw new ServiceException("娣诲姞宸℃浠诲姟澶辫触");
+                    }
+                }
             }
             return result;
         }
     }
 
-    private LocalDateTime calculateFirstExecutionTime(TimingTask task) {
+    public LocalDateTime calculateFirstExecutionTime(TimingTask task) {
         // 鏍规嵁棰戠巼绫诲瀷鍜岃鎯呰绠楅娆℃墽琛屾椂闂�
         String frequencyType = task.getFrequencyType();
         if ("DAILY".equals(frequencyType)) {
@@ -176,6 +224,7 @@
 
     // 鏄犲皠鏄熸湡绠�鍐欎笌DayOfWeek
     private static final Map<String, DayOfWeek> WEEK_DAY_MAP = new HashMap<>();
+
     static {
         WEEK_DAY_MAP.put("MON", DayOfWeek.MONDAY);
         WEEK_DAY_MAP.put("TUE", DayOfWeek.TUESDAY);
@@ -426,14 +475,29 @@
 
         for (String dayStr : dayStrs) {
             switch (dayStr) {
-                case "MON": days.add(DayOfWeek.MONDAY); break;
-                case "TUE": days.add(DayOfWeek.TUESDAY); break;
-                case "WED": days.add(DayOfWeek.WEDNESDAY); break;
-                case "THU": days.add(DayOfWeek.THURSDAY); break;
-                case "FRI": days.add(DayOfWeek.FRIDAY); break;
-                case "SAT": days.add(DayOfWeek.SATURDAY); break;
-                case "SUN": days.add(DayOfWeek.SUNDAY); break;
-                default: throw new IllegalArgumentException("鏃犳晥鐨勬槦鏈熷嚑: " + dayStr);
+                case "MON":
+                    days.add(DayOfWeek.MONDAY);
+                    break;
+                case "TUE":
+                    days.add(DayOfWeek.TUESDAY);
+                    break;
+                case "WED":
+                    days.add(DayOfWeek.WEDNESDAY);
+                    break;
+                case "THU":
+                    days.add(DayOfWeek.THURSDAY);
+                    break;
+                case "FRI":
+                    days.add(DayOfWeek.FRIDAY);
+                    break;
+                case "SAT":
+                    days.add(DayOfWeek.SATURDAY);
+                    break;
+                case "SUN":
+                    days.add(DayOfWeek.SUNDAY);
+                    break;
+                default:
+                    throw new IllegalArgumentException("鏃犳晥鐨勬槦鏈熷嚑: " + dayStr);
             }
         }
 
@@ -441,10 +505,15 @@
     }
 
 
-
     @Override
     public int delByIds(Long[] ids) {
-        return timingTaskMapper.deleteBatchIds(Arrays.asList(ids));
+        int i = timingTaskMapper.deleteBatchIds(Arrays.asList(ids));
+        if (i > 0) {
+            for (Long id : ids) {
+                timingTaskScheduler.unscheduleTimingTask(id);
+            }
+        }
+        return i;
     }
 
 }

--
Gitblit v1.9.3