SysDeptServiceImpl.java 9.1 KB

123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263646566676869707172737475767778798081828384858687888990919293949596979899100101102103104105106107108109110111112113114115116117118119120121122123124125126127128129130131132133134135136137138139140141142143144145146147148149150151152153154155156157158159160161162163164165166167168169170171172173174175176177178179180181182183184185186187188189190191192193194195196197198199200201202203204205206207208209210211212213214215216217218219220221222223224225226227228229230231232233234235236237238239240241242243244245246247248249250251252253254255256257258259260261262263264265266267268269270271272273274275276277278
  1. package com.ruoyi.system.service.impl;
  2. import cn.hutool.core.collection.CollUtil;
  3. import cn.hutool.core.convert.Convert;
  4. import cn.hutool.core.lang.tree.Tree;
  5. import cn.hutool.core.util.ObjectUtil;
  6. import com.baomidou.mybatisplus.core.conditions.query.LambdaQueryWrapper;
  7. import com.baomidou.mybatisplus.core.conditions.update.LambdaUpdateWrapper;
  8. import com.ruoyi.common.constant.UserConstants;
  9. import com.ruoyi.common.core.domain.entity.SysDept;
  10. import com.ruoyi.common.core.domain.entity.SysRole;
  11. import com.ruoyi.common.core.domain.entity.SysUser;
  12. import com.ruoyi.common.exception.ServiceException;
  13. import com.ruoyi.common.helper.DataBaseHelper;
  14. import com.ruoyi.common.helper.LoginHelper;
  15. import com.ruoyi.common.utils.StringUtils;
  16. import com.ruoyi.common.utils.TreeBuildUtils;
  17. import com.ruoyi.system.mapper.SysDeptMapper;
  18. import com.ruoyi.system.mapper.SysRoleMapper;
  19. import com.ruoyi.system.mapper.SysUserMapper;
  20. import com.ruoyi.system.service.ISysDeptService;
  21. import lombok.RequiredArgsConstructor;
  22. import org.springframework.stereotype.Service;
  23. import java.util.ArrayList;
  24. import java.util.Arrays;
  25. import java.util.List;
  26. /**
  27. * 部门管理 服务实现
  28. *
  29. * @author Lion Li
  30. */
  31. @RequiredArgsConstructor
  32. @Service
  33. public class SysDeptServiceImpl implements ISysDeptService {
  34. private final SysDeptMapper baseMapper;
  35. private final SysRoleMapper roleMapper;
  36. private final SysUserMapper userMapper;
  37. /**
  38. * 查询部门管理数据
  39. *
  40. * @param dept 部门信息
  41. * @return 部门信息集合
  42. */
  43. @Override
  44. public List<SysDept> selectDeptList(SysDept dept) {
  45. LambdaQueryWrapper<SysDept> lqw = new LambdaQueryWrapper<>();
  46. lqw.eq(SysDept::getDelFlag, "0")
  47. .eq(ObjectUtil.isNotNull(dept.getDeptId()), SysDept::getDeptId, dept.getDeptId())
  48. .eq(ObjectUtil.isNotNull(dept.getParentId()), SysDept::getParentId, dept.getParentId())
  49. .like(StringUtils.isNotBlank(dept.getDeptName()), SysDept::getDeptName, dept.getDeptName())
  50. .eq(StringUtils.isNotBlank(dept.getStatus()), SysDept::getStatus, dept.getStatus())
  51. .orderByAsc(SysDept::getParentId)
  52. .orderByAsc(SysDept::getOrderNum);
  53. return baseMapper.selectDeptList(lqw);
  54. }
  55. /**
  56. * 查询部门树结构信息
  57. *
  58. * @param dept 部门信息
  59. * @return 部门树信息集合
  60. */
  61. @Override
  62. public List<Tree<Long>> selectDeptTreeList(SysDept dept) {
  63. List<SysDept> depts = this.selectDeptList(dept);
  64. return buildDeptTreeSelect(depts);
  65. }
  66. /**
  67. * 构建前端所需要下拉树结构
  68. *
  69. * @param depts 部门列表
  70. * @return 下拉树结构列表
  71. */
  72. @Override
  73. public List<Tree<Long>> buildDeptTreeSelect(List<SysDept> depts) {
  74. if (CollUtil.isEmpty(depts)) {
  75. return CollUtil.newArrayList();
  76. }
  77. return TreeBuildUtils.build(depts, (dept, tree) ->
  78. tree.setId(dept.getDeptId())
  79. .setParentId(dept.getParentId())
  80. .setName(dept.getDeptName())
  81. .setWeight(dept.getOrderNum()));
  82. }
  83. /**
  84. * 根据角色ID查询部门树信息
  85. *
  86. * @param roleId 角色ID
  87. * @return 选中部门列表
  88. */
  89. @Override
  90. public List<Long> selectDeptListByRoleId(Long roleId) {
  91. SysRole role = roleMapper.selectById(roleId);
  92. return baseMapper.selectDeptListByRoleId(roleId, role.getDeptCheckStrictly());
  93. }
  94. /**
  95. * 根据部门ID查询信息
  96. *
  97. * @param deptId 部门ID
  98. * @return 部门信息
  99. */
  100. @Override
  101. public SysDept selectDeptById(Long deptId) {
  102. SysDept dept = baseMapper.selectById(deptId);
  103. SysDept parentDept = baseMapper.selectOne(new LambdaQueryWrapper<SysDept>()
  104. .select(SysDept::getDeptName).eq(SysDept::getDeptId, dept.getParentId()));
  105. dept.setParentName(ObjectUtil.isNotNull(parentDept) ? parentDept.getDeptName() : null);
  106. return dept;
  107. }
  108. /**
  109. * 根据ID查询所有子部门数(正常状态)
  110. *
  111. * @param deptId 部门ID
  112. * @return 子部门数
  113. */
  114. @Override
  115. public long selectNormalChildrenDeptById(Long deptId) {
  116. return baseMapper.selectCount(new LambdaQueryWrapper<SysDept>()
  117. .eq(SysDept::getStatus, UserConstants.DEPT_NORMAL)
  118. .apply(DataBaseHelper.findInSet(deptId, "ancestors")));
  119. }
  120. /**
  121. * 是否存在子节点
  122. *
  123. * @param deptId 部门ID
  124. * @return 结果
  125. */
  126. @Override
  127. public boolean hasChildByDeptId(Long deptId) {
  128. return baseMapper.exists(new LambdaQueryWrapper<SysDept>()
  129. .eq(SysDept::getParentId, deptId));
  130. }
  131. /**
  132. * 查询部门是否存在用户
  133. *
  134. * @param deptId 部门ID
  135. * @return 结果 true 存在 false 不存在
  136. */
  137. @Override
  138. public boolean checkDeptExistUser(Long deptId) {
  139. return userMapper.exists(new LambdaQueryWrapper<SysUser>()
  140. .eq(SysUser::getDeptId, deptId));
  141. }
  142. /**
  143. * 校验部门名称是否唯一
  144. *
  145. * @param dept 部门信息
  146. * @return 结果
  147. */
  148. @Override
  149. public String checkDeptNameUnique(SysDept dept) {
  150. boolean exist = baseMapper.exists(new LambdaQueryWrapper<SysDept>()
  151. .eq(SysDept::getDeptName, dept.getDeptName())
  152. .eq(SysDept::getParentId, dept.getParentId())
  153. .ne(ObjectUtil.isNotNull(dept.getDeptId()), SysDept::getDeptId, dept.getDeptId()));
  154. if (exist) {
  155. return UserConstants.NOT_UNIQUE;
  156. }
  157. return UserConstants.UNIQUE;
  158. }
  159. /**
  160. * 校验部门是否有数据权限
  161. *
  162. * @param deptId 部门id
  163. */
  164. @Override
  165. public void checkDeptDataScope(Long deptId) {
  166. if (!LoginHelper.isAdmin()) {
  167. SysDept dept = new SysDept();
  168. dept.setDeptId(deptId);
  169. List<SysDept> depts = this.selectDeptList(dept);
  170. if (CollUtil.isEmpty(depts)) {
  171. throw new ServiceException("没有权限访问部门数据!");
  172. }
  173. }
  174. }
  175. /**
  176. * 新增保存部门信息
  177. *
  178. * @param dept 部门信息
  179. * @return 结果
  180. */
  181. @Override
  182. public int insertDept(SysDept dept) {
  183. SysDept info = baseMapper.selectById(dept.getParentId());
  184. // 如果父节点不为正常状态,则不允许新增子节点
  185. if (!UserConstants.DEPT_NORMAL.equals(info.getStatus())) {
  186. throw new ServiceException("部门停用,不允许新增");
  187. }
  188. dept.setAncestors(info.getAncestors() + "," + dept.getParentId());
  189. return baseMapper.insert(dept);
  190. }
  191. /**
  192. * 修改保存部门信息
  193. *
  194. * @param dept 部门信息
  195. * @return 结果
  196. */
  197. @Override
  198. public int updateDept(SysDept dept) {
  199. SysDept newParentDept = baseMapper.selectById(dept.getParentId());
  200. SysDept oldDept = baseMapper.selectById(dept.getDeptId());
  201. if (ObjectUtil.isNotNull(newParentDept) && ObjectUtil.isNotNull(oldDept)) {
  202. String newAncestors = newParentDept.getAncestors() + "," + newParentDept.getDeptId();
  203. String oldAncestors = oldDept.getAncestors();
  204. dept.setAncestors(newAncestors);
  205. updateDeptChildren(dept.getDeptId(), newAncestors, oldAncestors);
  206. }
  207. int result = baseMapper.updateById(dept);
  208. if (UserConstants.DEPT_NORMAL.equals(dept.getStatus()) && StringUtils.isNotEmpty(dept.getAncestors())
  209. && !StringUtils.equals(UserConstants.DEPT_NORMAL, dept.getAncestors())) {
  210. // 如果该部门是启用状态,则启用该部门的所有上级部门
  211. updateParentDeptStatusNormal(dept);
  212. }
  213. return result;
  214. }
  215. /**
  216. * 修改该部门的父级部门状态
  217. *
  218. * @param dept 当前部门
  219. */
  220. private void updateParentDeptStatusNormal(SysDept dept) {
  221. String ancestors = dept.getAncestors();
  222. Long[] deptIds = Convert.toLongArray(ancestors);
  223. baseMapper.update(null, new LambdaUpdateWrapper<SysDept>()
  224. .set(SysDept::getStatus, UserConstants.DEPT_NORMAL)
  225. .in(SysDept::getDeptId, Arrays.asList(deptIds)));
  226. }
  227. /**
  228. * 修改子元素关系
  229. *
  230. * @param deptId 被修改的部门ID
  231. * @param newAncestors 新的父ID集合
  232. * @param oldAncestors 旧的父ID集合
  233. */
  234. public void updateDeptChildren(Long deptId, String newAncestors, String oldAncestors) {
  235. List<SysDept> children = baseMapper.selectList(new LambdaQueryWrapper<SysDept>()
  236. .apply(DataBaseHelper.findInSet(deptId, "ancestors")));
  237. List<SysDept> list = new ArrayList<>();
  238. for (SysDept child : children) {
  239. SysDept dept = new SysDept();
  240. dept.setDeptId(child.getDeptId());
  241. dept.setAncestors(child.getAncestors().replaceFirst(oldAncestors, newAncestors));
  242. list.add(dept);
  243. }
  244. if (list.size() > 0) {
  245. baseMapper.updateBatchById(list);
  246. }
  247. }
  248. /**
  249. * 删除部门管理信息
  250. *
  251. * @param deptId 部门ID
  252. * @return 结果
  253. */
  254. @Override
  255. public int deleteDeptById(Long deptId) {
  256. return baseMapper.deleteById(deptId);
  257. }
  258. }