From 3b7c832ffe25aed9cbdf0a40cbb332905b698351 Mon Sep 17 00:00:00 2001
From: liujie <1793218484@qq.com>
Date: 星期三, 22 十月 2025 18:27:10 +0800
Subject: [PATCH] 人员详情

---
 ruoyi-admin/src/main/java/com/ruoyi/web/controller/api/TAppUserController.java |  127 +++++++++++++++++++++++++++++++++--------
 1 files changed, 101 insertions(+), 26 deletions(-)

diff --git a/ruoyi-admin/src/main/java/com/ruoyi/web/controller/api/TAppUserController.java b/ruoyi-admin/src/main/java/com/ruoyi/web/controller/api/TAppUserController.java
index 60f09c4..5b92633 100644
--- a/ruoyi-admin/src/main/java/com/ruoyi/web/controller/api/TAppUserController.java
+++ b/ruoyi-admin/src/main/java/com/ruoyi/web/controller/api/TAppUserController.java
@@ -2,27 +2,32 @@
 
 
 import com.alibaba.fastjson2.JSON;
+import com.baomidou.mybatisplus.core.conditions.query.LambdaQueryWrapper;
 import com.baomidou.mybatisplus.core.toolkit.Wrappers;
 import com.ruoyi.common.basic.PageInfo;
 import com.ruoyi.common.core.domain.R;
 import com.ruoyi.common.utils.SecurityUtils;
 import com.ruoyi.framework.web.service.TokenService;
+import com.ruoyi.system.dto.AuditUserDto;
+import com.ruoyi.system.dto.TAppUserDTO;
 import com.ruoyi.system.dto.UpAndDownDTO;
-import com.ruoyi.system.mapper.SysUserMapper;
+import com.ruoyi.system.dto.UserIdDto;
 import com.ruoyi.system.model.TAppUser;
+import com.ruoyi.system.model.TMajor;
+import com.ruoyi.system.model.TUserMajor;
 import com.ruoyi.system.query.TAppUserQuery;
 import com.ruoyi.system.service.TAppUserService;
+import com.ruoyi.system.service.TMajorService;
+import com.ruoyi.system.service.TUserMajorService;
 import com.ruoyi.system.vo.TAppUserPageVo;
 import io.swagger.annotations.Api;
 import io.swagger.annotations.ApiOperation;
 import org.springframework.beans.factory.annotation.Autowired;
-import org.springframework.security.access.prepost.PreAuthorize;
-import org.springframework.security.crypto.password.PasswordEncoder;
-import org.springframework.web.bind.annotation.PostMapping;
-import org.springframework.web.bind.annotation.RequestBody;
-import org.springframework.web.bind.annotation.RequestMapping;
-import org.springframework.web.bind.annotation.RestController;
+import org.springframework.util.CollectionUtils;
+import org.springframework.util.StringUtils;
+import org.springframework.web.bind.annotation.*;
 
+import java.util.List;
 import java.util.stream.Collectors;
 
 /**
@@ -40,11 +45,15 @@
 
     private final TokenService tokenService;
     private final TAppUserService appUserService;
+    private final TUserMajorService userMajorService;
+    private final TMajorService majorService;
 
     @Autowired
-    public TAppUserController(TokenService tokenService, TAppUserService appUserService) {
+    public TAppUserController(TokenService tokenService, TAppUserService appUserService, TUserMajorService userMajorService, TMajorService majorService) {
         this.tokenService = tokenService;
         this.appUserService = appUserService;
+        this.userMajorService = userMajorService;
+        this.majorService = majorService;
     }
 
     /**
@@ -63,14 +72,30 @@
      * 添加人员
      */
     //    @PreAuthorize("@ss.hasPermi('system:user:addUser')")
-    @ApiOperation(value = "添加人员")
+    @ApiOperation(value = "添加人员",notes = "请求参数:TAppUserDTO对象",response = TAppUserDTO.class)
     @PostMapping(value = "/api/t-app-user/addUser")
     public R<?> addUser(@RequestBody String param) {
-        TAppUser tAppUser = JSON.parseObject(param, TAppUser.class);
-        String pwd = SecurityUtils.encryptPassword(tAppUser.getPassword());
-        tAppUser.setPassword(pwd);
-        tAppUser.setState(1);
-        appUserService.save(tAppUser);
+        TAppUserDTO dto = JSON.parseObject(param, TAppUserDTO.class);
+        if(!StringUtils.hasLength(dto.getAccount())){
+            return R.fail("请输入账号");
+        }
+        if (appUserService.isExit(dto)) {
+            return R.fail("该账号已存在");
+        }
+        List<TUserMajor> userMajors = dto.getUserMajors();
+        if(CollectionUtils.isEmpty(userMajors)){
+            return R.fail("请选择专业");
+        }
+        String pwd = SecurityUtils.encryptPassword(dto.getPassword());
+        dto.setPassword(pwd);
+        dto.setState(1);
+        appUserService.save(dto);
+
+        for (TUserMajor userMajor : userMajors) {
+            userMajor.setAppUserId(dto.getId());
+        }
+        userMajorService.saveBatch(userMajors);
+
         return R.ok();
     }
 
@@ -81,13 +106,22 @@
     @ApiOperation(value = "编辑人员", response = TAppUser.class)
     @PostMapping(value = "/api/t-app-user/updateUser")
     public R<?> updateUser(@RequestBody String param) {
-        TAppUser tAppUser = JSON.parseObject(param, TAppUser.class);
-        if(tAppUser.getPassword()!=null && !tAppUser.getPassword().isEmpty()){
-            String pwd = SecurityUtils.encryptPassword(tAppUser.getPassword());
-            tAppUser.setPassword(pwd);
+        TAppUserDTO dto = JSON.parseObject(param, TAppUserDTO.class);
+        if (appUserService.isExit(dto)) {
+            return R.fail("该账号已存在");
         }
-        tAppUser.setState(1);
-        appUserService.updateById(tAppUser);
+        List<TUserMajor> userMajors = dto.getUserMajors();
+        if(dto.getPassword()!=null && !dto.getPassword().isEmpty()){
+            String pwd = SecurityUtils.encryptPassword(dto.getPassword());
+            dto.setPassword(pwd);
+        }
+        dto.setState(1);
+        appUserService.updateById(dto);
+        userMajorService.remove(Wrappers.lambdaQuery(TUserMajor.class).eq(TUserMajor::getAppUserId,dto.getId()));
+        for (TUserMajor userMajor : userMajors) {
+            userMajor.setAppUserId(dto.getId());
+        }
+        userMajorService.saveBatch(userMajors);
         return R.ok();
     }
 
@@ -98,8 +132,8 @@
     @ApiOperation(value = "删除人员")
     @PostMapping(value = "/api/t-app-user/delUser")
     public R<?> delUser(@RequestBody String param) {
-        String id = JSON.parseObject(param, String.class);
-        TAppUser appUser = appUserService.getById(id);
+        UserIdDto dto = JSON.parseObject(param, UserIdDto.class);
+        TAppUser appUser = appUserService.getById(dto.getId());
         appUser.setDisabled(true);
         appUserService.updateById(appUser);
         return R.ok();
@@ -129,8 +163,8 @@
     @ApiOperation(value = "重置密码")
     @PostMapping(value = "/api/t-app-user/resetPwd")
     public R<?> resetPwd(@RequestBody String param) {
-        String id = JSON.parseObject(param, String.class);
-        TAppUser appUser = appUserService.getById(id);
+        UserIdDto dto = JSON.parseObject(param, UserIdDto.class);
+        TAppUser appUser = appUserService.getById(dto.getId());
         String pwd = SecurityUtils.encryptPassword("123456");
         appUser.setPassword(pwd);
         appUserService.updateById(appUser);
@@ -159,8 +193,49 @@
     @ApiOperation(value = "获取人员审核管理详情", response = TAppUserPageVo.class)
     @PostMapping(value = "/api/t-app-user/auditDetail")
     public R<TAppUserPageVo> auditDetail(@RequestBody String param) {
-        String id = JSON.parseObject(param, String.class);
-        return R.ok(appUserService.pageAuditDetail(id));
+        UserIdDto dto = JSON.parseObject(param, UserIdDto.class);
+        return R.ok(appUserService.pageAuditDetail(dto.getId()));
+    }
+
+
+    /**
+     * 编辑人员
+     */
+    //    @PreAuthorize("@ss.hasPermi('system:user:auditUser')")
+    @ApiOperation(value = "人员审核", response = AuditUserDto.class)
+    @PostMapping(value = "/api/t-app-user/auditUser")
+    public R<?> auditUser(@RequestBody String param) {
+        AuditUserDto dto = JSON.parseObject(param, AuditUserDto.class);
+        TAppUser tAppUser = appUserService.getById(dto.getId());
+        tAppUser.setStatus(dto.getStatus());
+        tAppUser.setTeamId(dto.getTeamId());
+        appUserService.updateById(tAppUser);
+        return R.ok();
+    }
+
+
+    /**
+     * 详情
+     */
+    //    @PreAuthorize("@ss.hasPermi('system:user:auditUser')")
+    @ApiOperation(value = "人员详情", response = AuditUserDto.class)
+    @PostMapping(value = "/api/t-app-user/detailUser")
+    public R<TAppUser> detailUser(@RequestBody String param) {
+        UserIdDto dto = JSON.parseObject(param, UserIdDto.class);
+        TAppUser tAppUser = appUserService.getById(dto.getId());
+        List<TUserMajor> list = userMajorService.list(new LambdaQueryWrapper<TUserMajor>().eq(TUserMajor::getAppUserId, dto.getId()));
+        if(!list.isEmpty()){
+            List<String> mjIds = list.stream().map(TUserMajor::getMajorId).collect(Collectors.toList());
+            List<TMajor> mjList = majorService.list(new LambdaQueryWrapper<TMajor>().in(TMajor::getId, mjIds));
+            for (TUserMajor tUserMajor : list) {
+                TMajor tMajor = mjList.stream().filter(mj -> mj.getId().equals(tUserMajor.getMajorId())).findFirst().orElse(null);
+                if(tMajor!=null){
+                    tUserMajor.setIndicator(tMajor.getMajorName());
+                }
+            }
+        }
+        tAppUser.setUserMajors(list);
+        return R.ok(tAppUser);
     }
 
 

--
Gitblit v1.7.1