From 8219cdfcb825b6d75c3a235a7e5195c8cac9a2ea Mon Sep 17 00:00:00 2001
From: songhuangfeng123 <shf18767906695@163.com>
Date: 星期二, 06 九月 2022 11:32:14 +0800
Subject: [PATCH] 统计接口rpc

---
 emergency/emergency-service/src/main/java/com/gkhy/safePlatform/emergency/service/impl/EmergencyCountServiceImpl.java |  145 ++++++++++++++++++++++++++++++++++++++----------
 1 files changed, 114 insertions(+), 31 deletions(-)

diff --git a/emergency/emergency-service/src/main/java/com/gkhy/safePlatform/emergency/service/impl/EmergencyCountServiceImpl.java b/emergency/emergency-service/src/main/java/com/gkhy/safePlatform/emergency/service/impl/EmergencyCountServiceImpl.java
index 63a3827..5ad92ea 100644
--- a/emergency/emergency-service/src/main/java/com/gkhy/safePlatform/emergency/service/impl/EmergencyCountServiceImpl.java
+++ b/emergency/emergency-service/src/main/java/com/gkhy/safePlatform/emergency/service/impl/EmergencyCountServiceImpl.java
@@ -7,6 +7,7 @@
 import com.gkhy.safePlatform.commons.exception.BusinessException;
 import com.gkhy.safePlatform.commons.query.PageQuery;
 import com.gkhy.safePlatform.commons.utils.BeanCopyUtils;
+import com.gkhy.safePlatform.commons.utils.StringUtils;
 import com.gkhy.safePlatform.commons.vo.ResultVO;
 import com.gkhy.safePlatform.commons.vo.SearchResultVO;
 import com.gkhy.safePlatform.emergency.entity.*;
@@ -23,11 +24,11 @@
 import com.gkhy.safePlatform.emergency.service.baseService.EmergencyDrillExecuteInfoService;
 import com.gkhy.safePlatform.emergency.service.baseService.EmergencySuppliesInfoService;
 import com.gkhy.safePlatform.emergency.utils.TimeUtils;
-import com.sun.org.apache.bcel.internal.generic.IF_ACMPEQ;
 import org.apache.dubbo.config.annotation.DubboReference;
 import org.springframework.beans.factory.annotation.Autowired;
 import org.springframework.stereotype.Service;
 import org.springframework.util.CollectionUtils;
+import sun.security.pkcs11.wrapper.CK_SSL3_KEY_MAT_OUT;
 
 import java.text.SimpleDateFormat;
 import java.util.*;
@@ -47,40 +48,64 @@
     @Override
     public SearchResultVO<EmergencyExecuteTimeRPCResp> getTimeByDeptId(EmergencyExecuteTimeRPCReq query) {
         EmergencyExecuteTimeRPCResp emergencyExecuteTimeRPCResp = new EmergencyExecuteTimeRPCResp();
-
         // 获取id对应的部门
         DepInfoRPCRespDTO depInfoRPCRespDTO = getDepInfoByDepId(query.getDeptId());
-
         emergencyExecuteTimeRPCResp.setDeptId(depInfoRPCRespDTO.getDepId());
         emergencyExecuteTimeRPCResp.setDeptName(depInfoRPCRespDTO.getDepName());
         emergencyExecuteTimeRPCResp.setDeptLevel(depInfoRPCRespDTO.getDepLevel());
-        String lastTime = emergencyDrillExecuteInfoService.selectEmergencyDrillExecuteIntervalTimeByDeptId(query.getDeptId());
-        emergencyExecuteTimeRPCResp.setLastTime(lastTime);
-        emergencyExecuteTimeRPCResp.setDays(TimeUtils.differentDays(lastTime, TimeUtils.formatDate(new Date())));
 
-        return new SearchResultVO<>(
+        getSingleTimeData(emergencyExecuteTimeRPCResp);
+        SearchResultVO searchResultVO = new SearchResultVO<>(
                 false,
                 null,
                 null,
                 null,
-                1L,
+                null,
                 emergencyExecuteTimeRPCResp,
                 ResultCodes.OK
         );
+        searchResultVO.setCount(1);
+        return searchResultVO;
     }
 
     @Override
     public SearchResultVO<List<EmergencyExecuteTimeRPCResp>> getTimeByDeptIds(EmergencyExecuteTimeRPCReq query) {
         List<EmergencyExecuteTimeRPCResp> list = new ArrayList<>();
-        return new SearchResultVO<>(
+
+        // 获取该部门及其子部门的所有信息
+        List<DepInfoRPCRespDTO> depList = getDepListInfoByDepId(query.getDeptId());
+        for (DepInfoRPCRespDTO depInfoRPCRespDTO : depList){
+            EmergencyExecuteTimeRPCResp emergencyExecuteTimeRPCResp = new EmergencyExecuteTimeRPCResp();
+            emergencyExecuteTimeRPCResp.setDeptId(depInfoRPCRespDTO.getDepId());
+            emergencyExecuteTimeRPCResp.setDeptName(depInfoRPCRespDTO.getDepName());
+            emergencyExecuteTimeRPCResp.setDeptLevel(depInfoRPCRespDTO.getDepLevel());
+
+            getSingleTimeData(emergencyExecuteTimeRPCResp);
+            list.add(emergencyExecuteTimeRPCResp);
+        }
+
+        SearchResultVO searchResultVO = new SearchResultVO<>(
                 false,
                 null,
                 null,
                 null,
-                (long) list.size(),
+                null,
                 list,
                 ResultCodes.OK
         );
+        if (!list.isEmpty()){
+            searchResultVO.setCount(list.size());
+        }
+        return searchResultVO;
+    }
+
+    private void getSingleTimeData(EmergencyExecuteTimeRPCResp emergencyExecuteTimeRPCResp){
+        // 查询该部门最后一次演练时间
+        String lastTime = emergencyDrillExecuteInfoService.selectEmergencyDrillExecuteIntervalTimeByDeptId(emergencyExecuteTimeRPCResp.getDeptId());
+        if (StringUtils.isNotBlank(lastTime)){
+            emergencyExecuteTimeRPCResp.setLastTime(lastTime);
+//            emergencyExecuteTimeRPCResp.setDays(TimeUtils.differentDays(lastTime, TimeUtils.formatDate(new Date())));
+        }
     }
 
     @Override
@@ -91,45 +116,90 @@
         EmergencyExecuteNumRPCResp emergencyExecuteNumRPCResp = new EmergencyExecuteNumRPCResp();
         // 获取id对应的部门
         DepInfoRPCRespDTO depInfoRPCRespDTO = getDepInfoByDepId(query.getDeptId());
-
         emergencyExecuteNumRPCResp.setDeptId(depInfoRPCRespDTO.getDepId());
         emergencyExecuteNumRPCResp.setDeptName(depInfoRPCRespDTO.getDepName());
         emergencyExecuteNumRPCResp.setDeptLevel(depInfoRPCRespDTO.getDepLevel());
 
-        // 查到该年度对应月份的数据
-        List<Map<String,String>> mapList = new ArrayList<>();
-        String startTime = TimeUtils.getYearFirst(query.getYear());
-        String endTime = TimeUtils.getYearLast(query.getYear());
-        List<Long> deptIds = new ArrayList<>();
-        deptIds.add(query.getDeptId());
-        List<EmergencyDrillExecuteCountData> emergencyDrillExecuteCountDataList = emergencyDrillExecuteInfoService.selectByMonthAndDept(startTime, endTime, deptIds);
-        if (!emergencyDrillExecuteCountDataList.isEmpty()){
-            for (EmergencyDrillExecuteCountData emergencyDrillExecuteCountData : emergencyDrillExecuteCountDataList){
-                Map<String ,String> map = new HashMap<>();
-                map.put("name",emergencyDrillExecuteCountData.getName());
-                map.put("num",emergencyDrillExecuteCountData.getNum().toString());
-                mapList.add(map);
-            }
-        }
-        emergencyExecuteNumRPCResp.setData(mapList);
+        getSingleNumData(emergencyExecuteNumRPCResp,query);
 
-        return new SearchResultVO<>(
+        SearchResultVO searchResultVO = new SearchResultVO<>(
                 false,
                 null,
                 null,
                 null,
-                1L,
+                null,
                 emergencyExecuteNumRPCResp,
                 ResultCodes.OK
         );
+        searchResultVO.setCount(1);
+        return searchResultVO;
     }
 
     @Override
     public SearchResultVO<List<EmergencyExecuteNumRPCResp>> getNumByDeptIds(EmergencyExecuteNumRPCReq query) {
-        return null;
+        List<EmergencyExecuteNumRPCResp> list = new ArrayList<>();
+
+        // 获取该部门及其子部门的所有信息
+        List<DepInfoRPCRespDTO> deptList = getDepListInfoByDepId(query.getDeptId());
+
+        for (DepInfoRPCRespDTO depInfoRPCRespDTO : deptList){
+            EmergencyExecuteNumRPCResp emergencyExecuteNumRPCResp = new EmergencyExecuteNumRPCResp();
+            emergencyExecuteNumRPCResp.setDeptId(depInfoRPCRespDTO.getDepId());
+            emergencyExecuteNumRPCResp.setDeptName(depInfoRPCRespDTO.getDepName());
+            emergencyExecuteNumRPCResp.setDeptLevel(depInfoRPCRespDTO.getDepLevel());
+
+            getSingleNumData(emergencyExecuteNumRPCResp,query);
+            list.add(emergencyExecuteNumRPCResp);
+        }
+
+        SearchResultVO searchResultVO = new SearchResultVO<>(
+                false,
+                null,
+                null,
+                null,
+                null,
+                list,
+                ResultCodes.OK
+        );
+        if (!list.isEmpty()){
+            searchResultVO.setCount(list.size());
+        }
+        return searchResultVO;
     }
 
-    public DepInfoRPCRespDTO getDepInfoByDepId(Long deptId) {
+    private void getSingleNumData(EmergencyExecuteNumRPCResp emergencyExecuteNumRPCResp,EmergencyExecuteNumRPCReq query){
+        List<Long> deptIds = new ArrayList<>();
+        deptIds.add(emergencyExecuteNumRPCResp.getDeptId());
+
+        List<Map<String,Integer>> mapList = new ArrayList<>();
+        List<EmergencyDrillExecuteCountRPC> emergencyDrillExecuteCountDataList = new ArrayList<>();
+
+        String startTime ;
+        String endTime ;
+        if (query.getMonth()==null){
+            // 查该年度12个月份的
+            startTime = TimeUtils.getYearFirst(query.getYear());
+            endTime = TimeUtils.getYearLast(query.getYear());
+            emergencyDrillExecuteCountDataList= emergencyDrillExecuteInfoService.selectByMonthAndDeptForIntegerMonth(startTime, endTime, deptIds);
+        }else{
+            // 查该年度指定月份的
+            startTime = TimeUtils.getMonthFirst(query.getYear(),query.getMonth());
+            endTime = TimeUtils.getMonthLast(query.getYear(),query.getMonth());
+            emergencyDrillExecuteCountDataList= emergencyDrillExecuteInfoService.selectByDayAndDept(startTime, endTime, deptIds);
+        }
+        if (!emergencyDrillExecuteCountDataList.isEmpty()){
+            for (EmergencyDrillExecuteCountRPC emergencyDrillExecuteCountRPC : emergencyDrillExecuteCountDataList){
+                Map<String ,Integer> map = new HashMap<>();
+                // 名称+数据 1如果为查询的是年:返回的name为月份 2如果查询的是月,返回的name为天
+                map.put("name",emergencyDrillExecuteCountRPC.getName());
+                map.put("num",emergencyDrillExecuteCountRPC.getNum());
+                mapList.add(map);
+            }
+        }
+        emergencyExecuteNumRPCResp.setData(mapList);
+    }
+
+    private DepInfoRPCRespDTO getDepInfoByDepId(Long deptId) {
         DepInfoRPCRespDTO dep = new DepInfoRPCRespDTO();
         ResultVO<DepInfoRPCRespDTO> rpcResult = accountDepartmentService.getDepInfoByDepId(deptId);
         if (rpcResult != null && rpcResult.getCode().equals(ResultCodes.OK.getCode())) {
@@ -142,6 +212,19 @@
         return dep;
     }
 
+    private List<DepInfoRPCRespDTO> getDepListInfoByDepId(Long deptId){
+        List<DepInfoRPCRespDTO> depList = new ArrayList<>();
+        ResultVO<List<DepInfoRPCRespDTO>> rpcResult = accountDepartmentService.listDepAndSubDepByDepId(deptId);
+        if (rpcResult != null && rpcResult.getCode().equals(ResultCodes.OK.getCode())) {
+            if (rpcResult.getData() != null) {
+                depList = (List<DepInfoRPCRespDTO>)rpcResult.getData();
+            }
+        } else {
+            throw new BusinessException(ResultCodes.CLIENT_DEP_NOT_EXIST);
+        }
+        return depList;
+    }
+
     @Override
     public ResultVO<EmergencyDrillExecuteCountRespDTO> countEmergencyDrillExecute(EmergencyDrillExecuteCountQuery query) {
 

--
Gitblit v1.9.2