From 7aab004601e77890b158f19d1735594a8326feaa Mon Sep 17 00:00:00 2001
From: liurunyu <lry9898@163.com>
Date: 星期四, 24 四月 2025 17:11:17 +0800
Subject: [PATCH] 数据库事务注解位置调整

---
 pipIrr-platform/pipIrr-web/pipIrr-web-wechat/src/main/java/com/dy/pipIrrWechat/irrigatePlan/IrrigatePlanCtrl.java |  413 +++++++++++++++++++++++++++++++++++++++++++++++++---------
 1 files changed, 345 insertions(+), 68 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 1e9be73..a30cb61 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
@@ -2,18 +2,23 @@
 
 import com.dy.common.webUtil.BaseResponse;
 import com.dy.common.webUtil.BaseResponseUtils;
+import com.dy.common.webUtil.QueryConditionVo;
 import com.dy.common.webUtil.QueryResultVo;
 import com.dy.pipIrrGlobal.pojoIr.IrIrrigatePlan;
 import com.dy.pipIrrGlobal.pojoIr.IrIrrigateSchedule;
-import com.dy.pipIrrGlobal.pojoIr.IrOpeningSchedule;
 import com.dy.pipIrrGlobal.pojoIr.IrPlanOperate;
-import com.dy.pipIrrGlobal.voIr.VoIrrigatePlan;
-import com.dy.pipIrrGlobal.voIr.VoIrrigateSchedule;
+import com.dy.pipIrrGlobal.pojoIr.IrPlanSchedule;
+import com.dy.pipIrrGlobal.pojoRm.RmCommandHistory;
+import com.dy.pipIrrGlobal.voIr.*;
+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;
 import com.dy.pipIrrWechat.irrigatePlan.enums.OperateTypeENUM;
-import com.dy.pipIrrWechat.irrigatePlan.qo.QoIrrigatePlan;
 import jakarta.validation.Valid;
 import lombok.RequiredArgsConstructor;
 import lombok.extern.slf4j.Slf4j;
@@ -22,8 +27,13 @@
 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.Map;
 import java.util.Objects;
 
 /**
@@ -39,6 +49,7 @@
 @RequiredArgsConstructor
 public class IrrigatePlanCtrl {
     private final IrrigatePlanSv irrigatePlanSv;
+    private final CommandSv commandSv;
 
     /**
      * 鍒涘缓鐏屾簤璁″垝
@@ -50,21 +61,53 @@
      * @return
      */
     @PostMapping(path = "createPlan", consumes = MediaType.APPLICATION_JSON_VALUE)
-    @Transactional(rollbackFor = Exception.class)
+    //@Transactional(rollbackFor = Exception.class)
     public BaseResponse<Boolean> createPlan(@RequestBody @Valid IrrigatePlan planAndSchedule, BindingResult bindingResult){
         if(bindingResult != null && bindingResult.hasErrors()){
             return BaseResponseUtils.buildErrorMsg(Objects.requireNonNull(bindingResult.getFieldError()).getDefaultMessage());
         }
 
+        Long projectId = planAndSchedule.getProjectId();
         Long operatorId = planAndSchedule.getOperatorId();
+        Byte startupMode = planAndSchedule.getStartupMode();
+        Date planStartTime = planAndSchedule.getPlanStartTime();;
+        Date planStopTime = null;
 
-        // 娣诲姞鐏屾簤璁″垝
+        Integer duration = 0;
+        for(IrrigateSchedule schedule : planAndSchedule.getSchedules()){
+            duration = duration + schedule.getDuration();
+        }
+
+        if(startupMode == 2){
+            if(planStartTime == null) {
+                return BaseResponseUtils.buildErrorMsg("鑷姩鍚姩妯″紡蹇呴』鎸囧畾璁″垝鍚姩鏃堕棿");
+            }
+
+            LocalDateTime startTime = planStartTime.toInstant().atZone(ZoneId.systemDefault()) .toLocalDateTime();
+            LocalDateTime currentTime = LocalDateTime.now();
+            currentTime = currentTime.plusHours(8);
+
+            if(!startTime.isAfter(currentTime)) {
+                return BaseResponseUtils.buildErrorMsg("鍚姩鏃堕棿涓嶈兘鍦�8灏忔椂涔嬪唴");
+            }
+        }
+
+        //if(startupMode == 1){
+        //    planStartTime = new Date();
+        //}
+        //LocalDateTime startTime = planStartTime.toInstant().atZone(ZoneId.systemDefault()) .toLocalDateTime();
+        //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());
+
         IrIrrigatePlan plan = new IrIrrigatePlan();
-        plan.setProjectId(planAndSchedule.getProjectId());
+        plan.setProjectId(projectId);
         plan.setPlanName(planAndSchedule.getPlanName());
-        plan.setStartupMode(planAndSchedule.getStartupMode());
-        plan.setPlanStartTime(planAndSchedule.getPlanStartTime());
-        plan.setPlanStopTime(planAndSchedule.getPlanStopTime());
+        plan.setStartupMode(startupMode);
+        plan.setPlanStartTime(planStartTime);
+        //plan.setPlanStopTime(planStopTime);
+        plan.setDuration(duration);
         plan.setPlanState((byte)1);
         plan.setExecutingState((byte)1);
         plan.setDeleted(0L);
@@ -74,35 +117,38 @@
             return BaseResponseUtils.buildErrorMsg("鍒涘缓鐏屾簤璁″垝澶辫触");
         }
 
-        // 娣诲姞鐏屾簤娆″簭
-        if(planId != null){
-            for(IrrigateSchedule schedule : planAndSchedule.getSchedules()){
-                IrIrrigateSchedule po = new IrIrrigateSchedule();
-                po.setPlanId(planId);
+        // 娣诲姞鐏屾簤娆″簭鍙婅鍒掓搴忓叧鑱旇〃
+        //Date scheduleStartTime = null;
+        Integer sort = 1;
+        for(IrrigateSchedule schedule : planAndSchedule.getSchedules()){
+            IrIrrigateSchedule po = new IrIrrigateSchedule();
+            po.setGroupId(schedule.getGroupId());
 
-                if(planAndSchedule.getIrrigateType() == 1) {
-                    po.setGroupId(schedule.getIrrigateId());
-                    List<Long> intakesData = irrigatePlanSv.getIntakesByGroupId(schedule.getIrrigateId());
-                    if(intakesData != null && intakesData.size() > 0){
-                        String intakeIds = "";
-                        for(Long intakeId : intakesData){
-                            intakeIds += intakeId + ",";
-                        }
-                        po.setIntakeIds(intakeIds.substring(0, intakeIds.length() - 1));
-                    }
-                }else {
-                    po.setUnitId(schedule.getIrrigateId());
-                    Long intakeId = irrigatePlanSv.getIntakeIdByUnitId(schedule.getIrrigateId());
-                    if(intakeId != null){
-                        po.setIntakeIds(intakeId.toString());
-                    }
-                }
+            //if(scheduleStartTime == null) {
+            //    scheduleStartTime = planStartTime;
+            //}
+            //po.setStartTime(scheduleStartTime);
+            //// 璁$畻涓嬩竴缁勭殑寮�濮嬫椂闂�
+            //LocalDateTime LocalscheduleStartTime = scheduleStartTime.toInstant().atZone(ZoneId.systemDefault()) .toLocalDateTime();
+            //LocalscheduleStartTime = LocalscheduleStartTime.plusMinutes(schedule.getDuration());
+            //scheduleStartTime = Date.from(LocalscheduleStartTime.atZone(ZoneId.systemDefault()).toInstant());
 
-                po.setStartTime(schedule.getStartTime());
-                po.setStopTime(schedule.getStopTime());
-                po.setCurrentState((byte)1);
-                Long scheduleId = irrigatePlanSv.addIrrigateSchedule(po);
+            po.setDuration(schedule.getDuration());
+            po.setCurrentState((byte)1);
+            Long scheduleId = irrigatePlanSv.addIrrigateSchedule(po);
+            if(scheduleId == null) {
+                return BaseResponseUtils.buildErrorMsg("鍒涘缓鐏屾簤璁″垝澶辫触");
             }
+
+            IrPlanSchedule planSchedule = new IrPlanSchedule();
+            planSchedule.setPlanId(planId);
+            planSchedule.setScheduleId(scheduleId);
+            planSchedule.setSort(sort++);
+            Long planScheduleId = irrigatePlanSv.addPlanSchedule(planSchedule);
+            if(planScheduleId == null) {
+                return BaseResponseUtils.buildErrorMsg("鍒涘缓鐏屾簤璁″垝澶辫触");
+            }
+
         }
 
         // 娣诲姞鐏屾簤璁″垝鎿嶄綔璁板綍
@@ -119,6 +165,25 @@
     }
 
     /**
+     * 鍒犻櫎鐏屾簤璁″垝
+     * @param planSimple
+     * @param bindingResult
+     * @return
+     */
+    @PostMapping(path = "deletePlan")
+    public BaseResponse<Boolean> deletePlan(@RequestBody @Valid PlanSimple planSimple, BindingResult bindingResult) {
+        if(bindingResult != null && bindingResult.hasErrors()){
+            return BaseResponseUtils.buildErrorMsg(Objects.requireNonNull(bindingResult.getFieldError()).getDefaultMessage());
+        }
+
+        Map map_result = irrigatePlanSv.deletePlan(planSimple);
+        if(map_result.get("success").equals(false)) {
+            return BaseResponseUtils.buildErrorMsg(map_result.get("msg").toString());
+        }
+        return BaseResponseUtils.buildSuccess() ;
+    }
+
+    /**
      * 鍙戝竷鐏屾簤璁″垝
      * 1. 淇敼鐏屾簤璁″垝鐘舵�佷负鍙戝竷鐘舵��
      * 2. 娣诲姞鐏屾簤璁″垝鎿嶄綔璁板綍
@@ -128,62 +193,274 @@
      * @return
      */
     @PostMapping(path = "publishPlan", consumes = MediaType.APPLICATION_JSON_VALUE)
-    @Transactional(rollbackFor = Exception.class)
+    //@Transactional(rollbackFor = Exception.class)
     public BaseResponse<Boolean> publishPlan(@RequestBody @Valid PlanSimple planSimple, BindingResult bindingResult){
         if(bindingResult != null && bindingResult.hasErrors()){
             return BaseResponseUtils.buildErrorMsg(Objects.requireNonNull(bindingResult.getFieldError()).getDefaultMessage());
         }
+
+        Map map_result = irrigatePlanSv.publishPlan(planSimple);
+        if(map_result.get("success").equals(false)) {
+            return BaseResponseUtils.buildErrorMsg(map_result.get("msg").toString());
+        }
+        return BaseResponseUtils.buildSuccess() ;
+
+        //Long planId = planSimple.getPlanId();
+        //Long operatorId = planSimple.getOperatorId();
+        //Byte operateType = 1;
+        //
+        ///**
+        // * 鑾峰彇鐏屾簤璁″垝淇℃伅
+        // * 鏇存柊鐏屾簤璁″垝璧锋鏃堕棿鍙婅鍒掔姸鎬�
+        // */
+        //VoPlanSimple plan = irrigatePlanSv.getPlanSimple(planId);
+        //if(plan == null){
+        //    return BaseResponseUtils.buildErrorMsg("鎮ㄨ鍙戝竷鐨勮鍒掍笉瀛樺湪锛屾垨璇ヨ鍒掑凡鍙戝竷");
+        //}
+        //
+        //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());
+        //
+        //
+        //if(irrigatePlanSv.updatePlanTimes(planStartTime, planStopTime, planId) == 0) {
+        //    return BaseResponseUtils.buildErrorMsg("璁″垝淇℃伅鏇存柊澶辫触");
+        //}
+        //
+        //// 鏇存柊姣忎釜鐏屾簤娆″簭鐨勫紑濮嬫椂闂�
+        //List<VoIrrigateSchedule> schedules = irrigatePlanSv.getSchedulesByPlanId(planId);
+        //Date scheduleStartTime = null;
+        //Integer sort = 0;
+        //for(VoIrrigateSchedule schedule : schedules){
+        //    if(scheduleStartTime == null) {
+        //        scheduleStartTime = planStartTime;
+        //    }
+        //    irrigatePlanSv.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(irrigatePlanSv.addPlanOperate(planOperate) == 0){
+        //    return BaseResponseUtils.buildErrorMsg("娣诲姞鐏屾簤璁″垝鎿嶄綔璁板綍澶辫触");
+        //}
+        //
+        //schedules = irrigatePlanSv.getSchedulesByPlanId(planId);
+        //for(VoIrrigateSchedule schedule : schedules) {
+        //    Long groupId = schedule.getGroupId();
+        //    List<Long> intakeIds = irrigatePlanSv.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());
+        //        }
+        //    }
+        //}
+        //
+        //return BaseResponseUtils.buildSuccess();
+    }
+
+    /**
+     * 鏍规嵁璁″垝ID鑾峰彇璁″垝鏈�鏂扮姸鎬�
+     * @param planId
+     * @return
+     */
+    @GetMapping(path = "/getPlanLatestState")
+    public BaseResponse<Integer> getPlanLatestState(@RequestParam Long planId) {
+        if(planId == null) {
+            return BaseResponseUtils.buildErrorMsg("璁″垝ID涓嶈兘涓虹┖");
+        }
+
+        try {
+            return BaseResponseUtils.buildSuccess(irrigatePlanSv.getPlanLatestState(planId));
+        } catch (Exception e) {
+            log.error("鑾峰彇鏈畬鐨勮鍒掑紓甯�", e);
+            return BaseResponseUtils.buildException(e.getMessage());
+        }
+    }
+
+    /**
+     * 缁堟鐏屾簤璁″垝
+     * @param planSimple
+     * @param bindingResult
+     * @return
+     */
+    @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();
 
-        // 淇敼鐏屾簤璁″垝鐘舵�佷负鍙戝竷鐘舵��
-        if(irrigatePlanSv.publishIrrigatePlan(planId) == 0){
-            return BaseResponseUtils.buildErrorMsg("淇敼鐏屾簤璁″垝鐘舵�佸け璐�");
+        // 鐢熸垚缁堟寮�濮嬫椂闂淬�佺粓姝㈢亴婧夋椂闀�
+        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){
+            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.PUBLISH.getCode());
+        planOperate.setOperateType(OperateTypeENUM.TERMINATE.getCode());
         planOperate.setOperateTime(new Date());
         if(irrigatePlanSv.addPlanOperate(planOperate) == 0){
-            return BaseResponseUtils.buildErrorMsg("娣诲姞鐏屾簤璁″垝鎿嶄綔璁板綍澶辫触");
-        }
-
-        // 鐢熸垚寮�闃�璁″垝
-        List<VoIrrigateSchedule> schedules = irrigatePlanSv.getIrrigateSchedules(planId);
-        if(schedules == null || schedules.size() == 0) {
-            return BaseResponseUtils.buildErrorMsg("鏃犲彇姘村彛锛岀敓鎴愬紑闃�璁″垝澶辫触");
-        }
-        for (VoIrrigateSchedule schedule : schedules) {
-            for(String intakeId : schedule.getIntakeIds().split(",")){
-                // 娣诲姞鐏屾簤璁″垝寮�鍚褰�
-                IrOpeningSchedule openingSchedule = new IrOpeningSchedule();
-                openingSchedule.setScheduleId(schedule.getScheduleId());
-                openingSchedule.setIntakeId(Long.parseLong(intakeId));
-                openingSchedule.setStartTime(schedule.getStartTime());
-                openingSchedule.setDuration(schedule.getDuration());
-                if(irrigatePlanSv.addOpeningSchedule(openingSchedule) == 0){
-                    return BaseResponseUtils.buildErrorMsg("娣诲姞寮�闃�璁″垝澶辫触");
-                }
-            }
+            return BaseResponseUtils.buildErrorMsg("娣诲姞缁堟鎿嶄綔璁板綍澶辫触");
         }
         return BaseResponseUtils.buildSuccess();
     }
 
     /**
-     * 鑾峰彇鐏屾簤璁″垝鍒楄〃
-     * @param vo
+     * 鑾峰彇鏈畬鎴愮殑璁″垝鍒楄〃锛屽皬绋嬪簭璁″垝鍒楄〃椤典娇鐢�
      * @return
      */
-    @GetMapping(path = "/getIrrigatePlans")
-    public BaseResponse<QueryResultVo<List<VoIrrigatePlan>>> getIrrigatePlans(QoIrrigatePlan vo) {
+    @GetMapping(path = "/getNotCompletePlans")
+    public BaseResponse<List<VoPlans>> getNotCompletePlans() {
         try {
-            QueryResultVo<List<VoIrrigatePlan>> res = irrigatePlanSv.getIrrigatePlans(vo);
+            List<VoPlans> res = irrigatePlanSv.getNotCompletePlans();
             return BaseResponseUtils.buildSuccess(res);
         } catch (Exception e) {
-            log.error("鑾峰彇杞亴缁勮褰曞紓甯�", e);
+            log.error("鑾峰彇鏈畬鐨勮鍒掑紓甯�", e);
+            return BaseResponseUtils.buildException(e.getMessage());
+        }
+    }
+
+    /**
+     * 鑾峰彇宸插畬鎴愮殑璁″垝鍒楄〃锛屽皬绋嬪簭璁″垝鍒楄〃椤典娇鐢�
+     * @return
+     */
+    @GetMapping(path = "/getCompletedPlans")
+    public BaseResponse<QueryResultVo<List<VoPlans>>> getCompletedPlans(QueryConditionVo qo) {
+        try {
+            return BaseResponseUtils.buildSuccess(irrigatePlanSv.getCompletedPlans(qo));
+        } catch (Exception e) {
+            log.error("鑾峰彇椤圭洰璁板綍寮傚父", e);
+            return BaseResponseUtils.buildException(e.getMessage());
+        }
+    }
+
+    /**
+     * 鏍规嵁璁″垝ID鑾峰彇璁″垝鍙戝竷缁撴灉
+     * @param planId
+     * @return
+     */
+    @GetMapping(path = "/getPublishResults")
+    public BaseResponse<VoPlanDetails> getPublishResults(@RequestParam Long planId) {
+        if(planId == null) {
+            return BaseResponseUtils.buildErrorMsg("璁″垝ID涓嶈兘涓虹┖");
+        }
+
+        try {
+            VoPlanDetails res = irrigatePlanSv.getPublishResults(planId);
+            return BaseResponseUtils.buildSuccess(res);
+        } catch (Exception e) {
+            log.error("鑾峰彇璁″垝鍙戝竷缁撴灉寮傚父", e);
+            return BaseResponseUtils.buildException(e.getMessage());
+        }
+    }
+
+    /**
+     * 鏍规嵁璁″垝ID鑾峰彇璁″垝缁堟鎿嶄綔缁撴灉
+     * @param planId
+     * @return
+     */
+    @GetMapping(path = "/getTerminateResults")
+    public BaseResponse<VoPlanDetails> getTerminateResults(@RequestParam Long planId) {
+        if(planId == null) {
+            return BaseResponseUtils.buildErrorMsg("璁″垝ID涓嶈兘涓虹┖");
+        }
+
+        try {
+            VoPlanDetails res = irrigatePlanSv.getTerminateResults(planId);
+            return BaseResponseUtils.buildSuccess(res);
+        } catch (Exception e) {
+            log.error("鑾峰彇璁″垝鍙戝竷缁撴灉寮傚父", e);
             return BaseResponseUtils.buildException(e.getMessage());
         }
     }

--
Gitblit v1.8.0