From f78a9e03ae3f455a85dfd4d8a258dc0fbbb9e694 Mon Sep 17 00:00:00 2001
From: zhanzhiqin <895896009@qq.com>
Date: 星期三, 20 四月 2022 15:39:36 +0800
Subject: [PATCH] fix

---
 ximon-admin/src/main/java/com/sandu/ximon/admin/controller/XiXunController.java |  148 ++++++++++++++++++++++++++++---------------------
 1 files changed, 85 insertions(+), 63 deletions(-)

diff --git a/ximon-admin/src/main/java/com/sandu/ximon/admin/controller/XiXunController.java b/ximon-admin/src/main/java/com/sandu/ximon/admin/controller/XiXunController.java
index 1dbff1b..614f7f4 100644
--- a/ximon-admin/src/main/java/com/sandu/ximon/admin/controller/XiXunController.java
+++ b/ximon-admin/src/main/java/com/sandu/ximon/admin/controller/XiXunController.java
@@ -12,17 +12,19 @@
 import com.sandu.common.util.ResponseUtil;
 import com.sandu.ximon.admin.entity.ProgramPro;
 import com.sandu.ximon.admin.param.LEDScheduleParam_xixun;
+import com.sandu.ximon.admin.param.SetBrightnessParam;
 import com.sandu.ximon.admin.param.SetScreenOpenParam;
 import com.sandu.ximon.admin.param.SetVolumeParam;
+import com.sandu.ximon.admin.security.PermissionConfig;
 import com.sandu.ximon.admin.security.SecurityUtils;
-import com.sandu.ximon.admin.service.ClientService;
-import com.sandu.ximon.admin.service.LedScheduleService;
-import com.sandu.ximon.admin.service.PoleLightemitService;
-import com.sandu.ximon.admin.service.XiXunPlayerService;
+import com.sandu.ximon.admin.service.*;
 import com.sandu.ximon.admin.utils.LightemitUtils;
+import com.sandu.ximon.dao.domain.Pole;
+import com.sandu.ximon.dao.domain.PoleBinding;
 import com.sandu.ximon.dao.domain.PoleLightemitEntity;
 import com.sandu.ximon.dao.domain.PoleXixunPlayerEntity;
 import com.sandu.ximon.dao.enums.AdministratorEnums;
+import com.sandu.ximon.dao.enums.MenuEnum;
 import lombok.AllArgsConstructor;
 import org.springframework.web.bind.annotation.*;
 
@@ -43,6 +45,9 @@
     private final PoleLightemitService poleLightemitService;
     private final LightemitUtils lightemitUtils;
     private final LedScheduleService scheduleService;
+    private final PoleBindingService bindingService;
+    private final PoleService poleService;
+    private PermissionConfig permissionConfig;
     // private final ListPageUtil listPageUtil;
 
     /**
@@ -64,7 +69,7 @@
     public ResponseVO<Object> update(@RequestBody ProgramPro programPro) {
         PoleXixunPlayerEntity byId = xiXunPlayerService.getById(programPro.getProgramId());
         if (byId == null) {
-            throw new BusinessException("鍙傛暟閿欒");
+            throw new BusinessException("鏈�夋嫨LED灞�");
         }
 //        QueryWrapper<PoleXixunPlayerEntity> queryWrapper = new QueryWrapper<>();
 //        queryWrapper.eq("program_code", programPro.get_id());
@@ -107,31 +112,13 @@
      */
     @GetMapping("/list")
     public ResponseVO<Object> list(BaseConditionVO baseConditionVO, @RequestParam(value = "keyword", required = false) String keyword) {
+        if (!permissionConfig.check(MenuEnum.LED_PROGRAM_LIST.getCode())) {
+            return ResponseUtil.fail("缂哄皯瀵瑰簲鐢ㄦ埛鏉冮檺");
+        }
+        LambdaQueryWrapper<PoleXixunPlayerEntity> wrapper = xiXunPlayerService.XixunPlayerList(keyword);
         PageHelper.startPage(baseConditionVO.getPageNo(), baseConditionVO.getPageSize());
 
-        LambdaQueryWrapper<PoleXixunPlayerEntity> wrapper = Wrappers.lambdaQuery(PoleXixunPlayerEntity.class).like(PoleXixunPlayerEntity::getProgramName, keyword);
-//        if(AdministratorEnums.CUSTOMER.getCode().equals(SecurityUtils.getAdministratorIdentity())){
-//            boolean clientId = clientService.findClientId();
-//            if(clientId){
-//                wrapper= wrapper.eq(PoleXixunPlayerEntity::getUserId,SecurityUtils.getUserId());
-//            }
-//            wrapper= wrapper.eq(PoleXixunPlayerEntity::getClientId,clientService.getClientId());
-//        }
-//        wrapper=Wrappers.lambdaQuery(PoleXixunPlayerEntity.class);
-//        if(StrUtil.isNotBlank(keyword)){
-//            wrapper.like(PoleXixunPlayerEntity::getLightemitName,keyword).or(
-//                    lambdaQueryWrapper -> {
-//                        lambdaQueryWrapper.like(PoleXixunPlayerEntity::getLightemitControlCode, keyword);
-//                    }
-//            );
-//        }
-//        return ResponseUtil.success(poleLightemitService.list(wrapper));
-        if (AdministratorEnums.CUSTOMER.getCode().equals(SecurityUtils.getAdministratorIdentity())) {
-
-            return ResponseUtil.success(xiXunPlayerService.list(wrapper)); //  todo
-        } else {
-            return ResponseUtil.success(xiXunPlayerService.list(wrapper));
-        }
+        return ResponseUtil.success(xiXunPlayerService.list(wrapper));
     }
 
 
@@ -142,8 +129,8 @@
      * @param lightemitIds
      * @return
      */
-    @GetMapping("/pushToXixun/{pid}")
-    public ResponseVO<Object> getByPid(@PathVariable Long pid, @RequestBody List<Long> lightemitIds) {
+    @PostMapping("/pushToXixun/{pid}")
+    public ResponseVO<Object> pushByPid(@PathVariable Long pid, @RequestBody List<Long> lightemitIds) {
         xiXunPlayerService.videoXixunPlayer(pid, lightemitIds);
         return ResponseUtil.success("鎺ㄩ�佹垚鍔�");
     }
@@ -208,39 +195,28 @@
     @GetMapping("/listLed")
     public ResponseVO<Object> listLed(BaseConditionVO baseConditionVO, @RequestParam(value = "keyword", required = false) String keyword,
                                       @RequestParam(value = "isOnLine", required = false) boolean isOnLine) {
-        PageHelper.startPage(baseConditionVO.getPageNo(), baseConditionVO.getPageSize());
-        LambdaQueryWrapper<PoleLightemitEntity> wrapper = Wrappers.lambdaQuery(PoleLightemitEntity.class);
-        if (AdministratorEnums.CUSTOMER.getCode().equals(SecurityUtils.getAdministratorIdentity())) {
-            boolean clientId = clientService.findClientId();
-            if (clientId) {
-                wrapper = wrapper.eq(PoleLightemitEntity::getUserId, SecurityUtils.getUserId());
-            }
-            wrapper = wrapper.eq(PoleLightemitEntity::getClientId, clientService.getClientId());
+        if (!permissionConfig.check(MenuEnum.LED_LIST.getCode())) {
+            return ResponseUtil.fail("缂哄皯瀵瑰簲鐢ㄦ埛鏉冮檺");
         }
-        wrapper = Wrappers.lambdaQuery(PoleLightemitEntity.class);
-        if (StrUtil.isNotBlank(keyword)) {
-            wrapper.like(PoleLightemitEntity::getLightemitName, keyword).or(
-                    lambdaQueryWrapper -> {
-                        lambdaQueryWrapper.like(PoleLightemitEntity::getLightemitControlCode, keyword);
-                    }
-            );
+        List<PoleLightemitEntity> poleLightemitEntityList = poleLightemitService.listLed(keyword, isOnLine);
+
+        CommonPage commonPage = CommonPage.restPage(poleLightemitEntityList);
+        int size = poleLightemitEntityList.size();
+        commonPage.setTotal((long) size);
+        commonPage.setTotalPage(size / baseConditionVO.getPageSize() + 1);
+        if (size % baseConditionVO.getPageSize() == 0) {
+            commonPage.setTotalPage(size / baseConditionVO.getPageSize());
         }
-        List<PoleLightemitEntity> list = poleLightemitService.list(wrapper);
-        if (isOnLine) {
-            List<PoleLightemitEntity> results = poleLightemitService.ledOnline(list);
-            CommonPage commonPage = CommonPage.restPage(results);
-            int size = results.size();
-            commonPage.setTotal((long) size);
-            commonPage.setTotalPage(size / baseConditionVO.getPageSize() + 1);
-            if (size % baseConditionVO.getPageSize() == 0) {
-                commonPage.setTotalPage(size / baseConditionVO.getPageSize());
-            }
-            return ResponseUtil.success(commonPage);
-        } else {
-            poleLightemitService.ledOnlineCheck(list);
-            return ResponseUtil.success(list);
-        }
-//        return ResponseUtil.success(poleLightemitService.list(wrapper));
+        return ResponseUtil.success(commonPage);
+    }
+
+    /**
+     * @param
+     * @return
+     */
+    @GetMapping("/getbycode")
+    public ResponseVO<Object> getLedByLightControlCode(String lightemitControlCode) {
+        return ResponseUtil.success(poleLightemitService.getLedByLightControlCode(lightemitControlCode));
     }
 
     /*
@@ -313,13 +289,36 @@
 
 
     /*
-  璁剧疆闊抽噺
+    璁剧疆浜害
    */
+    @PostMapping("/setBrightness")
+    public ResponseVO<Object> setBrightness(@RequestBody SetBrightnessParam setBrightnessParam) {
+
+        if (setBrightnessParam == null || setBrightnessParam.getIds() == null || setBrightnessParam.getBrightness() > 255) {
+            throw new BusinessException("鍙傛暟閿欒涓虹┖鎴栦寒搴︿笉鑳借秴杩�255");
+        }
+
+        Collection poleLightemitControllers = poleLightemitService.listByIds(Arrays.asList(setBrightnessParam.getIds()));
+        if (!poleLightemitControllers.isEmpty()) {
+            Iterator iterator = poleLightemitControllers.iterator();
+            while (iterator.hasNext()) {
+                PoleLightemitEntity poleLightemitEntity = (PoleLightemitEntity) iterator.next();
+                poleLightemitService.setBrightness(poleLightemitEntity.getLightemitControlCode(), setBrightnessParam.getBrightness());
+            }
+            return ResponseUtil.success("璁剧疆浜害鎴愬姛");
+        } else {
+            throw new BusinessException("鏈�夋嫨LED灞�");
+        }
+    }
+
+    /*
+ 璁剧疆闊抽噺
+  */
     @PostMapping("/setVolume")
     public ResponseVO<Object> setVolume(@RequestBody SetVolumeParam setVolumeEntity) {
 
         if (setVolumeEntity == null || setVolumeEntity.getIds() == null || setVolumeEntity.getVolume() > 15) {
-            throw new BusinessException("鍙傛暟閿欒");
+            throw new BusinessException("闊抽噺鑼冨洿涓�0---15");
         }
 
         Collection poleLightemitControllers = poleLightemitService.listByIds(Arrays.asList(setVolumeEntity.getIds()));
@@ -345,11 +344,34 @@
         return ResponseUtil.success(scheduleService.updateSchedule(ledEntity));
     }
 
+    @PostMapping("/deleteSchedule")
+    public ResponseVO<Object> deleteSchedule(@RequestBody List<Integer> ids) {
+        return ResponseUtil.success(scheduleService.removeByIds(ids));
+    }
+
     @GetMapping("/getSchedule/{id}")
     public ResponseVO<Object> getSchedule(@PathVariable Integer id) {
         return ResponseUtil.success(scheduleService.getSchedule(id));
     }
 
+
+    @GetMapping("/listSchedule")
+    public ResponseVO<Object> listSchedule(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());
+        return ResponseUtil.success(scheduleService.listSchedule(baseConditionVO, keyword));
+    }
+
+
+    /**
+     * 璁剧疆瀹氭椂
+     *
+     * @param id
+     * @param lightemitIds
+     * @return
+     */
     @PostMapping("/pushSchedule/{id}")
     public ResponseVO<Object> pushSchedule(@PathVariable Integer id, @RequestBody Long[] lightemitIds) {
         scheduleService.ledschedulepush(id, lightemitIds);

--
Gitblit v1.9.3