SysDeptController.java 4.8 KB

123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263646566676869707172737475767778798081828384858687888990919293949596979899100101102103104105106107108109110111112113114115116117118119120121122123124125126127128129130131132133134135136137138139140
  1. package com.xunmei.system.controller;
  2. import com.baomidou.mybatisplus.core.conditions.query.QueryWrapper;
  3. import com.xunmei.common.core.constant.UserConstants;
  4. import com.xunmei.common.core.utils.StringUtils;
  5. import com.xunmei.common.core.web.controller.BaseController;
  6. import com.xunmei.common.core.web.domain.AjaxResult;
  7. import com.xunmei.common.log.annotation.Log;
  8. import com.xunmei.common.log.enums.BusinessType;
  9. import com.xunmei.common.security.annotation.RequiresPermissions;
  10. import com.xunmei.common.security.utils.SecurityUtils;
  11. import com.xunmei.system.api.domain.SysDept;
  12. import com.xunmei.system.api.domain.SysOrg;
  13. import com.xunmei.system.api.domain.SysUser;
  14. import com.xunmei.system.service.ISysDeptService;
  15. import com.xunmei.system.service.ISysOrgService;
  16. import com.xunmei.system.service.ISysUserService;
  17. import org.apache.commons.lang3.ArrayUtils;
  18. import org.springframework.beans.factory.annotation.Autowired;
  19. import org.springframework.validation.annotation.Validated;
  20. import org.springframework.web.bind.annotation.*;
  21. import java.util.Date;
  22. import java.util.List;
  23. /**
  24. * 部门信息
  25. *
  26. * @author ruoyi
  27. */
  28. @RestController
  29. @RequestMapping("/dept")
  30. public class SysDeptController extends BaseController
  31. {
  32. @Autowired
  33. private ISysDeptService deptService;
  34. @Autowired
  35. private ISysOrgService orgService;
  36. @Autowired
  37. private ISysUserService userService;
  38. /**
  39. * 获取部门列表
  40. */
  41. @RequiresPermissions("system:dept:list")
  42. @GetMapping("/list")
  43. public AjaxResult list(SysOrg dept)
  44. {
  45. List<SysOrg> depts = orgService.list(new QueryWrapper<>(dept));
  46. return success(depts);
  47. }
  48. /**
  49. * 查询部门列表(排除节点)
  50. */
  51. @RequiresPermissions("system:dept:list")
  52. @GetMapping("/list/exclude/{deptId}")
  53. public AjaxResult excludeChild(@PathVariable(value = "deptId", required = false) Long deptId)
  54. {
  55. List<SysOrg> depts = orgService.list();
  56. depts.removeIf(d -> d.getId().intValue() == deptId || ArrayUtils.contains(StringUtils.split(d.getPath(), "-"), deptId + ""));
  57. return success(depts);
  58. }
  59. /**
  60. * 根据部门编号获取详细信息
  61. */
  62. @RequiresPermissions("system:dept:query")
  63. @GetMapping(value = "/{deptId}")
  64. public AjaxResult getInfo(@PathVariable Long deptId)
  65. {
  66. // deptService.checkDeptDataScope(deptId);
  67. return success(orgService.getById(deptId));
  68. }
  69. /**
  70. * 新增部门
  71. */
  72. @RequiresPermissions("system:dept:add")
  73. @Log(title = "部门管理", businessType = BusinessType.INSERT)
  74. @PostMapping
  75. public AjaxResult add(@Validated @RequestBody SysOrg dept)
  76. {
  77. if (orgService.list(new QueryWrapper<SysOrg>().eq("name",dept.getName())).size()>0)
  78. {
  79. return error("新增部门'" + dept.getName() + "'失败,部门名称已存在");
  80. }
  81. dept.setCreateBy(SecurityUtils.getUsername());
  82. dept.setCreateTime(new Date());
  83. return toAjax(orgService.save(dept));
  84. }
  85. /**
  86. * 修改部门
  87. */
  88. @RequiresPermissions("system:dept:edit")
  89. @Log(title = "部门管理", businessType = BusinessType.UPDATE)
  90. @PutMapping
  91. public AjaxResult edit(@Validated @RequestBody SysOrg dept)
  92. {
  93. Long deptId = dept.getId();
  94. // deptService.checkDeptDataScope(deptId);
  95. if (orgService.list(new QueryWrapper<SysOrg>().eq("name",dept.getName()).eq("deleted",0L)).size()>0)
  96. {
  97. return error("修改部门'" + dept.getName() + "'失败,部门名称已存在");
  98. }
  99. else if (dept.getParentId().equals(deptId))
  100. {
  101. return error("修改部门'" + dept.getName() + "'失败,上级部门不能是自己");
  102. }
  103. // else if (StringUtils.equals(UserConstants.DEPT_DISABLE, dept.getIsLock()) && deptService.selectNormalChildrenDeptById(deptId) > 0)
  104. // {
  105. // return error("该部门包含未停用的子部门!");
  106. // }
  107. dept.setUpdateBy(SecurityUtils.getUsername());
  108. dept.setUpdateTime(new Date());
  109. return toAjax(orgService.update(new QueryWrapper<>(dept)));
  110. }
  111. /**
  112. * 删除部门
  113. */
  114. @RequiresPermissions("system:dept:remove")
  115. @Log(title = "部门管理", businessType = BusinessType.DELETE)
  116. @DeleteMapping("/{deptId}")
  117. public AjaxResult remove(@PathVariable Long deptId)
  118. {
  119. if (orgService.list(new QueryWrapper<SysOrg>().eq("parent_id",deptId).eq("deleted",0L)).size()>0)
  120. {
  121. return warn("存在下级部门,不允许删除");
  122. }
  123. if (userService.list(new QueryWrapper<SysUser>().eq("org_id",deptId).eq("deleted",0L)).size()>0)
  124. {
  125. return warn("部门存在用户,不允许删除");
  126. }
  127. // deptService.checkDeptDataScope(deptId);
  128. return toAjax(orgService.removeById(deptId));
  129. }
  130. }