From b173d31976fc4731b7c247d4038de92134eba317 Mon Sep 17 00:00:00 2001
From: java110 <928255095@qq.com>
Date: 星期四, 29 六月 2023 11:42:17 +0800
Subject: [PATCH] Merge branch 'master' of http://git.homecommunity.cn/supervip/MicroCommunity

---
 service-report/src/main/java/com/java110/report/cmd/dataReport/QueryDataReportFeeStatisticsCmd.java |  143 ++++++++++++++++++++++++++++++-----------------
 1 files changed, 92 insertions(+), 51 deletions(-)

diff --git a/service-report/src/main/java/com/java110/report/cmd/dataReport/QueryDataReportFeeStatisticsCmd.java b/service-report/src/main/java/com/java110/report/cmd/dataReport/QueryDataReportFeeStatisticsCmd.java
index 6cc64e4..ee20a1a 100644
--- a/service-report/src/main/java/com/java110/report/cmd/dataReport/QueryDataReportFeeStatisticsCmd.java
+++ b/service-report/src/main/java/com/java110/report/cmd/dataReport/QueryDataReportFeeStatisticsCmd.java
@@ -1,23 +1,25 @@
 package com.java110.report.cmd.dataReport;
 
+import com.alibaba.fastjson.JSONArray;
 import com.alibaba.fastjson.JSONObject;
 import com.java110.core.annotation.Java110Cmd;
 import com.java110.core.context.ICmdDataFlowContext;
 import com.java110.core.event.cmd.Cmd;
 import com.java110.core.event.cmd.CmdEvent;
+import com.java110.dto.floor.FloorDto;
 import com.java110.dto.report.QueryStatisticsDto;
+import com.java110.intf.community.IFloorV1InnerServiceSMO;
+import com.java110.report.statistics.IBaseDataStatistics;
 import com.java110.report.statistics.IFeeStatistics;
 import com.java110.utils.exception.CmdException;
 import com.java110.utils.util.Assert;
+import com.java110.utils.util.DateUtil;
 import com.java110.utils.util.StringUtil;
 import com.java110.vo.ResultVo;
 import org.springframework.beans.factory.annotation.Autowired;
 
-import java.math.BigDecimal;
 import java.text.ParseException;
-import java.util.ArrayList;
 import java.util.List;
-import java.util.Map;
 
 /**
  * 鏌ヨ鏀惰垂鎯呭喌鍒嗘瀽
@@ -28,6 +30,12 @@
 
     @Autowired
     private IFeeStatistics feeStatisticsImpl;
+
+    @Autowired
+    private IFloorV1InnerServiceSMO floorV1InnerServiceSMOImpl;
+
+    @Autowired
+    private IBaseDataStatistics baseDataStatisticsImpl;
 
     @Override
     public void validate(CmdEvent event, ICmdDataFlowContext context, JSONObject reqJson) throws CmdException, ParseException {
@@ -48,63 +56,96 @@
 
     @Override
     public void doCmd(CmdEvent event, ICmdDataFlowContext context, JSONObject reqJson) throws CmdException, ParseException {
+
+        String[] floorIds = reqJson.getString("floorIds").split(",");
+        //todo 濡傛灉娌℃湁鍖呭惈妤兼爧淇℃伅 鐩存帴杩斿洖绌�
+        if (floorIds == null || floorIds.length < 1) {
+            return;
+        }
+        JSONArray data = new JSONArray();
+        //todo 鏍规嵁妤兼爧ID寰幆鏌ヨ
+        for (String floorId : floorIds) {
+            //todo 鑾峰彇鍒版暟鎹�
+            doGetData(floorId, data, reqJson);
+        }
+        context.setResponseEntity(ResultVo.createResponseEntity(data));
+    }
+
+    /**
+     * 鏌ヨ鏁版嵁
+     *
+     * @param floorId
+     * @param datas
+     */
+    private void doGetData(String floorId, JSONArray datas, JSONObject reqJson) {
+        JSONObject data = new JSONObject();
         QueryStatisticsDto queryStatisticsDto = new QueryStatisticsDto();
         queryStatisticsDto.setCommunityId(reqJson.getString("communityId"));
+        queryStatisticsDto.setFloorId(floorId);
         queryStatisticsDto.setStartDate(reqJson.getString("startDate"));
         queryStatisticsDto.setEndDate(reqJson.getString("endDate"));
-        queryStatisticsDto.setConfigId(reqJson.getString("configId"));
-        queryStatisticsDto.setObjName(reqJson.getString("objName"));
         queryStatisticsDto.setFeeTypeCd(reqJson.getString("feeTypeCd"));
-        queryStatisticsDto.setOwnerName(reqJson.getString("ownerName"));
 
-        List<Map> datas = null;
-        // todo 鎸夋ゼ鏍嬭绠楀疄鏀舵儏鍐�
-        datas = feeStatisticsImpl.getReceivedFeeByFloor(queryStatisticsDto);
+        // todo 鏌ヨ妤兼爧
+        FloorDto floorDto = new FloorDto();
+        floorDto.setFloorId(floorId);
+        floorDto.setCommunityId(reqJson.getString("communityId"));
+        List<FloorDto> floorDtos = floorV1InnerServiceSMOImpl.queryFloors(floorDto);
+        Assert.listOnlyOne(floorDtos, "妤兼爧涓嶅瓨鍦�");
+        data.put("floorNum", floorDtos.get(0).getFloorNum());
 
-        datas = computeFloorReceivedFee(datas);
+        // todo 鏌ヨ鎴锋暟
+        long roomCount = baseDataStatisticsImpl.getRoomCount(queryStatisticsDto);
+        data.put("roomCount", roomCount);
 
-        context.setResponseEntity(ResultVo.createResponseEntity(datas));
+        // todo 鏌ヨ绌虹疆鎴锋暟
+        long freeCount = baseDataStatisticsImpl.getFreeRoomCount(queryStatisticsDto);
+        data.put("freeCount", freeCount);
+
+        // todo 鏌ヨ 鍘嗗彶娆犺垂
+        double hisMonthOweFee = feeStatisticsImpl.getHisMonthOweFee(queryStatisticsDto);
+        data.put("hisMonthOweFee", hisMonthOweFee);
+
+        // todo 鏌ヨ鎬绘瑺璐�
+        double oweFee = feeStatisticsImpl.getOweFee(queryStatisticsDto);
+        data.put("oweFee", oweFee);
+
+        // todo 鏈棩宸蹭氦鎴锋暟
+        queryStatisticsDto.setStartDate(DateUtil.getFormatTimeStringB(DateUtil.getCurrentDate()) + " 00:00:00");
+        queryStatisticsDto.setEndDate(DateUtil.getFormatTimeStringB(DateUtil.getCurrentDate()) + " 23:59:59");
+        queryStatisticsDto.setHisDate(DateUtil.getFormatTimeStringB(DateUtil.getFirstDate()));
+        double todayReceivedRoomCount = feeStatisticsImpl.getReceivedRoomCount(queryStatisticsDto);
+        data.put("todayReceivedRoomCount", todayReceivedRoomCount);
+
+        // todo 鏈棩宸蹭氦閲戦
+        double todayReceivedRoomAmount = feeStatisticsImpl.getReceivedRoomAmount(queryStatisticsDto);
+        data.put("todayReceivedRoomAmount", todayReceivedRoomAmount);
+
+        // todo 鍘嗗彶娆犺垂娓呯即鎴�
+        double hisOweReceivedRoomCount = feeStatisticsImpl.getHisOweReceivedRoomCount(queryStatisticsDto);
+        data.put("hisOweReceivedRoomCount", hisOweReceivedRoomCount);
+        // todo 鍘嗗彶娆犺垂娓呯即閲戦
+        double hisOweReceivedRoomAmount = feeStatisticsImpl.getHisOweReceivedRoomAmount(queryStatisticsDto);
+        data.put("hisOweReceivedRoomAmount", hisOweReceivedRoomAmount);
+
+        // todo 杩欓噷鏃堕棿鍙堟敼鍥炴潵
+        queryStatisticsDto.setStartDate(reqJson.getString("startDate"));
+        queryStatisticsDto.setEndDate(reqJson.getString("endDate"));
+        // todo 鏈湀宸叉敹鎴�
+        double monthReceivedRoomCount = feeStatisticsImpl.getReceivedRoomCount(queryStatisticsDto);
+        data.put("monthReceivedRoomCount", monthReceivedRoomCount);
+
+        // todo 宸叉敹閲戦
+        double monthReceivedRoomAmount = feeStatisticsImpl.getReceivedRoomAmount(queryStatisticsDto);
+        data.put("monthReceivedRoomAmount", monthReceivedRoomAmount);
+        // todo 鍓╀綑鏈敹
+        double curMonthOweFee = feeStatisticsImpl.getCurMonthOweFee(queryStatisticsDto);
+        data.put("curMonthOweFee", curMonthOweFee);
+
+        datas.add(data);
+
+
     }
 
-    private List<Map> computeFloorReceivedFee(List<Map> datas) {
-        if (datas == null || datas.size() < 1) {
-            return new ArrayList<>();
-        }
-
-        List<Map> tmpDatas = new ArrayList<>();
-        for (Map data : datas) {
-            if (!hasInTmp(tmpDatas, data)) {
-                tmpDatas.add(data);
-            }
-        }
-
-        if (tmpDatas == null || tmpDatas.size() < 1) {
-            return new ArrayList<>();
-        }
-
-        BigDecimal receivedFee = new BigDecimal(0.00);
-        for (Map tmpData : tmpDatas) {
-            for (Map data : datas) {
-                if (!data.get("floorId").toString().equals(tmpData.get("floorId"))) {
-                    continue;
-                }
-
-                receivedFee = receivedFee.add(new BigDecimal(data.get("receivedFee").toString()));
-                tmpData.put("receivedFee" + data.get("feeTypeCd").toString(), data.get("receivedFee"));
-            }
-            tmpData.put("receivedFee", receivedFee.doubleValue());
-        }
-
-        return tmpDatas;
-    }
-
-    private boolean hasInTmp(List<Map> tmpDatas, Map data) {
-        for (Map tmpData : tmpDatas) {
-            if (tmpData.get("floorId").equals(data.get("floorId"))) {
-                return true;
-            }
-        }
-        return false;
-    }
 
 }

--
Gitblit v1.8.0