From cda9d3a12240ad659efc11603862487d946715b2 Mon Sep 17 00:00:00 2001
From: zhanzhiqin <895896009@qq.com>
Date: 星期三, 27 四月 2022 18:14:08 +0800
Subject: [PATCH] fix

---
 ximon-admin/src/main/java/com/sandu/ximon/admin/service/LightTaskService.java |   39 +++++++++++++++++++++++++++++++--------
 1 files changed, 31 insertions(+), 8 deletions(-)

diff --git a/ximon-admin/src/main/java/com/sandu/ximon/admin/service/LightTaskService.java b/ximon-admin/src/main/java/com/sandu/ximon/admin/service/LightTaskService.java
index 6e36081..7dd71e2 100644
--- a/ximon-admin/src/main/java/com/sandu/ximon/admin/service/LightTaskService.java
+++ b/ximon-admin/src/main/java/com/sandu/ximon/admin/service/LightTaskService.java
@@ -57,6 +57,7 @@
 
     private final PoleService poleService;
     private final LightTaskPoleRelationService lightTaskPoleRelationService;
+    private final LightTaskMapper lightTaskMapper;
 
     /**
      * 鏂板璺伅浠诲姟
@@ -74,6 +75,7 @@
         lightTask.setClientId(SecurityUtils.getClientId());
         lightTask.setTaskName(param.getTaskName());
         lightTask.setWeek(week);
+        lightTask.setLightAdress(param.getLightAddress());
         lightTask.setCloseOrder(param.getCloseOrder());
         lightTask.setOpenOrder(param.getOpenOrder());
         lightTask.setControlOrder(param.getControlOrder());
@@ -86,7 +88,7 @@
         List<Long> poleIdList = param.getPoleIdList();
         if (CollectionUtil.isNotEmpty(poleIdList)) {
 
-            List<LightTaskPoleRelation> lightTaskPoleRelationList = sendControllerFrame(lightTask, poleIdList, lightTask.getFramePayload());
+            List<LightTaskPoleRelation> lightTaskPoleRelationList = sendControllerFrame(lightTask, poleIdList, lightTask.getFramePayload(), param.getLightAddress());
 
             // 娣诲姞缁戝畾鐏潌
             if (!lightTaskPoleRelationService.saveBatch(lightTaskPoleRelationList)) {
@@ -117,6 +119,7 @@
         lightTask.setControlOrder(param.getControlOrder());
         lightTask.setOpenOrder(param.getOpenOrder());
         lightTask.setCloseOrder(param.getCloseOrder());
+        lightTask.setLightAdress(param.getLightAddress());
         lightTask.setUpdateTime(LocalDateTime.now());
         lightTask.setFramePayload(buildControlFramePayload(param.getOpenOrder(), param.getCloseOrder(), param.getControlOrder(), week));
 
@@ -127,7 +130,7 @@
         List<Long> poleIdList = param.getPoleIdList();
         if (CollectionUtil.isNotEmpty(poleIdList)) {
 
-            List<LightTaskPoleRelation> lightTaskPoleRelationList = sendControllerFrame(lightTask, poleIdList, lightTask.getFramePayload());
+            List<LightTaskPoleRelation> lightTaskPoleRelationList = sendControllerFrame(lightTask, poleIdList, lightTask.getFramePayload(), param.getLightAddress());
 
             lightTaskPoleRelationService.remove(Wrappers.lambdaQuery(LightTaskPoleRelation.class).eq(LightTaskPoleRelation::getTaskId, lightTask.getTaskId()));
             // 娣诲姞缁戝畾鐏潌
@@ -149,8 +152,8 @@
      * @param deviceCode   璁惧鍚�
      * @return 杩斿洖甯�
      */
-    public A5LightTimerRespInnerFrame sendTimeRRpc(String framePayload, String deviceCode) {
-        IRequestFrame requestFrame = FrameBuilder.builderA5().innerFrame(new A5LightTimerReqInnerFrame(framePayload))
+    public A5LightTimerRespInnerFrame sendTimeRRpc(String framePayload, String deviceCode, String lightAddress) {
+        IRequestFrame requestFrame = FrameBuilder.builderA5().innerFrame(new A5LightTimerReqInnerFrame(framePayload, lightAddress))
                 .orderType(A5OrderEnum.REQUEST_LIGHT_DATA.getCode()).build();
         WrapResponseCommonFrame<A5LightTimerRespInnerFrame> responseCommonFrame = MainBoardInvokeSyncService.getInstance()
                 .sendRRPC(deviceCode, requestFrame, A5LightTimerRespInnerFrame.class);
@@ -169,7 +172,7 @@
             });
         }
 
-        if(conditionVO!=null){
+        if (conditionVO != null) {
             PageHelper.startPage(conditionVO.getPageNo(), conditionVO.getPageSize());
         }
         List<LightTask> list = list(wrapper);
@@ -185,8 +188,28 @@
         return page;
     }
 
+    /**
+     * 鎵ц涓殑璺伅浠诲姟
+     *
+     * @return
+     */
+    public List<LightTaskDto> listTask() {
+        Long clientId = SecurityUtils.getClientId();
+        List<LightTask> lightTasks = lightTaskMapper.listLightTask(clientId);
+        Page<LightTaskDto> page = new Page<>();
+        BeanUtils.copyProperties(lightTasks, page);
+        for (LightTask lightTask : lightTasks) {
+            LightTaskDto lightTaskDto = new LightTaskDto();
+            BeanUtils.copyProperties(lightTask, lightTaskDto);
+            lightTaskDto.setWeekList(TaskOrderUtil.parseLightWeek2List(lightTask.getWeek()));
+            page.add(lightTaskDto);
+        }
+        return page;
+    }
+
+
     // 姣忎釜璺伅鍙戦�佹帶鍒跺抚 杩斿洖鍏宠仈鍒楄〃
-    private List<LightTaskPoleRelation> sendControllerFrame(LightTask lightTask, List<Long> poleIdList, String framePayload) {
+    private List<LightTaskPoleRelation> sendControllerFrame(LightTask lightTask, List<Long> poleIdList, String framePayload, String lightAddress) {
         List<LightTaskPoleRelation> lightTaskPoleRelationList = new ArrayList<>();
 
         List<Pole> poles = poleService.listByIds(poleIdList);
@@ -200,7 +223,7 @@
             lightTaskPoleRelation.setTaskId(lightTask.getTaskId());
             // rrpc 鍙戠敓瀹氭椂鍛戒护
             try {
-                A5LightTimerRespInnerFrame a5LightTimerRespInnerFrame = sendTimeRRpc(framePayload, pole.getDeviceCode());
+                A5LightTimerRespInnerFrame a5LightTimerRespInnerFrame = sendTimeRRpc(framePayload, pole.getDeviceCode(), lightAddress);
                 if (a5LightTimerRespInnerFrame == null) {
                     lightTaskPoleRelation.setIssueStatus(DeviceRespStatusEnums.OTHER_ERROR.getCode());
                 } else {
@@ -311,7 +334,7 @@
             throw new BusinessException("鎵句笉鍒颁换鍔�");
         }
         String framePayload = buildControlFramePayload(lightTask.getOpenOrder(), lightTask.getCloseOrder(), lightTask.getControlOrder(), lightTask.getWeek());
-        List<LightTaskPoleRelation> lightTaskPoleRelationList = sendControllerFrame(lightTask, ListUtil.toList(param.getPoleId()), framePayload);
+        List<LightTaskPoleRelation> lightTaskPoleRelationList = sendControllerFrame(lightTask, ListUtil.toList(param.getPoleId()), framePayload, lightTask.getLightAdress());
         if (CollectionUtil.isNotEmpty(lightTaskPoleRelationList)) {
             return lightTaskPoleRelationService.update(lightTaskPoleRelationList.get(0),
                     Wrappers.lambdaUpdate(LightTaskPoleRelation.class).eq(LightTaskPoleRelation::getPoleId, param.getPoleId())

--
Gitblit v1.9.3