From d711c899e42e8cacee3ed6408f4c57e91c962dc8 Mon Sep 17 00:00:00 2001
From: zhubaomin <zhubaomin>
Date: 星期四, 17 四月 2025 17:03:10 +0800
Subject: [PATCH] 改正发布判断bug

---
 pipIrr-platform/pipIrr-web/pipIrr-web-wechat/src/main/java/com/dy/pipIrrWechat/irrigatePlan/IrrigatePlanSv.java |  199 +++++++++++++++++++++++++++++++++++++++++++------
 1 files changed, 173 insertions(+), 26 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 abb4064..1ac23ad 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
@@ -1,9 +1,5 @@
 package com.dy.pipIrrWechat.irrigatePlan;
 
-import com.alibaba.fastjson2.JSON;
-import com.alibaba.fastjson2.JSONArray;
-import com.alibaba.fastjson2.JSONObject;
-import com.dy.common.webUtil.BaseResponseUtils;
 import com.dy.common.webUtil.QueryConditionVo;
 import com.dy.common.webUtil.QueryResultVo;
 import com.dy.pipIrrGlobal.daoIr.*;
@@ -14,7 +10,8 @@
 import com.dy.pipIrrGlobal.pojoIr.IrPlanSchedule;
 import com.dy.pipIrrGlobal.voIr.*;
 import com.dy.pipIrrGlobal.voRm.VoIntakeVc;
-import com.dy.pipIrrGlobal.voSe.VoClient;
+import com.dy.pipIrrWechat.command.CommandSv;
+import com.dy.pipIrrWechat.command.dto.AutomaticClose;
 import com.dy.pipIrrWechat.irrigatePlan.dto.PlanSimple;
 import com.dy.pipIrrWechat.irrigatePlan.enums.OperateTypeENUM;
 import lombok.extern.slf4j.Slf4j;
@@ -23,6 +20,8 @@
 import org.springframework.beans.factory.annotation.Autowired;
 import org.springframework.stereotype.Service;
 
+import java.time.LocalDateTime;
+import java.time.ZoneId;
 import java.util.*;
 
 /**
@@ -64,6 +63,9 @@
 
     @Autowired
     private RmCommandHistoryMapper rmdCommandHistoryMapper;
+
+    @Autowired
+    private CommandSv commandSv;
 
     /**
      * 娣诲姞鐏屾簤璁″垝
@@ -122,6 +124,137 @@
             map.put("content", null);
             return map;
         }
+    }
+
+    /**
+     * 鍙戝竷鐏屾簤璁″垝
+     * @param planSimple
+     * @return
+     */
+    public Map publishPlan(PlanSimple planSimple) {
+        Long planId = planSimple.getPlanId();
+        Long operatorId = planSimple.getOperatorId();
+        Byte operateType = 1;
+
+        if(irrigatePlanMapper.hasPlan_CurrentProject(planId) > 0) {
+            Map map = new HashMap<>();
+            map.put("success", false);
+            map.put("msg", "褰撳墠椤圭洰瀛樺湪鏈畬鎴愮殑鐏屾簤璁″垝");
+            map.put("content", null);
+            return map;
+        }
+
+        if(irrigatePlanMapper.hasPlan_OtherProject(planId) > 0) {
+            Map map = new HashMap<>();
+            map.put("success", false);
+            map.put("msg", "寰呭彂甯冭鍒掔殑杞亴缁勫湪鍏朵粬椤圭洰鐨勭亴婧夎鍒掍腑锛屼笖璇ヨ鍒掑皻鏈畬鎴�");
+            map.put("content", null);
+            return map;
+        }
+
+        /**
+         * 鑾峰彇鐏屾簤璁″垝淇℃伅
+         * 鏇存柊鐏屾簤璁″垝璧锋鏃堕棿鍙婅鍒掔姸鎬�
+         */
+        VoPlanSimple plan = irrigatePlanMapper.getPlanSimple(planId);
+        if(plan == null){
+            Map map = new HashMap<>();
+            map.put("success", false);
+            map.put("msg", "鎮ㄨ鍙戝竷鐨勮鍒掍笉瀛樺湪锛屾垨璇ヨ鍒掑凡鍙戝竷");
+            map.put("content", null);
+            return map;
+        }
+
+        Byte startupMode = plan.getStartupMode();
+        Integer duration = plan.getDuration();
+        Date planStartTime = plan.getPlanStartTime();
+        Date planStopTime = null;
+
+        if(startupMode == 1){
+            planStartTime = new Date();
+        }
+        LocalDateTime startTime = planStartTime.toInstant().atZone(ZoneId.systemDefault()) .toLocalDateTime();
+        if(startupMode == 1){
+            // 娴嬭瘯闃舵寤跺悗2鍒嗛挓锛屾寮忓彂甯冧负5鍒嗛挓
+            startTime = startTime.plusMinutes(2);
+            //startTime = startTime.plusMinutes(5);
+        }
+        planStartTime = Date.from(startTime.atZone(ZoneId.systemDefault()).toInstant());
+        LocalDateTime stopTime = startTime.plusMinutes(duration);
+        planStopTime = Date.from(stopTime.atZone(ZoneId.systemDefault()).toInstant());
+
+        // 鏍规嵁璁″垝ID鏇存柊璁″垝淇℃伅锛堣捣姝㈡椂闂淬�佽鍒掔姸鎬侊級
+        if(irrigatePlanMapper.updatePlanTimes(planStartTime, planStopTime, planId) == 0) {
+            Map map = new HashMap<>();
+            map.put("success", false);
+            map.put("msg", "璁″垝淇℃伅鏇存柊澶辫触");
+            map.put("content", null);
+            return map;
+        }
+
+        // 鏇存柊姣忎釜鐏屾簤娆″簭鐨勫紑濮嬫椂闂�
+        List<VoIrrigateSchedule> schedules = getSchedulesByPlanId(planId);
+        Date scheduleStartTime = null;
+        Integer sort = 0;
+        for(VoIrrigateSchedule schedule : schedules){
+            if(scheduleStartTime == null) {
+                scheduleStartTime = planStartTime;
+            }
+            updateScheduleStartTime(schedule.getScheduleId(), scheduleStartTime);
+
+            // 璁$畻涓嬩竴缁勭殑寮�濮嬫椂闂�
+            LocalDateTime LocalscheduleStartTime = scheduleStartTime.toInstant().atZone(ZoneId.systemDefault()) .toLocalDateTime();
+            LocalscheduleStartTime = LocalscheduleStartTime.plusMinutes(schedule.getDuration());
+            scheduleStartTime = Date.from(LocalscheduleStartTime.atZone(ZoneId.systemDefault()).toInstant());
+        }
+
+        // 娣诲姞鐏屾簤璁″垝鎿嶄綔璁板綍
+        IrPlanOperate planOperate  = new IrPlanOperate();
+        planOperate.setPlanId(planId);
+        planOperate.setOperator(operatorId);
+        planOperate.setOperateType(OperateTypeENUM.PUBLISH.getCode());
+        planOperate.setOperateTime(new Date());
+        if(addPlanOperate(planOperate) == 0){
+            Map map = new HashMap<>();
+            map.put("success", false);
+            map.put("msg", "娣诲姞鐏屾簤璁″垝鎿嶄綔璁板綍澶辫触");
+            map.put("content", null);
+            return map;
+        }
+
+        schedules = getSchedulesByPlanId(planId);
+        for(VoIrrigateSchedule schedule : schedules) {
+            Long groupId = schedule.getGroupId();
+            List<Long> intakeIds = getIntakeIdsByGroupId(groupId);
+            for(Long intakeId : intakeIds) {
+                if(schedule.getDuration() > 0) {
+                    // 浠婂彂甯冪亴婧夋椂闀垮ぇ浜�0鐨�
+                    AutomaticClose automaticClose = new AutomaticClose();
+                    automaticClose.setIntakeId(intakeId);
+                    automaticClose.setPlannedOpenTime(schedule.getStartTime());
+                    automaticClose.setMinutes(schedule.getDuration());
+                    automaticClose.setOperator(operatorId);
+                    automaticClose.setOpenType(Byte.valueOf("1"));
+
+                    commandSv.planedOpenTimedClose(automaticClose, planId, operateType, schedule.getStartTime(), schedule.getDuration());
+                }
+            }
+        }
+
+        Map map = new HashMap<>();
+        map.put("success", true);
+        map.put("msg", "鐏屾簤椤圭洰鍒犻櫎鎴愬姛");
+        map.put("content", null);
+        return map;
+    }
+
+    /**
+     * 鏍规嵁璁″垝ID鑾峰彇璁″垝鏈�鏂扮姸鎬�
+     * @param planId
+     * @return
+     */
+    public Integer getPlanLatestState(Long planId) {
+        return irrigatePlanMapper.getPlanLatestState(planId);
     }
 
     /**
@@ -290,26 +423,6 @@
     }
 
     /**
-     * 鏍规嵁璁″垝ID鑾峰彇璁″垝绠�鍗曚俊鎭垪琛�
-     * @param planId
-     * @return
-     */
-    public VoPlanSimple getPlanSimple(Long planId) {
-        return irrigatePlanMapper.getPlanSimple(planId);
-    }
-
-    /**
-     * 鏍规嵁璁″垝ID鏇存柊璁″垝淇℃伅锛堣捣姝㈡椂闂淬�佽鍒掔姸鎬侊級
-     * @param planStartTime
-     * @param planEndTime
-     * @param planId
-     * @return
-     */
-    public Integer updatePlanTimes(Date planStartTime, Date planEndTime, Long planId) {
-        return irrigatePlanMapper.updatePlanTimes(planStartTime, planEndTime, planId);
-    }
-
-    /**
      * 鏍规嵁鐏屾簤娆″簭ID鏇存柊娆″簭寮�濮嬫椂闂�
      * @param scheduleId
      * @param startTime
@@ -348,10 +461,11 @@
         if(planDetails == null){
             return null;
         }
-
         Integer failureCount = Optional.ofNullable(irIntakeOperateMapper.getFailureCount(planId)).orElse(0);
         planDetails.setFailureCount(failureCount);
 
+        Date terminateTime = Optional.ofNullable(irPlanOperateMapper.getTerminateTime(planId)).orElse(null);
+
         List<VoGroupResult> groupResults = irIrrigateGroupMapper.getGroupResult(planId);
         if(groupResults == null || groupResults.size() == 0){
             return null;
@@ -368,4 +482,37 @@
         return planDetails;
 
     }
+
+    /**
+     * 鏍规嵁璁″垝ID鑾峰彇璁″垝缁堟鎿嶄綔缁撴灉
+     * @param planId
+     * @return
+     */
+    public VoPlanDetails getTerminateResults(Long planId) {
+        // 鑾峰彇璁″垝缁堟鏃堕棿
+        Date terminateTime = Optional.ofNullable(irPlanOperateMapper.getTerminateTime(planId)).orElse(null);
+
+        VoPlanDetails planDetails = irrigatePlanMapper.getPlanDetails_terminate(planId, terminateTime);
+        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){
+            return null;
+        }
+
+        for (VoGroupResult groupResult : groupResults) {
+            List<VoIntakeResult> intakeResults = irIntakeOperateMapper.getIntakeResult(planId, groupResult.getGroupId());
+            if(intakeResults != null) {
+                groupResult.setPublishResult(intakeResults);
+            }
+        }
+
+        planDetails.setGroups(groupResults);
+        return planDetails;
+
+    }
 }

--
Gitblit v1.8.0