SysDeptServiceImpl.java 11 KB

123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263646566676869707172737475767778798081828384858687888990919293949596979899100101102103104105106107108109110111112113114115116117118119120121122123124125126127128129130131132133134135136137138139140141142143144145146147148149150151152153154155156157158159160161162163164165166167168169170171172173174175176177178179180181182183184185186187188189190191192193194195196197198199200201202203204205206207208209210211212213214215216217218219220221222223224225226227228229230231232233234235236237238239240241242243244245246247248249250251252253254255256257258259260261262263264265266267268269270271272273274275276277278279280281282283284285286287288289290291292293294295296297298299300301302303304305306307308309310311312313314315316317318319320321322323324325326327328329330331332333334335336337338339
  1. package com.ruoyi.system.service.impl;
  2. import cn.hutool.core.convert.Convert;
  3. import cn.hutool.core.util.StrUtil;
  4. import cn.hutool.json.JSONObject;
  5. import com.baomidou.mybatisplus.core.conditions.query.LambdaQueryWrapper;
  6. import com.baomidou.mybatisplus.core.conditions.update.LambdaUpdateWrapper;
  7. import com.baomidou.mybatisplus.core.toolkit.Wrappers;
  8. import com.ruoyi.common.constant.UserConstants;
  9. import com.ruoyi.common.core.domain.TreeSelect;
  10. import com.ruoyi.common.core.domain.entity.SysDept;
  11. import com.ruoyi.common.core.domain.entity.SysRole;
  12. import com.ruoyi.common.core.domain.entity.SysUser;
  13. import com.ruoyi.common.core.mybatisplus.core.ServicePlusImpl;
  14. import com.ruoyi.common.exception.ServiceException;
  15. import com.ruoyi.common.utils.FindsDepartsChildrenUtil;
  16. import com.ruoyi.common.utils.SecurityUtils;
  17. import com.ruoyi.common.utils.StringUtils;
  18. import com.ruoyi.common.utils.spring.SpringUtils;
  19. import com.ruoyi.system.mapper.SysDeptMapper;
  20. import com.ruoyi.system.mapper.SysRoleMapper;
  21. import com.ruoyi.system.mapper.SysUserMapper;
  22. import com.ruoyi.system.service.ISysDeptService;
  23. import org.springframework.beans.factory.annotation.Autowired;
  24. import org.springframework.stereotype.Service;
  25. import java.util.ArrayList;
  26. import java.util.Arrays;
  27. import java.util.List;
  28. import java.util.stream.Collectors;
  29. /**
  30. * 部门管理 服务实现
  31. *
  32. * @author ruoyi
  33. */
  34. @Service
  35. public class SysDeptServiceImpl extends ServicePlusImpl<SysDeptMapper, SysDept, SysDept> implements ISysDeptService {
  36. @Autowired
  37. private SysRoleMapper roleMapper;
  38. @Autowired
  39. private SysUserMapper userMapper;
  40. private List<SysDept> allDept;
  41. /**
  42. * 查询部门管理数据
  43. *
  44. * @param dept 部门信息
  45. * @return 部门信息集合
  46. */
  47. @Override
  48. // @DataScope(deptAlias = "d")
  49. public List<SysDept> selectDeptList(SysDept dept) {
  50. return baseMapper.selectDeptList(dept);
  51. }
  52. /**
  53. * 构建前端所需要树结构
  54. *
  55. * @param depts 部门列表
  56. * @return 树结构列表
  57. */
  58. @Override
  59. public List<SysDept> buildDeptTree(List<SysDept> depts) {
  60. List<SysDept> returnList = new ArrayList<>();
  61. List<String> tempList = new ArrayList<>();
  62. for (SysDept dept : depts) {
  63. tempList.add(dept.getDeptId());
  64. }
  65. for (SysDept dept : depts) {
  66. // 如果是顶级节点, 遍历该父节点的所有子节点
  67. if (!tempList.contains(dept.getParentId())) {
  68. recursionFn(depts, dept);
  69. returnList.add(dept);
  70. }
  71. }
  72. if (returnList.isEmpty()) {
  73. returnList = depts;
  74. }
  75. return returnList;
  76. }
  77. /**
  78. * 构建前端所需要下拉树结构
  79. *
  80. * @param depts 部门列表
  81. * @return 下拉树结构列表
  82. */
  83. @Override
  84. public List<TreeSelect> buildDeptTreeSelect(List<SysDept> depts) {
  85. List<SysDept> deptTrees = buildDeptTree(depts);
  86. return deptTrees.stream().map(TreeSelect::new).collect(Collectors.toList());
  87. }
  88. /**
  89. * 根据角色ID查询部门树信息
  90. *
  91. * @param roleId 角色ID
  92. * @return 选中部门列表
  93. */
  94. @Override
  95. public List<String> selectDeptListByRoleId(String roleId) {
  96. SysRole role = roleMapper.selectById(roleId);
  97. return baseMapper.selectDeptListByRoleId(roleId, role.isDeptCheckStrictly());
  98. }
  99. /**
  100. * 根据部门ID查询信息
  101. *
  102. * @param deptId 部门ID
  103. * @return 部门信息
  104. */
  105. @Override
  106. public SysDept selectDeptById(String deptId) {
  107. return getById(deptId);
  108. }
  109. /**
  110. * 根据ID查询所有子部门(正常状态)
  111. *
  112. * @param deptId 部门ID
  113. * @return 子部门数
  114. */
  115. @Override
  116. public long selectNormalChildrenDeptById(String deptId) {
  117. return count(new LambdaQueryWrapper<SysDept>()
  118. .eq(SysDept::getStatus, 0)
  119. .apply("find_in_set({0}, ancestors)", deptId));
  120. }
  121. /**
  122. * 是否存在子节点
  123. *
  124. * @param deptId 部门ID
  125. * @return 结果
  126. */
  127. @Override
  128. public boolean hasChildByDeptId(String deptId) {
  129. long result = count(new LambdaQueryWrapper<SysDept>()
  130. .eq(SysDept::getParentId, deptId)
  131. .last("limit 1"));
  132. return result > 0;
  133. }
  134. /**
  135. * 查询部门是否存在用户
  136. *
  137. * @param deptId 部门ID
  138. * @return 结果 true 存在 false 不存在
  139. */
  140. @Override
  141. public boolean checkDeptExistUser(String deptId) {
  142. long result = userMapper.selectCount(new LambdaQueryWrapper<SysUser>()
  143. .eq(SysUser::getDeptId, deptId));
  144. return result > 0;
  145. }
  146. /**
  147. * 校验部门名称是否唯一
  148. *
  149. * @param dept 部门信息
  150. * @return 结果
  151. */
  152. @Override
  153. public String checkDeptNameUnique(SysDept dept) {
  154. String deptId = StrUtil.isBlank(dept.getDeptId()) ? "-1" : dept.getDeptId();
  155. SysDept info = getOne(new LambdaQueryWrapper<SysDept>()
  156. .eq(SysDept::getDeptName, dept.getDeptName())
  157. .eq(SysDept::getParentId, dept.getParentId())
  158. .last("limit 1"));
  159. if (StringUtils.isNotNull(info) && !info.getDeptId().equals(deptId)) {
  160. return UserConstants.NOT_UNIQUE;
  161. }
  162. return UserConstants.UNIQUE;
  163. }
  164. /**
  165. * 校验部门是否有数据权限
  166. *
  167. * @param deptId 部门id
  168. */
  169. @Override
  170. public void checkDeptDataScope(String deptId) {
  171. if (!SysUser.isAdmin(SecurityUtils.getUserId())) {
  172. SysDept dept = new SysDept();
  173. dept.setDeptId(deptId);
  174. List<SysDept> depts = SpringUtils.getAopProxy(this).selectDeptList(dept);
  175. if (StringUtils.isEmpty(depts)) {
  176. throw new ServiceException("没有权限访问部门数据!");
  177. }
  178. }
  179. }
  180. /**
  181. * 新增保存部门信息
  182. *
  183. * @param dept 部门信息
  184. * @return 结果
  185. */
  186. @Override
  187. public int insertDept(SysDept dept) {
  188. SysDept info = getById(dept.getParentId());
  189. if (info != null) {
  190. // 如果父节点不为正常状态,则不允许新增子节点
  191. if (!UserConstants.DEPT_NORMAL.equals(info.getStatus())) {
  192. throw new ServiceException("部门停用,不允许新增");
  193. }
  194. dept.setAncestors(info.getAncestors() + "," + dept.getParentId());
  195. }
  196. String departFullNamePrefix = FindsDepartsChildrenUtil.departFullName(this.list(), dept.getParentId());
  197. dept.setFullName(StrUtil.isBlank(departFullNamePrefix) ? dept.getDeptName() : departFullNamePrefix + dept.getDeptName());
  198. return baseMapper.insert(dept);
  199. }
  200. /**
  201. * 修改保存部门信息
  202. *
  203. * @param dept 部门信息
  204. * @return 结果
  205. */
  206. @Override
  207. public int updateDept(SysDept dept) {
  208. SysDept newParentDept = getById(dept.getParentId());
  209. SysDept oldDept = getById(dept.getDeptId());
  210. if (StringUtils.isNotNull(newParentDept) && StringUtils.isNotNull(oldDept)) {
  211. String newAncestors = newParentDept.getAncestors() + "," + newParentDept.getDeptId();
  212. String oldAncestors = oldDept.getAncestors();
  213. dept.setAncestors(newAncestors);
  214. updateDeptChildren(dept.getDeptId(), newAncestors, oldAncestors);
  215. }
  216. String departFullNamePrefix = FindsDepartsChildrenUtil.departFullName(this.list(), dept.getParentId());
  217. dept.setFullName(StrUtil.isBlank(departFullNamePrefix) ? dept.getDeptName() : departFullNamePrefix + dept.getDeptName());
  218. int result = baseMapper.updateById(dept);
  219. if (UserConstants.DEPT_NORMAL.equals(dept.getStatus()) && StringUtils.isNotEmpty(dept.getAncestors())
  220. && !StringUtils.equals("0", dept.getAncestors())) {
  221. // 如果该部门是启用状态,则启用该部门的所有上级部门
  222. updateParentDeptStatusNormal(dept);
  223. }
  224. return result;
  225. }
  226. /**
  227. * 修改该部门的父级部门状态
  228. *
  229. * @param dept 当前部门
  230. */
  231. private void updateParentDeptStatusNormal(SysDept dept) {
  232. String ancestors = dept.getAncestors();
  233. String[] deptIds = Convert.toStrArray(ancestors);
  234. update(null, new LambdaUpdateWrapper<SysDept>()
  235. .set(SysDept::getStatus, "0")
  236. .in(SysDept::getDeptId, Arrays.asList(deptIds)));
  237. }
  238. /**
  239. * 修改子元素关系
  240. *
  241. * @param deptId 被修改的部门ID
  242. * @param newAncestors 新的父ID集合
  243. * @param oldAncestors 旧的父ID集合
  244. */
  245. public void updateDeptChildren(String deptId, String newAncestors, String oldAncestors) {
  246. List<SysDept> children = list(new LambdaQueryWrapper<SysDept>()
  247. // mysql和postgrep区别
  248. // .apply("find_in_set({0},ancestors)", deptId));
  249. .apply("{0} = ANY (string_to_array(ancestors,','))", deptId));
  250. for (SysDept child : children) {
  251. child.setAncestors(child.getAncestors().replaceFirst(oldAncestors, newAncestors));
  252. }
  253. if (children.size() > 0) {
  254. baseMapper.updateDeptChildren(children);
  255. }
  256. }
  257. /**
  258. * 删除部门管理信息
  259. *
  260. * @param deptId 部门ID
  261. * @return 结果
  262. */
  263. @Override
  264. public int deleteDeptById(String deptId) {
  265. return baseMapper.deleteById(deptId);
  266. }
  267. /**
  268. * 递归列表
  269. */
  270. private void recursionFn(List<SysDept> list, SysDept t) {
  271. // 得到子节点列表
  272. List<SysDept> childList = getChildList(list, t);
  273. t.setChildren(childList);
  274. for (SysDept tChild : childList) {
  275. if (hasChild(list, tChild)) {
  276. recursionFn(list, tChild);
  277. }
  278. }
  279. }
  280. /**
  281. * 得到子节点列表
  282. */
  283. private List<SysDept> getChildList(List<SysDept> list, SysDept t) {
  284. List<SysDept> tlist = new ArrayList<>();
  285. for (SysDept n : list) {
  286. if (StringUtils.isNotNull(n.getParentId()) && n.getParentId().equals(t.getDeptId())) {
  287. tlist.add(n);
  288. }
  289. }
  290. return tlist;
  291. }
  292. /**
  293. * 判断是否有子节点
  294. */
  295. private boolean hasChild(List<SysDept> list, SysDept t) {
  296. return getChildList(list, t).size() > 0;
  297. }
  298. @Override
  299. public List<JSONObject> queryTUcDept() {
  300. return baseMapper.queryTUcDept();
  301. }
  302. @Override
  303. public SysDept getOrgDept(SysDept sysDept) {
  304. if ("0".equals(sysDept.getFlag())) {
  305. return sysDept;
  306. }
  307. if (allDept == null) {
  308. allDept = baseMapper.selectList(Wrappers.emptyWrapper());
  309. }
  310. SysDept orgDept = allDept.stream().filter(x -> StrUtil.equals(x.getDeptId(), sysDept.getParentId())).findFirst().get();
  311. return getOrgDept(orgDept);
  312. }
  313. }