From 38f1a806a4e1d8e1560f07a5a26b51cf6a4692be Mon Sep 17 00:00:00 2001
From: mitao <2763622819@qq.com>
Date: 星期一, 17 三月 2025 10:57:57 +0800
Subject: [PATCH] 党员管理接口调试修改

---
 springcloud_k8s_panzhihuazhihuishequ/service_sangeshenbian/src/main/java/com/panzhihua/sangeshenbian/service/impl/PartyMemberServiceImpl.java |  120 ++++++++++++++++++++++++++++++++++++++++++++++++++----------
 1 files changed, 100 insertions(+), 20 deletions(-)

diff --git a/springcloud_k8s_panzhihuazhihuishequ/service_sangeshenbian/src/main/java/com/panzhihua/sangeshenbian/service/impl/PartyMemberServiceImpl.java b/springcloud_k8s_panzhihuazhihuishequ/service_sangeshenbian/src/main/java/com/panzhihua/sangeshenbian/service/impl/PartyMemberServiceImpl.java
index 1be7d89..1e6fd63 100644
--- a/springcloud_k8s_panzhihuazhihuishequ/service_sangeshenbian/src/main/java/com/panzhihua/sangeshenbian/service/impl/PartyMemberServiceImpl.java
+++ b/springcloud_k8s_panzhihuazhihuishequ/service_sangeshenbian/src/main/java/com/panzhihua/sangeshenbian/service/impl/PartyMemberServiceImpl.java
@@ -1,6 +1,7 @@
 package com.panzhihua.sangeshenbian.service.impl;
 
 import cn.hutool.core.bean.BeanUtil;
+import cn.hutool.core.date.DateUtil;
 import cn.hutool.core.collection.CollUtil;
 import cn.hutool.core.util.StrUtil;
 import cn.idev.excel.EasyExcel;
@@ -8,14 +9,21 @@
 import cn.idev.excel.FastExcel;
 import com.baomidou.mybatisplus.core.conditions.query.LambdaQueryWrapper;
 import com.baomidou.mybatisplus.extension.plugins.pagination.Page;
+import com.baomidou.mybatisplus.extension.service.impl.ServiceImpl;
+import com.panzhihua.common.exceptions.ServiceException;
+import com.panzhihua.common.model.vos.LoginUserInfoVO;
 import com.panzhihua.common.exceptions.ServiceException;
 import com.panzhihua.common.model.vos.sangeshenbian.SystemUserVo;
+import com.panzhihua.sangeshenbian.dao.PartyMemberMapper;
+import com.panzhihua.sangeshenbian.enums.AuditStatusEnum;
+import com.panzhihua.sangeshenbian.enums.FreezeStatusEnum;
+import com.panzhihua.sangeshenbian.enums.ReportTypeEnum;
 import com.panzhihua.sangeshenbian.enums.AuditStatusEnum;
 import com.panzhihua.sangeshenbian.model.entity.BcRegion;
 import com.panzhihua.sangeshenbian.model.entity.ComAct;
 import com.panzhihua.sangeshenbian.model.entity.ComStreet;
 import com.panzhihua.sangeshenbian.model.entity.PartyMember;
-import com.panzhihua.sangeshenbian.dao.PartyMemberMapper;
+import com.panzhihua.sangeshenbian.model.entity.SystemUser;
 import com.panzhihua.sangeshenbian.model.excel.PartyMemberExcel;
 import com.panzhihua.sangeshenbian.warpper.PartyMemberImportFailedVO;
 import com.panzhihua.sangeshenbian.model.excel.PartyMemberTemplate;
@@ -23,12 +31,15 @@
 import com.panzhihua.sangeshenbian.service.IComActService;
 import com.panzhihua.sangeshenbian.service.IComStreetService;
 import com.panzhihua.sangeshenbian.service.IPartyMemberService;
-import com.baomidou.mybatisplus.extension.service.impl.ServiceImpl;
+import com.panzhihua.sangeshenbian.service.ISystemUserService;
+import com.panzhihua.sangeshenbian.warpper.PartyMemberApplicationRequest;
 import com.panzhihua.sangeshenbian.warpper.PartyMemberDTO;
 import com.panzhihua.sangeshenbian.warpper.PartyMemberQuery;
+import com.panzhihua.sangeshenbian.warpper.PendingPartyMemberApplicationVO;
 import lombok.RequiredArgsConstructor;
 import org.springframework.context.annotation.Lazy;
 import org.springframework.stereotype.Service;
+import org.springframework.transaction.annotation.Transactional;
 import org.springframework.transaction.annotation.Transactional;
 import org.springframework.web.multipart.MultipartFile;
 
@@ -39,6 +50,7 @@
 import java.util.Collections;
 import java.util.List;
 import java.util.Objects;
+import java.util.Optional;
 
 /**
  * <p>
@@ -52,6 +64,7 @@
 @RequiredArgsConstructor(onConstructor_ = {@Lazy})
 public class PartyMemberServiceImpl extends ServiceImpl<PartyMemberMapper, PartyMember> implements IPartyMemberService {
     private final HttpServletResponse response;
+    private final ISystemUserService systemUserService;
     private final IBcRegionService bcRegionService;
     private final IComStreetService comStreetService;
     private final IComActService comActService;
@@ -76,10 +89,23 @@
         PartyMember partyMember = BeanUtil.copyProperties(dto, PartyMember.class);
         String idNumber = dto.getIdNumber();
         partyMember.setGender(getGender(idNumber));
+        BcRegion districtByCode = bcRegionService.getDistrictByCode(dto.getDistrictsCode());
+        if (Objects.nonNull(districtByCode)){
+            partyMember.setDistricts(districtByCode.getRegionName());
+        }
+        ComStreet street = comStreetService.getById(dto.getStreetId());
+        if (Objects.nonNull(street)){
+            partyMember.setStreet(street.getName());
+        }
+        ComAct act = comActService.getById(dto.getCommunityId());
+        if (Objects.nonNull(act)){
+            partyMember.setCommunity(act.getName());
+        }
         if (Objects.isNull(dto.getId())) {
             //添加
             partyMember.setCreateBy(Long.parseLong(loginUserInfo.getId().toString()));
             partyMember.setAuditStatus(AuditStatusEnum.APPROVED.getCode());
+            partyMember.setFreezeStatus(FreezeStatusEnum.NORMAL.getCode());
             partyMember.setSource(1);
             save(partyMember);
         } else {
@@ -141,38 +167,38 @@
         if (CollUtil.isEmpty(list)) {
             throw new ServiceException("导入数据为空");
         }
-        
+
         // 存储验证失败的记录
         List<PartyMemberImportFailedVO> failedList = new ArrayList<>();
         // 存储验证成功的记录
         List<PartyMember> validPartyMembers = new ArrayList<>();
-        
+
         // 手机号正则表达式
         String phoneRegex = "^1[3-9]\\d{9}$";
         // 身份证号正则表达式
         String idCardRegex = "(^\\d{15}$)|(^\\d{18}$)|(^\\d{17}(\\d|X|x)$)";
-        
+
         // 批量验证数据
         for (PartyMemberTemplate template : list) {
             PartyMemberImportFailedVO failedVO = new PartyMemberImportFailedVO();
             boolean isValid = true;
             StringBuilder errorMsg = new StringBuilder();
-            
+
             // 复制数据到失败记录对象
             BeanUtil.copyProperties(template, failedVO);
-            
+
             // 1. 验证手机号
             if (StrUtil.isBlank(template.getPhone()) || !template.getPhone().matches(phoneRegex)) {
                 isValid = false;
                 errorMsg.append("手机号格式不正确; ");
             }
-            
+
             // 2. 验证身份证号
             if (StrUtil.isBlank(template.getIdNumber()) || !template.getIdNumber().matches(idCardRegex)) {
                 isValid = false;
                 errorMsg.append("身份证号格式不正确; ");
             }
-            
+
             // 3. 验证账号是否已存在
             if (StrUtil.isNotBlank(template.getPhone())) {
                 LambdaQueryWrapper<PartyMember> queryWrapper = new LambdaQueryWrapper<>();
@@ -183,7 +209,7 @@
                     errorMsg.append("账号已存在");
                 }
             }
-            
+
             // 4. 验证所在社区
             String districtName = null;
             String streetName = null;
@@ -201,12 +227,12 @@
                     districtName = addressParts[0];
                     streetName = addressParts[1];
                     communityName = addressParts[2];
-                    
+
                     // 验证区县、街道、社区信息
-                    
+
                     // 验证区县是否存在
                     BcRegion district = bcRegionService.getDistrictByName(districtName);
-                    
+
                     if (Objects.isNull(district)) {
                         isValid = false;
                         errorMsg.append("区县不存在; ");
@@ -234,7 +260,7 @@
                 isValid = false;
                 errorMsg.append("社区信息不能为空; ");
             }
-            
+
             // 如果验证失败,添加到失败列表,否则添加到成功列表
             if (!isValid) {
                 failedVO.setFailReason(errorMsg.toString());
@@ -242,7 +268,7 @@
             } else {
                 PartyMember partyMember = new PartyMember();
                 BeanUtil.copyProperties(template, partyMember);
-                
+
                 // 设置创建人和更新人
                 partyMember.setCreateBy(Long.parseLong(loginUserInfo.getId().toString()));
                 partyMember.setUpdateBy(Long.parseLong(loginUserInfo.getId().toString()));
@@ -267,16 +293,33 @@
                 validPartyMembers.add(partyMember);
             }
         }
-        
+
         // 处理验证成功的数据
         if (!validPartyMembers.isEmpty()) {
             // 批量保存
             saveBatch(validPartyMembers);
         }
-        
+
         // 返回验证失败的数据
         return failedList;
     }
+
+    @Override
+    @Transactional(rollbackFor = Exception.class)
+    public void applyForMembership(PartyMemberApplicationRequest dto, LoginUserInfoVO loginUserInfo) {
+        PartyMember partyMember = BeanUtil.copyProperties(dto, PartyMember.class);
+        String idNumber = dto.getIdNumber();
+        partyMember.setPhone(loginUserInfo.getPhone());
+        partyMember.setGender(getGender(idNumber));
+        partyMember.setCreateBy(loginUserInfo.getUserId());
+        partyMember.setUpdateBy(loginUserInfo.getUserId());
+        partyMember.setAuditStatus(AuditStatusEnum.PENDING.getCode());
+        partyMember.setCreateTime(DateUtil.date());
+        partyMember.setUpdateTime(DateUtil.date());
+        partyMember.setSource(0);
+        saveOrUpdate(partyMember);
+    }
+
 
     /**
      * 审核
@@ -291,6 +334,36 @@
         updateById(partyMember);
     }
 
+    @Override
+    public Page<PendingPartyMemberApplicationVO> preAuditList(Page<PendingPartyMemberApplicationVO> page,
+                                                              LoginUserInfoVO loginUserInfo) {
+        SystemUser adminUser = systemUserService.getOne(new LambdaQueryWrapper<SystemUser>()
+                .eq(SystemUser::getPhone, loginUserInfo.getPhone())
+                .eq(SystemUser::getIsAdmin, 1)
+                .ne(SystemUser::getStatus, 3)
+                .last("LIMIT 1"));
+
+        if (adminUser == null){
+            throw new ServiceException("无权审核");
+        }
+
+        int accountLevel = adminUser.getAccountLevel();
+        Long communityId = null;
+        String streetId = null;
+        String districtsCode = null;
+        if (accountLevel == ReportTypeEnum.COMMUNITY.getCode()) {
+            communityId = adminUser.getCommunityId();
+        } else if (accountLevel == ReportTypeEnum.STREET.getCode()) {
+            streetId = adminUser.getStreetId();
+        } else if (accountLevel == ReportTypeEnum.DISTRICT.getCode()) {
+            districtsCode = adminUser.getDistrictsCode();
+        } else if(accountLevel != ReportTypeEnum.PARTY.getCode()){
+            throw new ServiceException("无权审核:未知等级");
+        }
+        String phone = loginUserInfo.getPhone();
+        return this.baseMapper.queryPreAuditPage(page, phone, accountLevel, districtsCode, streetId, communityId);
+    }
+
     /**
      * 根据身份证号获取性别
      * @param idNumber
@@ -301,8 +374,8 @@
         int genderDigit = Character.getNumericValue(genderChar);
         return (genderDigit % 2 == 0) ? 0 : 1;
     }
-    
-    
+
+
     /**
      * 根据电话号码查询有效的党员数据
      * @param phone
@@ -313,4 +386,11 @@
         PartyMember one = this.getOne(new LambdaQueryWrapper<PartyMember>().eq(PartyMember::getPhone, phone)
                 .eq(PartyMember::getAuditStatus, 1).eq(PartyMember::getFreezeStatus, 0).eq(PartyMember::getDelFlag, 0));
 		return one;
-	}}
+	}
+
+    @Override
+    public Boolean verifyPartyMemberByPhone(String phone) {
+        Optional<PartyMember> partyMember = this.lambdaQuery().eq(PartyMember::getPhone, phone).oneOpt();
+        return partyMember.isPresent();
+    }
+}

--
Gitblit v1.7.1