From e55c8b0a92eb9715edd90c31dfd4de51a47b588b Mon Sep 17 00:00:00 2001
From: liuhaonan <31457034@qq.com>
Date: 星期五, 04 十一月 2022 17:40:08 +0800
Subject: [PATCH] changes

---
 ximon-admin/src/main/java/com/sandu/ximon/admin/controller/PlayPlanNvController.java |  100 ++++++++++++++++++++++++++++++++++++++++++++-----
 1 files changed, 89 insertions(+), 11 deletions(-)

diff --git a/ximon-admin/src/main/java/com/sandu/ximon/admin/controller/PlayPlanNvController.java b/ximon-admin/src/main/java/com/sandu/ximon/admin/controller/PlayPlanNvController.java
index 14351f3..16a2b10 100644
--- a/ximon-admin/src/main/java/com/sandu/ximon/admin/controller/PlayPlanNvController.java
+++ b/ximon-admin/src/main/java/com/sandu/ximon/admin/controller/PlayPlanNvController.java
@@ -1,6 +1,5 @@
 package com.sandu.ximon.admin.controller;
 
-import cn.hutool.core.util.StrUtil;
 import com.alibaba.fastjson.JSON;
 import com.baomidou.mybatisplus.core.conditions.query.LambdaQueryWrapper;
 import com.baomidou.mybatisplus.core.toolkit.Wrappers;
@@ -12,16 +11,15 @@
 import com.sandu.ximon.admin.security.PermissionConfig;
 import com.sandu.ximon.admin.security.SecurityUtils;
 import com.sandu.ximon.admin.service.PlayPlanNvService;
-import com.sandu.ximon.dao.domain.Client;
+import com.sandu.ximon.admin.vo.NovaPushResultVO;
 import com.sandu.ximon.dao.domain.PlayPlanNv;
-import com.sandu.ximon.dao.enums.AdministratorEnums;
 import com.sandu.ximon.dao.enums.MenuEnum;
+import com.sandu.ximon.dao.enums.OrderByEnums;
 import lombok.AllArgsConstructor;
 import org.springframework.validation.annotation.Validated;
 import org.springframework.web.bind.annotation.*;
 
 import java.util.List;
-import java.util.Map;
 
 /**
  * @Author liuhaonan
@@ -37,35 +35,115 @@
 
     @PostMapping("/add")
     public ResponseVO<Object> addLEDPlan(@RequestBody @Validated PlayPlanParam param) {
+        if (!permissionConfig.check(MenuEnum.LED_N_PLAY_PLAN_ADD.getCode())) {
+            return ResponseUtil.fail("缂哄皯瀵瑰簲鐢ㄦ埛鏉冮檺");
+        }
         return ResponseUtil.success(playPlanNvService.addPlan(param));
     }
 
     @GetMapping("/getByPlanId/{planId}")
     public ResponseVO<Object> getPlan(@PathVariable Long planId) {
+        if (!permissionConfig.check(MenuEnum.LED_N_PLAY_PLAN_DETAIL.getCode())) {
+            return ResponseUtil.fail("缂哄皯瀵瑰簲鐢ㄦ埛鏉冮檺");
+        }
         return ResponseUtil.success(playPlanNvService.getByPlanId(planId));
     }
 
     @PostMapping("/update/{planId}")
     public ResponseVO<Object> updateLEDPlan(@PathVariable Long planId, @RequestBody @Validated PlayPlanParam param) {
+        if (!permissionConfig.check(MenuEnum.LED_N_PLAY_PLAN_UPDATE.getCode())) {
+            return ResponseUtil.fail("缂哄皯瀵瑰簲鐢ㄦ埛鏉冮檺");
+        }
         return ResponseUtil.success(playPlanNvService.updatePlan(planId, param));
     }
 
     @PostMapping("/delete")
     public ResponseVO<Object> deleteLEDPlan(@RequestBody List<Long> plianIds) {
+        if (!permissionConfig.check(MenuEnum.LED_N_PLAY_PLAN_DETELE.getCode())) {
+            return ResponseUtil.fail("缂哄皯瀵瑰簲鐢ㄦ埛鏉冮檺");
+        }
         return ResponseUtil.success(playPlanNvService.deletePlan(plianIds));
     }
 
-    @PostMapping(value = "/push/{plianId}", produces = "application/json;charset=UTF-8")
-    public ResponseVO<Object> pushToLed(@PathVariable Long plianId, @RequestBody List<String> playerIds) {
-        return ResponseUtil.success(playPlanNvService.pushToLed(plianId, playerIds));
+    /**
+     * 瀹氭椂鑺傜洰
+     *
+     * @param planId
+     * @param playerIds
+     * @return
+     */
+    @PostMapping(value = "/push/{planId}", produces = "application/json;charset=UTF-8")
+    public ResponseVO<Object> pushToLed(@PathVariable Long planId, @RequestBody List<NovaPushResultVO> playerIds) {
+        if (!permissionConfig.check(MenuEnum.LED_N_PLAY_PLAN_PUSH.getCode())) {
+            return ResponseUtil.fail("缂哄皯瀵瑰簲鐢ㄦ埛鏉冮檺");
+        }
+        return ResponseUtil.success(playPlanNvService.pushToLed(planId, playerIds));
     }
 
+
+    @PostMapping(value = "/pushSchedule/{planId}", produces = "application/json;charset=UTF-8")
+    public ResponseVO<Object> pushSchedule(@PathVariable Long planId, @RequestBody List<NovaPushResultVO> playerIds) {
+        if (!permissionConfig.check(MenuEnum.LED_N_PLAY_PLAN_PUSH_SCHEDULE.getCode())) {
+            return ResponseUtil.fail("缂哄皯瀵瑰簲鐢ㄦ埛鏉冮檺");
+        }
+        return ResponseUtil.success(playPlanNvService.pushSchedule(planId, playerIds));
+    }
+
+
+    /**
+     * 瀹炴椂鑺傜洰
+     *
+     * @param pid
+     * @param playerIds
+     * @return
+     */
+    @PostMapping(value = "/pushProgram/{pid}", produces = "application/json;charset=UTF-8")
+    public ResponseVO<Object> pushProgram(@PathVariable Long pid, @RequestBody List<NovaPushResultVO> playerIds) {
+        if (!permissionConfig.check(MenuEnum.LED_N_PLAY_PLAN_PUSH.getCode())) {
+            return ResponseUtil.fail("缂哄皯瀵瑰簲鐢ㄦ埛鏉冮檺");
+        }
+        return ResponseUtil.success(playPlanNvService.pushProgram(pid, playerIds));
+    }
+
+
     @GetMapping("/listPlan")
-    public ResponseVO<Object> list(BaseConditionVO baseConditionVO, @RequestParam(value = "keyword", required = false) String keyword) {
+    public ResponseVO<Object> list(BaseConditionVO baseConditionVO,
+                                   @RequestParam(value = "order", required = false) Integer order,
+                                   @RequestParam(value = "seq", required = false) Integer seq,
+                                   @RequestParam(value = "keyword", required = false) String keyword) {
         if (!permissionConfig.check(MenuEnum.PLAYPLAN_LIST.getCode())) {
             return ResponseUtil.fail("缂哄皯瀵瑰簲鐢ㄦ埛鏉冮檺");
         }
-        PageHelper.startPage(baseConditionVO.getPageNo(), baseConditionVO.getPageSize());
+        //鎺掑簭瀛楁
+        String orderByResult = "id";
+        //姝e簭銆佸�掑彊
+        String orderBySeq = OrderByEnums.ASC.getCode();
+        if (order != null) {
+            switch (order) {
+                case 1:
+                    orderByResult = OrderByEnums.LED_N_PLAY_PLAN_CREATE_TIME.getCode();
+                    break;
+                default:
+            }
+        }
+        if (seq != null) {
+            switch (seq) {
+                case 1:
+                    orderBySeq = " ASC";
+                    break;
+                case 2:
+                    orderBySeq = " DESC";
+                    break;
+                default:
+                    break;
+            }
+        }
+        //鎺掑簭鏂瑰紡
+        String orderBy = orderByResult + " " + orderBySeq;
+
+        if (baseConditionVO != null) {
+            PageHelper.startPage(baseConditionVO.getPageNo(), baseConditionVO.getPageSize(), orderBy);
+        }
         LambdaQueryWrapper<PlayPlanNv> wrapper = Wrappers.lambdaQuery(PlayPlanNv.class);
 
         if (SecurityUtils.getClientId() != null) {
@@ -73,12 +151,12 @@
                 w.eq(PlayPlanNv::getClientId, SecurityUtils.getUserId());
             });
         }
-        if (!keyword.isEmpty()) {
+        if (keyword != null && !keyword.isEmpty()) {
             wrapper = wrapper.like(PlayPlanNv::getName, keyword);
         }
         List<PlayPlanNv> list = playPlanNvService.list(wrapper);
         list.forEach(plan -> {
-            plan.setPlan(JSON.parseObject(plan.getSchedule(), Map.class));
+            plan.setPlan(JSON.parseObject(plan.getSchedules(), List.class));
         });
         return ResponseUtil.successPage(list);
     }

--
Gitblit v1.9.3