From ae2fc9a4f29e6d9d0b95f63585b058ab7c60c5be Mon Sep 17 00:00:00 2001
From: zhanzhiqin <895896009@qq.com>
Date: 星期一, 16 五月 2022 18:16:16 +0800
Subject: [PATCH] fix

---
 ximon-admin/src/main/java/com/sandu/ximon/admin/controller/LightController.java |   74 ++++++++++++++++++++++++++++++++-----
 1 files changed, 64 insertions(+), 10 deletions(-)

diff --git a/ximon-admin/src/main/java/com/sandu/ximon/admin/controller/LightController.java b/ximon-admin/src/main/java/com/sandu/ximon/admin/controller/LightController.java
index bac7ce1..d4c7ca0 100644
--- a/ximon-admin/src/main/java/com/sandu/ximon/admin/controller/LightController.java
+++ b/ximon-admin/src/main/java/com/sandu/ximon/admin/controller/LightController.java
@@ -1,9 +1,12 @@
 package com.sandu.ximon.admin.controller;
 
+import com.sandu.common.domain.CommonPage;
 import com.sandu.common.domain.ResponseVO;
 import com.sandu.common.object.BaseConditionVO;
+import com.sandu.common.security.annotation.AnonymousAccess;
 import com.sandu.common.util.ResponseUtil;
 import com.sandu.ximon.admin.param.LightControlParam;
+import com.sandu.ximon.admin.param.LightPowerSettingParam;
 import com.sandu.ximon.admin.param.LightRemarkParam;
 import com.sandu.ximon.admin.security.PermissionConfig;
 import com.sandu.ximon.admin.service.LightReportDataService;
@@ -17,6 +20,9 @@
 import org.springframework.validation.annotation.Validated;
 import org.springframework.web.bind.annotation.*;
 
+import javax.servlet.http.HttpServletRequest;
+import javax.servlet.http.HttpServletResponse;
+import java.util.ArrayList;
 import java.util.List;
 import java.util.Map;
 
@@ -47,6 +53,9 @@
 
     @PostMapping("/remark")
     public ResponseVO<Object> addRemark(@RequestBody @Validated LightRemarkParam param) {
+        if (!permissionConfig.check(MenuEnum.LIGHT_REMARK.getCode())) {
+            return ResponseUtil.fail("缂哄皯瀵瑰簲鐢ㄦ埛鏉冮檺");
+        }
         boolean result = lightService.addRemark(param);
         if (result) {
             return ResponseUtil.success("娣诲姞鎴愬姛");
@@ -67,38 +76,83 @@
         if (!permissionConfig.check(MenuEnum.LIGHT_DATA.getCode())) {
             return ResponseUtil.fail("缂哄皯瀵瑰簲鐢ㄦ埛鏉冮檺");
         }
-        List<LightReportDataBo> list = lightReportDataService.listReportData(conditionVO.getPageNo(), conditionVO.getPageSize(), keyword, deviceCode);
-        return ResponseUtil.success(list);
+        CommonPage commonPage = lightReportDataService.listReportData(conditionVO.getPageNo(), conditionVO.getPageSize(), keyword, deviceCode);
+        List<LightReportDataBo> lightReportDataBos = (List<LightReportDataBo>) commonPage.getList();
+
+        if (lightReportDataBos == null) {
+            return ResponseUtil.success(CommonPage.restPage(new ArrayList<>()));
+        }
+        CommonPage commonPage1 = CommonPage.restPage(lightReportDataBos);
+        commonPage1.setTotal(commonPage.getTotal());
+        commonPage1.setTotalPage(commonPage.getTotalPage());
+
+        return ResponseUtil.success(commonPage1);
     }
 
     /**
      * 瀵煎嚭Excel
-     * @param conditionVO
-     * @param keyword
+     *
      * @param deviceCode
      * @return
      */
     @GetMapping("/report/exportList")
-    public ResponseVO<Object> exportList(BaseConditionVO conditionVO, @RequestParam(required = false) String keyword, @RequestParam(required = false) String deviceCode) {
-        String url = lightReportDataService.exportList(conditionVO.getPageNo(), conditionVO.getPageSize(), keyword, deviceCode);
-        return ResponseUtil.success(url);
+    public ResponseVO<Object> exportList(HttpServletRequest request, HttpServletResponse response, @RequestParam(required = false) String deviceCode) {
+        if (!permissionConfig.check(MenuEnum.LIGHT_EXPORT_LIST.getCode())) {
+            return ResponseUtil.fail("缂哄皯瀵瑰簲鐢ㄦ埛鏉冮檺");
+        }
+        if (deviceCode.isEmpty()) {
+            return ResponseUtil.fail("璁惧缂栧彿涓嶈兘涓虹┖");
+        }
+        int length = deviceCode.length();
+        if (length != 24) {
+            return ResponseUtil.fail("璁惧缂栧彿闀垮害涓嶆纭�");
+        }
+        lightReportDataService.exportList(request, response, deviceCode);
+
+        return ResponseUtil.success("瀵煎嚭鎴愬姛");
     }
 
     @GetMapping("/error/list")
-    public ResponseVO<Object> listReportError(BaseConditionVO conditionVO, @RequestParam(required = false) String keyword) {
+    public ResponseVO<Object> listReportError(BaseConditionVO conditionVO, @RequestParam(required = false) String keyword
+            , @RequestParam(required = false) Integer errorCode) {
         if (!permissionConfig.check(MenuEnum.LIGHT_ERROR_LIST.getCode())) {
             return ResponseUtil.fail("缂哄皯瀵瑰簲鐢ㄦ埛鏉冮檺");
         }
-        List<LightReportErrorBo> list = lightReportErrorService.listReportError(conditionVO.getPageNo(), conditionVO.getPageSize(), keyword);
+        List<LightReportErrorBo> list = lightReportErrorService.listReportError(conditionVO.getPageNo(), conditionVO.getPageSize(), keyword, errorCode);
         return ResponseUtil.success(list);
     }
-
 
 
     // 浜害鎺у埗
     @PostMapping("/control")
     public ResponseVO<Object> controlBrightness(@RequestBody @Validated List<LightControlParam> paramList) {
+        if (!permissionConfig.check(MenuEnum.LIGHT_CONTROL.getCode())) {
+            return ResponseUtil.fail("缂哄皯瀵瑰簲鐢ㄦ埛鏉冮檺");
+        }
         List<Map<String, Object>> list = lightService.controlBrightness(paramList);
         return ResponseUtil.success(list);
     }
+
+    @PostMapping("/Energy")
+    public ResponseVO<Object> Energy() {
+        return ResponseUtil.success(lightService.controlEnergy());
+    }
+
+    @PostMapping("/EnergySaving")
+    public ResponseVO<Object> controlEnergySaving() {
+        return ResponseUtil.success(lightService.controlEnergySaving());
+    }
+
+
+    /**
+     * 璁剧疆鍔熺巼
+     */
+    @PostMapping("/setPower")
+    public ResponseVO<Object> setPower(@RequestBody LightPowerSettingParam lightPowerSettingParam) {
+        if (!permissionConfig.check(MenuEnum.LIGHT_SET_POWER.getCode())) {
+            return ResponseUtil.fail("缂哄皯瀵瑰簲鐢ㄦ埛鏉冮檺");
+        }
+        boolean resule = lightService.setPower(lightPowerSettingParam);
+        return ResponseUtil.success(resule);
+    }
 }

--
Gitblit v1.9.3