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.utils.EasyExcelUtils;
|
import com.moral.api.utils.NoModelWriteData;
|
import com.moral.constant.ResponseCodeEnum;
|
import com.moral.constant.ResultMessage;
|
import com.moral.util.WebUtils;
|
|
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
|
* @Description TODO
|
* @Author 陈凯裕
|
* @Date 2021/7/1 9:24
|
* @Version TODO
|
**/
|
@Slf4j
|
@Api(tags = {"设备数据"})
|
@RestController
|
@CrossOrigin(origins = "*", maxAge = 3600)
|
@RequestMapping("/monitorPoint")
|
public class MonitorPointController {
|
|
@Autowired
|
MonitorPointService monitorPointService;
|
|
@Autowired
|
private HistoryFiveMinutelyService historyFiveMinutelyService;
|
|
@GetMapping("queryMonitorPoints")
|
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.queryByOrgIdAndRegionCode(form);
|
|
//转换前端参数
|
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("")){
|
|
}*/
|
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);
|
}
|
|
/**
|
* @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);
|
}
|
}
|