From e11aff139734ce34e4f7468170ebf0f62ccbb50b Mon Sep 17 00:00:00 2001
From: liuhaonan <konodioda2333@vip.qq.com>
Date: 星期二, 19 四月 2022 16:07:11 +0800
Subject: [PATCH] 首页

---
 ximon-admin/src/main/java/com/sandu/ximon/admin/controller/PlayPlanNvController.java |   51 +++++++++++++++++++++++++++++++++++++--------------
 1 files changed, 37 insertions(+), 14 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 abf6007..45ad5aa 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,5 +1,7 @@
 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;
 import com.github.pagehelper.PageHelper;
@@ -7,14 +9,19 @@
 import com.sandu.common.object.BaseConditionVO;
 import com.sandu.common.util.ResponseUtil;
 import com.sandu.ximon.admin.param.PlayPlanParam;
+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.dao.domain.PlayPlanNv;
 import com.sandu.ximon.dao.enums.AdministratorEnums;
+import com.sandu.ximon.dao.enums.MenuEnum;
 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
@@ -26,38 +33,54 @@
 @RequestMapping("/v1/ledPlan")
 public class PlayPlanNvController {
     private final PlayPlanNvService playPlanNvService;
+    private PermissionConfig permissionConfig;
 
     @PostMapping("/add")
     public ResponseVO<Object> addLEDPlan(@RequestBody @Validated PlayPlanParam param) {
         return ResponseUtil.success(playPlanNvService.addPlan(param));
     }
 
+    @GetMapping("/getByPlanId/{planId}")
+    public ResponseVO<Object> getPlan(@PathVariable Long planId) {
+        return ResponseUtil.success(playPlanNvService.getByPlanId(planId));
+    }
+
     @PostMapping("/update/{planId}")
-    public ResponseVO<Object> updateLEDPlan(@PathVariable Long planId,@RequestBody @Validated  PlayPlanParam param) {
+    public ResponseVO<Object> updateLEDPlan(@PathVariable Long planId, @RequestBody @Validated PlayPlanParam param) {
         return ResponseUtil.success(playPlanNvService.updatePlan(planId, param));
     }
 
-    @PostMapping("/delete/{plianId}")
-    public ResponseVO<Object> deleteLEDPlan(@PathVariable Long plianId) {
-        return ResponseUtil.success(playPlanNvService.deletePlan(plianId));
+    @PostMapping("/delete")
+    public ResponseVO<Object> deleteLEDPlan(@RequestBody List<Long> plianIds) {
+        return ResponseUtil.success(playPlanNvService.deletePlan(plianIds));
     }
 
-    @PostMapping("/push/{plianId}")
-    public ResponseVO<Object> pushToLed(@PathVariable Long plianId) {
-        return ResponseUtil.success(playPlanNvService.pushToLed(plianId));
+    @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));
     }
+
     @GetMapping("/listPlan")
     public ResponseVO<Object> list(BaseConditionVO baseConditionVO, @RequestParam(value = "keyword", required = false) String keyword) {
+        if (!permissionConfig.check(MenuEnum.PLAYPLAN_LIST.getCode())) {
+            return ResponseUtil.fail("缂哄皯瀵瑰簲鐢ㄦ埛鏉冮檺");
+        }
         PageHelper.startPage(baseConditionVO.getPageNo(), baseConditionVO.getPageSize());
-        LambdaQueryWrapper<PlayPlanNv> wrapper = new LambdaQueryWrapper<>();//
-        if(AdministratorEnums.CUSTOMER.getCode().equals(SecurityUtils.getAdministratorIdentity())){
-           wrapper= Wrappers.lambdaQuery(PlayPlanNv.class).eq(PlayPlanNv::getUserId,SecurityUtils.getUserId());
+        LambdaQueryWrapper<PlayPlanNv> wrapper = Wrappers.lambdaQuery(PlayPlanNv.class);
+
+        if (SecurityUtils.getClientId() != null) {
+            wrapper = wrapper.eq(PlayPlanNv::getUserId, SecurityUtils.getUserId()).or(w -> {
+                w.eq(PlayPlanNv::getClientId, SecurityUtils.getUserId());
+            });
         }
-        wrapper=Wrappers.lambdaQuery(PlayPlanNv.class);
-        if(null!=keyword){
-            wrapper.like(PlayPlanNv::getName,keyword);
+        if (keyword != null && !keyword.isEmpty()) {
+            wrapper = wrapper.like(PlayPlanNv::getName, keyword);
         }
-        return ResponseUtil.successPage(playPlanNvService.list(wrapper));
+        List<PlayPlanNv> list = playPlanNvService.list(wrapper);
+        list.forEach(plan -> {
+            plan.setPlan(JSON.parseObject(plan.getSchedule(), Map.class));
+        });
+        return ResponseUtil.successPage(list);
     }
 
 }

--
Gitblit v1.9.3