From c1413aeb9fe5d736af38e25285ac8d88074a89bf Mon Sep 17 00:00:00 2001
From: wuxw <928255095@qq.com>
Date: 星期五, 28 二月 2025 01:01:23 +0800
Subject: [PATCH] 开发完成运营房屋查询
---
service-community/src/main/java/com/java110/community/bmo/room/impl/QueryRoomStatisticsBMOImpl.java | 86 ++++++++++++++++++++++++++++++++++++++++--
1 files changed, 81 insertions(+), 5 deletions(-)
diff --git a/service-community/src/main/java/com/java110/community/bmo/room/impl/QueryRoomStatisticsBMOImpl.java b/service-community/src/main/java/com/java110/community/bmo/room/impl/QueryRoomStatisticsBMOImpl.java
index 18eb223..0be9211 100644
--- a/service-community/src/main/java/com/java110/community/bmo/room/impl/QueryRoomStatisticsBMOImpl.java
+++ b/service-community/src/main/java/com/java110/community/bmo/room/impl/QueryRoomStatisticsBMOImpl.java
@@ -1,6 +1,7 @@
package com.java110.community.bmo.room.impl;
import com.java110.community.bmo.room.IQueryRoomStatisticsBMO;
+import com.java110.dto.owner.OwnerRoomRelDto;
import com.java110.dto.room.RoomDto;
import com.java110.intf.store.IComplaintV1InnerServiceSMO;
import com.java110.intf.community.IRepairPoolV1InnerServiceSMO;
@@ -22,7 +23,7 @@
@Service
public class QueryRoomStatisticsBMOImpl implements IQueryRoomStatisticsBMO {
- public static final int MAX_LINE_COUNT = 15;
+ public static final int MAX_LINE_COUNT = 30;
@Autowired
private IOwnerRoomRelV1InnerServiceSMO ownerRoomRelV1InnerServiceSMOImpl;
@@ -48,7 +49,7 @@
@Override
public List<RoomDto> query(List<RoomDto> roomDtos) {
- if (roomDtos == null || roomDtos.size() < 1) {
+ if (ListUtil.isNull(roomDtos)) {
return roomDtos;
}
@@ -59,6 +60,8 @@
List<String> roomIds = new ArrayList<>();
List<String> ownerIds = new ArrayList<>();
List<String> ownerTels = new ArrayList<>();
+
+
for (RoomDto roomDto : roomDtos) {
if (!StringUtil.isEmpty(roomDto.getOwnerId())) {
ownerIds.add(roomDto.getOwnerId());
@@ -69,6 +72,7 @@
roomIds.add(roomDto.getRoomId());
}
+
// 鏌ヨ 瀹跺涵鎴愬憳鏁�
queryOwnerMemberCount(ownerIds, roomDtos);
@@ -97,6 +101,77 @@
return roomDtos;
}
+
+ @Override
+ public List<RoomDto> querySimple(List<RoomDto> roomDtos) {
+ if (ListUtil.isNull(roomDtos)) {
+ return roomDtos;
+ }
+
+ //杩欓噷闄愬埗琛屾暟锛屼互鍏嶅奖鍝嶇郴缁熸�ц兘
+ if (roomDtos.size() > MAX_LINE_COUNT) {
+ return roomDtos;
+ }
+ List<String> roomIds = new ArrayList<>();
+
+ for (RoomDto roomDto : roomDtos) {
+ roomIds.add(roomDto.getRoomId());
+ }
+ // 鏌ヨ涓氫富淇℃伅
+ queryRoomOwner(roomIds, roomDtos);
+ List<String> ownerIds = new ArrayList<>();
+ List<String> ownerTels = new ArrayList<>();
+ for (RoomDto roomDto : roomDtos) {
+ if (!StringUtil.isEmpty(roomDto.getOwnerId())) {
+ ownerIds.add(roomDto.getOwnerId());
+ }
+ if (!StringUtil.isEmpty(roomDto.getOwnerTel())) {
+ ownerTels.add(roomDto.getOwnerTel());
+ }
+ }
+
+ // 鏌ヨ 瀹跺涵鎴愬憳鏁�
+ queryOwnerMemberCount(ownerIds, roomDtos);
+
+ // 鏌ヨ 杞﹁締鏁�
+ queryCarCount(ownerIds, roomDtos);
+
+ // 鏌ヨ 鎴垮眿鏁伴噺
+ queryRoomCount(ownerIds, roomDtos);
+
+ // 鏌ヨ鎴垮眿 鍚堝悓
+ queryRoomContract(roomIds, roomDtos);
+
+ return roomDtos;
+ }
+
+
+ private void queryRoomOwner(List<String> roomIds, List<RoomDto> roomDtos) {
+ if (ListUtil.isNull(roomDtos)) {
+ return;
+ }
+
+ OwnerRoomRelDto ownerRoomRelDto = new OwnerRoomRelDto();
+ ownerRoomRelDto.setRoomIds(roomIds.toArray(new String[roomIds.size()]));
+ List<OwnerRoomRelDto> ownerRoomRelDtos = ownerRoomRelV1InnerServiceSMOImpl.queryOwnerRoomRels(ownerRoomRelDto);
+ if (ListUtil.isNull(ownerRoomRelDtos)) {
+ return;
+ }
+ for (RoomDto tmpRoomDto : roomDtos) {
+ for (OwnerRoomRelDto tOwnerRoomRelDto : ownerRoomRelDtos) {
+ if (!tmpRoomDto.getRoomId().equals(tOwnerRoomRelDto.getRoomId())) {
+ continue;
+ }
+ tmpRoomDto.setOwnerId(tOwnerRoomRelDto.getOwnerId());
+ tmpRoomDto.setOwnerName(tOwnerRoomRelDto.getOwnerName());
+ tmpRoomDto.setOwnerTel(tOwnerRoomRelDto.getLink());
+ tmpRoomDto.setStartTime(tOwnerRoomRelDto.getStartTime());
+ tmpRoomDto.setEndTime(tOwnerRoomRelDto.getEndTime());
+ tmpRoomDto.setLink(tOwnerRoomRelDto.getLink());
+ }
+ }
+ }
+
@Override
public List<RoomDto> queryRoomOweFee(List<RoomDto> roomDtos) {
if (ListUtil.isNull(roomDtos)) {
@@ -111,6 +186,7 @@
return roomDtos;
}
+
/**
* 鏌ヨ
*
@@ -118,7 +194,7 @@
* @param roomDtos
*/
private void queryRoomContract(List<String> roomIds, List<RoomDto> roomDtos) {
- if (roomDtos == null || roomDtos.size() < 1) {
+ if (ListUtil.isNull(roomDtos)) {
return;
}
Map info = new HashMap();
@@ -231,7 +307,7 @@
* @param roomDtos
*/
private void queryComplaintCount(List<String> ownerTels, List<RoomDto> roomDtos) {
- if (ownerTels == null || ownerTels.size() < 1) {
+ if (ListUtil.isNull(ownerTels)) {
return;
}
@@ -289,7 +365,7 @@
* @param roomDtos
*/
private void queryOwnerMemberCount(List<String> ownerIds, List<RoomDto> roomDtos) {
- if (ownerIds == null || ownerIds.size() < 1) {
+ if (ListUtil.isNull(ownerIds)) {
return;
}
--
Gitblit v1.8.0