From 8b7258c9427882bb1798f1502eaa35184c6e374e Mon Sep 17 00:00:00 2001
From: linwe <872216996@qq.com>
Date: Fri, 09 Aug 2024 14:29:18 +0800
Subject: [PATCH] 短信指定楼栋发送

---
 src/main/java/org/springblade/modules/house/service/impl/HouseRentalServiceImpl.java |  135 ++++++++++++++++++++++++++++++--------------
 1 files changed, 91 insertions(+), 44 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 6ae6bc9..456d393 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
@@ -25,6 +25,7 @@
 import org.springblade.common.constant.CommonConstant;
 import org.springblade.common.param.CommonParamSet;
 import org.springblade.common.utils.SpringUtils;
+import org.springblade.core.mp.support.Condition;
 import org.springblade.core.secure.utils.AuthUtil;
 import org.springblade.core.tool.utils.DigestUtil;
 import org.springblade.modules.grid.service.IGridService;
@@ -39,7 +40,9 @@
 import org.springblade.modules.house.vo.HouseRentalVO;
 import org.springblade.modules.house.vo.HouseholdVO;
 import org.springblade.modules.system.entity.User;
+import org.springblade.modules.system.entity.UserInfo;
 import org.springblade.modules.system.service.IUserService;
+import org.springblade.modules.system.vo.UserDetailVO;
 import org.springblade.modules.system.vo.UserVO;
 import org.springframework.beans.factory.annotation.Autowired;
 import org.springframework.stereotype.Service;
@@ -142,10 +145,12 @@
 			// 待审核
 			houseRentalVO.setAuditStatus(0);
 		}
-		//保存自身
+		//保存自身(租赁)
 		flag = save(houseRentalVO);
 		//保存到住户
-		flag = saveHousehold(houseRentalVO, flag);
+		if (flag){
+			flag = saveHousehold(houseRentalVO, flag);
+		}
 		return flag;
 	}
 
@@ -157,42 +162,72 @@
 	 * @return
 	 */
 	public boolean saveHousehold(HouseRentalVO houseRentalVO, boolean flag) {
-		if (flag && houseRentalVO.getHouseholdVOList().size() > 0) {
-			List<String> phoneList = new ArrayList<>();
-			List<HouseholdEntity> householdEntityList = new ArrayList<>();
+		if (houseRentalVO.getHouseholdVOList().size() > 0) {
 			houseRentalVO.getHouseholdVOList().forEach(e -> {
 				e.setHouseCode(houseRentalVO.getHouseCode());
 				e.setHousingRentalId(houseRentalVO.getId());
 				e.setRelationship(18);
 				e.setResidentialStatus(1);
-				e.setRoleType(2);
-				householdEntityList.add(e);
-				phoneList.add(e.getPhoneNumber());
-			});
-			try {
-				// 查询租户是否有居民角色,没有则添加居民角色
-				IUserService bean = SpringUtils.getBean(IUserService.class);
-				List<User> list = bean.list(Wrappers.<User>lambdaQuery()
-					.in(User::getPhone, phoneList)
-					.eq(User::getIsDeleted, 0));
-				for (User user : list) {
-					if (StringUtils.isNoneBlank(user.getRoleId())) {
-						boolean contains = user.getRoleId().contains("1717429059648606209");
-						if (contains) {
-							continue;
-						}
-						user.setRoleId(user.getRoleId() + ",1717429059648606209");
-					} else {
-						user.setRoleId("1717429059648606209");
-					}
+				if (!Strings.isBlank(e.getIdCard())){
+					e.setCardType(111);
 				}
-				bean.updateBatchById(list);
-			} catch (Exception e) {
-				log.error("保存用户角色为居民:", e);
-			}
-			flag = iHouseholdService.saveBatch(householdEntityList);
+				e.setRoleType(2);
+				// 添加住户
+				iHouseholdService.save(e);
+				// 绑定用户
+				bindUserHandle(e);
+			});
 		}
 		return flag;
+	}
+
+	/**
+	 * 租客和用户绑定
+	 *
+	 * @param
+	 */
+	public User bindUserHandle(HouseholdEntity householdEntity) {
+		IUserService userService = SpringUtils.getBean(IUserService.class);
+		IHouseholdService householdService = SpringUtils.getBean(IHouseholdService.class);
+		User newUser = new User();
+		if (null != householdEntity.getPhoneNumber() && !householdEntity.getPhoneNumber().equals("")) {
+			//根据手机号查询库里的数据
+			List<User> list = userService.getUserListByPhoneOrAccount(householdEntity.getPhoneNumber());
+			if (list.size()>0) {
+				User user = list.get(0);
+				//如果用户存在,则该用户id绑定场所
+				householdEntity.setAssociatedUserId(user.getId());
+				//更新住户信息
+				householdService.updateById(householdEntity);
+				newUser = user;
+				// 判断用户是否包含了居民角色,不包含则需更新
+				if (!user.getRoleId().contains("1717429059648606209")) {
+					user.setRoleId(user.getRoleId() + ",1717429059648606209");
+					//更新
+					userService.updateById(user);
+				}
+			} else {
+				//如果用户不存在,则新增一个用户
+				newUser.setAccount(householdEntity.getPhoneNumber());
+				newUser.setPhone(householdEntity.getPhoneNumber());
+				newUser.setName(householdEntity.getName());
+				newUser.setRealName(householdEntity.getName());
+				// 社区群众部门
+				newUser.setDeptId("1727979636479037441");
+				// 目前暂定居民角色,
+				newUser.setRoleId("1717429059648606209");
+				//默认密码为 123456
+				newUser.setPassword("123456");
+				// 设置机构
+				// 用户新增
+				boolean submit = userService.submit(newUser);
+				//绑定id
+				householdEntity.setAssociatedUserId(newUser.getId());
+				//更新住户信息
+				householdService.updateById(householdEntity);
+			}
+		}
+		return newUser;
 	}
 
 	/**
@@ -227,6 +262,13 @@
 		boolean removeFlag = true;
 		houseRental.setUpdateUser(AuthUtil.getUserId());
 		houseRental.setUpdateTime(new Date());
+		// 获取请求头中的角色别名
+		String roleName = SpringUtils.getRequestParam("roleName");
+		// 居民
+		if (!Strings.isBlank(roleName) && roleName.equals("inhabitant")) {
+			// 待审核
+			houseRental.setAuditStatus(0);
+		}
 		//更新自身
 		boolean update = updateById(houseRental);
 		// 查询对应已存在的租户
@@ -246,16 +288,17 @@
 			if (null == householdEntity.getId()) {
 				User user = new User();
 				// 新增或更新用户
-				boolean save = isSave(userService, householdEntity, user);
+				user = 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) {
+				if (!Strings.isBlank(householdEntity.getIdCard())){
+					householdEntity.setCardType(111);
+				}
+				if (user.getId() != null) {
 					householdEntity.setAssociatedUserId(user.getId());
 				}
 				addList.add(householdEntity);
@@ -284,8 +327,8 @@
 				phoneList.add(householdEntity.getPhoneNumber());
 				User user = new User();
 				// 修改用户,用户存在则更新用户,不存在则新增用户
-				boolean save = isSave(userService, householdEntity, user);
-				if (save) {
+				user = isSave(userService, householdEntity, user);
+				if (user.getId() != null) {
 					householdEntity.setAssociatedUserId(user.getId());
 				}
 			}
@@ -297,7 +340,7 @@
 			// 删除用户。判断用户是否有其他角色,
 			for (HouseholdEntity householdEntity : removeList) {
 				if (householdEntity.getAssociatedUserId() != null) {
-					UserVO userVO = userService.getuserById(householdEntity.getAssociatedUserId());
+					User userVO = userService.getById(householdEntity.getAssociatedUserId());
 					if (userVO.getRoleId().contains("1717429059648606209")) {
 						List<String> stringList = Arrays.asList(userVO.getRoleId().split(","));
 						// 有其他角色
@@ -307,7 +350,9 @@
 							userService.updateById(userVO);
 						} else {
 							// 没有其他角色
-							userService.removeById(userVO.getId());
+							userVO.setRoleId("");
+							boolean b = userService.updateById(userVO);
+							System.out.println(b);
 						}
 					}
 				}
@@ -319,21 +364,23 @@
 
 	/**
 	 * 保存或更新用户
+	 *
 	 * @param userService
 	 * @param householdEntity
 	 * @param user
 	 * @return
 	 */
-	private boolean isSave(IUserService userService, HouseholdEntity householdEntity, User user) {
+	private User 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::getAccount, householdEntity.getPhoneNumber())
 			.eq(User::getIsDeleted, 0).last("limit 1"));
 		if (user1 != null) {
 			user = user1;
 			user.setName(householdEntity.getName());
+			user.setRealName(householdEntity.getName());
 			if (StringUtils.isNoneBlank(user.getRoleId())) {
 				boolean contains = user.getRoleId().contains("1717429059648606209");
 				if (!contains) {
@@ -344,7 +391,7 @@
 			}
 			// 更新用户
 			save = userService.updateById(user);
-			return save;
+			return user;
 		}
 		// 新增用户
 		user.setAccount(householdEntity.getPhoneNumber());
@@ -355,7 +402,7 @@
 		user.setPassword(DigestUtil.encrypt(CommonConstant.DEFAULT_PASSWORD));
 		user.setRoleId("1717429059648606209");
 		save = userService.save(user);
-		return save;
+		return user;
 	}
 
 	/**
@@ -404,7 +451,7 @@
 	@Override
 	public Integer getStatisticsCount(HouseRentalTenantVO houseRental) {
 		CommonParamSet<Object> commonParamSet = new CommonParamSet<>().invoke(HouseRentalTenantVO.class, houseRental);
-		return baseMapper.getStatisticsCount(houseRental, commonParamSet.getGridCodeList(),
-			commonParamSet.getRegionChildCodesList(), commonParamSet.getIsAdministrator());
+		return baseMapper.getStatisticsCount(houseRental, commonParamSet.getRegionChildCodesList(),
+			commonParamSet.getGridCodeList(), commonParamSet.getIsAdministrator());
 	}
 }

--
Gitblit v1.9.3