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