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