/** # __----~~~~~~~~~~~------___ # . . ~~//====...... __--~ ~~ # -. \_|// |||\\ ~~~~~~::::... /~ # ___-==_ _-~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 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 modify(ReqModifyWaterFacility request) { // 验证记录是否存在 ExecutedResult 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 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> getFacilityList() { List result = new ArrayList<>(); List pointPOList = waterMonitoryPointMapper.getList(); List facilityPOList = mapper.getList(); List 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 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> deviceCount(){ List result = new ArrayList<>(); List pointPOList = waterMonitoryPointMapper.getList(); List facilityPOList = mapper.getList(); for(WaterMonitoryPointPO po:pointPOList){ List 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> getList(List listId) { List result = new ArrayList<>(); List list = mapper.getList(listId); if (ListUtil.isNotNullOrEmpty(list)) { // 转换vo result = WaterFacilityConvert.INSTANCE.toVo(list); } return ExecutedResult.success(result); } public ExecutedResult> search(SearchWaterFacility search) { // 处理创建时间范围-查询参数 Tuple 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 pageList = mapper.search(search); List listVo = new ArrayList<>(); List list = pageList.getList(); if (ListUtil.isNotNullOrEmpty(list)) { pageList.setLastId(list.get(list.size() - 1).getId()); // 转换vo listVo = WaterFacilityConvert.INSTANCE.toVo(list); } PagerResult result = new PagerResult<>(pageList.getLimit(), pageList.getPage(), pageList.getTotal(), listVo); result.setLastId(pageList.getLastId()); return ExecutedResult.success(result); } protected ExecutedResult check4Id(Long id) { WaterFacilityPO exists = mapper.get(id); if (Objects.isNull(exists)) { return ExecutedResult.failed("[设备信息]不存在:" + id); } return ExecutedResult.success(exists); } protected ExecutedResult> check4Id(List listId) { // 从数据库查找设备信息 List list = mapper.getList(listId); if (ListUtil.isNullOrEmpty(list)) { return ExecutedResult.failed("[设备信息]不存在." + listId); } // 数据库找到的id列表 List listIdFind = list.stream().map(WaterFacilityPO::getId).collect(Collectors.toList()); // 数量不一致 if (listId.size() != listIdFind.size()) { // 筛选数据库不存在的设备信息 List listIdNotFound = listId.stream().filter(c -> !listIdFind.contains(c)).collect(Collectors.toList()); if (ListUtil.isNullOrEmpty(list)) { return ExecutedResult.failed("[设备信息]不存在." + listIdNotFound); } } return ExecutedResult.success(list); } }