From bd3a56723062aad602636ee47c91fccf2b2868f6 Mon Sep 17 00:00:00 2001
From: huanghongfa <huanghongfa123456>
Date: 星期一, 07 六月 2021 16:50:11 +0800
Subject: [PATCH] 定时上报网格员定位数据

---
 springcloud_k8s_panzhihuazhihuishequ/service_grid/src/main/java/com/panzhihua/service_grid/service/impl/EventServiceImpl.java |   93 ++++++++++++++++++++++++++++++++++++++++------
 1 files changed, 80 insertions(+), 13 deletions(-)

diff --git a/springcloud_k8s_panzhihuazhihuishequ/service_grid/src/main/java/com/panzhihua/service_grid/service/impl/EventServiceImpl.java b/springcloud_k8s_panzhihuazhihuishequ/service_grid/src/main/java/com/panzhihua/service_grid/service/impl/EventServiceImpl.java
index d927b3f..71390d5 100644
--- a/springcloud_k8s_panzhihuazhihuishequ/service_grid/src/main/java/com/panzhihua/service_grid/service/impl/EventServiceImpl.java
+++ b/springcloud_k8s_panzhihuazhihuishequ/service_grid/src/main/java/com/panzhihua/service_grid/service/impl/EventServiceImpl.java
@@ -11,10 +11,7 @@
 import com.panzhihua.common.model.dtos.grid.*;
 import com.panzhihua.common.model.vos.R;
 import com.panzhihua.common.model.vos.community.ComActVO;
-import com.panzhihua.common.model.vos.grid.EventDetailsVO;
-import com.panzhihua.common.model.vos.grid.EventResourceVO;
-import com.panzhihua.common.model.vos.grid.EventTransferRecordVO;
-import com.panzhihua.common.model.vos.grid.EventVO;
+import com.panzhihua.common.model.vos.grid.*;
 import com.panzhihua.common.service.community.CommunityService;
 import com.panzhihua.common.utlis.StringUtils;
 import com.panzhihua.service_grid.dao.*;
@@ -487,7 +484,8 @@
         if(updated!=1){
             throw new ServiceException("更新突发事件状态更新失败");
         }
-        addTransferRecord(eventDO.getId(), commonEventReportDTO.getToId(), comActVO.getName(), 2, commonEventReportDTO.getProcessResult(),2);
+        addTransferRecord(eventDO.getId(), commonEventReportDTO.getToId(), comActVO.getName(), 2, commonEventReportDTO.getProcessResult(),
+                commonEventReportDTO.getUserId(), commonEventReportDTO.getUserName(), 2);
         return R.ok();
 
     }
@@ -558,7 +556,7 @@
             processType = 1;
         }
         EventTransferRecordDO transferRecordDO =
-                addTransferRecord(eventDO.getId(), commonEventDealDTO.getUserId(), commonEventDealDTO.getUserName(),1, "网格员自处理完成", processType);
+                addTransferRecord(eventDO.getId(), commonEventDealDTO.getUserId(), commonEventDealDTO.getUserName(),1, "网格员自处理完成",  commonEventDealDTO.getUserId(), commonEventDealDTO.getUserName(), processType);
         if(transferRecordDO!=null && transferRecordDO.getId()!=null){
             //添加音频
             if(StringUtils.isNotEmpty(commonEventDealDTO.getAudio())){
@@ -646,9 +644,9 @@
     @Override
     public R republishEvent(CommonEventRepublishDTO commonEventRepublishDTO) {
         EventDO eventDO = this.getBaseMapper().selectById(commonEventRepublishDTO.getId());
-        boolean canRepublishByUser = eventDO.getEventStatus()==4;
+        boolean canRepublishByUser = eventDO.getEventStatus()==4||eventDO.getEventStatus()==1;
         if(!canRepublishByUser){
-            return R.fail("当前不是撤销状态");
+            return R.fail("当前不是撤销/草稿状态");
         }
 
         eventDO.setEventStatus(2);//2 发布
@@ -659,7 +657,8 @@
         if(updated!=1){
             return R.fail("更新事件状态失败");
         }
-        addTransferRecord(eventDO.getId(), commonEventRepublishDTO.getUserId(), commonEventRepublishDTO.getUserName(), 1, "重新发布已撤销事件", 8);
+        addTransferRecord(eventDO.getId(), commonEventRepublishDTO.getUserId(), commonEventRepublishDTO.getUserName(), 1,
+                "重新发布已撤销事件", commonEventRepublishDTO.getUserId(), commonEventRepublishDTO.getUserName(), 8);
         return R.ok();
     }
 
@@ -1284,7 +1283,8 @@
         eventDO.setInvalid(true);
         int updated = this.getBaseMapper().updateById(eventDO);
         if(updated == 1){
-            addTransferRecord(eventDO.getId(), commonEventRepublishDTO.getUserId(), commonEventRepublishDTO.getUserName(), 1,"重新发布事件成功", 9 );
+            addTransferRecord(eventDO.getId(), commonEventRepublishDTO.getUserId(), commonEventRepublishDTO.getUserName(), 1,"重新发布事件成功",
+                    commonEventRepublishDTO.getUserId(), commonEventRepublishDTO.getUserName(), 9 );
             return R.ok();
         }
         return R.fail();
@@ -1301,6 +1301,24 @@
             return R.fail("事件当前不是上报状态");
         }
 
+        List<EventTransferRecordDO> list = eventTransferRecordService.getBaseMapper().selectList(new LambdaQueryWrapper<EventTransferRecordDO>()
+                .eq(EventTransferRecordDO::getEventId, eventDO.getId())
+                .orderByDesc(EventTransferRecordDO::getCreateAt)
+        );
+
+        Long reportToInDB = -1L;
+        for (int i = 0; i < list.size(); i++) {
+            EventTransferRecordDO eventTransferRecordDO = list.get(i);
+            if(eventTransferRecordDO.getProcessType()!=null && eventTransferRecordDO.getProcessType()==2){
+                reportToInDB = eventTransferRecordDO.getToId();
+            }
+        }
+        if(commonEventDealDTO.getCommunityId()==null){
+            return R.fail("当前用户社区获取失败");
+        }
+        if(reportToInDB.longValue() != commonEventDealDTO.getCommunityId().longValue()){
+            return R.fail("用户上报的社区不是当前社区");
+        }
         if(commonEventDealDTO.getNeedVerify()){
             eventDO.setEventProcessStatus(3);//待验证状态
             eventDO.setProcessType(1);//交给网格员处理-验证
@@ -1320,7 +1338,8 @@
             return R.fail("更新事件状态失败");
         }
         EventTransferRecordDO transferRecordDO =
-                addTransferRecord(eventDO.getId(), commonEventDealDTO.getUserId(), commonEventDealDTO.getUserName(),1, "社区处理完成", 3);
+                addTransferRecord(eventDO.getId(), commonEventDealDTO.getUserId(), commonEventDealDTO.getUserName(),1,
+                        "社区处理完成", commonEventDealDTO.getCommunityId(), commonEventDealDTO.getCommunityName(), 3);
         if(transferRecordDO!=null && transferRecordDO.getId()!=null){
             //添加音频
             if(StringUtils.isNotEmpty(commonEventDealDTO.getAudio())){
@@ -1506,9 +1525,9 @@
      * @param msg 流转消息
      * @return
      */
-    private EventTransferRecordDO addTransferRecord(Long eventId, Long toId, String toName, Integer toType, String msg,Integer processType){
+   /* private EventTransferRecordDO addTransferRecord(Long eventId, Long toId, String toName, Integer toType, String msg,Integer processType){
         return addTransferRecord(eventId, toId, toName, toType, msg, null, null, processType);
-    }
+    }*/
 
     /**
      * 根据子状态 查询用户事件处理状态
@@ -1600,4 +1619,52 @@
     public R gridMemberStatistics(MemberStatisticsAdminDTO statisticsAdminDTO){
         return R.ok(eventGridMemberRelationMapper.gridMemberStatistics(new Page(statisticsAdminDTO.getPageNum(),statisticsAdminDTO.getPageSize()),statisticsAdminDTO));
     }
+
+    /**
+     * 根据网格id查询网格统计数据
+     * @param gridId    网格id
+     * @return  网格统计数据
+     */
+    @Override
+    public R getGridEventStatisticsByApp(Long gridId){
+        return R.ok(this.baseMapper.getGridEventStatisticsByApp(gridId));
+    }
+
+    /**
+     * 查询网格事件统计数据
+     * @param statisticsDTO 请求参数
+     * @return  网格事件统计数据
+     */
+    @Override
+    public R getGridEventDetailStatisticsByApp(GridEventStatisticsDTO statisticsDTO){
+        GridEventStatisticsDetailVO statisticsDetailVO = this.baseMapper.getGridEventDetailStatisticsByApp(statisticsDTO);
+        if(statisticsDetailVO == null){
+            statisticsDetailVO = new GridEventStatisticsDetailVO();
+        }
+
+        if(statisticsDetailVO.getEventSSPTotal() == null){
+            statisticsDetailVO.setEventSSPTotal(0);
+        }
+        if(statisticsDetailVO.getNoEventSSPTotal() == null){
+            statisticsDetailVO.setNoEventSSPTotal(0);
+        }
+        if(statisticsDetailVO.getEventZFTotal() == null){
+            statisticsDetailVO.setEventZFTotal(0);
+        }
+        if(statisticsDetailVO.getNoEventZFTotal() == null){
+            statisticsDetailVO.setNoEventZFTotal(0);
+        }
+
+        //统计数据
+        Integer sum = statisticsDetailVO.getEventTFTotal() + statisticsDetailVO.getEventMDTotal() + statisticsDetailVO.getEventZATotal()
+                + statisticsDetailVO.getEventBWDTotal() + statisticsDetailVO.getEventTSTotal() + statisticsDetailVO.getEventGGTotal()
+                + statisticsDetailVO.getEventXCTotal() + statisticsDetailVO.getEventSSPTotal() + statisticsDetailVO.getEventZFTotal();
+        statisticsDetailVO.setSum(sum);
+
+        Integer noSum = statisticsDetailVO.getNoEventTFTotal() + statisticsDetailVO.getNoEventMDTotal() + statisticsDetailVO.getNoEventZATotal()
+                + statisticsDetailVO.getNoEventBWDTotal() + statisticsDetailVO.getNoEventTSTotal() + statisticsDetailVO.getNoEventGGTotal()
+                + statisticsDetailVO.getNoEventSSPTotal() + statisticsDetailVO.getNoEventZFTotal();
+        statisticsDetailVO.setNoSum(noSum);
+        return R.ok(statisticsDetailVO);
+    }
 }

--
Gitblit v1.7.1