/**
|
* # __----~~~~~~~~~~~------___
|
* # . . ~~//====...... __--~ ~~
|
* # -. \_|// |||\\ ~~~~~~::::... /~
|
* # ___-==_ _-~o~ \/ ||| \\ _/~~-
|
* # __---~~~.==~||\=_ -_--~/_-~|- |\\ \\ _/~
|
* # _-~~ .=~ | \\-_ '-~7 /- / || \ /
|
* # .~ .~ | \\ -_ / /- / || \ /
|
* # / ____ / | \\ ~-_/ /|- _/ .|| \ /
|
* # |~~ ~~|--~~~~--_ \ ~==-/ | \~--===~~ .\
|
* # ' ~-| /| |-~\~~ __--~~
|
* # |-~~-_/ | | ~\_ _-~ /\
|
* # / \ \__ \/~ \__
|
* # _--~ _/ | .-~~____--~-/ ~~==.
|
* # ((->/~ '.|||' -_| ~~-/ , . _||
|
* # -_ ~\ ~~---l__i__i__i--~~_/
|
* # _-~-__ ~) \--______________--~~
|
* # //.-~~~-~_--~- |-------~~~~~~~~
|
* # //.-~~~--\
|
* # 神兽保佑
|
* # 永无BUG!
|
*/
|
package com.nanjing.water.service;
|
|
import com.baomidou.mybatisplus.core.conditions.query.LambdaQueryWrapper;
|
import com.nanjing.water.common.*;
|
import com.nanjing.water.common.model.Tuple;
|
import com.nanjing.water.common.util.*;
|
import com.nanjing.water.entity.request.waterfacilityparameter.ReqAddParameter;
|
import com.nanjing.water.entity.request.waterfacilityparameter.ReqCreateWaterFacilityParameter;
|
import com.nanjing.water.entity.request.waterfacilityparameter.ReqModifyWaterFacilityParameter;
|
import com.nanjing.water.entity.search.SearchWaterFacilityParameter;
|
import com.nanjing.water.repository.impl.WaterFacilityMapperImpl;
|
import com.nanjing.water.repository.impl.WaterFacilityParameterMapperImpl;
|
import com.nanjing.water.repository.impl.WaterMonitoryPointMapperImpl;
|
import com.nanjing.water.repository.po.WaterFacilityPO;
|
import com.nanjing.water.repository.po.WaterFacilityParameterPO;
|
import com.nanjing.water.repository.vo.FacilityParameterDataVO;
|
import com.nanjing.water.repository.vo.WaterFacilityParameterVO;
|
import com.nanjing.water.repository.vo.WaterFacilityVO;
|
import org.springframework.beans.factory.annotation.Autowired;
|
import org.springframework.data.redis.core.RedisTemplate;
|
import org.springframework.data.redis.core.StringRedisTemplate;
|
import org.springframework.stereotype.Service;
|
|
import java.math.BigDecimal;
|
import java.math.RoundingMode;
|
import java.util.ArrayList;
|
import java.util.List;
|
import java.util.Objects;
|
import java.util.concurrent.TimeUnit;
|
import java.util.stream.Collectors;
|
|
/**
|
* 设备设定参数
|
* @author lin.liu
|
*/
|
@Service
|
public class WaterFacilityParameterService extends BaseService {
|
@Autowired
|
private WaterFacilityParameterMapperImpl mapper;
|
@Autowired
|
private WaterFacilityMapperImpl waterFacilityMapper;
|
@Autowired
|
private WaterMonitoryPointMapperImpl waterMonitoryPointMapper;
|
@Autowired
|
private StringRedisTemplate redisTemplate;
|
|
public ExecutedResult<String> create(ReqAddParameter request) {
|
WaterFacilityPO facilityPO = waterFacilityMapper.get(request.getFacilityId());
|
if (Objects.isNull(facilityPO)) {
|
return ExecutedResult.failed("所属设备[id=" + request.getFacilityId() + "]不存在。");
|
}
|
List<WaterFacilityParameterPO> list = mapper.getListByFacilityId(request.getFacilityId());
|
// List<Long> ids = new ArrayList<Long>();
|
// if (ListUtil.isNotNullOrEmpty(list)) {
|
// list.forEach(x -> {
|
// ids.add(x.getId());
|
// });
|
// }
|
// if (ListUtil.isNotNullOrEmpty(ids)) {
|
// mapper.remove(ids);
|
// }
|
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<String> modify(ReqModifyWaterFacilityParameter request) {
|
// 验证记录是否存在
|
ExecutedResult<WaterFacilityParameterPO> checkExists = this.check4Id(request.getId());
|
if (checkExists.isFailed()) {
|
return ExecutedResult.failed(checkExists.getMsg());
|
}
|
// 转换po
|
WaterFacilityParameterPO item = CopierUtil.mapTo(request, WaterFacilityParameterPO.class);
|
|
int rowCount = mapper.updateById(item);
|
if (rowCount != 1) {
|
return ExecutedResult.failed("编辑[设备设定参数]失败。");
|
}
|
return ExecutedResult.success();
|
}
|
|
public ExecutedResult<WaterFacilityParameterVO> get(Long id) {
|
WaterFacilityParameterVO result = new WaterFacilityParameterVO();
|
|
WaterFacilityParameterPO find = mapper.get(id);
|
if (null != find) {
|
result = CopierUtil.mapTo(find, WaterFacilityParameterVO.class);
|
}
|
return ExecutedResult.success(result);
|
}
|
|
/**
|
*
|
* @return
|
*/
|
public ExecutedResult<String> getNewDataPump(){
|
//获取所有泵房启泵次数
|
List<FacilityParameterDataVO> listNewPump = mapper.getListNewPump();
|
redisTemplate.opsForValue().set("pump_start_number",SerializeUtil.toJson(listNewPump));
|
redisTemplate.expire("pump_start_number",24,TimeUnit.HOURS);
|
return ExecutedResult.success();
|
}
|
public ExecutedResult<List<WaterFacilityParameterPO>> getListByFacilityId(Long facilityId) {
|
List<WaterFacilityParameterPO> list = new ArrayList<>();
|
LambdaQueryWrapper<WaterFacilityParameterPO> wrapper = new LambdaQueryWrapper<>();
|
wrapper.eq(WaterFacilityParameterPO::getFacilityId, facilityId);
|
list = mapper.selectList(wrapper);
|
return ExecutedResult.success(list);
|
}
|
// public ExecutedResult<String> stop(Long id) {
|
// // 验证记录是否存在
|
// ExecutedResult<WaterFacilityParameterPO> 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<String> enable(Long id) {
|
// // 验证记录是否存在
|
// ExecutedResult<WaterFacilityParameterPO> 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);\n" +
|
// if (rowCount != 1) {
|
// return ExecutedResult.failed("启用[设备设定参数]失败。");
|
// }
|
// return ExecutedResult.success();
|
// }
|
//
|
// public ExecutedResult<String> setSort(ReqSetSort request) {
|
// // 验证记录是否存在
|
// ExecutedResult<WaterFacilityParameterPO> 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);\n" +
|
// if (rowCount != 1) {
|
// return ExecutedResult.failed("设置[设备设定参数]排序值失败。");
|
// }
|
// return ExecutedResult.success();
|
// }
|
//
|
// public ExecutedResult<String> listSetSort(ReqListSetSort request) {
|
// // id列表
|
// List<Long> listId = request.getList().stream().map(ReqSetSort::getId).collect(Collectors.toList());
|
// // 验证记录是否存在
|
// ExecutedResult<List<WaterFacilityParameterPO>> checkExists = this.check4Id(listId);
|
// if (checkExists.isFailed()) {
|
// return ExecutedResult.failed(checkExists.getMsg());
|
// }
|
//
|
// List<WaterFacilityParameterPO> 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<String> remove(Long id) {
|
// Boolean result = mapper.deleteLogic(id);
|
// if (BooleanUtils.isFalse(result)) {
|
// return ExecutedResult.failed("删除[设备设定参数]失败。");
|
// }
|
// return ExecutedResult.success();
|
// }
|
//
|
// public ExecutedResult<String> removeList(List<Long> ids) {
|
// Boolean result = mapper.deleteLogic(ids);
|
// if (BooleanUtils.isFalse(result)) {
|
// return ExecutedResult.failed("删除[设备设定参数]失败。");
|
// }
|
// return ExecutedResult.success();
|
// }
|
|
public ExecutedResult<List<WaterFacilityParameterVO>> getList(List<Long> listId) {
|
List<WaterFacilityParameterVO> result = new ArrayList<>();
|
|
List<WaterFacilityParameterPO> list = mapper.getList(listId);
|
if (ListUtil.isNotNullOrEmpty(list)) {
|
result = CopierUtil.mapTo(list, WaterFacilityParameterVO.class);
|
}
|
return ExecutedResult.success(result);
|
}
|
|
public ExecutedResult<PagerResult<WaterFacilityParameterVO>> search(SearchWaterFacilityParameter 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<WaterFacilityParameterPO> pageList = mapper.search(search);
|
List<WaterFacilityParameterVO> listVo = new ArrayList<>();
|
List<WaterFacilityParameterPO> list = pageList.getList();
|
if (ListUtil.isNotNullOrEmpty(list)) {
|
pageList.setLastId(list.get(list.size() - 1).getId());
|
// 转换vo
|
listVo = CopierUtil.mapTo(list, WaterFacilityParameterVO.class);
|
List<WaterFacilityPO> facilityPOList = waterFacilityMapper.getList();
|
for (WaterFacilityParameterVO vo : listVo) {
|
String facilityName = facilityPOList.stream().filter(x -> x.getId().equals(vo.getFacilityId())).map(WaterFacilityPO::getFacilityName).findFirst().orElse(null);
|
if (StringUtil.isNotNullOrEmpty(facilityName)) {
|
vo.setFacilityName(facilityName);
|
}
|
}
|
}
|
PagerResult<WaterFacilityParameterVO> result = new PagerResult<>(pageList.getLimit(), pageList.getPage(), pageList.getTotal(), listVo);
|
result.setLastId(pageList.getLastId());
|
return ExecutedResult.success(result);
|
}
|
public ExecutedResult<List<WaterFacilityVO>> getData(){
|
List<WaterFacilityVO>result=new ArrayList<>();
|
//获取泵房数据
|
List<WaterFacilityPO> facilityPOList = waterFacilityMapper.getList();
|
//获取泵房设备参数
|
List<WaterFacilityParameterPO> parameterPOList = mapper.getList();
|
if(ListUtil.isNotNullOrEmpty(facilityPOList)){
|
result = CopierUtil.mapTo(facilityPOList, WaterFacilityVO.class);
|
int sumTime=0;
|
for(WaterFacilityVO facilityVO:result){
|
List<WaterFacilityParameterPO> collect = parameterPOList.stream().filter(x -> x.getFacilityId().equals(facilityVO.getId())).collect(Collectors.toList());
|
if(ListUtil.isNotNullOrEmpty(collect)){
|
List<WaterFacilityParameterVO>parameterVOList=CopierUtil.mapTo(collect, WaterFacilityParameterVO.class);
|
for(WaterFacilityParameterVO parameterVO:parameterVOList){
|
boolean matches = parameterVO.getColumnValue().matches("-?\\d+(\\.\\d+)?");
|
if (matches) {
|
BigDecimal value = new BigDecimal(parameterVO.getColumnValue()).setScale(3, BigDecimal.ROUND_DOWN);
|
parameterVO.setColumnValue(value.toString());
|
}
|
if("false".equals(parameterVO.getColumnValue())){
|
parameterVO.setColumnValue("关");
|
}
|
if("true".equals(parameterVO.getColumnValue())){
|
parameterVO.setColumnValue("开");
|
}
|
if(parameterVO.getColumnsCode().equals("B001TimeSum")||parameterVO.getColumnsCode().equals("B002TimeSum")){
|
int time = new BigDecimal(parameterVO.getColumnValue()).intValue();
|
sumTime=sumTime+time;
|
if(sumTime>0){
|
String timeString = timeString(sumTime);
|
facilityVO.setTotalTime(timeString);
|
}
|
}
|
if(parameterVO.getColumnsCode().equals("B001Time")||parameterVO.getColumnsCode().equals("B002Time")||parameterVO.getColumnsCode().equals("B001TimeSum")||parameterVO.getColumnsCode().equals("B002TimeSum")){
|
//计算时分秒
|
Integer time= new BigDecimal(parameterVO.getColumnValue()).intValue();
|
if(time>0){
|
String timeString = timeString(time);
|
parameterVO.setColumnValue(timeString);
|
}
|
}
|
}
|
facilityVO.setParameterVOList(parameterVOList);
|
}
|
}
|
|
}
|
return ExecutedResult.success(result);
|
}
|
public String timeString(Integer time){
|
int hours=time/3600;
|
int minutes=(time%3600)/60;
|
int seconds=time%60;
|
return hours+"时"+minutes+"分"+seconds+"秒";
|
}
|
protected ExecutedResult<WaterFacilityParameterPO> check4Id(Long id) {
|
WaterFacilityParameterPO exists = mapper.get(id);
|
if (Objects.isNull(exists)) {
|
return ExecutedResult.failed("[设备设定参数]不存在:" + id);
|
}
|
return ExecutedResult.success(exists);
|
}
|
|
protected ExecutedResult<List<WaterFacilityParameterPO>> check4Id(List<Long> listId) {
|
// 从数据库查找设备设定参数
|
List<WaterFacilityParameterPO> list = mapper.getList(listId);
|
if (ListUtil.isNullOrEmpty(list)) {
|
return ExecutedResult.failed("[设备设定参数]不存在." + listId);
|
}
|
// 数据库找到的id列表
|
List<Long> listIdFind = list.stream().map(WaterFacilityParameterPO::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);
|
}
|
|
}
|