From 95d8d3df562c8f7fca74ba994cddbbf41564488e Mon Sep 17 00:00:00 2001
From: zhubaomin <zhubaomin>
Date: 星期二, 08 四月 2025 20:08:15 +0800
Subject: [PATCH] 优化未完成计划列表、已完成计划列表接口

---
 pipIrr-platform/pipIrr-web/pipIrr-web-wechat/src/main/java/com/dy/pipIrrWechat/irrigatePlan/IrrigatePlanCtrl.java |  129 ++++++++++++++++++++++++++++++++++++-------
 1 files changed, 108 insertions(+), 21 deletions(-)

diff --git a/pipIrr-platform/pipIrr-web/pipIrr-web-wechat/src/main/java/com/dy/pipIrrWechat/irrigatePlan/IrrigatePlanCtrl.java b/pipIrr-platform/pipIrr-web/pipIrr-web-wechat/src/main/java/com/dy/pipIrrWechat/irrigatePlan/IrrigatePlanCtrl.java
index 2d11845..2108113 100644
--- a/pipIrr-platform/pipIrr-web/pipIrr-web-wechat/src/main/java/com/dy/pipIrrWechat/irrigatePlan/IrrigatePlanCtrl.java
+++ b/pipIrr-platform/pipIrr-web/pipIrr-web-wechat/src/main/java/com/dy/pipIrrWechat/irrigatePlan/IrrigatePlanCtrl.java
@@ -6,11 +6,16 @@
 import com.dy.pipIrrGlobal.pojoIr.IrIrrigateSchedule;
 import com.dy.pipIrrGlobal.pojoIr.IrPlanOperate;
 import com.dy.pipIrrGlobal.pojoIr.IrPlanSchedule;
+import com.dy.pipIrrGlobal.pojoRm.RmCommandHistory;
 import com.dy.pipIrrGlobal.voIr.VoIrrigateSchedule;
 import com.dy.pipIrrGlobal.voIr.VoPlanSimple;
 import com.dy.pipIrrGlobal.voIr.VoPlans;
+import com.dy.pipIrrGlobal.voIr.VoToTerminateIntakes;
+import com.dy.pipIrrGlobal.voRm.VoIntakeVc;
 import com.dy.pipIrrWechat.command.CommandSv;
 import com.dy.pipIrrWechat.command.dto.AutomaticClose;
+import com.dy.pipIrrWechat.command.dto.ValveClose;
+import com.dy.pipIrrWechat.command.dto.ValveOpen;
 import com.dy.pipIrrWechat.irrigatePlan.dto.IrrigatePlan;
 import com.dy.pipIrrWechat.irrigatePlan.dto.IrrigateSchedule;
 import com.dy.pipIrrWechat.irrigatePlan.dto.PlanSimple;
@@ -23,8 +28,10 @@
 import org.springframework.validation.BindingResult;
 import org.springframework.web.bind.annotation.*;
 
+import java.time.LocalDate;
 import java.time.LocalDateTime;
 import java.time.ZoneId;
+import java.time.format.DateTimeFormatter;
 import java.util.Date;
 import java.util.List;
 import java.util.Objects;
@@ -112,7 +119,7 @@
 
         // 娣诲姞鐏屾簤娆″簭鍙婅鍒掓搴忓叧鑱旇〃
         //Date scheduleStartTime = null;
-        Integer sort = 0;
+        Integer sort = 1;
         for(IrrigateSchedule schedule : planAndSchedule.getSchedules()){
             IrIrrigateSchedule po = new IrIrrigateSchedule();
             po.setGroupId(schedule.getGroupId());
@@ -205,6 +212,7 @@
 
         Long planId = planSimple.getPlanId();
         Long operatorId = planSimple.getOperatorId();
+        Byte operateType = 1;
 
         /**
          * 鑾峰彇鐏屾簤璁″垝淇℃伅
@@ -225,7 +233,9 @@
         }
         LocalDateTime startTime = planStartTime.toInstant().atZone(ZoneId.systemDefault()) .toLocalDateTime();
         if(startupMode == 1){
-            startTime = startTime.plusMinutes(5);
+            // 娴嬭瘯闃舵寤跺悗2鍒嗛挓锛屾寮忓彂甯冧负5鍒嗛挓
+            startTime = startTime.plusMinutes(2);
+            //startTime = startTime.plusMinutes(5);
         }
         planStartTime = Date.from(startTime.atZone(ZoneId.systemDefault()).toInstant());
         LocalDateTime stopTime = startTime.plusMinutes(duration);
@@ -266,14 +276,17 @@
             Long groupId = schedule.getGroupId();
             List<Long> intakeIds = irrigatePlanSv.getIntakeIdsByGroupId(groupId);
             for(Long intakeId : intakeIds) {
-                AutomaticClose automaticClose = new AutomaticClose();
-                automaticClose.setIntakeId(intakeId);
-                automaticClose.setPlannedOpenTime(schedule.getStartTime());
-                automaticClose.setMinutes(schedule.getDuration());
-                automaticClose.setOperator(operatorId);
-                automaticClose.setOpenType(Byte.valueOf("1"));
+                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, schedule.getStartTime(), schedule.getDuration());
+                    commandSv.planedOpenTimedClose(automaticClose, planId, operateType, schedule.getStartTime(), schedule.getDuration());
+                }
             }
         }
 
@@ -281,18 +294,92 @@
     }
 
     /**
-     * 鑾峰彇鐏屾簤璁″垝鍒楄〃
-     * @param vo
+     * 缁堟鐏屾簤璁″垝
+     * @param planSimple
+     * @param bindingResult
      * @return
      */
-    //@GetMapping(path = "/getIrrigatePlans")
-    //public BaseResponse<QueryResultVo<List<VoIrrigatePlan>>> getIrrigatePlans(QoIrrigatePlan vo) {
-    //    try {
-    //        QueryResultVo<List<VoIrrigatePlan>> res = irrigatePlanSv.getIrrigatePlans(vo);
-    //        return BaseResponseUtils.buildSuccess(res);
-    //    } catch (Exception e) {
-    //        log.error("鑾峰彇杞亴缁勮褰曞紓甯�", e);
-    //        return BaseResponseUtils.buildException(e.getMessage());
-    //    }
-    //}
+    @PostMapping(path = "terminatePlan", consumes = MediaType.APPLICATION_JSON_VALUE)
+    @Transactional(rollbackFor = Exception.class)
+    public BaseResponse<Boolean> terminatePlan(@RequestBody @Valid PlanSimple planSimple, BindingResult bindingResult){
+        if(bindingResult != null && bindingResult.hasErrors()){
+            return BaseResponseUtils.buildErrorMsg(Objects.requireNonNull(bindingResult.getFieldError()).getDefaultMessage());
+        }
+
+        Long planId = planSimple.getPlanId();
+        Long operatorId = planSimple.getOperatorId();
+
+        // 鐢熸垚缁堟寮�濮嬫椂闂淬�佺粓姝㈢亴婧夋椂闀�
+        DateTimeFormatter formatter = DateTimeFormatter.ofPattern("yyyy-MM-dd HH:mm:ss");
+        String terminateStartTimeStr = LocalDate.now().getYear() + "-01-01 00:00:00";
+        Date terminateStartTime = Date.from(LocalDateTime.parse(terminateStartTimeStr, formatter).atZone(ZoneId.systemDefault()).toInstant());
+        Integer terminateDuration = 9999;
+
+        // 鍒ゆ柇璇ヨ鍒掓槸鍚﹀彲鎵ц缁堟鎿嶄綔锛氭湭鍒犻櫎銆佹湭缁堟銆佸凡鍙戝竷銆佸綋鍓嶆椂闂村皬浜庤鍒掔粨鏉熸椂闂�
+        Date planStartTime = irrigatePlanSv.getToTerminatePlan(planId);
+        if(planStartTime == null){
+            return BaseResponseUtils.buildErrorMsg("璇ヨ鍒掍笉瀛樺湪鎴栦笉鏀寔缁堟鎿嶄綔");
+        }
+
+        List<VoToTerminateIntakes> toTerminateIntakes = irrigatePlanSv.getToTerminateIntakes(planId);
+        if(toTerminateIntakes == null || toTerminateIntakes.size() == 0){
+            return BaseResponseUtils.buildErrorMsg("璇ヨ鍒掍笉瀛樺湪鎴栧凡缁堟");
+        }
+
+        for(VoToTerminateIntakes toTerminateIntake : toTerminateIntakes){
+            Long intakeId = toTerminateIntake.getIntakeId();
+            Long commandId = toTerminateIntake.getCommandId();
+            Date startTime = toTerminateIntake.getStartTime();
+            Date currentTime = new Date();
+            if(currentTime.before(startTime)){
+                // 鍙栨秷锛堣鐩栧紑闃�璁″垝锛�
+                AutomaticClose automaticClose = new AutomaticClose();
+                automaticClose.setIntakeId(intakeId);
+                automaticClose.setPlannedOpenTime(terminateStartTime);
+                automaticClose.setMinutes(terminateDuration);
+                automaticClose.setOperator(operatorId);
+                automaticClose.setOpenType(Byte.valueOf("1"));
+
+                commandSv.planedOpenTimedClose(automaticClose, planId, (byte)2, terminateStartTime, terminateDuration);
+            }else {
+                // 缁堟锛堣繙绋嬪叧闃�锛�
+                VoIntakeVc intakeVc = irrigatePlanSv.getValveOpen(commandId);
+                String rtuAddr = intakeVc.getRtuAddr();
+                String vcNum = intakeVc.getVcNum();
+                String orderNo = intakeVc.getOrderNo();
+
+                ValveClose valveClose = new ValveClose();
+                valveClose.setRtuAddr(rtuAddr);
+                valveClose.setVcNum(vcNum);
+                valveClose.setOrderNo(orderNo);
+                valveClose.setOperator(operatorId);
+                valveClose.setOpenType(Byte.valueOf("1"));
+                commandSv.closeWx(valveClose, planId, (byte)3);
+            }
+        }
+
+        // 缁堟璁″垝
+        IrIrrigatePlan iIrrigatePlan = new IrIrrigatePlan();
+        iIrrigatePlan.setId(planId);
+        iIrrigatePlan.setExecutingState((byte)3);
+        if(irrigatePlanSv.updatePlan(iIrrigatePlan) == 0){
+            return BaseResponseUtils.buildErrorMsg("缁堟璁″垝澶辫触");
+        }
+
+        // 缁堟鐏屾簤娆″簭
+        if(irrigatePlanSv.terminateSchedule(planId) == 0){
+            return BaseResponseUtils.buildErrorMsg("缁堟鐏屾簤娆″簭澶辫触");
+        }
+
+        // 娣诲姞缁堟鎿嶄綔璁板綍
+        IrPlanOperate planOperate  = new IrPlanOperate();
+        planOperate.setPlanId(planId);
+        planOperate.setOperator(operatorId);
+        planOperate.setOperateType(OperateTypeENUM.TERMINATE.getCode());
+        planOperate.setOperateTime(new Date());
+        if(irrigatePlanSv.addPlanOperate(planOperate) == 0){
+            return BaseResponseUtils.buildErrorMsg("娣诲姞缁堟鎿嶄綔璁板綍澶辫触");
+        }
+        return BaseResponseUtils.buildSuccess();
+    }
 }

--
Gitblit v1.8.0