From e3aaacbccfe7aa6f99e3f116138efd9499abe7a5 Mon Sep 17 00:00:00 2001
From: 101captain <237651143@qq.com>
Date: 星期二, 14 六月 2022 10:27:56 +0800
Subject: [PATCH] bug修改

---
 springcloud_k8s_panzhihuazhihuishequ/service_user/src/main/java/com/panzhihua/service_user/service/impl/UserServiceImpl.java |  226 ++++++++++++++++++++++++++++++++++++++++++--------------
 1 files changed, 170 insertions(+), 56 deletions(-)

diff --git a/springcloud_k8s_panzhihuazhihuishequ/service_user/src/main/java/com/panzhihua/service_user/service/impl/UserServiceImpl.java b/springcloud_k8s_panzhihuazhihuishequ/service_user/src/main/java/com/panzhihua/service_user/service/impl/UserServiceImpl.java
index 2d6673a..d18f6f1 100644
--- a/springcloud_k8s_panzhihuazhihuishequ/service_user/src/main/java/com/panzhihua/service_user/service/impl/UserServiceImpl.java
+++ b/springcloud_k8s_panzhihuazhihuishequ/service_user/src/main/java/com/panzhihua/service_user/service/impl/UserServiceImpl.java
@@ -16,10 +16,11 @@
 import java.util.stream.Collectors;
 
 import javax.annotation.Resource;
-import javax.validation.constraints.NotBlank;
 
 import com.alibaba.fastjson.JSONObject;
 import com.panzhihua.common.model.dtos.community.microCommercialStreet.BindUserPhoneDTO;
+import com.panzhihua.common.model.vos.community.ComAreaTownCommunityVO;
+import com.panzhihua.common.model.vos.community.acid.ComActAcidMemberVO;
 import com.panzhihua.common.model.vos.community.microCommercialStreet.McsLoginUserInfoVO;
 import com.panzhihua.service_user.dao.*;
 import com.panzhihua.service_user.entity.SysAppConfig;
@@ -331,6 +332,10 @@
             loginUserInfoVO.setCommunityId(sysUserDO.getCommunityId());
             if(comActVO!=null){
                 loginUserInfoVO.setComActVO(comActVO);
+                String areaName=userDao.selectAreaCodeByStreetId(comActVO.getStreetId());
+                if(StringUtils.isNotEmpty(areaName)){
+                    loginUserInfoVO.setAreaName(areaName);
+                }
                 SysAppConfig sysAppConfig=sysAppConfigDao.selectOne(new QueryWrapper<SysAppConfig>().lambda().eq(SysAppConfig::getAreaCode,comActVO.getAreaCode()));
                 if(sysAppConfig!=null){
                     loginUserInfoVO.setAppId(sysAppConfig.getAppId());
@@ -377,6 +382,8 @@
         loginUserInfoVO.setIsCommunityWorker(2);
         loginUserInfoVO.setIsPropertyWorker(2);
         loginUserInfoVO.setIsSocialWorker(2);
+        loginUserInfoVO.setIsFmsMember(2);
+        loginUserInfoVO.setIsAcidMember(0);
         // 志愿者状态
         String phone = sysUserDO.getPhone();
         Long userCommunityId = sysUserDO.getCommunityId();
@@ -410,6 +417,34 @@
             int countPropertyWorker = userDao.countPropertyWorker(Long.parseLong(userId), userCommunityId);
             if (countPropertyWorker > 0) {
                 loginUserInfoVO.setIsPropertyWorker(1);
+            }
+            //是否微团队成员
+            int countFmsMember = userDao.countFmsMember(phone, userCommunityId);
+            if (countFmsMember > 0) {
+                loginUserInfoVO.setIsFmsMember(1);
+            }
+            //是否是防疫工作人员
+            ComActAcidMemberVO acidMember = userDao.selectAcidMemberByPhone(phone);
+            if (nonNull(acidMember)) {
+                if(acidMember.getRelationName().equals("panzhihua")||acidMember.getRelationName().equals("西区")||acidMember.getRelationName().equals("东区")||acidMember.getRelationName().equals("仁和区")||acidMember.getRelationName().equals("米易县")||acidMember.getRelationName().equals("盐边县")){
+                    loginUserInfoVO.setIsAcidMember(1);
+                }
+                else {
+                    loginUserInfoVO.setIsAcidMember(2);
+                }
+                loginUserInfoVO.setRelationName(acidMember.getRelationName());
+            }
+            Integer count=userDao.selectOrgAdmin(phone);
+            if(count>0){
+                loginUserInfoVO.setIsCheckUnitAdmin(1);
+            }
+            else {
+                loginUserInfoVO.setIsCheckUnitAdmin(0);
+            }
+            //是否网格员
+            int easyPhotoMember = userDao.countEasyPhotoMember(phone, userCommunityId);
+            if (easyPhotoMember > 0) {
+                loginUserInfoVO.setIsEasyPhotoMember(1);
             }
             // 是否是"管理员"或者 本社区 "社区团队"、"党委成员"
             Integer countTeam = userDao.selectCountTeam(phone, userCommunityId);
@@ -704,6 +739,11 @@
         }
         ComActVO comActVO = userDao.selectCommunity(loginUserInfoVO.getCommunityId());
         if (!ObjectUtils.isEmpty(comActVO)) {
+            String areaName=userDao.selectAreaCodeByStreetId(comActVO.getStreetId());
+            if(StringUtils.isNotEmpty(areaName)){
+                loginUserInfoVO.setAreaName(areaName);
+            }
+            loginUserInfoVO.setComActVO(comActVO);
             loginUserInfoVO.setCommunityName(comActVO.getName());
             loginUserInfoVO.setAreaCode(comActVO.getAreaCode());
         }
@@ -713,6 +753,21 @@
         //是否是社区物业人员
         int countPropertyWorker = userDao.countPropertyWorker(userId, loginUserInfoVO.getCommunityId());
         loginUserInfoVO.setIsPropertyWorker(countPropertyWorker > 0 ? 1 : 0);
+        //是否微团队成员
+        int countFmsMember = userDao.countFmsMember(loginUserInfoVO.getPhone(), loginUserInfoVO.getCommunityId());
+        loginUserInfoVO.setIsFmsMember(countFmsMember > 0 ? 1 : 0);
+        //是否是防疫工作人员
+        loginUserInfoVO.setIsAcidMember(0);
+        ComActAcidMemberVO acidMember = userDao.selectAcidMemberByPhone(loginUserInfoVO.getPhone());
+        if (nonNull(acidMember)) {
+            if(acidMember.getRelationName().equals("panzhihua")||acidMember.getRelationName().equals("西区")||acidMember.getRelationName().equals("东区")||acidMember.getRelationName().equals("仁和区")||acidMember.getRelationName().equals("米易县")||acidMember.getRelationName().equals("盐边县")){
+                loginUserInfoVO.setIsAcidMember(1);
+            }
+            else {
+                loginUserInfoVO.setIsAcidMember(2);
+            }
+            loginUserInfoVO.setRelationName(acidMember.getRelationName());
+        }
         loginUserInfoVO.setIdCard(SensitiveUtil.desensitizedIdNumber(loginUserInfoVO.getIdCard()));
         loginUserInfoVO.setPhone(SensitiveUtil.desensitizedPhoneNumber(loginUserInfoVO.getPhone()));
         //判断账号类型
@@ -907,7 +962,7 @@
                 // 实名认证成功推送订阅消息给用户
                 try {
                     WxXCXTempSend util = new WxXCXTempSend();
-                    String accessToken = util.getAppAccessToken();
+                    String accessToken = util.getAccessToken();
                     SysTemplateConfig sysTemplateConfig=sysTemplateConfigDao.selectOne(new QueryWrapper<SysTemplateConfig>().lambda().eq(SysTemplateConfig::getAreaCode, loginUserInfoVO.getComActVO()).eq(SysTemplateConfig::getType,5));
                     // 用户实名认证推送消息
                     WxUtil.sendSubscribeRZSH(user.getOpenid(), accessToken, "实名认证",
@@ -1097,6 +1152,21 @@
     @Override
     @Transactional(rollbackFor = Exception.class)
     public R addUserBackstage(AdministratorsUserVO administratorsUserVO) {
+        ComActVO comActVO = userDao.selectCommunity(administratorsUserVO.getCommunityId());
+        if (nonNull(comActVO)) {
+            List<ComAreaTownCommunityVO> areaTownList = userDao.selectAreaTownCommunity(comActVO.getName());
+            if (!areaTownList.isEmpty()) {
+                administratorsUserVO.setRelationName(comActVO.getName());
+                String address = comActVO.getAddress();
+                if (areaTownList.size() > 1 && isNotBlank(address)) {
+                    ComAreaTownCommunityVO townCommunityVO = areaTownList.stream()
+                            .filter(e -> address.contains(e.getArea()) && address.contains(e.getTown())).findFirst().orElse(null);
+                    if (nonNull(townCommunityVO)) {
+                        administratorsUserVO.setRelationName(String.join(",", townCommunityVO.getArea(), townCommunityVO.getTown(), townCommunityVO.getCommunity()));
+                    }
+                }
+            }
+        }
         SysUserDO sysUserDO = new SysUserDO();
         Long roleId = administratorsUserVO.getRoleId();
         if (roleId.intValue() == 999999999 || roleId.intValue() == 888888888) {
@@ -1159,6 +1229,9 @@
                     menu.add(233L);
                     menu.add(237L);
                 }
+                else {
+                    menuRoleVO.setIsAll(1);
+                }
                 menuRoleVO.setMenuIds(menu);
                 menuRoleVO.setRoleId(roleId);
                 this.putMenuRole(menuRoleVO);
@@ -1186,31 +1259,6 @@
             }
 
         }
-
-        if (insert > 0 && sysUserDO.getType() == 3 &&sysUserDO.getStreetId()==null) {// 添加的用户是社区账号时
-            // 添加网格综合治理管理后台用户
-            SysUserDO sysUserDOWangGe = new SysUserDO();
-            BeanUtils.copyProperties(sysUserDO, sysUserDOWangGe);
-            sysUserDOWangGe.setUserId(null);
-            sysUserDOWangGe.setType(7);// 网格综治后台
-            try {
-                int addWange = userDao.insert(sysUserDOWangGe);
-                if (addWange != 1) {
-                    throw new ServiceException("新增网格综合治理管理后台用户失败");
-                }
-            } catch (Exception e) {
-                e.printStackTrace();
-                log.error("网格综合治理管理后台用户报错【{}】", e.getMessage());
-                if (e.getMessage().contains("union_phone_type")) {
-                    throw new ServiceException("手机号已经存在");
-                } else if (e.getMessage().contains("union_account_type")) {
-                    throw new ServiceException("账户已经存在");
-                }else if(e.getMessage().contains("23000")){
-                    throw new ServiceException("手机号已存在");
-                }
-
-            }
-        }
         if (insert > 0) {
             SysUserDO sysUserDO1 = userDao
                 .selectOne(new QueryWrapper<SysUserDO>().lambda().eq(SysUserDO::getType, administratorsUserVO.getType())
@@ -1237,25 +1285,23 @@
             List<Long> menu=new ArrayList<>();
             if(administratorsUserVO.getSocialType()==1){
                 sysRoleDO.setRoleKey(Constants.STREET_ROLE_KEY + administratorsUserVO.getStreetId());
-                menu.add(233L);
-                menu.add(234L);
-                menu.add(235L);
-                menu.add(236L);
-                menu.add(237L);
+                menu.add(300L);
+                menu.add(301L);
+                menu.add(302L);
+                menu.add(303L);
+                menu.add(304L);
             }
             else if(administratorsUserVO.getSocialType()==2){
                 sysRoleDO.setRoleKey("social_org" + administratorsUserVO.getStreetId());
-                menu.add(233L);
-                menu.add(76L);
-                menu.add(234L);
-                menu.add(236L);
-                menu.add(237L);
-                menu.add(238L);
+                menu.add(300L);
+                menu.add(301L);
+                menu.add(302L);
+                menu.add(303L);
             }
             else if(administratorsUserVO.getSocialType()==3){
                 sysRoleDO.setRoleKey("social_org_member" + administratorsUserVO.getStreetId());
-                menu.add(233L);
-                menu.add(237L);
+                menu.add(300L);
+                menu.add(303L);
             }
 
             sysRoleDO.setRoleSort(0);
@@ -1270,7 +1316,7 @@
                 // 新街道管理员角色设置固定三社权限
                 MenuRoleVO menuRoleVO = new MenuRoleVO();
                 menuRoleVO.setMenuIds(menu);
-                menuRoleVO.setRoleId(roleId);
+                menuRoleVO.setRoleId(sysRoleDO.getRoleId());
                 this.putMenuRole(menuRoleVO);
             }
         }
@@ -1370,7 +1416,7 @@
                         .anyMatch(sysRoleMenuDO -> sysRoleMenuDO.getMenuId().equals(menuId))).collect(Collectors.toList());
             }
             if (!menuIds.isEmpty()) {
-                if(menuRoleVO.getMenuIds().isEmpty()){
+                if(menuRoleVO.getMenuIds()==null){
                     sysRoleMenuDAO.batchInsertWithRoleId(menuIds, roleId);
                 }
                 else {
@@ -1448,7 +1494,6 @@
      * @return 删除结果
      */
     @Override
-    @Transactional(rollbackFor = Exception.class)
     public R deleteUserBackstage(AdministratorsUserVO administratorsUserVO) {
         Long userId = administratorsUserVO.getUserId();
         SysUserDO sysUserDO = userDao.selectById(userId);
@@ -1844,7 +1889,7 @@
     @Override
     public R dataKanban(String areaCode) {
         IndexDataKanbanVO indexDataKanbanVO = userDao.selectIndexDataKanban(areaCode);
-        List<DataKanbanDTO> dataKanbanDTOS = userDao.selectCommunityUserOrder(areaCode);
+        List<DataKanbanDTO> dataKanbanDTOS = userDao.selectCommunityUserOrder(new Page(1L, 9999L), areaCode).getRecords();
 
         List<String> communityUserX = new ArrayList<>();
         List<Integer> communityUserY = new ArrayList<>();
@@ -1952,6 +1997,30 @@
                 stringRedisTemplate.delete(userKey);
             }
             log.info("新增党员修改用户党员状态成功 身份证号【{}】", idCard);
+        }
+        return R.ok();
+    }
+
+    /**
+     * 修改用户的党员状态
+     *
+     * @param phone
+     *            身份证号
+     * @return 修改结果
+     */
+    @Override
+    public R updateUserIsPartymemberByPhone(String phone) {
+        SysUserDO sysUserDO = userDao.selectOne(
+                new QueryWrapper<SysUserDO>().lambda().eq(SysUserDO::getPhone, phone).eq(SysUserDO::getType, 1));
+        if (sysUserDO != null) {
+            sysUserDO.setIsPartymember(1);
+            int updated = userDao.updateById(sysUserDO);
+            if (updated > 0) {
+                // 删除用户信息缓存
+                String userKey = UserConstants.LOGIN_USER_INFO + sysUserDO.getUserId();
+                stringRedisTemplate.delete(userKey);
+            }
+            log.info("新增党员修改用户党员状态成功 手机号【{}】", phone);
         }
         return R.ok();
     }
@@ -2299,7 +2368,7 @@
 
     /**
      * 修改app用户密码
-     * 
+     *
      * @param userInfoAppDTO
      *            请求参数
      * @return 修改结果
@@ -2331,7 +2400,7 @@
 
     /**
      * 添加网格员
-     * 
+     *
      * @param eventGridMemberAddDTO
      *            请求参数
      * @return 结果
@@ -2448,7 +2517,7 @@
 
     /**
      * 网格员管理
-     * 
+     *
      * @param memberRelationDTO
      *            请求参数
      * @return 网格员列表
@@ -2485,7 +2554,7 @@
 
     /**
      * 修改网格员信息
-     * 
+     *
      * @param gridMemberDTO
      *            请求参数
      * @return 修改结果
@@ -2581,7 +2650,7 @@
 
     /**
      * 重置网格员密码
-     * 
+     *
      * @param gridMemberDTO
      *            请求参数
      * @return 重置结果
@@ -2599,7 +2668,7 @@
 
     /**
      * 批量删除网格员
-     * 
+     *
      * @param Ids
      *            网格员id集合
      * @return 删除结果
@@ -2638,7 +2707,7 @@
 
     /**
      * 查询社区的收益说明
-     * 
+     *
      * @param communityId
      *            社区id
      * @return 收益说明
@@ -2685,7 +2754,7 @@
 
     /**
      * 根据用户id查询用户openid
-     * 
+     *
      * @param userId
      *            用户id
      * @return openid
@@ -2701,7 +2770,7 @@
 
     /**
      * 查询社区后台工作人员列表
-     * 
+     *
      * @param communityId
      *            社区id
      * @return 社区后台工作人员列表
@@ -2835,7 +2904,7 @@
         userDao.disableOrEnableMerchantUsers(disableOrEnableConvenientMerchantDTO.getType(), disableOrEnableConvenientMerchantDTO.getUserIds());
         return R.ok();
     }
-    
+
     /**
      * 根据openid维护社区团队里是否注册
      * @param openid    用户微信唯一标识
@@ -2867,10 +2936,18 @@
         List<Integer> communityActiveUserZ = new ArrayList<>();
 
         List<DataKanbanDTO> dataKanbanDTOS = null;
+        Page page = new Page<>();
+        if (nonNull(dataKanBansDto.getPageNum()) && nonNull(dataKanBansDto.getPageSize())) {
+            page.setCurrent(dataKanBansDto.getPageNum());
+            page.setSize(dataKanBansDto.getPageSize());
+        } else {
+            page.setCurrent(1L);
+            page.setSize(20L);
+        }
         if(dataKanBansDto.getType() != null && dataKanBansDto.getType().equals(DataKanBansDto.type.by)){
-            dataKanbanDTOS = userDao.selectCommunityUserOrderMonth(dataKanBansDto.getAreaCode());
+            dataKanbanDTOS = userDao.selectCommunityUserOrderMonth(page, dataKanBansDto.getAreaCode()).getRecords();
         }else{
-            dataKanbanDTOS = userDao.selectCommunityUserOrder(dataKanBansDto.getAreaCode());
+            dataKanbanDTOS = userDao.selectCommunityUserOrder(page, dataKanBansDto.getAreaCode()).getRecords();
         }
         if (!ObjectUtils.isEmpty(dataKanbanDTOS)) {
             dataKanbanDTOS.forEach(dataKanbanDTO -> {
@@ -2933,6 +3010,28 @@
         LoginUserInfoVO loginUserInfoVO = new LoginUserInfoVO();
         BeanUtils.copyProperties(sysUserDO, loginUserInfoVO);
         return R.ok(loginUserInfoVO);
+    }
+
+    @Override
+    public R updateStreetId(AdministratorsUserVO administratorsUserVO) {
+        SysUserDO sysUserDO=new SysUserDO();
+        BeanUtils.copyProperties(administratorsUserVO,sysUserDO);
+        userDao.updateById(sysUserDO);
+        return R.ok();
+    }
+
+    /**
+     * 删除用户信息缓存
+     * @param phone
+     */
+    @Override
+    public R deleteUserCashByPhone(String phone) {
+        SysUserDO sysUserDO = this.userDao.selectOne(new LambdaQueryWrapper<SysUserDO>().eq(SysUserDO::getPhone, phone).eq(SysUserDO::getType, 1));
+        if (nonNull(sysUserDO)) {
+            String userKey = UserConstants.LOGIN_USER_INFO + sysUserDO.getUserId();
+            stringRedisTemplate.delete(userKey);
+        }
+        return R.ok();
     }
 
     /**
@@ -3172,4 +3271,19 @@
         }
         return rs.toString();
     }
+
+    @Override
+    public R updateUserPartyStatus(Long userId) {
+        SysUserDO sysUserDO = userDao.selectById(userId);
+        if (sysUserDO != null) {
+            sysUserDO.setIsPartymember(1);
+            int updated = userDao.updateById(sysUserDO);
+            if (updated > 0) {
+                // 删除用户信息缓存
+                String userKey = UserConstants.LOGIN_USER_INFO + sysUserDO.getUserId();
+                stringRedisTemplate.delete(userKey);
+            }
+        }
+        return R.ok();
+    }
 }

--
Gitblit v1.7.1