From 6992aaf0587c09f7c511c1afd12e1519d91363d3 Mon Sep 17 00:00:00 2001
From: cjl <276999030@qq.com>
Date: Thu, 14 Dec 2023 15:38:45 +0800
Subject: [PATCH] Merge remote-tracking branch 'origin/cjl' into qa

---
 screen-api/src/main/java/com/moral/api/controller/MonitorPointController.java |  235 +++++++++++++++++++++++++++++++++++++++++++++++++++++++---
 1 files changed, 223 insertions(+), 12 deletions(-)

diff --git a/screen-api/src/main/java/com/moral/api/controller/MonitorPointController.java b/screen-api/src/main/java/com/moral/api/controller/MonitorPointController.java
index 8eb74e9..e2e3b41 100644
--- a/screen-api/src/main/java/com/moral/api/controller/MonitorPointController.java
+++ b/screen-api/src/main/java/com/moral/api/controller/MonitorPointController.java
@@ -1,21 +1,32 @@
 package com.moral.api.controller;
 
+import com.moral.api.dto.MonitoringStationDTO;
+import com.moral.api.dto.MonitoringStationDTOResult;
 import com.moral.api.entity.MonitorPoint;
 import com.moral.api.pojo.form.device.MonitorPointQueryForm;
 import com.moral.api.pojo.vo.monitorPoint.MonitorPointsVO;
+import com.moral.api.service.HistoryFiveMinutelyService;
 import com.moral.api.service.MonitorPointService;
-import com.moral.api.service.OrganizationService;
+import com.moral.api.utils.EasyExcelUtils;
+import com.moral.api.utils.NoModelWriteData;
 import com.moral.constant.ResponseCodeEnum;
 import com.moral.constant.ResultMessage;
-import io.swagger.annotations.Api;
-import lombok.extern.slf4j.Slf4j;
-import org.springframework.beans.factory.annotation.Autowired;
-import org.springframework.web.bind.annotation.CrossOrigin;
-import org.springframework.web.bind.annotation.GetMapping;
-import org.springframework.web.bind.annotation.RequestMapping;
-import org.springframework.web.bind.annotation.RestController;
+import com.moral.util.WebUtils;
 
-import java.util.List;
+import io.swagger.annotations.*;
+import lombok.extern.slf4j.Slf4j;
+import org.apache.commons.collections4.CollectionUtils;
+import org.apache.commons.lang3.StringUtils;
+import org.apache.poi.ss.formula.functions.T;
+import org.springframework.beans.factory.annotation.Autowired;
+import org.springframework.web.bind.annotation.*;
+
+import java.math.BigDecimal;
+import java.util.*;
+import java.util.stream.Collectors;
+
+import javax.servlet.http.HttpServletRequest;
+import javax.servlet.http.HttpServletResponse;
 
 /**
  * @ClassName DeviceController
@@ -34,20 +45,220 @@
     @Autowired
     MonitorPointService monitorPointService;
 
+    @Autowired
+    private HistoryFiveMinutelyService historyFiveMinutelyService;
+
     @GetMapping("queryMonitorPoints")
-    public ResultMessage queryMonitorPointsAndDevices(MonitorPointQueryForm form){
+    public ResultMessage queryMonitorPointsAndDevices(MonitorPointQueryForm form) {
         //������������������������
         if (!form.valid())
             return ResultMessage.fail(ResponseCodeEnum.PARAMETERS_IS_MISSING.getCode(),
                     ResponseCodeEnum.PARAMETERS_IS_MISSING.getMsg());
         //������������������
-        List<MonitorPoint> monitorPoints = monitorPointService.query(form);
+        List<MonitorPoint> monitorPoints = monitorPointService.queryByOrgIdAndRegionCode(form);
 
         //������������������
-        MonitorPointsVO vo = MonitorPointsVO.convert(monitorPoints);
+        MonitorPointsVO vo = MonitorPointsVO.convert(monitorPoints,false);
 
         return new ResultMessage(ResponseCodeEnum.SUCCESS.getCode(), ResponseCodeEnum.SUCCESS.getMsg(), vo);
     }
 
+    @GetMapping("queryMonitorPointsState")
+    public ResultMessage queryMonitorPointsState(MonitorPointQueryForm form) {
+        //������������������������
+        if (!form.valid())
+            return ResultMessage.fail(ResponseCodeEnum.PARAMETERS_IS_MISSING.getCode(),
+                    ResponseCodeEnum.PARAMETERS_IS_MISSING.getMsg());
+        //������������������
+        List<MonitorPoint> monitorPoints = monitorPointService.queryByOrgIdAndRegionCode(form);
 
+        //������������������
+        MonitorPointsVO vo = MonitorPointsVO.convert(monitorPoints,true);
+
+        return new ResultMessage(ResponseCodeEnum.SUCCESS.getCode(), ResponseCodeEnum.SUCCESS.getMsg(), vo);
+    }
+
+    /**
+     * @Description: ������������������������������id������name
+     * @Param: [organizationId]
+     * @return: com.moral.constant.ResultMessage
+     * @Author: ���������
+     * @Date: 2021/9/26
+     */
+    @GetMapping("queryAllMonitorPoints")
+    public ResultMessage queryAllMonitorPoints(Integer organizationId) {
+        //������������������
+        List<MonitorPoint> monitorPoints = monitorPointService.queryAllMonitorPoints(organizationId);
+        //������������
+        return new ResultMessage(ResponseCodeEnum.SUCCESS.getCode(), ResponseCodeEnum.SUCCESS.getMsg(), monitorPoints);
+    }
+
+
+    /**
+     * @param request ������������
+     * @return ������������������������������������
+     */
+    @GetMapping("getWindData")
+    @ApiOperation(value = "������������������", notes = "������������������")
+    @ApiImplicitParams(value = {
+            @ApiImplicitParam(name = "token", value = "token", required = true, paramType = "header", dataType = "String"),
+            @ApiImplicitParam(name = "monitorPointIds", value = "������id", required = true, paramType = "query", dataType = "String")
+    })
+    public ResultMessage getWindData(HttpServletRequest request) {
+        Map<String, Object> params = WebUtils.getParametersStartingWith(request, null);
+        if (!params.containsKey("monitorPointIds")) {
+            return ResultMessage.fail(ResponseCodeEnum.PARAMETERS_IS_MISSING.getCode(), ResponseCodeEnum.PARAMETERS_IS_MISSING.getMsg());
+        }
+        String monitorPoint = params.remove("monitorPointIds").toString();
+        /*if(monitorPoint.contains("")){
+
+        }*/
+        params.put("monitorPointList", monitorPoint);
+        String[] monitorPointIds = monitorPoint.split(",");
+        if (monitorPointIds.length > 3) {
+            return ResultMessage.ok();
+        }
+
+        params.put("monitorPointIds", monitorPointIds);
+        List<Object> response = historyFiveMinutelyService.getAreaWindData(params);
+        return ResultMessage.ok(response);
+    }
+    @GetMapping("getWindDataCenter")
+    @ApiOperation(value = "������������������������", notes = "������������������������")
+    @ApiImplicitParams(value = {
+            @ApiImplicitParam(name = "token", value = "token", required = true, paramType = "header", dataType = "String"),
+            @ApiImplicitParam(name = "monitorPointIds", value = "������id", required = true, paramType = "query", dataType = "String")
+    })
+    public ResultMessage getWindDataCenter(HttpServletRequest request) {
+        Map<String, Object> params = WebUtils.getParametersStartingWith(request, null);
+        if (!params.containsKey("monitorPointIds")) {
+            return ResultMessage.fail(ResponseCodeEnum.PARAMETERS_IS_MISSING.getCode(), ResponseCodeEnum.PARAMETERS_IS_MISSING.getMsg());
+        }
+        String monitorPoint = params.remove("monitorPointIds").toString();
+        params.put("monitorPointList", monitorPoint);
+        String[] monitorPointIds = monitorPoint.split(",");
+        if (monitorPointIds.length > 3) {
+            return ResultMessage.ok();
+        }
+
+        params.put("monitorPointIds", monitorPointIds);
+        List<Object> response = historyFiveMinutelyService.getAreaWindDataCenter(params);
+        return ResultMessage.ok(response);
+    }
+
+    /**
+     * @Description: ������������������������������
+     * @Param: [request]
+     * @return: com.moral.constant.ResultMessage
+     * @Author: lizijie
+     * @Date: 2022-10-10 14:00
+     **/
+    @GetMapping("getHourlyDataByMonitorPoint")
+    public ResultMessage getHourlyDataByMonitorPoint(HttpServletRequest request) {
+        Map<String, Object> params = WebUtils.getParametersStartingWith(request, null);
+        if (!params.containsKey("monitorPointId") || !params.containsKey("sensors") || !params.containsKey("startTime") || !params.containsKey("endTime")) {
+            return ResultMessage.fail(ResponseCodeEnum.PARAMETERS_IS_MISSING.getCode(), ResponseCodeEnum.PARAMETERS_IS_MISSING.getMsg());
+        }
+        List<Map<String, Object>> resultList = monitorPointService.getHourlyDataByMonitorPoint(params);
+        return ResultMessage.ok(resultList);
+    }
+
+    /**
+     * ������������������������
+     *
+     * @param params
+     * @return
+     */
+    @PostMapping("getHourlyDataExcel")
+    public ResultMessage getHourlyDataExcel(@RequestBody Map<String, Object> params) {
+        if (!params.containsKey("macs") || !params.containsKey("sensors") || !params.containsKey("times") || !params.containsKey("type")) {
+            return ResultMessage.fail(ResponseCodeEnum.PARAMETERS_IS_MISSING.getCode(), ResponseCodeEnum.PARAMETERS_IS_MISSING.getMsg());
+        }
+        List<Map<String, Object>> resList = monitorPointService.getHourlyDataDataV3(params);
+        return ResultMessage.ok(resList);
+    }
+
+
+    @PostMapping("getHourlyDataExcelNew")
+    public ResultMessage getHourlyDataExcelNew(@RequestBody Map<String, Object> params) {
+        if (!params.containsKey("macs") || !params.containsKey("sensors") || !params.containsKey("times") || !params.containsKey("type")) {
+            return ResultMessage.fail(ResponseCodeEnum.PARAMETERS_IS_MISSING.getCode(), ResponseCodeEnum.PARAMETERS_IS_MISSING.getMsg());
+        }
+        List<Map<String, Object>> resList = monitorPointService.getHourlyDataDataV3Excel(params);
+        return ResultMessage.ok(resList);
+    }
+
+    @PostMapping("/exlOut")
+    @ApiImplicitParams(value = {
+            @ApiImplicitParam(name = "token", value = "token", required = true, paramType = "header", dataType = "String")
+    })
+    public void exlOut(HttpServletResponse response,@RequestBody Map<String, Object> params) {
+        //������������������
+        // List<ExcelHeader> excelHeaders = Arrays.asList(new ExcelHeader("phone", "���������"), new ExcelHeader("sexStr", "������"));
+       /* Map<String, Object> params = new HashMap<>();
+        params.put("macs", Arrays.asList("p5dnd7a0245446", "p5dnd7a0745450"));
+        params.put("sensors", "a34004,a34002");
+        params.put("type", "hours");
+        params.put("times", Arrays.asList("2023-07-01 00", "2023-07-02 00"));*/
+        if (!params.containsKey("macs") || !params.containsKey("sensors") || !params.containsKey("times") || !params.containsKey("type")) {
+            return;
+        }
+        //������������
+        List<Map<String, Object>> resList = monitorPointService.getHourlyDataDataV3Excel(params);
+        if (CollectionUtils.isEmpty(resList)) {
+            return;
+        }
+        Map<String, Object> map = resList.get(0);
+        List<String> list = new ArrayList<>();
+        for (String key : map.keySet()) {
+            list.add(key);
+        }
+        String[] s2 = new String[list.size()];
+        list.toArray(s2);
+        NoModelWriteData d = new NoModelWriteData();
+        d.setFileName("������������");
+        d.setHeadMap(s2);
+        d.setDataStrMap(s2);
+        d.setDataList(resList);
+        try {
+            EasyExcelUtils easyExcelUtils = new EasyExcelUtils();
+            easyExcelUtils.noModleWrite(d, response);
+        } catch (Exception e) {
+            int i = 0;
+        }
+
+    }
+    @PostMapping("listMonitoring")
+    public ResultMessage listMonitoring(@RequestBody Map<String, Object> params) {
+
+        /*@RequestParam @ApiParam(value = "mac",name = "mac���") List<String> mac,
+        @RequestParam @ApiParam(value = "startTime",name = "������������") String startTime,
+        @RequestParam @ApiParam(value = "reportType",name = "type") int reportType,
+        @RequestParam @ApiParam(value = "endTime",name = "������������") String endTime*/
+        List<MonitoringStationDTO> resList = monitorPointService.listMonitoringStationDTO(params,Integer.parseInt(params.get("reportType").toString()),params.get("startTime").toString(),params.get("endTime").toString());
+        /*List<MonitoringStationDTOResult> list = new ArrayList<>();
+        for(MonitoringStationDTO m : resList){
+            MonitoringStationDTOResult result = new MonitoringStationDTOResult();
+            result.setName(m.getName());
+            result.setMac(m.getMac());
+            result.setPM25(m.getPM25().compareTo(BigDecimal.ZERO)==0?"-":m.getPM25().toString());
+            result.setPM25Num(m.getPM25Num()==0?"-":String.valueOf(m.getPM25Num()));
+            result.setO3(m.getO3().compareTo(BigDecimal.ZERO)==0?"-":m.getO3().toString());
+            result.setO3Num(m.getO3Num()==0?"-":String.valueOf(m.getO3Num()));
+            result.setTovc(m.getTovc().compareTo(BigDecimal.ZERO)==0?"-":m.getTovc().toString());
+            result.setTOVCNum(m.getTOVCNum()==0?"-":String.valueOf(m.getTOVCNum()));
+            result.setComposite(m.getComposite().compareTo(BigDecimal.ZERO)==0?"-":m.getComposite().toString());
+            result.setCompositeNum(m.getCompositeNum()==0?"-":String.valueOf(m.getCompositeNum()));
+            result.setSO2(m.getSO2().compareTo(BigDecimal.ZERO)==0?"-":m.getSO2().toString());
+            result.setSO2Num(m.getSO2Num()==0?"-":String.valueOf(m.getSO2Num()));
+            result.setNO2(m.getNO2().compareTo(BigDecimal.ZERO)==0?"-":m.getNO2().toString());
+            result.setNO2Num(m.getNO2Num()==0?"-":String.valueOf(m.getNO2Num()));
+            result.setPM10(m.getPM10().compareTo(BigDecimal.ZERO)==0?"-":m.getPM10().toString());
+            result.setPM10Num(m.getPM10Num()==0?"-":String.valueOf(m.getPM10Num()));
+            result.setCO(m.getCO().compareTo(BigDecimal.ZERO)==0?"-":m.getCO().toString());
+            result.setCONum(m.getCONum()==0?"-":String.valueOf(m.getCONum()));
+            list.add(result);
+        }*/
+        return ResultMessage.ok(resList);
+    }
 }

--
Gitblit v1.8.0