From 8ffcd66acb57d4e34ced2906a0049e40affe8b1b Mon Sep 17 00:00:00 2001
From: lin <sbla5888@163.com>
Date: Wed, 20 Mar 2024 16:03:49 +0800
Subject: [PATCH] 重点人员管理接口调整

---
 src/main/java/org/springblade/modules/house/service/impl/HouseRentalServiceImpl.java |  118 +++++++++++++++++++++++++++++++++++++++++-----------------
 1 files changed, 83 insertions(+), 35 deletions(-)

diff --git a/src/main/java/org/springblade/modules/house/service/impl/HouseRentalServiceImpl.java b/src/main/java/org/springblade/modules/house/service/impl/HouseRentalServiceImpl.java
index b450c26..6ae6bc9 100644
--- a/src/main/java/org/springblade/modules/house/service/impl/HouseRentalServiceImpl.java
+++ b/src/main/java/org/springblade/modules/house/service/impl/HouseRentalServiceImpl.java
@@ -20,6 +20,7 @@
 import com.baomidou.mybatisplus.core.metadata.IPage;
 import com.baomidou.mybatisplus.core.toolkit.Wrappers;
 import com.baomidou.mybatisplus.extension.service.impl.ServiceImpl;
+import liquibase.repackaged.org.apache.commons.lang3.StringUtils;
 import org.apache.logging.log4j.util.Strings;
 import org.springblade.common.constant.CommonConstant;
 import org.springblade.common.param.CommonParamSet;
@@ -39,11 +40,13 @@
 import org.springblade.modules.house.vo.HouseholdVO;
 import org.springblade.modules.system.entity.User;
 import org.springblade.modules.system.service.IUserService;
+import org.springblade.modules.system.vo.UserVO;
 import org.springframework.beans.factory.annotation.Autowired;
 import org.springframework.stereotype.Service;
 import org.springframework.transaction.annotation.Transactional;
 
 import java.util.ArrayList;
+import java.util.Arrays;
 import java.util.Date;
 import java.util.List;
 import java.util.stream.Collectors;
@@ -167,18 +170,21 @@
 				phoneList.add(e.getPhoneNumber());
 			});
 			try {
-				// 查询租户是否网格员身份的,给网格员设置居民角色
+				// 查询租户是否有居民角色,没有则添加居民角色
 				IUserService bean = SpringUtils.getBean(IUserService.class);
-				String str = "1717429261910528001";
 				List<User> list = bean.list(Wrappers.<User>lambdaQuery()
 					.in(User::getPhone, phoneList)
-					.like(User::getRoleId, str));
+					.eq(User::getIsDeleted, 0));
 				for (User user : list) {
-					boolean contains = user.getRoleId().contains("1717429059648606209");
-					if (contains) {
-						continue;
+					if (StringUtils.isNoneBlank(user.getRoleId())) {
+						boolean contains = user.getRoleId().contains("1717429059648606209");
+						if (contains) {
+							continue;
+						}
+						user.setRoleId(user.getRoleId() + ",1717429059648606209");
+					} else {
+						user.setRoleId("1717429059648606209");
 					}
-					user.setRoleId(user.getRoleId() + ",1717429059648606209");
 				}
 				bean.updateBatchById(list);
 			} catch (Exception e) {
@@ -233,33 +239,27 @@
 		List<HouseholdEntity> addList = new ArrayList<>();
 		List<HouseholdEntity> updateList = new ArrayList<>();
 		List<HouseholdEntity> removeList = new ArrayList<>();
-		List<User> addUserList = new ArrayList<>();
-//		List<User> updateUserList = new ArrayList<>();
-//		List<User> removeUserList = new ArrayList<>();
 		// 找出需要新增的,否则组成新集合进行比对
 		List<String> phoneList = new ArrayList<>();
 		IUserService userService = SpringUtils.getBean(IUserService.class);
 		for (HouseholdEntity householdEntity : list) {
 			if (null == householdEntity.getId()) {
-				// 新增用戶
 				User user = new User();
-				user.setAccount(householdEntity.getPhoneNumber());
-				user.setUserType(1);
-				user.setRealName(householdEntity.getName());
-				user.setName(householdEntity.getName());
-				user.setPassword(DigestUtil.encrypt(CommonConstant.DEFAULT_PASSWORD));
-				user.setRoleId("1717429059648606209");
-				boolean save = userService.save(user);
+				// 新增或更新用户
+				boolean save = isSave(userService, householdEntity, user);
 				// 新增住户
 				householdEntity.setHouseCode(houseRental.getHouseCode());
 				householdEntity.setHousingRentalId(houseRental.getId());
 				householdEntity.setRelationship(18);
 				householdEntity.setResidentialStatus(1);
+//				householdEntity.setIdCard(houseRental.getid);
 				householdEntity.setRoleType(2);
+//				householdEntity.setName();
 				if (save) {
 					householdEntity.setAssociatedUserId(user.getId());
 				}
 				addList.add(householdEntity);
+				// 添加手机号
 				phoneList.add(householdEntity.getPhoneNumber());
 			} else {
 				newList.add(householdEntity);
@@ -269,6 +269,7 @@
 		// 取旧数据和新提交数据差集--删除
 		removeList = oldList.stream().filter(vo -> !newList.stream().map(e ->
 			e.getId()).collect(Collectors.toList()).contains(vo.getId())).collect(Collectors.toList());
+
 		// 取旧数据和新提交数据交集--更新
 		updateList = newList.stream().filter(vo -> oldList.stream().map(e ->
 			e.getId()).collect(Collectors.toList()).contains(vo.getId())).collect(Collectors.toList());
@@ -279,38 +280,85 @@
 		}
 		// 批量修改
 		if (updateList.size() > 0) {
-			updateFlag = iHouseholdService.updateBatchById(updateList);
 			for (HouseholdEntity householdEntity : updateList) {
 				phoneList.add(householdEntity.getPhoneNumber());
+				User user = new User();
+				// 修改用户,用户存在则更新用户,不存在则新增用户
+				boolean save = isSave(userService, householdEntity, user);
+				if (save) {
+					householdEntity.setAssociatedUserId(user.getId());
+				}
 			}
+			updateFlag = iHouseholdService.updateBatchById(updateList);
 		}
 		// 批量删除
 		if (removeList.size() > 0) {
 			removeFlag = iHouseholdService.removeBatchByIds(removeList);
-		}
-		try {
-			// 查询租户是否网格员身份的,给网格员设置居民角色
-			IUserService bean = SpringUtils.getBean(IUserService.class);
-			String str = "1717429261910528001";
-			List<User> list2 = bean.list(Wrappers.<User>lambdaQuery()
-				.in(User::getPhone, phoneList)
-				.like(User::getRoleId, str));
-			for (User user : list2) {
-				boolean contains = user.getRoleId().contains("1717429059648606209");
-				if (contains) {
-					continue;
+			// 删除用户。判断用户是否有其他角色,
+			for (HouseholdEntity householdEntity : removeList) {
+				if (householdEntity.getAssociatedUserId() != null) {
+					UserVO userVO = userService.getuserById(householdEntity.getAssociatedUserId());
+					if (userVO.getRoleId().contains("1717429059648606209")) {
+						List<String> stringList = Arrays.asList(userVO.getRoleId().split(","));
+						// 有其他角色
+						if (stringList.size() >= 2) {
+							List<String> collect = stringList.stream().filter(item -> !item.equals("1717429059648606209")).collect(Collectors.toList());
+							userVO.setRoleId(StringUtils.join(collect, ","));
+							userService.updateById(userVO);
+						} else {
+							// 没有其他角色
+							userService.removeById(userVO.getId());
+						}
+					}
 				}
-				user.setRoleId(user.getRoleId() + ",1717429059648606209");
 			}
-			bean.updateBatchById(list2);
-		} catch (Exception e) {
-			log.error("保存用户角色为居民:", e);
 		}
 		// 返回
 		return update && addFlag && updateFlag && removeFlag;
 	}
 
 	/**
+	 * 保存或更新用户
+	 * @param userService
+	 * @param householdEntity
+	 * @param user
+	 * @return
+	 */
+	private boolean isSave(IUserService userService, HouseholdEntity householdEntity, User user) {
+		boolean save;
+		// 查询该住户是否有账号
+		IUserService userService1 = SpringUtils.getBean(IUserService.class);
+		User user1 = userService1.getOne(Wrappers.<User>lambdaQuery()
+			.eq(User::getPhone, householdEntity.getPhoneNumber())
+			.eq(User::getIsDeleted, 0).last("limit 1"));
+		if (user1 != null) {
+			user = user1;
+			user.setName(householdEntity.getName());
+			if (StringUtils.isNoneBlank(user.getRoleId())) {
+				boolean contains = user.getRoleId().contains("1717429059648606209");
+				if (!contains) {
+					user.setRoleId(user.getRoleId() + ",1717429059648606209");
+				}
+			} else {
+				user.setRoleId("1717429059648606209");
+			}
+			// 更新用户
+			save = userService.updateById(user);
+			return save;
+		}
+		// 新增用户
+		user.setAccount(householdEntity.getPhoneNumber());
+		user.setUserType(1);
+		user.setPhone(householdEntity.getPhoneNumber());
+		user.setRealName(householdEntity.getName());
+		user.setName(householdEntity.getName());
+		user.setPassword(DigestUtil.encrypt(CommonConstant.DEFAULT_PASSWORD));
+		user.setRoleId("1717429059648606209");
+		save = userService.save(user);
+		return save;
+	}
+
+	/**
 	 * 获取统计数据
 	 *
 	 * @return

--
Gitblit v1.9.3