|
@@ -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;
|
|
@@ -15,14 +17,16 @@ import com.zksy.base.mapper.EquipmentStatusMapper;
|
|
|
import com.zksy.base.mapper.EquipmentTypeMapper;
|
|
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.ManholeDevicePageInDTO;
|
|
|
|
|
+import com.zksy.manhole.dto.out.EquipmentBaseOutDTO;
|
|
|
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.util.HashSet;
|
|
|
|
|
-import java.util.List;
|
|
|
|
|
-import java.util.Set;
|
|
|
|
|
|
|
+import java.util.*;
|
|
|
|
|
+import java.util.function.Function;
|
|
|
import java.util.stream.Collectors;
|
|
import java.util.stream.Collectors;
|
|
|
|
|
|
|
|
@Slf4j
|
|
@Slf4j
|
|
@@ -229,4 +233,65 @@ 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::getProductionDate);
|
|
|
|
|
+ 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)));
|
|
|
|
|
+ }
|
|
|
|
|
+ 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){
|
|
|
|
|
+ outDTO.setCurrentStatus(equipmentStatus.getCurrentStatus());
|
|
|
|
|
+ outDTO.setAlarmStatus(equipmentStatus.getAlarmStatus());
|
|
|
|
|
+ outDTO.setOnlineStatus(equipmentStatus.getOnlineStatus());
|
|
|
|
|
+ }
|
|
|
|
|
+ }
|
|
|
|
|
+ }
|
|
|
|
|
+ Page<EquipmentBaseOutDTO> outPage = new Page<>(pageInDTO.getPageNum(), pageInDTO.getPageSize(), rs.getTotal());
|
|
|
|
|
+ outPage.setRecords(outDTOList);
|
|
|
|
|
+ return outPage;
|
|
|
|
|
+ }
|
|
|
|
|
+
|
|
|
}
|
|
}
|