/**
|
# __----~~~~~~~~~~~------___
|
# . . ~~//====...... __--~ ~~
|
# -. \_|// |||\\ ~~~~~~::::... /~
|
# ___-==_ _-~o~ \/ ||| \\ _/~~-
|
# __---~~~.==~||\=_ -_--~/_-~|- |\\ \\ _/~
|
# _-~~ .=~ | \\-_ '-~7 /- / || \ /
|
# .~ .~ | \\ -_ / /- / || \ /
|
# / ____ / | \\ ~-_/ /|- _/ .|| \ /
|
# |~~ ~~|--~~~~--_ \ ~==-/ | \~--===~~ .\
|
# ' ~-| /| |-~\~~ __--~~
|
# |-~~-_/ | | ~\_ _-~ /\
|
# / \ \__ \/~ \__
|
# _--~ _/ | .-~~____--~-/ ~~==.
|
# ((->/~ '.|||' -_| ~~-/ , . _||
|
# -_ ~\ ~~---l__i__i__i--~~_/
|
# _-~-__ ~) \--______________--~~
|
# //.-~~~-~_--~- |-------~~~~~~~~
|
# //.-~~~--\
|
# 神兽保佑
|
# 永无BUG!
|
*/
|
package com.fengdu.gas.service;
|
|
import com.fengdu.gas.common.*;
|
import com.fengdu.gas.common.enums.*;
|
import com.fengdu.gas.common.model.Tuple;
|
import com.fengdu.gas.common.util.*;
|
import com.fengdu.gas.entity.response.facility.FacilityCount;
|
import com.fengdu.gas.entity.response.facility.FacilityData;
|
import com.fengdu.gas.repository.impl.WaterFacilityParameterMapperImpl;
|
import com.fengdu.gas.repository.impl.WaterMonitoryPointMapperImpl;
|
import com.fengdu.gas.repository.po.WaterFacilityParameterPO;
|
import com.fengdu.gas.repository.po.WaterMonitoryPointPO;
|
import org.apache.commons.lang3.BooleanUtils;
|
import org.springframework.beans.factory.annotation.Autowired;
|
import org.springframework.stereotype.Service;
|
|
import java.math.BigDecimal;
|
import java.util.*;
|
import java.util.stream.Collectors;
|
import java.util.stream.Stream;
|
|
import com.fengdu.gas.repository.impl.WaterFacilityMapperImpl;
|
import com.fengdu.gas.repository.po.WaterFacilityPO;
|
import com.fengdu.gas.entity.request.waterfacility.ReqCreateWaterFacility;
|
import com.fengdu.gas.entity.request.waterfacility.ReqModifyWaterFacility;
|
import com.fengdu.gas.entity.search.SearchWaterFacility;
|
import com.fengdu.gas.repository.vo.WaterFacilityVO;
|
import com.fengdu.gas.service.convert.WaterFacilityConvert;
|
|
/**
|
* 设备信息
|
* @author zr
|
*/
|
@Service
|
public class WaterFacilityService extends BaseService {
|
@Autowired
|
private WaterFacilityMapperImpl mapper;
|
@Autowired
|
private WaterFacilityParameterMapperImpl waterFacilityParameterMapper;
|
@Autowired
|
private WaterMonitoryPointMapperImpl waterMonitoryPointMapper;
|
|
public ExecutedResult<Long> create(ReqCreateWaterFacility request) {
|
// 转换po
|
WaterFacilityPO item = CopierUtil.mapTo(request, WaterFacilityPO.class);
|
// 设置状态
|
//item.setStatus(EState.NORMAL.getValue());
|
// 设置记录创建时间
|
item.setCreateTime(LocalDateTimeUtil.nowTimeStamp());
|
// 是否删除(逻辑删除)初始值
|
item.setIsDelete(EYesOrNo.NO.getValue());
|
|
int rowCount = mapper.insert(item);
|
if (rowCount != 1) {
|
return ExecutedResult.failed("创建[设备信息]失败。");
|
}
|
return ExecutedResult.success(item.getId());
|
}
|
|
public ExecutedResult<String> modify(ReqModifyWaterFacility request) {
|
// 验证记录是否存在
|
ExecutedResult<WaterFacilityPO> checkExists = this.check4Id(request.getId());
|
if (checkExists.isFailed()) {
|
return ExecutedResult.failed(checkExists.getMsg());
|
}
|
// 转换po
|
WaterFacilityPO item = WaterFacilityConvert.INSTANCE.toModify(request);
|
|
int rowCount = mapper.updateById(item);
|
if (rowCount != 1) {
|
return ExecutedResult.failed("编辑[设备信息]失败。");
|
}
|
return ExecutedResult.success();
|
}
|
|
public ExecutedResult<WaterFacilityVO> get(Long id) {
|
WaterFacilityVO result = new WaterFacilityVO();
|
|
WaterFacilityPO find = mapper.get(id);
|
if (null != find) {
|
// 转换vo
|
result = WaterFacilityConvert.INSTANCE.toVo(find);
|
}
|
return ExecutedResult.success(result);
|
}
|
|
public ExecutedResult<List<FacilityData>> getFacilityList() {
|
List<FacilityData> result = new ArrayList<>();
|
List<WaterMonitoryPointPO> pointPOList = waterMonitoryPointMapper.getList();
|
List<WaterFacilityPO> facilityPOList = mapper.getList();
|
List<WaterFacilityParameterPO> parameterPOList = waterFacilityParameterMapper.getList();
|
for (WaterFacilityPO facilityPO : facilityPOList) {
|
WaterMonitoryPointPO pointPO = pointPOList.stream().filter(item -> item.getId().equals(facilityPO.getPointId())).findFirst().orElse(null);
|
FacilityData data = new FacilityData();
|
data.setPointId(facilityPO.getPointId());
|
data.setPointName(facilityPO.getPointName());
|
data.setLeft(pointPO.getLeftMargin());
|
data.setTop(pointPO.getTopMargin());
|
data.setFacilityId(facilityPO.getId());
|
data.setFacilityName(facilityPO.getFacilityName());
|
data.setFacilityState(EFacilityState.getByValue(facilityPO.getFacilityState()).getDesc());
|
data.setFacilityFanState(EFacilityState.getByValue(facilityPO.getFacilityFanState()).getDesc());
|
List<WaterFacilityParameterPO> poList = parameterPOList.stream().filter(item -> item.getFacilityId().equals(facilityPO.getId())).collect(Collectors.toList());
|
if (ListUtil.isNotNullOrEmpty(poList)) {
|
//获取甲烷值
|
String methaneValue = poList.stream().filter(item -> item.getColumnsCode().equals("JW001")).map(WaterFacilityParameterPO::getColumnValue).findFirst().orElse(null);
|
//获取硫化氢值
|
String hyrothionValue = poList.stream().filter(item -> item.getColumnsCode().equals("LHQ001")).map(WaterFacilityParameterPO::getColumnValue).findFirst().orElse(null);
|
//获取温度
|
String temperature = poList.stream().filter(item -> item.getColumnsCode().equals("WD001")).map(WaterFacilityParameterPO::getColumnValue).findFirst().orElse(null);
|
|
if (StringUtil.isNotNullOrEmpty(methaneValue))
|
data.setMethaneValue(new BigDecimal(methaneValue));
|
if (StringUtil.isNotNullOrEmpty(hyrothionValue))
|
data.setHyrothionValue(new BigDecimal(hyrothionValue));
|
if (StringUtil.isNotNullOrEmpty(temperature))
|
data.setTemperature(new BigDecimal(temperature));
|
}
|
result.add(data);
|
}
|
return ExecutedResult.success(result);
|
}
|
public ExecutedResult<List<FacilityCount>> deviceCount(){
|
List<FacilityCount> result = new ArrayList<>();
|
List<WaterMonitoryPointPO> pointPOList = waterMonitoryPointMapper.getList();
|
List<WaterFacilityPO> facilityPOList = mapper.getList();
|
for(WaterMonitoryPointPO po:pointPOList){
|
List<WaterFacilityPO> collect = facilityPOList.stream().filter(item -> item.getPointId().equals(po.getId())).collect(Collectors.toList());
|
if(ListUtil.isNotNullOrEmpty(collect)&&collect.size()>0){
|
FacilityCount count=new FacilityCount();
|
count.setPointId(po.getId());
|
count.setPointName(po.getPointName());
|
count.setFacilityFanCount(collect.size());
|
count.setMethaneCount(collect.size());
|
count.setHyrothionCount(collect.size());
|
count.setBoxCount(collect.size());
|
int i = count.getFacilityFanCount() + count.getMethaneCount() + count.getHyrothionCount() + count.getBoxCount();
|
count.setSumCount( i);
|
result.add(count);
|
}
|
}
|
return ExecutedResult.success(result);
|
}
|
|
public ExecutedResult<List<WaterFacilityVO>> getList(List<Long> listId) {
|
List<WaterFacilityVO> result = new ArrayList<>();
|
|
List<WaterFacilityPO> list = mapper.getList(listId);
|
if (ListUtil.isNotNullOrEmpty(list)) {
|
// 转换vo
|
result = WaterFacilityConvert.INSTANCE.toVo(list);
|
}
|
return ExecutedResult.success(result);
|
}
|
|
public ExecutedResult<PagerResult<WaterFacilityVO>> search(SearchWaterFacility search) {
|
// 处理创建时间范围-查询参数
|
Tuple<String, String> createTimeRange = ParameterUtil.getTimeRange(search.getCreateTimeRange());
|
if (StringUtil.isNotNullOrEmpty(createTimeRange.getItem1())) {
|
search.setCreateTimeStart(LocalDateTimeUtil.getTimeStamp(createTimeRange.getItem1()).getTime());
|
}
|
if (StringUtil.isNotNullOrEmpty(createTimeRange.getItem2())) {
|
search.setCreateTimeEnd(LocalDateTimeUtil.getTimeStamp(createTimeRange.getItem2()).getTime());
|
}
|
|
PagerResult<WaterFacilityPO> pageList = mapper.search(search);
|
List<WaterFacilityVO> listVo = new ArrayList<>();
|
List<WaterFacilityPO> list = pageList.getList();
|
if (ListUtil.isNotNullOrEmpty(list)) {
|
pageList.setLastId(list.get(list.size() - 1).getId());
|
// 转换vo
|
listVo = WaterFacilityConvert.INSTANCE.toVo(list);
|
}
|
PagerResult<WaterFacilityVO> result = new PagerResult<>(pageList.getLimit(), pageList.getPage(), pageList.getTotal(), listVo);
|
result.setLastId(pageList.getLastId());
|
return ExecutedResult.success(result);
|
}
|
|
protected ExecutedResult<WaterFacilityPO> check4Id(Long id) {
|
WaterFacilityPO exists = mapper.get(id);
|
if (Objects.isNull(exists)) {
|
return ExecutedResult.failed("[设备信息]不存在:" + id);
|
}
|
return ExecutedResult.success(exists);
|
}
|
|
protected ExecutedResult<List<WaterFacilityPO>> check4Id(List<Long> listId) {
|
// 从数据库查找设备信息
|
List<WaterFacilityPO> list = mapper.getList(listId);
|
if (ListUtil.isNullOrEmpty(list)) {
|
return ExecutedResult.failed("[设备信息]不存在." + listId);
|
}
|
// 数据库找到的id列表
|
List<Long> listIdFind = list.stream().map(WaterFacilityPO::getId).collect(Collectors.toList());
|
// 数量不一致
|
if (listId.size() != listIdFind.size()) {
|
// 筛选数据库不存在的设备信息
|
List<Long> listIdNotFound = listId.stream().filter(c -> !listIdFind.contains(c)).collect(Collectors.toList());
|
if (ListUtil.isNullOrEmpty(list)) {
|
return ExecutedResult.failed("[设备信息]不存在." + listIdNotFound);
|
}
|
}
|
return ExecutedResult.success(list);
|
}
|
}
|