From 35b68d05c92ae1eab2e409529a070a217ba492ae Mon Sep 17 00:00:00 2001
From: zhanzhiqin <895896009@qq.com>
Date: 星期一, 25 四月 2022 09:53:23 +0800
Subject: [PATCH] fix 客户列表bug修复

---
 ximon-admin/src/main/java/com/sandu/ximon/admin/controller/XiXunController.java |  205 +++++++++++++++++++++++++++++----------------------
 1 files changed, 116 insertions(+), 89 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 607b135..7aab8c1 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
@@ -1,9 +1,7 @@
 package com.sandu.ximon.admin.controller;
 
-import cn.hutool.core.util.StrUtil;
 import com.baomidou.mybatisplus.core.conditions.query.LambdaQueryWrapper;
 import com.baomidou.mybatisplus.core.conditions.query.QueryWrapper;
-import com.baomidou.mybatisplus.core.toolkit.Wrappers;
 import com.github.pagehelper.PageHelper;
 import com.sandu.common.domain.CommonPage;
 import com.sandu.common.domain.ResponseVO;
@@ -12,16 +10,17 @@
 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.*;
 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.admin.vo.LedScheduleVO;
 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.*;
 
@@ -44,6 +43,7 @@
     private final LedScheduleService scheduleService;
     private final PoleBindingService bindingService;
     private final PoleService poleService;
+    private PermissionConfig permissionConfig;
     // private final ListPageUtil listPageUtil;
 
     /**
@@ -65,7 +65,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());
@@ -108,31 +108,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));
     }
 
 
@@ -143,11 +125,18 @@
      * @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("鎺ㄩ�佹垚鍔�");
     }
+
+    //鎵ц涓殑鑺傜洰
+    @GetMapping("/getProgram/{lightemitId}")
+    public ResponseVO<Object> getProgram(@PathVariable Long lightemitId) {
+        return ResponseUtil.success(xiXunPlayerService.getByPid(lightemitId));
+    }
+
 
     /**
      * LED灞忓箷鏂板
@@ -162,7 +151,11 @@
             throw new BusinessException("LED鎺у埗鍗$紪鍙蜂笉鑳介噸澶�");
         }
 
-        poleLightemit.setCreateUserId(SecurityUtils.getClientId());
+        if (SecurityUtils.getClientId() == null) {
+            poleLightemit.setClientId(clientService.getClientId());
+            poleLightemit.setUserId(SecurityUtils.getUserId());
+            poleLightemit.setCreateUserId(SecurityUtils.getUserId());
+        }
 
         poleLightemitService.savePoleLightemit(poleLightemit);
 
@@ -209,63 +202,34 @@
     @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);
+        poleLightemitEntityList.forEach(
+                led -> {
+                    led.setStreetlightId(led.getPoleId());
+                    led.setStreetlightName(led.getPoleName());
+                }
+        );
+
+        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<PoleBinding> bindings = bindingService.list(Wrappers.lambdaQuery(PoleBinding.class).eq(PoleBinding::getDeviceType, 1));
-        List<PoleLightemitEntity> list = poleLightemitService.list(wrapper);
-        if (isOnLine) {
-            List<PoleLightemitEntity> results = poleLightemitService.ledOnline(list);
-            results.forEach(
-                    led -> {
-                        bindings.forEach(
-                                bind -> {
-                                    if (bind.getDeviceCode() != null && led.getLightemitControlCode() == bind.getDeviceCode()) {
-                                        led.setStreetlightId(bind.getPoleId());
-                                    }
-                                }
-                        );
-                    }
-            );
-            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);
-            list.forEach(
-                    led -> {
-                        bindings.forEach(
-                                bind -> {
-                                    if (bind.getDeviceCode() != null && led.getLightemitControlCode().equals(bind.getDeviceCode())) {
-                                        led.setStreetlightId(bind.getPoleId());
-                                        led.setPoleName(poleService.getOne(Wrappers.lambdaQuery(Pole.class).eq(Pole::getId, bind.getPoleId())).getPoleName());
-                                    }
-                                }
-                        );
-                    }
-            );
-            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));
     }
 
     /*
@@ -338,13 +302,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()));
@@ -370,16 +357,56 @@
         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);
         return ResponseUtil.success("璁剧疆鎴愬姛");
     }
 
+    /**
+     * 鑾峰彇鎵ц涓殑瀹氭椂
+     * @param
+     * @return
+     */
 
+    @GetMapping("/getPushSchedule")
+    public ResponseVO<Object> getPushSchedule(@RequestBody List<Long> ids) {
+        if(ids.isEmpty()){
+            throw new BusinessException("鏈�夋嫨LED灞�");
+        }
+        List<LedScheduleVO> list = new ArrayList<>();
+        for(Long id : ids) {
+            LedScheduleVO ledScheduleVO = scheduleService.getledschedules(id);
+            list.add(ledScheduleVO);
+        }
+        return ResponseUtil.success(list);
+    }
 }

--
Gitblit v1.9.3