|
@@ -1,6 +1,8 @@
|
|
|
package com.zksy.base.service.impl;
|
|
package com.zksy.base.service.impl;
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
+import cn.hutool.core.bean.BeanUtil;
|
|
|
|
|
+import cn.hutool.core.collection.CollUtil;
|
|
|
import com.baomidou.mybatisplus.core.conditions.query.LambdaQueryWrapper;
|
|
import com.baomidou.mybatisplus.core.conditions.query.LambdaQueryWrapper;
|
|
|
import com.baomidou.mybatisplus.core.toolkit.CollectionUtils;
|
|
import com.baomidou.mybatisplus.core.toolkit.CollectionUtils;
|
|
|
import com.baomidou.mybatisplus.extension.plugins.pagination.Page;
|
|
import com.baomidou.mybatisplus.extension.plugins.pagination.Page;
|
|
@@ -9,15 +11,33 @@ import com.zksy.base.domain.*;
|
|
|
import com.zksy.base.mapper.*;
|
|
import com.zksy.base.mapper.*;
|
|
|
import com.zksy.base.alarm.domain.WarningThreshold;
|
|
import com.zksy.base.alarm.domain.WarningThreshold;
|
|
|
import com.zksy.base.alarm.mapper.WarningThresholdMapper;
|
|
import com.zksy.base.alarm.mapper.WarningThresholdMapper;
|
|
|
|
|
+import com.zksy.base.domain.EquipmentBase;
|
|
|
|
|
+import com.zksy.base.domain.EquipmentMaintain;
|
|
|
|
|
+import com.zksy.base.domain.EquipmentStatus;
|
|
|
|
|
+import com.zksy.base.domain.EquipmentType;
|
|
|
|
|
+import com.zksy.base.manhole.domain.ManholeData;
|
|
|
|
|
+import com.zksy.base.manhole.mapper.ManholeDataMapper;
|
|
|
|
|
+import com.zksy.base.mapper.EquipmentBaseMapper;
|
|
|
|
|
+import com.zksy.base.mapper.EquipmentMaintainMapper;
|
|
|
|
|
+import com.zksy.base.mapper.EquipmentStatusMapper;
|
|
|
|
|
+import com.zksy.base.mapper.EquipmentTypeMapper;
|
|
|
import com.zksy.base.service.EquipmentBaseService;
|
|
import com.zksy.base.service.EquipmentBaseService;
|
|
|
import com.zksy.common.exception.ServiceException;
|
|
import com.zksy.common.exception.ServiceException;
|
|
|
|
|
+import com.zksy.manhole.dto.in.ManholeDeviceListInDTO;
|
|
|
|
|
+import com.zksy.manhole.dto.in.ManholeDevicePageInDTO;
|
|
|
|
|
+import com.zksy.manhole.dto.out.EquipmentBaseOutDTO;
|
|
|
|
|
+import com.zksy.manhole.dto.out.EquipmentStatusOutDTO;
|
|
|
|
|
+import com.zksy.manhole.dto.out.ManholeDataOutDTO;
|
|
|
import lombok.extern.slf4j.Slf4j;
|
|
import lombok.extern.slf4j.Slf4j;
|
|
|
|
|
+import org.apache.commons.lang3.StringUtils;
|
|
|
import org.springframework.beans.factory.annotation.Autowired;
|
|
import org.springframework.beans.factory.annotation.Autowired;
|
|
|
import org.springframework.stereotype.Service;
|
|
import org.springframework.stereotype.Service;
|
|
|
import org.springframework.transaction.annotation.Transactional;
|
|
import org.springframework.transaction.annotation.Transactional;
|
|
|
|
|
|
|
|
import java.time.LocalDateTime;
|
|
import java.time.LocalDateTime;
|
|
|
import java.util.*;
|
|
import java.util.*;
|
|
|
|
|
+import java.util.*;
|
|
|
|
|
+import java.util.function.Function;
|
|
|
import java.util.stream.Collectors;
|
|
import java.util.stream.Collectors;
|
|
|
|
|
|
|
|
@Slf4j
|
|
@Slf4j
|
|
@@ -43,6 +63,9 @@ public class EquipmentBaseServiceImpl extends ServiceImpl<EquipmentBaseMapper, E
|
|
|
@Autowired
|
|
@Autowired
|
|
|
private WarningThresholdMapper warningThresholdMapper;
|
|
private WarningThresholdMapper warningThresholdMapper;
|
|
|
|
|
|
|
|
|
|
+ @Autowired
|
|
|
|
|
+ private ManholeDataMapper manholeDataMapper;
|
|
|
|
|
+
|
|
|
@Override
|
|
@Override
|
|
|
public Page<EquipmentBase> findByPage(long pageNum, long pageSize,
|
|
public Page<EquipmentBase> findByPage(long pageNum, long pageSize,
|
|
|
String equipmentCode, String equipmentName,
|
|
String equipmentCode, String equipmentName,
|
|
@@ -218,6 +241,158 @@ public class EquipmentBaseServiceImpl extends ServiceImpl<EquipmentBaseMapper, E
|
|
|
return this.removeByIds(existIds);
|
|
return this.removeByIds(existIds);
|
|
|
}
|
|
}
|
|
|
|
|
|
|
|
|
|
+ /**
|
|
|
|
|
+ * 分页查询监测设备台账列表
|
|
|
|
|
+ * @param pageInDTO
|
|
|
|
|
+ * @return
|
|
|
|
|
+ */
|
|
|
|
|
+ @Override
|
|
|
|
|
+ public Page<EquipmentBaseOutDTO> findManholeDeviceByPage(ManholeDevicePageInDTO pageInDTO) {
|
|
|
|
|
+ log.info("分页查询监测设备台账列表-入参:{}", pageInDTO);
|
|
|
|
|
+ List<String> equipmentIds = null;
|
|
|
|
|
+ if(pageInDTO.getCurrentStatus() != null){
|
|
|
|
|
+ List<EquipmentStatus> equipmentStatusList = equipmentStatusMapper.selectList(new LambdaQueryWrapper<EquipmentStatus>()
|
|
|
|
|
+ .eq(EquipmentStatus::getCurrentStatus, pageInDTO.getCurrentStatus()));
|
|
|
|
|
+ if(CollUtil.isEmpty(equipmentStatusList)){
|
|
|
|
|
+ return new Page<>(pageInDTO.getPageNum(), pageInDTO.getPageSize(), 0);
|
|
|
|
|
+ }
|
|
|
|
|
+ equipmentIds = equipmentStatusList.stream().map(EquipmentStatus::getEquipmentId).distinct().collect(Collectors.toList());
|
|
|
|
|
+ }
|
|
|
|
|
+ Page<EquipmentBase> page = new Page<>(pageInDTO.getPageNum(), pageInDTO.getPageSize());
|
|
|
|
|
+ LambdaQueryWrapper<EquipmentBase> queryWrapper = new LambdaQueryWrapper<>();
|
|
|
|
|
+ queryWrapper.eq(StringUtils.isNotEmpty(pageInDTO.getDeviceCode()), EquipmentBase::getEquipmentCode, pageInDTO.getDeviceCode())
|
|
|
|
|
+ .eq(StringUtils.isNotEmpty(pageInDTO.getEquipmentTypeId()), EquipmentBase::getEquipmentTypeId, pageInDTO.getEquipmentTypeId())
|
|
|
|
|
+ .in(CollUtil.isNotEmpty(equipmentIds), EquipmentBase::getEquipmentId, equipmentIds)
|
|
|
|
|
+ .like(StringUtils.isNotEmpty(pageInDTO.getDeviceName()), EquipmentBase::getEquipmentName, pageInDTO.getDeviceName())
|
|
|
|
|
+ .like(StringUtils.isNotEmpty(pageInDTO.getEquipmentLocation()), EquipmentBase::getEquipmentLocation, pageInDTO.getEquipmentLocation())
|
|
|
|
|
+ .orderByDesc(EquipmentBase::getUpdateTime);
|
|
|
|
|
+ Page<EquipmentBase> rs = this.page(page, queryWrapper);
|
|
|
|
|
+ List<EquipmentBaseOutDTO> outDTOList = BeanUtil.copyToList(rs.getRecords(), EquipmentBaseOutDTO.class);
|
|
|
|
|
+ if (CollUtil.isNotEmpty(outDTOList)) {
|
|
|
|
|
+ //查询设备类型
|
|
|
|
|
+ List<String> equipmentTypeIdList = outDTOList.stream().map(EquipmentBaseOutDTO::getEquipmentTypeId).distinct().collect(Collectors.toList());
|
|
|
|
|
+ List<EquipmentType> equipmentTypeList = equipmentTypeMapper.selectBatchIds(equipmentTypeIdList);
|
|
|
|
|
+ Map<String, EquipmentType> equipmentTypeMap = new HashMap<>();
|
|
|
|
|
+ if(CollUtil.isNotEmpty(equipmentTypeList)){
|
|
|
|
|
+ equipmentTypeMap.putAll(equipmentTypeList.stream().collect(Collectors.toMap(EquipmentType::getTypeId, Function.identity(), (key1, key2) -> key2)));
|
|
|
|
|
+ }
|
|
|
|
|
+ //查询设备状态
|
|
|
|
|
+ List<String> equipmentIdList = outDTOList.stream().map(EquipmentBaseOutDTO::getEquipmentId).distinct().collect(Collectors.toList());
|
|
|
|
|
+ List<EquipmentStatus> equipmentStatusList = equipmentStatusMapper.selectList(new LambdaQueryWrapper<EquipmentStatus>()
|
|
|
|
|
+ .in(EquipmentStatus::getEquipmentId, equipmentIdList));
|
|
|
|
|
+ Map<String, EquipmentStatus> EquipmentStatusMap = new HashMap<>();
|
|
|
|
|
+ if(CollUtil.isNotEmpty(equipmentStatusList)){
|
|
|
|
|
+ EquipmentStatusMap.putAll(equipmentStatusList.stream().collect(Collectors.toMap(EquipmentStatus::getEquipmentId, Function.identity(), (key1, key2) -> key2)));
|
|
|
|
|
+ }
|
|
|
|
|
+ //查询设备监测状态
|
|
|
|
|
+ Map<String, List<ManholeData>> imeiCardNumberMapList = new HashMap<>();
|
|
|
|
|
+ if(pageInDTO.getIsQueryManholeData()){
|
|
|
|
|
+ List<String> equipmentCodeList = outDTOList.stream().map(EquipmentBaseOutDTO::getEquipmentCode).distinct().collect(Collectors.toList());
|
|
|
|
|
+ List<ManholeData> manholeDataList = manholeDataMapper.selectList(new LambdaQueryWrapper<ManholeData>()
|
|
|
|
|
+ .in(ManholeData::getImeiCardNumber, equipmentCodeList)
|
|
|
|
|
+ .orderByDesc(ManholeData::getCreateTime));
|
|
|
|
|
+ imeiCardNumberMapList.putAll(manholeDataList.stream().collect(Collectors.groupingBy(ManholeData::getImeiCardNumber)));
|
|
|
|
|
+ }
|
|
|
|
|
+ List<ManholeData> manholeDataList = null;
|
|
|
|
|
+ for(EquipmentBaseOutDTO outDTO : outDTOList) {
|
|
|
|
|
+ EquipmentType equipmentType = equipmentTypeMap.get(outDTO.getEquipmentTypeId());
|
|
|
|
|
+ if(equipmentType != null){
|
|
|
|
|
+ outDTO.setEquipmentTypeName(equipmentType.getTypeName());
|
|
|
|
|
+ }
|
|
|
|
|
+ EquipmentStatus equipmentStatus = EquipmentStatusMap.get(outDTO.getEquipmentId());
|
|
|
|
|
+ if(equipmentStatus != null){
|
|
|
|
|
+ EquipmentStatusOutDTO equipmentStatusOutDTO = BeanUtil.copyProperties(equipmentStatus, EquipmentStatusOutDTO.class);
|
|
|
|
|
+ outDTO.setEquipmentStatus(equipmentStatusOutDTO);
|
|
|
|
|
+ }
|
|
|
|
|
+ if(pageInDTO.getIsQueryManholeData()){
|
|
|
|
|
+ manholeDataList = imeiCardNumberMapList.get(outDTO.getEquipmentCode());
|
|
|
|
|
+ if(CollUtil.isNotEmpty(manholeDataList)){
|
|
|
|
|
+ ManholeData manholeData = manholeDataList.get(0);
|
|
|
|
|
+ ManholeDataOutDTO manholeDataOutDTO = BeanUtil.copyProperties(manholeData, ManholeDataOutDTO.class);
|
|
|
|
|
+ outDTO.setManholeData(manholeDataOutDTO);
|
|
|
|
|
+ }
|
|
|
|
|
+ }
|
|
|
|
|
+ }
|
|
|
|
|
+ }
|
|
|
|
|
+ Page<EquipmentBaseOutDTO> outPage = new Page<>(pageInDTO.getPageNum(), pageInDTO.getPageSize(), rs.getTotal());
|
|
|
|
|
+ outPage.setRecords(outDTOList);
|
|
|
|
|
+ return outPage;
|
|
|
|
|
+ }
|
|
|
|
|
+
|
|
|
|
|
+ /**
|
|
|
|
|
+ * 查询井盖监测设备列表
|
|
|
|
|
+ * @param listInDTO
|
|
|
|
|
+ * @return
|
|
|
|
|
+ */
|
|
|
|
|
+ @Override
|
|
|
|
|
+ public List<EquipmentBaseOutDTO> getManholeDataList(ManholeDeviceListInDTO listInDTO) {
|
|
|
|
|
+ log.info("查询井盖监测设备列表-入参:{}", listInDTO);
|
|
|
|
|
+ List<String> equipmentIds = null;
|
|
|
|
|
+ if(listInDTO.getCurrentStatus() != null || listInDTO.getAlarmStatus() != null || listInDTO.getOnlineStatus() != null){
|
|
|
|
|
+ List<EquipmentStatus> equipmentStatusList = equipmentStatusMapper.selectList(new LambdaQueryWrapper<EquipmentStatus>()
|
|
|
|
|
+ .eq(listInDTO.getCurrentStatus() != null, EquipmentStatus::getCurrentStatus, listInDTO.getCurrentStatus())
|
|
|
|
|
+ .eq(listInDTO.getAlarmStatus() != null, EquipmentStatus::getAlarmStatus, listInDTO.getAlarmStatus())
|
|
|
|
|
+ .eq(listInDTO.getOnlineStatus() != null, EquipmentStatus::getOnlineStatus, listInDTO.getOnlineStatus()));
|
|
|
|
|
+ if(CollUtil.isEmpty(equipmentStatusList)){
|
|
|
|
|
+ return new ArrayList<>();
|
|
|
|
|
+ }
|
|
|
|
|
+ equipmentIds = equipmentStatusList.stream().map(EquipmentStatus::getEquipmentId).distinct().collect(Collectors.toList());
|
|
|
|
|
+ }
|
|
|
|
|
+ LambdaQueryWrapper<EquipmentBase> queryWrapper = new LambdaQueryWrapper<>();
|
|
|
|
|
+ queryWrapper.in(CollUtil.isNotEmpty(equipmentIds), EquipmentBase::getEquipmentId, equipmentIds)
|
|
|
|
|
+ .orderByDesc(EquipmentBase::getUpdateTime);
|
|
|
|
|
+ List<EquipmentBase> equipmentBaseList = this.list(queryWrapper);
|
|
|
|
|
+ if (CollUtil.isEmpty(equipmentBaseList)) {
|
|
|
|
|
+ return new ArrayList<>();
|
|
|
|
|
+ }
|
|
|
|
|
+ List<EquipmentBaseOutDTO> outDTOList = BeanUtil.copyToList(equipmentBaseList, EquipmentBaseOutDTO.class);
|
|
|
|
|
+ //查询设备类型
|
|
|
|
|
+ List<String> equipmentTypeIdList = outDTOList.stream().map(EquipmentBaseOutDTO::getEquipmentTypeId).distinct().collect(Collectors.toList());
|
|
|
|
|
+ List<EquipmentType> equipmentTypeList = equipmentTypeMapper.selectBatchIds(equipmentTypeIdList);
|
|
|
|
|
+ Map<String, EquipmentType> equipmentTypeMap = new HashMap<>();
|
|
|
|
|
+ if(CollUtil.isNotEmpty(equipmentTypeList)){
|
|
|
|
|
+ equipmentTypeMap.putAll(equipmentTypeList.stream().collect(Collectors.toMap(EquipmentType::getTypeId, Function.identity(), (key1, key2) -> key2)));
|
|
|
|
|
+ }
|
|
|
|
|
+ //查询设备状态
|
|
|
|
|
+ List<String> equipmentIdList = outDTOList.stream().map(EquipmentBaseOutDTO::getEquipmentId).distinct().collect(Collectors.toList());
|
|
|
|
|
+ List<EquipmentStatus> equipmentStatusList = equipmentStatusMapper.selectList(new LambdaQueryWrapper<EquipmentStatus>()
|
|
|
|
|
+ .in(EquipmentStatus::getEquipmentId, equipmentIdList));
|
|
|
|
|
+ Map<String, EquipmentStatus> EquipmentStatusMap = new HashMap<>();
|
|
|
|
|
+ if(CollUtil.isNotEmpty(equipmentStatusList)){
|
|
|
|
|
+ EquipmentStatusMap.putAll(equipmentStatusList.stream().collect(Collectors.toMap(EquipmentStatus::getEquipmentId, Function.identity(), (key1, key2) -> key2)));
|
|
|
|
|
+ }
|
|
|
|
|
+ //查询设备监测状态
|
|
|
|
|
+ Map<String, List<ManholeData>> imeiCardNumberMapList = new HashMap<>();
|
|
|
|
|
+ if(listInDTO.getIsQueryManholeData()){
|
|
|
|
|
+ List<String> equipmentCodeList = outDTOList.stream().map(EquipmentBaseOutDTO::getEquipmentCode).distinct().collect(Collectors.toList());
|
|
|
|
|
+ List<ManholeData> manholeDataList = manholeDataMapper.selectList(new LambdaQueryWrapper<ManholeData>()
|
|
|
|
|
+ .in(ManholeData::getImeiCardNumber, equipmentCodeList)
|
|
|
|
|
+ .orderByDesc(ManholeData::getCreateTime));
|
|
|
|
|
+ imeiCardNumberMapList.putAll(manholeDataList.stream().collect(Collectors.groupingBy(ManholeData::getImeiCardNumber)));
|
|
|
|
|
+ }
|
|
|
|
|
+ List<ManholeData> manholeDataList = null;
|
|
|
|
|
+ for(EquipmentBaseOutDTO outDTO : outDTOList) {
|
|
|
|
|
+ EquipmentType equipmentType = equipmentTypeMap.get(outDTO.getEquipmentTypeId());
|
|
|
|
|
+ if(equipmentType != null){
|
|
|
|
|
+ outDTO.setEquipmentTypeName(equipmentType.getTypeName());
|
|
|
|
|
+ }
|
|
|
|
|
+ EquipmentStatus equipmentStatus = EquipmentStatusMap.get(outDTO.getEquipmentId());
|
|
|
|
|
+ if(equipmentStatus != null){
|
|
|
|
|
+ EquipmentStatusOutDTO equipmentStatusOutDTO = BeanUtil.copyProperties(equipmentStatus, EquipmentStatusOutDTO.class);
|
|
|
|
|
+ outDTO.setEquipmentStatus(equipmentStatusOutDTO);
|
|
|
|
|
+ }
|
|
|
|
|
+ if(listInDTO.getIsQueryManholeData()){
|
|
|
|
|
+ manholeDataList = imeiCardNumberMapList.get(outDTO.getEquipmentCode());
|
|
|
|
|
+ if(CollUtil.isNotEmpty(manholeDataList)){
|
|
|
|
|
+ ManholeData manholeData = manholeDataList.get(0);
|
|
|
|
|
+ ManholeDataOutDTO manholeDataOutDTO = BeanUtil.copyProperties(manholeData, ManholeDataOutDTO.class);
|
|
|
|
|
+ outDTO.setManholeData(manholeDataOutDTO);
|
|
|
|
|
+ }
|
|
|
|
|
+ }
|
|
|
|
|
+ }
|
|
|
|
|
+ return outDTOList;
|
|
|
|
|
+ }
|
|
|
|
|
+
|
|
|
@Override
|
|
@Override
|
|
|
@Transactional
|
|
@Transactional
|
|
|
public boolean updateEquipmentStatus(String equipmentId, Integer currentStatus) {
|
|
public boolean updateEquipmentStatus(String equipmentId, Integer currentStatus) {
|