From c10d6358b9f014375a13821465bc978d0c0da22e Mon Sep 17 00:00:00 2001
From: linwe <872216996@qq.com>
Date: Wed, 29 May 2024 17:17:08 +0800
Subject: [PATCH] 通过E呼即办数据统计

---
 src/main/java/org/springblade/modules/ownersCommittee/service/impl/OwnersCommitteeServiceImpl.java |   39 ++++++++++++++++++++++++++++++++++++++-
 1 files changed, 38 insertions(+), 1 deletions(-)

diff --git a/src/main/java/org/springblade/modules/ownersCommittee/service/impl/OwnersCommitteeServiceImpl.java b/src/main/java/org/springblade/modules/ownersCommittee/service/impl/OwnersCommitteeServiceImpl.java
index 1550559..af3be18 100644
--- a/src/main/java/org/springblade/modules/ownersCommittee/service/impl/OwnersCommitteeServiceImpl.java
+++ b/src/main/java/org/springblade/modules/ownersCommittee/service/impl/OwnersCommitteeServiceImpl.java
@@ -53,7 +53,7 @@
 		String userRole = AuthUtil.getUserRole();
 		// 街道身份,只查找该街道下面的业委会
 		if (userRole.contains("jdgly")) {
-			List<String> regionChildCodesList = SysCache.getRegionChildCodesByDeptId(AuthUtil.getDeptId());
+			List<String> regionChildCodesList = SysCache.getRegionChildCodesByDeptId(AuthUtil.getDeptId(),null);
 			IDistrictService bean = SpringUtils.getBean(IDistrictService.class);
 			List<DistrictEntity> list = bean.list(Wrappers.<DistrictEntity>lambdaQuery()
 				.in(DistrictEntity::getCommunityCode, regionChildCodesList));
@@ -103,6 +103,43 @@
 	}
 
 	@Override
+	public Boolean updateOwnersCommittee(OwnersCommitteeEntity ownersCommittee) {
+		OwnersCommitteeEntity one = getOne(Wrappers.<OwnersCommitteeEntity>lambdaQuery().eq(OwnersCommitteeEntity::getId, ownersCommittee.getId()));
+		// 负责人没有变化
+		if(one.getPrincipalId().equals(ownersCommittee.getPrincipalId())){
+			// 更新业委会信息
+			return updateById(ownersCommittee);
+		}
+		// 负责人有变化
+		// 1.更新原负责人用户角色
+		IUserService bean = SpringUtils.getBean(IUserService.class);
+		User userInfo = bean.getOne(Wrappers.<User>lambdaQuery().eq(User::getId, one.getPrincipalId()));
+		// 判断角色
+		if (userInfo.getRoleId().contains("1759487358708310017")) {
+			userInfo.setRoleId(userInfo.getRoleId().replace("1759487358708310017", ""));
+		}
+		List<String> stringList = Arrays.asList(userInfo.getRoleId().split(","));
+		// 查询是否对应有业委会负责人,如果有则删除,如果没有则不删除对应的角色
+		List<String> arrayList = new ArrayList<>();
+		for (String roleId : stringList) {
+			if (!roleId.equals("1759487358708310017")) {
+				arrayList.add(roleId);
+			}
+		}
+		userInfo.setRoleId(StringUtils.join(arrayList, ","));
+		bean.updateById(userInfo);
+		// 2.更新现在的负责人
+		User userInfoNew = bean.getOne(Wrappers.<User>lambdaQuery().eq(User::getId, ownersCommittee.getPrincipalId()));
+		// 判断角色
+		if (!userInfoNew.getRoleId().contains("1759487358708310017")) {
+			userInfoNew.setRoleId(userInfo.getRoleId() + ",1759487358708310017");
+		}
+		bean.updateById(userInfoNew);
+		// 3.更新业委会信息
+		return updateById(ownersCommittee);
+	}
+
+	@Override
 	public Boolean removeOwnersCommittee(List<Long> toLongList) {
 		for (Long aLong : toLongList) {
 			OwnersCommitteeEntity ownersCommittee = getOne(Wrappers.<OwnersCommitteeEntity>lambdaQuery().eq(OwnersCommitteeEntity::getId, aLong));

--
Gitblit v1.9.3