/** # __----~~~~~~~~~~~------___ # . . ~~//====...... __--~ ~~ # -. \_|// |||\\ ~~~~~~::::... /~ # ___-==_ _-~o~ \/ ||| \\ _/~~- # __---~~~.==~||\=_ -_--~/_-~|- |\\ \\ _/~ # _-~~ .=~ | \\-_ '-~7 /- / || \ / # .~ .~ | \\ -_ / /- / || \ / # / ____ / | \\ ~-_/ /|- _/ .|| \ / # |~~ ~~|--~~~~--_ \ ~==-/ | \~--===~~ .\ # ' ~-| /| |-~\~~ __--~~ # |-~~-_/ | | ~\_ _-~ /\ # / \ \__ \/~ \__ # _--~ _/ | .-~~____--~-/ ~~==. # ((->/~ '.|||' -_| ~~-/ , . _|| # -_ ~\ ~~---l__i__i__i--~~_/ # _-~-__ ~) \--______________--~~ # //.-~~~-~_--~- |-------~~~~~~~~ # //.-~~~--\ # 神兽保佑 # 永无BUG! */ package com.fengdu.gas.service; import com.fengdu.gas.common.*; import com.fengdu.gas.common.enums.EFacilityState; import com.fengdu.gas.common.model.Tuple; import com.fengdu.gas.common.util.*; import com.fengdu.gas.entity.request.waterfacilityparameter.ReqAddParameter; import com.fengdu.gas.entity.response.facility.FacilityParameterData; import com.fengdu.gas.repository.impl.WaterFacilityMapperImpl; import com.fengdu.gas.repository.impl.WaterMonitoryPointMapperImpl; import com.fengdu.gas.repository.po.WaterFacilityPO; import org.springframework.beans.factory.annotation.Autowired; import org.springframework.stereotype.Service; import java.util.*; import java.util.stream.Collectors; import com.fengdu.gas.repository.impl.WaterFacilityParameterMapperImpl; import com.fengdu.gas.repository.po.WaterFacilityParameterPO; import com.fengdu.gas.entity.request.waterfacilityparameter.ReqCreateWaterFacilityParameter; import com.fengdu.gas.entity.request.waterfacilityparameter.ReqModifyWaterFacilityParameter; import com.fengdu.gas.entity.search.SearchWaterFacilityParameter; import com.fengdu.gas.repository.vo.WaterFacilityParameterVO; import com.fengdu.gas.service.convert.WaterFacilityParameterConvert; /** * 设备设定参数 * @author zr */ @Service public class WaterFacilityParameterService extends BaseService { @Autowired private WaterFacilityParameterMapperImpl mapper; @Autowired private WaterFacilityMapperImpl waterFacilityMapper; @Autowired private WaterMonitoryPointMapperImpl waterMonitoryPointMapper; public ExecutedResult create(ReqAddParameter request) { WaterFacilityPO facilityPO = waterFacilityMapper.get(request.getFacilityId()); if (Objects.isNull(facilityPO)) { return ExecutedResult.failed("所属设备[id=" + request.getFacilityId() + "]不存在。"); } List list = mapper.getListByFacilityId(request.getFacilityId()); if (ListUtil.isNotNullOrEmpty(request.getParameterList())) { for (ReqCreateWaterFacilityParameter x : request.getParameterList()) { WaterFacilityParameterPO parameterPO = list.stream().filter(item -> item.getFacilityId().equals(request.getFacilityId()) && item.getColumnsCode().equals(x.getColumnsCode())).findFirst().orElse(null); if (Objects.isNull(parameterPO)) { WaterFacilityParameterPO item = new WaterFacilityParameterPO(); item.setId(SnowFlakeUtil.getId()); item.setFacilityId(facilityPO.getId()); item.setFacilityCode(facilityPO.getFacilityCode()); item.setCreateTime(LocalDateTimeUtil.nowTimeStamp()); item.setColumnsUnits(x.getColumnsUnits()); item.setColumnsCode(x.getColumnsCode()); item.setColumnsShow(x.getColumnsShow()); item.setColumnValue(""); item.setLastTime(""); this.mapper.insert(item); } } } return ExecutedResult.success("添加成功"); } public ExecutedResult modify(ReqModifyWaterFacilityParameter request) { // 验证记录是否存在 ExecutedResult checkExists = this.check4Id(request.getId()); if (checkExists.isFailed()) { return ExecutedResult.failed(checkExists.getMsg()); } // 转换po WaterFacilityParameterPO item = WaterFacilityParameterConvert.INSTANCE.toModify(request); int rowCount = mapper.updateById(item); if (rowCount != 1) { return ExecutedResult.failed("编辑[设备设定参数]失败。"); } return ExecutedResult.success(); } public ExecutedResult> getDataList(Long pointId, Integer facilityState) { List result = new ArrayList<>(); List facilityPOList = waterFacilityMapper.getList(); List listData = mapper.getListData(pointId, facilityState); if (ListUtil.isNotNullOrEmpty(listData)) { Map> dataMap = listData.stream().collect(Collectors.groupingBy(WaterFacilityParameterVO::getFacilityId)); for (Map.Entry> map : dataMap.entrySet()) { WaterFacilityPO facilityPO = facilityPOList.stream().filter(item -> item.getId().equals(map.getKey())).findFirst().orElse(null); WaterFacilityParameterVO jw001 = map.getValue().stream().filter(item -> item.getColumnsCode().equals("JW001")).findFirst().orElse(null); WaterFacilityParameterVO lhq001 = map.getValue().stream().filter(item -> item.getColumnsCode().equals("LHQ001")).findFirst().orElse(null); WaterFacilityParameterVO wd001 = map.getValue().stream().filter(item -> item.getColumnsCode().equals("WD001")).findFirst().orElse(null); FacilityParameterData data = new FacilityParameterData(); data.setFacilityName(facilityPO.getFacilityName()); data.setFacilityState(facilityPO.getFacilityState()); data.setFacilityStateName(EFacilityState.getByValue(facilityPO.getFacilityState()).getDesc()); data.setPointId(facilityPO.getPointId()); data.setPointName(facilityPO.getPointName()); if (Objects.nonNull(jw001)) data.setMethaneValue(jw001.getColumnValue()); if (Objects.nonNull(lhq001)) data.setHydrogenValue(lhq001.getColumnValue()); if (Objects.nonNull(wd001)) data.setTemperatureValue(wd001.getColumnValue()); result.add(data); } } return ExecutedResult.success(result); } public ExecutedResult get(Long id) { WaterFacilityParameterVO result = new WaterFacilityParameterVO(); WaterFacilityParameterPO find = mapper.get(id); if (null != find) { // 转换vo result = WaterFacilityParameterConvert.INSTANCE.toVo(find); } return ExecutedResult.success(result); } // public ExecutedResult stop(Long id) { // // 验证记录是否存在 // ExecutedResult checkExists = this.check4Id(id); // if (checkExists.isFailed()) { // return ExecutedResult.failed(checkExists.getMsg()); // } // WaterFacilityParameterPO item = new WaterFacilityParameterPO(); // item.setId(id); // item.setStatus(EState.DISABLED.getValue()); // // int rowCount = mapper.updateById(item); // if (rowCount != 1) { // return ExecutedResult.failed("停用[设备设定参数]失败。"); // } // return ExecutedResult.success(); // } // // public ExecutedResult enable(Long id) { // // 验证记录是否存在 // ExecutedResult checkExists = this.check4Id(id); // if (checkExists.isFailed()) { // return ExecutedResult.failed(checkExists.getMsg()); // } // WaterFacilityParameterPO item = new WaterFacilityParameterPO(); // item.setId(id); // item.setStatus(EState.NORMAL.getValue()); // // int rowCount = mapper.updateById(item); // if (rowCount != 1) { // return ExecutedResult.failed("启用[设备设定参数]失败。"); // } // return ExecutedResult.success(); // } // // public ExecutedResult setSort(ReqSetSort request) { // // 验证记录是否存在 // ExecutedResult checkExists = this.check4Id(request.getId()); // if (checkExists.isFailed()) { // return ExecutedResult.failed(checkExists.getMsg()); // } // WaterFacilityParameterPO item = new WaterFacilityParameterPO(); // item.setId(request.getId()); // item.setSort(request.getSort()); // // int rowCount = mapper.updateById(item); // if (rowCount != 1) { // return ExecutedResult.failed("设置[设备设定参数]排序值失败。"); // } // return ExecutedResult.success(); // } // // public ExecutedResult listSetSort(ReqListSetSort request) { // // id列表 // List listId = request.getList().stream().map(ReqSetSort::getId).collect(Collectors.toList()); // // 验证记录是否存在 // ExecutedResult> checkExists = this.check4Id(listId); // if (checkExists.isFailed()) { // return ExecutedResult.failed(checkExists.getMsg()); // } // // List listUpdate = request.getList().stream() // .map(c -> { // WaterFacilityParameterPO item = new WaterFacilityParameterPO(); // item.setId(c.getId()); // item.setSort(c.getSort()); // return item; // }) // .collect(Collectors.toList()); // Boolean result = mapper.modifyList(listUpdate); // if (result) { // return ExecutedResult.success(); // } // return ExecutedResult.failed("[设备设定参数]设置排序值失败"); // } // // public ExecutedResult remove(Long id) { // Boolean result = mapper.deleteLogic(id); // if (BooleanUtils.isFalse(result)) { // return ExecutedResult.failed("删除[设备设定参数]失败。"); // } // return ExecutedResult.success(); // } // // public ExecutedResult removeList(List ids) { // Boolean result = mapper.deleteLogic(ids); // if (BooleanUtils.isFalse(result)) { // return ExecutedResult.failed("删除[设备设定参数]失败。"); // } // return ExecutedResult.success(); // } public ExecutedResult> getList(List listId) { List result = new ArrayList<>(); List list = mapper.getList(listId); if (ListUtil.isNotNullOrEmpty(list)) { // 转换vo result = WaterFacilityParameterConvert.INSTANCE.toVo(list); } return ExecutedResult.success(result); } public ExecutedResult> search(SearchWaterFacilityParameter 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 = WaterFacilityParameterConvert.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) { WaterFacilityParameterPO 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(WaterFacilityParameterPO::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); } }