From 64f7ccb9ef8b5a0618e65cddc14b981c1f108ba3 Mon Sep 17 00:00:00 2001
From: 无关风月 <443237572@qq.com>
Date: 星期一, 04 十一月 2024 09:01:59 +0800
Subject: [PATCH] 代码提交

---
 xinquan-modules/xinquan-system/src/main/java/com/xinquan/system/controller/SysDeptController.java |  170 +++++++++++++++++++++++++++-----------------------------
 1 files changed, 83 insertions(+), 87 deletions(-)

diff --git a/xinquan-modules/xinquan-system/src/main/java/com/xinquan/system/controller/SysDeptController.java b/xinquan-modules/xinquan-system/src/main/java/com/xinquan/system/controller/SysDeptController.java
index 7c6c3da..37e1f08 100644
--- a/xinquan-modules/xinquan-system/src/main/java/com/xinquan/system/controller/SysDeptController.java
+++ b/xinquan-modules/xinquan-system/src/main/java/com/xinquan/system/controller/SysDeptController.java
@@ -1,134 +1,130 @@
 package com.xinquan.system.controller;
 
-import java.util.List;
 
-import com.xinquan.system.service.ISysDeptService;
-import org.apache.commons.lang3.ArrayUtils;
-import org.springframework.beans.factory.annotation.Autowired;
-import org.springframework.validation.annotation.Validated;
-import org.springframework.web.bind.annotation.DeleteMapping;
-import org.springframework.web.bind.annotation.GetMapping;
-import org.springframework.web.bind.annotation.PathVariable;
-import org.springframework.web.bind.annotation.PostMapping;
-import org.springframework.web.bind.annotation.PutMapping;
-import org.springframework.web.bind.annotation.RequestBody;
-import org.springframework.web.bind.annotation.RequestMapping;
-import org.springframework.web.bind.annotation.RestController;
-import com.xinquan.common.core.constant.UserConstants;
-import com.xinquan.common.core.utils.StringUtils;
+import com.baomidou.mybatisplus.extension.plugins.pagination.Page;
+import com.xinquan.common.core.domain.R;
+import com.xinquan.common.core.utils.page.PageDTO;
 import com.xinquan.common.core.web.controller.BaseController;
 import com.xinquan.common.core.web.domain.AjaxResult;
+import com.xinquan.common.core.web.page.PageInfo;
 import com.xinquan.common.log.annotation.Log;
 import com.xinquan.common.log.enums.BusinessType;
 import com.xinquan.common.security.annotation.RequiresPermissions;
+import com.xinquan.common.security.service.TokenService;
 import com.xinquan.common.security.utils.SecurityUtils;
 import com.xinquan.system.api.domain.SysDept;
+import com.xinquan.system.api.domain.SysRole;
+import com.xinquan.system.api.domain.SysUser;
+import com.xinquan.system.domain.SysUserDept;
+import com.xinquan.system.domain.dto.SysDeptUpdateStatusDTO;
+import com.xinquan.system.domain.dto.SysUserUpdateStatusDTO;
+import com.xinquan.system.domain.dto.UnfreeDto;
+import com.xinquan.system.service.ISysDeptService;
+import com.xinquan.system.service.ISysUserDeptService;
+import com.xinquan.system.service.ISysUserService;
+import io.swagger.annotations.Api;
+import io.swagger.annotations.ApiOperation;
+import org.springframework.beans.factory.annotation.Autowired;
+import org.springframework.validation.annotation.Validated;
+import org.springframework.web.bind.annotation.*;
+
+import javax.annotation.Resource;
+import java.text.SimpleDateFormat;
+import java.time.LocalDateTime;
+import java.util.Date;
+import java.util.List;
 
 /**
  * 部门信息
- * 
+ *
  * @author ruoyi
  */
 @RestController
 @RequestMapping("/dept")
+@Api(tags = "部门管理")
 public class SysDeptController extends BaseController
 {
     @Autowired
     private ISysDeptService deptService;
+    @Autowired
+    private ISysUserDeptService userDeptService;
 
-    /**
-     * 获取部门列表
-     */
-    @RequiresPermissions("system:dept:list")
     @GetMapping("/list")
-    public AjaxResult list(SysDept dept)
-    {
-        List<SysDept> depts = deptService.selectDeptList(dept);
-        return success(depts);
-    }
-
-    /**
-     * 查询部门列表(排除节点)
-     */
-    @RequiresPermissions("system:dept:list")
-    @GetMapping("/list/exclude/{deptId}")
-    public AjaxResult excludeChild(@PathVariable(value = "deptId", required = false) Long deptId)
-    {
-        List<SysDept> depts = deptService.selectDeptList(new SysDept());
-        depts.removeIf(d -> d.getDeptId().intValue() == deptId || ArrayUtils.contains(StringUtils.split(d.getAncestors(), ","), deptId + ""));
-        return success(depts);
-    }
-
-    /**
-     * 根据部门编号获取详细信息
-     */
-    @RequiresPermissions("system:dept:query")
-    @GetMapping(value = "/{deptId}")
-    public AjaxResult getInfo(@PathVariable Long deptId)
-    {
-        deptService.checkDeptDataScope(deptId);
-        return success(deptService.selectDeptById(deptId));
+    @ApiOperation("部门列表")
+    public R<PageDTO<SysDept>> list(String deptName, int pageCurr, int pageSize) {
+        Page<SysDept> res = new Page<>(pageCurr, pageSize);
+        PageInfo<SysDept> pageInfo = new PageInfo<>(pageCurr, pageSize);
+        List<SysDept> page = deptService.getList(pageInfo, deptName);
+        for (SysDept sysDept : page) {
+            int size = userDeptService.lambdaQuery().eq(SysUserDept::getDeptId, sysDept.getDeptId()).list().size();
+            sysDept.setUserCount(size);
+        }
+        pageInfo.setRecords(page);
+        res.setRecords(page);
+        PageDTO<SysDept> sysUserVOPageDTO = PageDTO.of(res, SysDept.class);
+        return R.ok(sysUserVOPageDTO);
     }
 
     /**
      * 新增部门
      */
-    @RequiresPermissions("system:dept:add")
-    @Log(title = "部门管理", businessType = BusinessType.INSERT)
-    @PostMapping
-    public AjaxResult add(@Validated @RequestBody SysDept dept)
+    @PostMapping("/add")
+    @ApiOperation("部门添加")
+    public AjaxResult add(@Validated @RequestBody SysDept dto)
     {
-        if (!deptService.checkDeptNameUnique(dept))
-        {
-            return error("新增部门'" + dept.getDeptName() + "'失败,部门名称已存在");
+        dto.setCreateTime(LocalDateTime.now());
+        if (!deptService.checkDeptNameUnique(dto)){
+            return error("新增部门失败,部门ID已存在");
         }
-        dept.setCreateBy(SecurityUtils.getUsername());
-        return toAjax(deptService.insertDept(dept));
+        dto.setCreateBy(SecurityUtils.getUsername());
+        return toAjax(deptService.insertDept(dto));
     }
 
+    @Resource
+    private TokenService tokenService;
+    @Resource
+    private ISysUserService service;
     /**
      * 修改部门
      */
-    @RequiresPermissions("system:dept:edit")
-    @Log(title = "部门管理", businessType = BusinessType.UPDATE)
-    @PutMapping
-    public AjaxResult edit(@Validated @RequestBody SysDept dept)
+    @PostMapping("/edit")
+    @ApiOperation("部门修改")
+    public R edit(@Validated @RequestBody SysDept dept)
     {
-        Long deptId = dept.getDeptId();
-        deptService.checkDeptDataScope(deptId);
-        if (!deptService.checkDeptNameUnique(dept))
-        {
-            return error("修改部门'" + dept.getDeptName() + "'失败,部门名称已存在");
+        if (!deptService.checkDeptNameUnique1(dept)){
+            return R.fail("修改部门失败,部门ID已存在");
         }
-        else if (dept.getParentId().equals(deptId))
-        {
-            return error("修改部门'" + dept.getDeptName() + "'失败,上级部门不能是自己");
-        }
-        else if (StringUtils.equals(UserConstants.DEPT_DISABLE, dept.getStatus()) && deptService.selectNormalChildrenDeptById(deptId) > 0)
-        {
-            return error("该部门包含未停用的子部门!");
-        }
-        dept.setUpdateBy(SecurityUtils.getUsername());
-        return toAjax(deptService.updateDept(dept));
+        Long userid = tokenService.getLoginUser().getUserid();
+        SysUser byId = service.getById(userid);
+        dept.setUpdateBy(byId.getNickName()+"("+byId.getUserName()+")");
+        dept.setHandleName(byId.getNickName()+"("+byId.getUserName()+")");
+        return R.ok(deptService.updateDept(dept));
     }
-
+    @Autowired
+    private ISysUserService userService;
+    @ApiOperation(value = "禁用启用")
+    @PutMapping("/changeStatus")
+    public AjaxResult changeStatus(@RequestBody SysDeptUpdateStatusDTO dto)
+    {
+        SysDept user = new SysDept();
+        user.setDeptId(dto.getDeptId());
+        user.setStatus(String.valueOf(dto.getStatus()));
+        user.setReason(dto.getReason());
+        Long userid = tokenService.getLoginUser().getUserid();
+        SysUser sysUser = userService.selectUserById(userid);
+        user.setUpdateBy(sysUser.getNickName()+"("+sysUser.getUserName()+")");
+        user.setHandleName(sysUser.getNickName()+"("+sysUser.getUserName()+")");
+        return AjaxResult.success(userService.updateDeptStatus(user));
+    }
     /**
      * 删除部门
      */
-    @RequiresPermissions("system:dept:remove")
-    @Log(title = "部门管理", businessType = BusinessType.DELETE)
     @DeleteMapping("/{deptId}")
+    @ApiOperation("删除部门")
     public AjaxResult remove(@PathVariable Long deptId)
     {
-        if (deptService.hasChildByDeptId(deptId))
-        {
-            return warn("存在下级部门,不允许删除");
-        }
-        if (deptService.checkDeptExistUser(deptId))
-        {
-            return warn("部门存在用户,不允许删除");
-        }
-        deptService.checkDeptDataScope(deptId);
         return toAjax(deptService.deleteDeptById(deptId));
     }
+
+
 }

--
Gitblit v1.7.1