wuxw лет назад: 2
Родитель
Сommit
8237814fbf

+ 16 - 0
java110-db/src/main/resources/mapper/report/BaseDataStatisticsServiceDaoImplMapper.xml

@@ -354,5 +354,21 @@
         group by t.community_id
         group by t.community_id
         ) a order by a.count desc limit 10
         ) a order by a.count desc limit 10
     </select>
     </select>
+    <select id="getCommunityRepairCount" parameterType="Map" resultType="Map">
+        select * from (
+        select t.community_id communityId,count(1) count from r_repair_pool t
+        where t.status_cd = '0'
+        <if test="communityIds !=null ">
+            and t.community_id in
+            <foreach collection="communityIds" item="item" open="(" close=")" separator=",">
+                #{item}
+            </foreach>
+        </if>
+        and t.create_time &gt;= #{startTime}
+        and t.create_time &lt;= #{endTime}
+        group by t.community_id
+        ) a order by a.count desc limit 10
+    </select>
+
 
 
 </mapper>
 </mapper>

+ 2 - 0
java110-interface/src/main/java/com/java110/intf/report/IBaseDataStatisticsInnerServiceSMO.java

@@ -65,4 +65,6 @@ public interface IBaseDataStatisticsInnerServiceSMO {
 
 
     @RequestMapping(value = "/getCommunityFeeDetailCount", method = RequestMethod.POST)
     @RequestMapping(value = "/getCommunityFeeDetailCount", method = RequestMethod.POST)
     List<Map> getCommunityFeeDetailCount(@RequestBody  Map info);
     List<Map> getCommunityFeeDetailCount(@RequestBody  Map info);
+
+    List<Map> getCommunityRepairCount(@RequestBody Map info);
 }
 }

+ 122 - 0
service-report/src/main/java/com/java110/report/cmd/admin/QueryCommunityRepairCmd.java

@@ -0,0 +1,122 @@
+package com.java110.report.cmd.admin;
+
+import com.alibaba.fastjson.JSONObject;
+import com.java110.core.annotation.Java110Cmd;
+import com.java110.core.context.CmdContextUtils;
+import com.java110.core.context.ICmdDataFlowContext;
+import com.java110.core.event.cmd.Cmd;
+import com.java110.core.event.cmd.CmdEvent;
+import com.java110.dto.community.CommunityDto;
+import com.java110.dto.store.StoreDto;
+import com.java110.intf.community.ICommunityInnerServiceSMO;
+import com.java110.intf.store.IStoreInnerServiceSMO;
+import com.java110.report.statistics.IBaseDataStatistics;
+import com.java110.utils.exception.CmdException;
+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.text.ParseException;
+import java.util.ArrayList;
+import java.util.HashMap;
+import java.util.List;
+import java.util.Map;
+
+@Java110Cmd(serviceCode = "admin.queryCommunityRepair")
+public class QueryCommunityRepairCmd extends Cmd {
+
+    @Autowired
+    private IStoreInnerServiceSMO storeInnerServiceSMOImpl;
+
+    @Autowired
+    private ICommunityInnerServiceSMO communityInnerServiceSMOImpl;
+
+    @Autowired
+    private IBaseDataStatistics baseDataStatisticsImpl;
+
+    @Override
+    public void validate(CmdEvent event, ICmdDataFlowContext context, JSONObject reqJson) throws CmdException, ParseException {
+
+        String storeId = CmdContextUtils.getStoreId(context);
+
+        StoreDto storeDto = new StoreDto();
+        storeDto.setStoreId(storeId);
+        storeDto.setStoreTypeCd(StoreDto.STORE_TYPE_ADMIN);
+        int count = storeInnerServiceSMOImpl.getStoreCount(storeDto);
+        if (count < 1) {
+            throw new CmdException("非法操作,请用系统管理员账户操作");
+        }
+
+        if (!reqJson.containsKey("startTime")) {
+            String startTime = DateUtil.getNow(DateUtil.DATE_FORMATE_STRING_B);
+            String endTime = startTime + " 23:59:59";
+            reqJson.put("startTime", startTime);
+            reqJson.put("endTime", endTime);
+        }
+
+        String startTime = reqJson.getString("startTime");
+        if (StringUtil.isEmpty(startTime)) {
+            startTime = DateUtil.getNow(DateUtil.DATE_FORMATE_STRING_B);
+            String endTime = startTime + " 23:59:59";
+            reqJson.put("startTime", startTime);
+            reqJson.put("endTime", endTime);
+        }
+    }
+
+    @Override
+    public void doCmd(CmdEvent event, ICmdDataFlowContext context, JSONObject reqJson) throws CmdException, ParseException {
+
+        CommunityDto communityDto = new CommunityDto();
+        communityDto.setPage(1);
+        communityDto.setRow(100);
+        List<CommunityDto> communityDtos = communityInnerServiceSMOImpl.queryCommunitys(communityDto);
+        List<Map> datas = null;
+        if (communityDtos == null || communityDtos.isEmpty()) {
+            datas = new ArrayList<>();
+            Map data = new HashMap();
+            data.put("communityId", "-1");
+            data.put("communityName", "未添加小区");
+            data.put("count", 0);
+
+            datas.add(data);
+            context.setResponseEntity(ResultVo.createResponseEntity(datas));
+            return;
+        }
+
+        List<String> communityIds = new ArrayList<>();
+        for (CommunityDto tmpCommunityDto : communityDtos) {
+            communityIds.add(tmpCommunityDto.getCommunityId());
+        }
+
+        reqJson.put("communityIds", communityIds.toArray(new String[communityIds.size()]));
+        datas = baseDataStatisticsImpl.getCommunityRepairCount(reqJson);
+
+        if (datas == null || datas.isEmpty()) {
+            datas = new ArrayList<>();
+            for (int communityIndex = 0; communityIndex < communityDtos.size(); communityIndex++) {
+                if (communityIndex > 9) {
+                    continue;
+                }
+                Map data = new HashMap();
+                data.put("communityId", communityDtos.get(communityIndex).getCommunityId());
+                data.put("communityName", communityDtos.get(communityIndex).getName());
+                data.put("count", 0);
+                datas = new ArrayList<>();
+                datas.add(data);
+            }
+            context.setResponseEntity(ResultVo.createResponseEntity(datas));
+            return;
+        }
+
+        for (Map data : datas) {
+            for (CommunityDto tmpCommunityDto : communityDtos) {
+                if (data.get("communityId").equals(tmpCommunityDto.getCommunityId())) {
+                    data.put("communityName", tmpCommunityDto.getName());
+                }
+            }
+        }
+
+        context.setResponseEntity(ResultVo.createResponseEntity(datas));
+    }
+}

+ 2 - 0
service-report/src/main/java/com/java110/report/dao/IBaseDataStatisticsServiceDao.java

@@ -51,4 +51,6 @@ public interface IBaseDataStatisticsServiceDao {
     List<Map> getOweRoomInfo(Map info);
     List<Map> getOweRoomInfo(Map info);
 
 
     List<Map> getCommunityFeeDetailCount(Map info);
     List<Map> getCommunityFeeDetailCount(Map info);
+
+    List<Map> getCommunityRepairCount(Map info);
 }
 }

+ 6 - 0
service-report/src/main/java/com/java110/report/dao/impl/BaseDataStatisticsServiceDaoImpl.java

@@ -80,4 +80,10 @@ public class BaseDataStatisticsServiceDaoImpl extends BaseServiceDao implements
         List<Map> infos = sqlSessionTemplate.selectList("baseDataStatisticsServiceDaoImpl.getCommunityFeeDetailCount", info);
         List<Map> infos = sqlSessionTemplate.selectList("baseDataStatisticsServiceDaoImpl.getCommunityFeeDetailCount", info);
         return infos;
         return infos;
     }
     }
+
+    @Override
+    public List<Map> getCommunityRepairCount(Map info) {
+        List<Map> infos = sqlSessionTemplate.selectList("baseDataStatisticsServiceDaoImpl.getCommunityRepairCount", info);
+        return infos;
+    }
 }
 }

+ 7 - 1
service-report/src/main/java/com/java110/report/smo/impl/BaseDataStatisticsInnerServiceSMOImpl.java

@@ -98,8 +98,14 @@ public class BaseDataStatisticsInnerServiceSMOImpl extends BaseServiceSMO implem
     }
     }
 
 
     @Override
     @Override
-    public List<Map> getCommunityFeeDetailCount(Map info) {
+    public List<Map> getCommunityFeeDetailCount(@RequestBody Map info) {
         List<Map> infos = baseDataStatisticsServiceDaoImpl.getCommunityFeeDetailCount(info);
         List<Map> infos = baseDataStatisticsServiceDaoImpl.getCommunityFeeDetailCount(info);
         return infos;
         return infos;
     }
     }
+
+    @Override
+    public List<Map> getCommunityRepairCount(@RequestBody Map info) {
+        List<Map> infos = baseDataStatisticsServiceDaoImpl.getCommunityRepairCount(info);
+        return infos;
+    }
 }
 }

+ 3 - 0
service-report/src/main/java/com/java110/report/statistics/IBaseDataStatistics.java

@@ -1,5 +1,6 @@
 package com.java110.report.statistics;
 package com.java110.report.statistics;
 
 
+import com.alibaba.fastjson.JSONObject;
 import com.java110.dto.room.RoomDto;
 import com.java110.dto.room.RoomDto;
 import com.java110.dto.contract.ContractDto;
 import com.java110.dto.contract.ContractDto;
 import com.java110.dto.owner.OwnerCarDto;
 import com.java110.dto.owner.OwnerCarDto;
@@ -97,4 +98,6 @@ public interface IBaseDataStatistics {
      * @return
      * @return
      */
      */
     List<Map> getCommunityFeeDetailCount(Map info);
     List<Map> getCommunityFeeDetailCount(Map info);
+
+    List<Map> getCommunityRepairCount(Map info);
 }
 }

+ 4 - 2
service-report/src/main/java/com/java110/report/statistics/impl/BaseDataStatisticsImpl.java

@@ -229,8 +229,10 @@ public class BaseDataStatisticsImpl implements IBaseDataStatistics {
        return baseDataStatisticsInnerServiceSMOImpl.getCommunityFeeDetailCount(info);
        return baseDataStatisticsInnerServiceSMOImpl.getCommunityFeeDetailCount(info);
     }
     }
 
 
-
-
+    @Override
+    public List<Map> getCommunityRepairCount(Map info) {
+        return baseDataStatisticsInnerServiceSMOImpl.getCommunityRepairCount(info);
+    }
 
 
 
 
     /**
     /**