From 5f54ba90abcc0ccf1b578472eac54fc98056767c Mon Sep 17 00:00:00 2001
From: zhubaomin <zhubaomin>
Date: 星期二, 08 四月 2025 17:15:13 +0800
Subject: [PATCH] 灌溉计划终止接口,包括远程关阀和取消灌溉计划

---
 pipIrr-platform/pipIrr-web/pipIrr-web-wechat/src/main/java/com/dy/pipIrrWechat/irrigatePlan/IrrigatePlanCtrl.java |   81 +++++++++++++++++++++-------------------
 1 files changed, 42 insertions(+), 39 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 4f02d79..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
@@ -10,9 +10,11 @@
 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;
@@ -26,6 +28,7 @@
 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;
@@ -305,18 +308,54 @@
 
         Long planId = planSimple.getPlanId();
         Long operatorId = planSimple.getOperatorId();
-        Byte operateType = 2;
 
         // 鐢熸垚缁堟寮�濮嬫椂闂淬�佺粓姝㈢亴婧夋椂闀�
         DateTimeFormatter formatter = DateTimeFormatter.ofPattern("yyyy-MM-dd HH:mm:ss");
-        String terminateStartTimeStr = "2000-01-01 00:00:00";
+        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);
+            }
         }
 
         // 缁堟璁″垝
@@ -341,42 +380,6 @@
         if(irrigatePlanSv.addPlanOperate(planOperate) == 0){
             return BaseResponseUtils.buildErrorMsg("娣诲姞缁堟鎿嶄綔璁板綍澶辫触");
         }
-
-        Date currentTime = new Date();
-        if(currentTime.before(planStartTime)){
-            // 鍙栨秷寮�闃�璁″垝
-            List<Long> intakeIds = irrigatePlanSv.getToTerminateIntakeIds(planId);
-            for(Long intakeId : intakeIds) {
-                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, operateType, terminateStartTime, terminateDuration);
-            }
-        } else {
-            // 鎵ц杩滅▼鍏抽榾
-            List<Long> commandIds = irrigatePlanSv.getTerminateCommandIds(planId);
-            for(Long commandId : commandIds) {
-                VoIntakeVc intakeVc = irrigatePlanSv.getIntakeVc(commandId);
-                Long intakeId = intakeVc.getIntakeId();
-                Long vdId = intakeVc.getVcId();
-
-                ValveOpen valve = new ValveOpen();
-                valve.setIntakeId(intakeId);
-                valve.setVcId(vdId);
-                valve.setForceOpen(true);
-                valve.setOperator(operatorId);
-                valve.setOpenType(Byte.valueOf("1"));
-
-                commandSv.openWx(valve, planId, operateType);
-            }
-
-        }
-
         return BaseResponseUtils.buildSuccess();
-
     }
 }

--
Gitblit v1.8.0