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