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 | 111 +++++++++++++++++++++++++++++++++++++++++++++++--------
1 files changed, 95 insertions(+), 16 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 743047d..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,14 +1,16 @@
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.community.IComplaintV1InnerServiceSMO;
+import com.java110.intf.store.IComplaintV1InnerServiceSMO;
import com.java110.intf.community.IRepairPoolV1InnerServiceSMO;
import com.java110.intf.report.IReportOweFeeInnerServiceSMO;
import com.java110.intf.store.IContractRoomInnerServiceSMO;
import com.java110.intf.user.IOwnerCarV1InnerServiceSMO;
import com.java110.intf.user.IOwnerRoomRelV1InnerServiceSMO;
import com.java110.intf.user.IOwnerV1InnerServiceSMO;
+import com.java110.utils.util.ListUtil;
import com.java110.utils.util.StringUtil;
import org.springframework.beans.factory.annotation.Autowired;
import org.springframework.stereotype.Service;
@@ -21,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;
@@ -47,7 +49,7 @@
@Override
public List<RoomDto> query(List<RoomDto> roomDtos) {
- if (roomDtos == null || roomDtos.size() < 1) {
+ if (ListUtil.isNull(roomDtos)) {
return roomDtos;
}
@@ -58,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());
@@ -68,6 +72,7 @@
roomIds.add(roomDto.getRoomId());
}
+
// 鏌ヨ 瀹跺涵鎴愬憳鏁�
queryOwnerMemberCount(ownerIds, roomDtos);
@@ -96,9 +101,80 @@
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 (roomDtos == null || roomDtos.size() < 1) {
+ if (ListUtil.isNull(roomDtos)) {
return roomDtos;
}
List<String> roomIds = new ArrayList<>();
@@ -110,6 +186,7 @@
return roomDtos;
}
+
/**
* 鏌ヨ
*
@@ -117,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();
@@ -139,7 +216,7 @@
}
private void queryRoomOweFee(List<String> roomIds, List<RoomDto> roomDtos) {
- if (roomIds == null || roomIds.size() < 1) {
+ if (ListUtil.isNull(roomIds)) {
return;
}
Map info = new HashMap();
@@ -149,12 +226,14 @@
for (RoomDto roomDto : roomDtos) {
for (Map count : repairCounts) {
- if (!StringUtil.isEmpty(roomDto.getRoomId()) && !StringUtil.isEmpty(count.get("roomId").toString())) {
- if (roomDto.getRoomId().equals(count.get("roomId").toString())) {
- roomDto.setRoomOweFee(count.get("oweFee").toString());
- }
- } else {
+ if (StringUtil.isEmpty(roomDto.getRoomId())) {
continue;
+ }
+ if (StringUtil.isEmpty(count.get("roomId").toString())) {
+ continue;
+ }
+ if (roomDto.getRoomId().equals(count.get("roomId").toString())) {
+ roomDto.setRoomOweFee(count.get("oweFee").toString());
}
}
}
@@ -176,7 +255,7 @@
List<Map> repairCounts = reportOweFeeInnerServiceSMOImpl.queryOweFeesByOwnerIds(info);
for (RoomDto roomDto : roomDtos) {
- if(StringUtil.isEmpty(roomDto.getOwnerId())){
+ if (StringUtil.isEmpty(roomDto.getOwnerId())) {
continue;
}
for (Map count : repairCounts) {
@@ -228,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;
}
@@ -264,7 +343,7 @@
List<Map> memberCounts = ownerCarV1InnerServiceSMOImpl.queryOwnerCarCountByOwnerIds(ownerIds);
for (RoomDto roomDto : roomDtos) {
- if(StringUtil.isEmpty(roomDto.getOwnerId())){
+ if (StringUtil.isEmpty(roomDto.getOwnerId())) {
continue;
}
for (Map count : memberCounts) {
@@ -286,14 +365,14 @@
* @param roomDtos
*/
private void queryOwnerMemberCount(List<String> ownerIds, List<RoomDto> roomDtos) {
- if (ownerIds == null || ownerIds.size() < 1) {
+ if (ListUtil.isNull(ownerIds)) {
return;
}
List<Map> memberCounts = ownerV1InnerServiceSMOImpl.queryOwnerMembersCount(ownerIds);
for (RoomDto roomDto : roomDtos) {
- if(StringUtil.isEmpty(roomDto.getOwnerId())){
+ if (StringUtil.isEmpty(roomDto.getOwnerId())) {
continue;
}
for (Map count : memberCounts) {
--
Gitblit v1.8.0