From eaac6d9314b98ea313c16f62b41f01ddbd1114f3 Mon Sep 17 00:00:00 2001
From: 张天森 <1292933220@qq.com>
Date: 星期二, 18 十月 2022 13:56:27 +0800
Subject: [PATCH] 三说会堂事件操作权限处理

---
 springcloud_k8s_panzhihuazhihuishequ/service_community/src/main/java/com/panzhihua/service_community/service/impl/ComEventServiceImpl.java |   49 ++++++++++++++++++++++++++-----------------------
 1 files changed, 26 insertions(+), 23 deletions(-)

diff --git a/springcloud_k8s_panzhihuazhihuishequ/service_community/src/main/java/com/panzhihua/service_community/service/impl/ComEventServiceImpl.java b/springcloud_k8s_panzhihuazhihuishequ/service_community/src/main/java/com/panzhihua/service_community/service/impl/ComEventServiceImpl.java
index e92bb30..93dc79c 100644
--- a/springcloud_k8s_panzhihuazhihuishequ/service_community/src/main/java/com/panzhihua/service_community/service/impl/ComEventServiceImpl.java
+++ b/springcloud_k8s_panzhihuazhihuishequ/service_community/src/main/java/com/panzhihua/service_community/service/impl/ComEventServiceImpl.java
@@ -12,6 +12,7 @@
 import com.baomidou.mybatisplus.core.metadata.IPage;
 import com.baomidou.mybatisplus.extension.plugins.pagination.Page;
 import com.baomidou.mybatisplus.extension.service.impl.ServiceImpl;
+import com.panzhihua.common.constants.Constants;
 import com.panzhihua.common.constants.ReturnMsgConstants;
 import com.panzhihua.common.enums.SanShuoEventStatusEnum;
 import com.panzhihua.common.model.dtos.community.sanshuo.IndexDateDTO;
@@ -85,6 +86,7 @@
     @Override
     public R pageByComEvent(ComEvent comEvent, Page pagination,LoginUserInfoVO loginUserInfoVO) {
         log.info("=================当前登陆的用户信息,用户类型"+loginUserInfoVO.getType()+"社区id"+loginUserInfoVO.getCommunityId());
+        log.info("=====================当前的userType1:="+comEvent.getUserType());
         Boolean isExpertCheck=false;
         Long expertId=null;
         Boolean isStretAccount = isStreetAccount(loginUserInfoVO);
@@ -127,13 +129,13 @@
                 comEvent.setCommunityIds(cids);
             }
         }
-//        if (nonNull(loginUserInfoVO.getAccount())){
-//            if (loginUserInfoVO.getAccount().equals("admin")){
-//                comEvent.setUserType(null);
-//            }
-//        }
+        if (nonNull(loginUserInfoVO.getAccount())){
+            if (loginUserInfoVO.getAccount().equals("admin") && loginUserInfoVO.getStreetId().equals(Constants.ADMIN_STREET_ID)){
+                comEvent.setUserType(null);
+            }
+        }
         IPage<ComEvent> list=null;
-        log.info("=====================当前的userType"+comEvent.getUserType());
+        log.info("=====================当前的userType2:="+comEvent.getUserType());
         log.info("=====================是否专家账号查看"+isExpertCheck);
         //是否为专家查看自己发布的事件
         if (isExpertCheck && comEvent.getUserType()!=1){
@@ -143,7 +145,6 @@
         }else{
             list = baseMapper.pageByComEvent(comEvent, pagination);
         }
-
         if (list.getRecords().size() < 1) {
             return R.ok(Collections.emptyList());
         }
@@ -334,7 +335,7 @@
         }else if (userType.equals(3)){
             //分配行业分中心操作权限
             //是否上报到行业分中心
-            if (comEvent.getReportCenter().equals(1) || comEvent.getCurrentProcessType().equals(1)){
+            if (comEvent.getCurrentProcessType().equals(1)){
                 //已经报到行业分中心
                 if (comEvent.getEventProcessStatus().equals(1) ){
                     //待受理和待验证状态,可以受理,分配专家
@@ -387,7 +388,7 @@
         }else if (userType.equals(5)  || isStreet){
             //街道权限,操作街道下属社区的所有事件
             //是否上报到街道
-            if (comEvent.getReportStreet().equals(1) || comEvent.getCurrentProcessType().equals(3)){
+            if (comEvent.getCurrentProcessType().equals(3)){
                 //已上报到街道
                 if (comEvent.getEventProcessStatus().equals(1) ){
                     //待受理和待验证状态,可以受理,分配专家
@@ -439,8 +440,14 @@
                     comEvent.setChangeExpert(0);
                     comEvent.setConciliation(0);
                 }
-            }else{
+            }else if (comEvent.getCurrentProcessType().equals(4)){
                 //未上报到街道,仅查看
+                comEvent.setSolve(0);
+                comEvent.setDistribution(0);
+                comEvent.setChangeExpert(0);
+                comEvent.setConciliation(0);
+
+            }else {
                 comEvent.setArchive(0);
                 comEvent.setSolve(0);
                 comEvent.setDistribution(0);
@@ -840,9 +847,7 @@
         ComSanshuoExpert specter = comSanShuoExpertService.getById(specialistId);
         comEvent.setSpecialistAcceptTime(new Date());
         comEvent.setSpecialistName(specter.getName());
-        if (comEvent.getEventProcessStatus()<SanShuoEventStatusEnum.conciliation.getCode()){
-            comEvent.setEventProcessStatus(SanShuoEventStatusEnum.VALID.getCode());
-        }
+        comEvent.setEventProcessStatus(SanShuoEventStatusEnum.VALID.getCode());
         int flag = baseMapper.updateById(comEvent);
         //添加一条对应记录
         comEventMapper.insertEventAndExpertRecord(id, specialistId,1);
@@ -856,22 +861,21 @@
         Boolean isExpertCheck=false;
         Long expertId=null;
         Boolean isStretAccount = isStreetAccount(loginUserInfoVO);
-        if (nonNull(comEvent.getUserType())){
-             if (loginUserInfoVO.getType().equals(13) || loginUserInfoVO.getType().equals(11)){
+        if (loginUserInfoVO.getType().equals(13) || loginUserInfoVO.getType().equals(11)){
                 ComSanshuoExpert expert=new ComSanshuoExpert();
                 //专家账号权限(后台)
-                if (nonNull(loginUserInfoVO.getPhone())){
+            if (nonNull(loginUserInfoVO.getPhone())){
                     expert = comSanShuoExpertService.getOne(new QueryWrapper<ComSanshuoExpert>().lambda().eq(ComSanshuoExpert::getPhone, loginUserInfoVO.getPhone()));
-                }else{
+            }else{
                     //账号获取
                     expert = comSanShuoExpertService.getOne(new QueryWrapper<ComSanshuoExpert>().lambda().eq(ComSanshuoExpert::getAccount, loginUserInfoVO.getAccount()));
-                }
-                comEvent.setUserType(2);
-                if (nonNull(expert)){
+            }
+            comEvent.setUserType(2);
+            if (nonNull(expert)){
                     comEvent.setSpecialistId(expert.getId());
                     isExpertCheck=true;
                     expertId=expert.getId();
-                }
+            }
             }else if (loginUserInfoVO.getType().equals(12)){
                 //行业分中心权限
                 comEvent.setUserType(3);
@@ -890,8 +894,7 @@
                 List<Long> cids = comActDAO.selectCommunityByStreetId(loginUserInfoVO.getStreetId());
                 comEvent.setUserType(5);
                 comEvent.setCommunityIds(cids);
-            }
-        }
+         }
         if (isExpertCheck && comEvent.getUserType()!=1){
             if (nonNull(comEventMapper.listEventIds(expertId))){
                 List<Long> eventIds = comEventMapper.listEventIds(expertId);

--
Gitblit v1.7.1