From e0c3d16c7ba1700be99b4739b883e4d01789cc62 Mon Sep 17 00:00:00 2001
From: zuoxiao <470321431@qq.com>
Date: 星期三, 30 四月 2025 16:20:50 +0800
Subject: [PATCH] feat(pipIrr): 新增计划终止后限制发布新计划的功能

---
 pipIrr-platform/pipIrr-web/pipIrr-web-wechat/src/main/java/com/dy/pipIrrWechat/irrigatePlan/IrrigatePlanSv.java |  117 +++++++++++++++++++++++++++++++++++++++-------------------
 1 files changed, 79 insertions(+), 38 deletions(-)

diff --git a/pipIrr-platform/pipIrr-web/pipIrr-web-wechat/src/main/java/com/dy/pipIrrWechat/irrigatePlan/IrrigatePlanSv.java b/pipIrr-platform/pipIrr-web/pipIrr-web-wechat/src/main/java/com/dy/pipIrrWechat/irrigatePlan/IrrigatePlanSv.java
index 2a3bbf3..5db3988 100644
--- a/pipIrr-platform/pipIrr-web/pipIrr-web-wechat/src/main/java/com/dy/pipIrrWechat/irrigatePlan/IrrigatePlanSv.java
+++ b/pipIrr-platform/pipIrr-web/pipIrr-web-wechat/src/main/java/com/dy/pipIrrWechat/irrigatePlan/IrrigatePlanSv.java
@@ -70,15 +70,19 @@
     private CommandSv commandSv;
 
     @Value("${wechat.irr.plan.delay:5}")
-    private Integer irrPlanDelay ;//杞亴涓鍒掑紑闃�鐨勫欢杩熸椂闀�
+    private Integer irrPlanDelay;//杞亴涓鍒掑紑闃�鐨勫欢杩熸椂闀�
 
-    private static final Integer irrPlanDelayDefault = 5 ;//杞亴涓鍒掑紑闃�鐨勯粯璁ゅ欢杩熸椂闀�
+    private static final Integer irrPlanDelayDefault = 5;//杞亴涓鍒掑紑闃�鐨勯粯璁ゅ欢杩熸椂闀�
 
     @Value("${wechat.irr.plan.preOpeningTime:10}")
     private Integer preOpeningTime;
 
+    @Value("${wechat.irr.plan.planTerminateLimitMinutes:5}")
+    private Integer planTerminateLimitMinutes; // 璁″垝缁堟鍚庨檺鍒跺彂甯冩柊璁″垝鐨勬椂闂撮棿闅�(鍒嗛挓)
+
     /**
      * 娣诲姞鐏屾簤璁″垝
+     *
      * @param po
      * @return
      */
@@ -90,6 +94,7 @@
 
     /**
      * 鍒犻櫎鐏屾簤璁″垝
+     *
      * @param planSimple
      * @return
      */
@@ -99,14 +104,14 @@
         Long operatorId = planSimple.getOperatorId();
 
         Integer planState = irrigatePlanMapper.getPlanState(planId);
-        if(planState == null) {
+        if (planState == null) {
             Map map = new HashMap<>();
             map.put("success", false);
             map.put("msg", "鐏屾簤璁″垝涓嶅瓨鍦�");
             map.put("content", null);
             return map;
         }
-        if(planState != 1) {
+        if (planState != 1) {
             Map map = new HashMap<>();
             map.put("success", false);
             map.put("msg", "鐏屾簤璁″垝闈炶崏绋跨姸鎬侊紝涓嶅厑璁稿垹闄�");
@@ -117,7 +122,7 @@
         try {
             irrigatePlanMapper.deleteByPrimaryKey(planId);
             // 娣诲姞鐏屾簤璁″垝鎿嶄綔璁板綍
-            IrPlanOperate planOperate  = new IrPlanOperate();
+            IrPlanOperate planOperate = new IrPlanOperate();
             planOperate.setPlanId(planId);
             planOperate.setOperator(operatorId);
             planOperate.setOperateType(OperateTypeENUM.DELETE.getCode());
@@ -140,6 +145,7 @@
 
     /**
      * 鍙戝竷鐏屾簤璁″垝
+     *
      * @param planSimple
      * @return
      */
@@ -148,7 +154,8 @@
         Long operatorId = planSimple.getOperatorId();
         Byte operateType = 1;
 
-        if(irrigatePlanMapper.hasPlan_CurrentProject(planId) > 0) {
+        // 妫�鏌ュ綋鍓嶉」鐩槸鍚﹀瓨鍦ㄦ湭瀹屾垚鐨勭亴婧夎鍒�
+        if (irrigatePlanMapper.hasPlan_CurrentProject(planId) > 0) {
             Map map = new HashMap<>();
             map.put("success", false);
             map.put("msg", "褰撳墠椤圭洰瀛樺湪鏈畬鎴愮殑鐏屾簤璁″垝");
@@ -156,7 +163,8 @@
             return map;
         }
 
-        if(irrigatePlanMapper.hasPlan_OtherProject(planId) > 0) {
+        // 妫�鏌ュ叾浠栭」鐩腑鏄惁瀛樺湪鏈畬鎴愮殑鐏屾簤璁″垝
+        if (irrigatePlanMapper.hasPlan_OtherProject(planId) > 0) {
             Map map = new HashMap<>();
             map.put("success", false);
             map.put("msg", "寰呭彂甯冭鍒掔殑杞亴缁勫湪鍏朵粬椤圭洰鐨勭亴婧夎鍒掍腑锛屼笖璇ヨ鍒掑皻鏈畬鎴�");
@@ -164,12 +172,25 @@
             return map;
         }
 
+        // 妫�鏌�5鍒嗛挓鍐呮槸鍚︽湁缁堟鐨勮鍒掞紝涓旇疆鐏岀粍鏈夐噸鍙�
+        Long lastTerminatedPlanId = irPlanOperateMapper.getLastTerminatedPlanId(planTerminateLimitMinutes);
+        if (lastTerminatedPlanId != null) {
+            // 妫�鏌ュ綋鍓嶈鍒掍笌鏈�杩戠粓姝㈣鍒掔殑杞亴缁勬槸鍚︽湁閲嶅彔
+            if (irrigatePlanMapper.hasPlanOverlapWithTerminated(planId, lastTerminatedPlanId) > 0) {
+                Map map = new HashMap<>();
+                map.put("success", false);
+                map.put("msg", "涓婁竴涓鍒掔粓姝㈠悗" + planTerminateLimitMinutes + "鍒嗛挓鍐呬笉鑳藉彂甯冩柊璁″垝");
+                map.put("content", null);
+                return map;
+            }
+        }
+
         /**
          * 鑾峰彇鐏屾簤璁″垝淇℃伅
          * 鏇存柊鐏屾簤璁″垝璧锋鏃堕棿鍙婅鍒掔姸鎬�
          */
         VoPlanSimple plan = irrigatePlanMapper.getPlanSimple(planId);
-        if(plan == null){
+        if (plan == null) {
             Map map = new HashMap<>();
             map.put("success", false);
             map.put("msg", "鎮ㄨ鍙戝竷鐨勮鍒掍笉瀛樺湪锛屾垨璇ヨ鍒掑凡鍙戝竷");
@@ -182,16 +203,16 @@
         Date planStartTime = plan.getPlanStartTime();
         Date planStopTime = null;
 
-        if(startupMode == 1){
+        if (startupMode == 1) {
             planStartTime = new Date();
         }
-        LocalDateTime startTime = planStartTime.toInstant().atZone(ZoneId.systemDefault()) .toLocalDateTime();
-        if(startupMode == 1){
+        LocalDateTime startTime = planStartTime.toInstant().atZone(ZoneId.systemDefault()).toLocalDateTime();
+        if (startupMode == 1) {
             // 娴嬭瘯闃舵寤跺悗2鍒嗛挓锛屾寮忓彂甯冧负5鍒嗛挓
             //startTime = startTime.plusMinutes(2);
             //startTime = startTime.plusMinutes(5);
-            if(irrPlanDelay == null || irrPlanDelay <= 0) {
-                irrPlanDelay = irrPlanDelayDefault ;
+            if (irrPlanDelay == null || irrPlanDelay <= 0) {
+                irrPlanDelay = irrPlanDelayDefault;
             }
             startTime = startTime.plusMinutes(irrPlanDelay);
         }
@@ -200,7 +221,7 @@
         planStopTime = Date.from(stopTime.atZone(ZoneId.systemDefault()).toInstant());
 
         // 鏍规嵁璁″垝ID鏇存柊璁″垝淇℃伅锛堣捣姝㈡椂闂淬�佽鍒掔姸鎬侊級
-        if(this.updatePlanTimes(planStartTime, planStopTime, planId) == 0) {
+        if (this.updatePlanTimes(planStartTime, planStopTime, planId) == 0) {
             Map map = new HashMap<>();
             map.put("success", false);
             map.put("msg", "璁″垝淇℃伅鏇存柊澶辫触");
@@ -212,31 +233,31 @@
         List<VoIrrigateSchedule> schedules = getSchedulesByPlanId(planId);
         Date scheduleStartTime = null;
         Integer sort = 0;
-        for(VoIrrigateSchedule schedule : schedules){
-            if(scheduleStartTime == null) {
+        for (VoIrrigateSchedule schedule : schedules) {
+            if (scheduleStartTime == null) {
                 scheduleStartTime = planStartTime;
             }
             this.updateScheduleStartTime(schedule.getScheduleId(), scheduleStartTime);
 
             // 璁$畻涓嬩竴缁勭殑寮�濮嬫椂闂�
-            LocalDateTime LocalscheduleStartTime = scheduleStartTime.toInstant().atZone(ZoneId.systemDefault()) .toLocalDateTime();
+            LocalDateTime LocalscheduleStartTime = scheduleStartTime.toInstant().atZone(ZoneId.systemDefault()).toLocalDateTime();
             LocalscheduleStartTime = LocalscheduleStartTime.plusMinutes(schedule.getDuration());
             LocalscheduleStartTime = LocalscheduleStartTime.minusMinutes(preOpeningTime);
             scheduleStartTime = Date.from(LocalscheduleStartTime.atZone(ZoneId.systemDefault()).toInstant());
-            
+
             // 纭繚涓嬩竴缁勭殑寮�濮嬫椂闂翠笉鏃╀簬璁″垝寮�濮嬫椂闂�
-            if(scheduleStartTime.before(planStartTime)) {
+            if (scheduleStartTime.before(planStartTime)) {
                 scheduleStartTime = planStartTime;
             }
         }
 
         // 娣诲姞鐏屾簤璁″垝鎿嶄綔璁板綍
-        IrPlanOperate planOperate  = new IrPlanOperate();
+        IrPlanOperate planOperate = new IrPlanOperate();
         planOperate.setPlanId(planId);
         planOperate.setOperator(operatorId);
         planOperate.setOperateType(OperateTypeENUM.PUBLISH.getCode());
         planOperate.setOperateTime(new Date());
-        if(addPlanOperate(planOperate) == 0){
+        if (addPlanOperate(planOperate) == 0) {
             Map map = new HashMap<>();
             map.put("success", false);
             map.put("msg", "娣诲姞鐏屾簤璁″垝鎿嶄綔璁板綍澶辫触");
@@ -245,11 +266,11 @@
         }
 
         schedules = getSchedulesByPlanId(planId);
-        for(VoIrrigateSchedule schedule : schedules) {
+        for (VoIrrigateSchedule schedule : schedules) {
             Long groupId = schedule.getGroupId();
             List<Long> intakeIds = getIntakeIdsByGroupId(groupId);
-            for(Long intakeId : intakeIds) {
-                if(schedule.getDuration() > 0) {
+            for (Long intakeId : intakeIds) {
+                if (schedule.getDuration() > 0) {
                     // 浠婂彂甯冪亴婧夋椂闀垮ぇ浜�0鐨�
                     AutomaticClose automaticClose = new AutomaticClose();
                     automaticClose.setIntakeId(intakeId);
@@ -272,6 +293,7 @@
 
     /**
      * 鏍规嵁璁″垝ID鑾峰彇璁″垝鏈�鏂扮姸鎬�
+     *
      * @param planId
      * @return
      */
@@ -281,6 +303,7 @@
 
     /**
      * 鏍规嵁璁″垝ID鑾峰彇寰呯粓姝㈣鍒掔殑缁撴潫鏃堕棿锛氭湭鍒犻櫎銆佹湭缁堟銆佸凡鍙戝竷銆佸綋鍓嶆椂闂村皬浜庤鍒掔粨鏉熸椂闂�
+     *
      * @param planId
      * @return
      */
@@ -290,6 +313,7 @@
 
     /**
      * 鏍规嵁璁″垝ID鑾峰彇寰呯粓姝㈢殑鍙栨按鍙D锛堝凡鍙戝竷寮�鍙戝懡浠わ紝鏃犺鏄惁鎴愬姛锛�
+     *
      * @param planId
      * @return
      */
@@ -299,6 +323,7 @@
 
     /**
      * 鏍规嵁璁″垝ID鑾峰彇寰呯粓姝㈢殑鍛戒护ID鍒楄〃
+     *
      * @param planId
      * @return
      */
@@ -308,6 +333,7 @@
 
     /**
      * 鏍规嵁璁″垝ID鑾峰彇寰呯粓姝㈢殑鍙栨按鍙e垪琛紙寮�闃�鎴愬姛鐨勶級
+     *
      * @param planId
      * @return
      */
@@ -317,6 +343,7 @@
 
     /**
      * 鏍规嵁鍛戒护鏃ュ織ID鑾峰彇鍙栨按鍙e強铏氭嫙鍗′俊鎭紝缁堟鐏屾簤璁″垝鏃朵娇鐢紝鐢ㄦ潵鎵ц杩滅▼鍏抽榾
+     *
      * @param commandId
      * @return
      */
@@ -326,6 +353,7 @@
 
     /**
      * 淇敼鐏屾簤璁″垝
+     *
      * @param po
      * @return
      */
@@ -336,7 +364,8 @@
 
     /**
      * 鑾峰彇鏈畬鎴愮殑璁″垝鍒楄〃锛屽皬绋嬪簭璁″垝鍒楄〃椤典娇鐢�
-      * @return
+     *
+     * @return
      */
     public List<VoPlans> getNotCompletePlans() {
         return irrigatePlanMapper.getNotCompletePlans();
@@ -344,24 +373,26 @@
 
     /**
      * 鑾峰彇宸插畬鎴愮殑璁″垝鍒楄〃锛屽皬绋嬪簭璁″垝鍒楄〃椤典娇鐢�
+     *
      * @return
      */
     public QueryResultVo<List<VoPlans>> getCompletedPlans(QueryConditionVo queryVo) {
-        Map<String, Object> params = (Map<String, Object>) PojoUtils.generalize(queryVo) ;
+        Map<String, Object> params = (Map<String, Object>) PojoUtils.generalize(queryVo);
 
-        Long itemTotal = (long)irrigatePlanMapper.getCompletedPlansCount(params);
-        QueryResultVo<List<VoPlans>> rsVo = new QueryResultVo<>() ;
-        rsVo.pageSize = queryVo.pageSize ;
-        rsVo.pageCurr = queryVo.pageCurr ;
+        Long itemTotal = (long) irrigatePlanMapper.getCompletedPlansCount(params);
+        QueryResultVo<List<VoPlans>> rsVo = new QueryResultVo<>();
+        rsVo.pageSize = queryVo.pageSize;
+        rsVo.pageCurr = queryVo.pageCurr;
 
         rsVo.calculateAndSet(itemTotal, params);
         rsVo.obj = irrigatePlanMapper.getCompletedPlans(params);
 
-        return rsVo ;
+        return rsVo;
     }
 
     /**
      * 鏍规嵁鎸囧畾鐨勮鍒扞D鑾峰彇鍚姩妯″紡
+     *
      * @param planId
      * @return
      */
@@ -390,6 +421,7 @@
 
     /**
      * 娣诲姞鐏屾簤璁″垝鎿嶄綔璁板綍
+     *
      * @param po
      * @return
      */
@@ -401,6 +433,7 @@
 
     /**
      * 娣诲姞鐏屾簤娆″簭璁板綍
+     *
      * @param po
      * @return
      */
@@ -412,6 +445,7 @@
 
     /**
      * 鏍规嵁璁″垝ID缁堟鐏屾簤娆″簭锛屽皢鐏屾簤娆″簭鐨勫綋鍓嶇姸鎬佹敼涓哄凡缁堟
+     *
      * @param planId
      * @return
      */
@@ -422,6 +456,7 @@
 
     /**
      * 鏍规嵁璁″垝ID鑾峰彇鐏屾簤娆″簭璁板綍
+     *
      * @param planId
      * @return
      */
@@ -431,6 +466,7 @@
 
     /**
      * 鏍规嵁缁処D鑾峰彇鍙栨按鍙D闆嗗悎
+     *
      * @param groupId
      * @return
      */
@@ -440,6 +476,7 @@
 
     /**
      * 娣诲姞璁″垝娆″簭鍏宠仈璁板綍
+     *
      * @param po
      * @return
      */
@@ -451,6 +488,7 @@
 
     /**
      * 鏍规嵁鐏屾簤娆″簭ID鏇存柊娆″簭寮�濮嬫椂闂�
+     *
      * @param scheduleId
      * @param startTime
      * @return
@@ -472,6 +510,7 @@
 
     /**
      * 鏍规嵁鐏屾簤鍗曞厓ID鑾峰彇鍙栨按鍙D
+     *
      * @param unitId
      * @return
      */
@@ -481,12 +520,13 @@
 
     /**
      * 鏍规嵁璁″垝ID鑾峰彇璁″垝鍙戝竷缁撴灉
+     *
      * @param planId
      * @return
      */
     public VoPlanDetails getPublishResults(Long planId) {
         VoPlanDetails planDetails = irrigatePlanMapper.getPlanDetails(planId);
-        if(planDetails == null){
+        if (planDetails == null) {
             return null;
         }
         Integer failureCount = Optional.ofNullable(irIntakeOperateMapper.getFailureCount(planId)).orElse(0);
@@ -495,13 +535,13 @@
         Date terminateTime = Optional.ofNullable(irPlanOperateMapper.getTerminateTime(planId)).orElse(null);
 
         List<VoGroupResult> groupResults = irIrrigateGroupMapper.getGroupResult(planId);
-        if(groupResults == null || groupResults.size() == 0){
+        if (groupResults == null || groupResults.size() == 0) {
             return null;
         }
 
         for (VoGroupResult groupResult : groupResults) {
             List<VoIntakeResult> intakeResults = irIntakeOperateMapper.getIntakeResult(planId, groupResult.getGroupId());
-            if(intakeResults != null) {
+            if (intakeResults != null) {
                 groupResult.setPublishResult(intakeResults);
             }
         }
@@ -513,6 +553,7 @@
 
     /**
      * 鏍规嵁璁″垝ID鑾峰彇璁″垝缁堟鎿嶄綔缁撴灉
+     *
      * @param planId
      * @return
      */
@@ -521,20 +562,20 @@
         Date terminateTime = Optional.ofNullable(irPlanOperateMapper.getTerminateTime(planId)).orElse(null);
 
         VoPlanDetails planDetails = irrigatePlanMapper.getPlanDetails_terminate(planId, terminateTime);
-        if(planDetails == null){
+        if (planDetails == null) {
             return null;
         }
         Integer failureCount = Optional.ofNullable(irIntakeOperateMapper.getFailureCount(planId)).orElse(0);
         planDetails.setFailureCount(failureCount);
 
         List<VoGroupResult> groupResults = irIrrigateGroupMapper.getGroupResult_terminate(planId, terminateTime);
-        if(groupResults == null || groupResults.size() == 0){
+        if (groupResults == null || groupResults.size() == 0) {
             return null;
         }
 
         for (VoGroupResult groupResult : groupResults) {
             List<VoIntakeResult> intakeResults = irIntakeOperateMapper.getIntakeResult(planId, groupResult.getGroupId());
-            if(intakeResults != null) {
+            if (intakeResults != null) {
                 groupResult.setPublishResult(intakeResults);
             }
         }
@@ -545,7 +586,7 @@
     }
 
     @Transactional(rollbackFor = Exception.class)
-    Integer updatePlanTimes(Date planStartTime, Date planEndTime, Long planId){
+    Integer updatePlanTimes(Date planStartTime, Date planEndTime, Long planId) {
         return irrigatePlanMapper.updatePlanTimes(planStartTime, planEndTime, planId);
     }
 

--
Gitblit v1.8.0