From 4a9a9fa60f52be1e7c91f01df54b3cbae8c11d6c Mon Sep 17 00:00:00 2001
From: baizonghao <1719256278@qq.com>
Date: 星期日, 23 四月 2023 13:11:21 +0800
Subject: [PATCH] 用户导出

---
 src/main/java/com/example/jz/controller/UserController.java |   84 ++++++++++++++++++++++++++++++++++++------
 1 files changed, 72 insertions(+), 12 deletions(-)

diff --git a/src/main/java/com/example/jz/controller/UserController.java b/src/main/java/com/example/jz/controller/UserController.java
index 958d7e5..5b4cf3b 100644
--- a/src/main/java/com/example/jz/controller/UserController.java
+++ b/src/main/java/com/example/jz/controller/UserController.java
@@ -4,21 +4,28 @@
 import com.baomidou.mybatisplus.core.conditions.query.QueryWrapper;
 import com.baomidou.mybatisplus.core.conditions.update.UpdateWrapper;
 import com.baomidou.mybatisplus.core.toolkit.StringUtils;
+import com.baomidou.mybatisplus.core.toolkit.Wrappers;
 import com.baomidou.mybatisplus.extension.api.ApiController;
 import com.baomidou.mybatisplus.extension.plugins.pagination.Page;
 import com.example.jz.modle.R;
 import com.example.jz.modle.dto.ManagerDto;
+import com.example.jz.modle.dto.UserExpDto;
 import com.example.jz.modle.entity.*;
 import com.example.jz.service.*;
+import com.example.jz.utils.EasyExcelUtils;
 import com.example.jz.utils.Md5Utils;
 import io.swagger.annotations.Api;
 import io.swagger.annotations.ApiOperation;
+import org.springframework.beans.BeanUtils;
 import org.springframework.beans.factory.annotation.Autowired;
 import org.springframework.web.bind.annotation.*;
 
+import javax.servlet.http.HttpServletResponse;
 import java.io.Serializable;
-import java.util.Date;
+import java.util.*;
 import java.util.function.Consumer;
+import java.util.function.Function;
+import java.util.stream.Collectors;
 
 /**
  * 鐢ㄦ埛琛�(User)琛ㄦ帶鍒跺眰
@@ -117,16 +124,16 @@
 
     @GetMapping("/status")
     @ApiOperation("绂佺敤/鍚敤鐢ㄦ埛")
-    public R updateStatus(Integer id,Integer status){
+    public R updateStatus(Integer id, Integer status) {
         int newStatus = 0;
-        if(status!=null){
-            if(status==1){
-                newStatus=0;
-            }else{
-                newStatus=1;
+        if (status != null) {
+            if (status == 1) {
+                newStatus = 0;
+            } else {
+                newStatus = 1;
             }
         }
-        userService.update(new UpdateWrapper<User>().set("status", newStatus).eq("id",id));
+        userService.update(new UpdateWrapper<User>().set("status", newStatus).eq("id", id));
         return R.ok();
     }
 
@@ -143,13 +150,38 @@
     }
 
     @DeleteMapping("/manager")
-    @ApiOperation("鍒犻櫎绠$悊")
+    @ApiOperation("鍒犻櫎绠$悊浜哄憳")
     public R removeManager(@RequestParam Integer id) {
-        causeService.list(new LambdaQueryWrapper<Cause>().eq(Cause::getUserId, id)).forEach(item -> {
-            causeService.deleteCause(item.getId());
-        });
+        List<Cause> list = causeService.list(new LambdaQueryWrapper<Cause>().eq(Cause::getUserId, id));
+        if (!Objects.isNull(list) && list.size() != 0){
+            ArrayList<Map> maps = new ArrayList<>();
+            for (Cause cause : list) {
+                HashMap<String, String> map = new HashMap<>();
+                map.put("caseName", cause.getName());
+                map.put("caseNumber", cause.getNumber());
+                maps.add(map);
+            }
+            return R.failed(maps, "璇ヨ鍛樿繕鏈夋浠跺叧鑱�,鑻ヨ鍒犻櫎璇峰厛淇敼瀵瑰簲妗堜欢鍏宠仈鐨勮鍛�");
+        }
+//        causeService.list(new LambdaQueryWrapper<Cause>().eq(Cause::getUserId, id)).forEach(item -> {
+//            causeService.deleteCause(item.getId());
+//        });
+//        userService.remove(new LambdaQueryWrapper<User>().eq(User::getId, id));
         messageService.remove(new LambdaQueryWrapper<Message>().eq(Message::getCopId, id));
         return R.ok(userService.removeById(id));
+    }
+
+    @DeleteMapping("/crowd")
+    @ApiOperation("鍒犻櫎鏅�氱敤鎴�")
+    public R removeCrowd(@RequestParam Integer id){
+        List<Report> list = reportService.list(Wrappers.<Report>lambdaQuery().eq(Report::getUserId, id));
+        for (Report report : list) {
+            groupUserService.remove(new LambdaQueryWrapper<GroupUser>().eq(GroupUser::getUserId, report.getId()));
+            messageService.remove(new LambdaQueryWrapper<Message>().eq(Message::getUserId, report.getId()));
+            reportService.removeById(report.getId());
+        }
+        userService.remove(Wrappers.<User>lambdaQuery().eq(User::getId, id));
+        return R.ok();
     }
 
     @GetMapping("/manager")
@@ -198,4 +230,32 @@
         user.setLoginPassword(Md5Utils.md5(user.getUserIdcard().substring(user.getUserIdcard().length() - 6)));
         return R.ok(userService.updateById(user));
     }
+
+    /**
+     * 杞负绠$悊鍛�
+     *
+     * @param id 鐢ㄦ埛id
+     * @return
+     */
+    @GetMapping("/toManager/{id}")
+    @ApiOperation("杞负绠$悊鍛�")
+    public R toManager(@PathVariable Serializable id) {
+        User user = userService.getById(id);
+        user.setRole(1);
+        return R.ok(userService.updateById(user));
+    }
+
+
+    @ApiOperation("鐢ㄦ埛淇℃伅瀵煎嚭")
+    @PostMapping("/exp")
+    public void UserExp(HttpServletResponse response){
+        List<User> list = userService.list(Wrappers.<User>lambdaQuery().eq(User::getRole, 0).eq(User::getStatus, 1));
+        List<UserExpDto> userExpDtos = list.stream().map(user -> {
+            UserExpDto userExpDto = new UserExpDto();
+            BeanUtils.copyProperties(user, userExpDto);
+            return userExpDto;
+        }).collect(Collectors.toList());
+        String sheetName = "鐢ㄦ埛瀵煎嚭";
+        EasyExcelUtils.export1(response, sheetName, UserExpDto.class, userExpDtos, "鐢ㄦ埛瀵煎嚭");
+    }
 }

--
Gitblit v1.8.0