xieb
2025-01-21 bd8d88e5e984e59a5c895ec1a254e3dbae1f9f21
src/main/java/org/springblade/modules/evaluate/controller/EvaluateTaskController.java
@@ -16,51 +16,47 @@
 */
package org.springblade.modules.evaluate.controller;
import com.alibaba.fastjson.JSON;
import com.alibaba.fastjson.JSONArray;
import com.baomidou.mybatisplus.extension.plugins.pagination.Page;
import com.baomidou.mybatisplus.core.conditions.query.QueryWrapper;
import com.baomidou.mybatisplus.core.metadata.IPage;
import com.github.xiaoymin.knife4j.annotations.ApiOperationSupport;
import io.swagger.annotations.Api;
import io.swagger.annotations.ApiOperation;
import io.swagger.annotations.ApiParam;
import com.github.xiaoymin.knife4j.annotations.ApiOperationSupport;
import lombok.AllArgsConstructor;
import javax.validation.Valid;
import org.springblade.core.secure.BladeUser;
import org.springblade.core.boot.ctrl.BladeController;
import org.springblade.core.excel.util.ExcelUtil;
import org.springblade.core.mp.support.Condition;
import org.springblade.core.mp.support.Query;
import org.springblade.core.secure.BladeUser;
import org.springblade.core.secure.utils.AuthUtil;
import org.springblade.core.tool.api.R;
import org.springblade.core.tool.constant.BladeConstant;
import org.springblade.core.tool.utils.DateUtil;
import org.springblade.core.tool.utils.Func;
import org.springblade.modules.assessment.wrapper.CandidateJsonObj;
import org.springblade.modules.evaluate.entity.EvaluateResultEntity;
import org.springblade.modules.evaluate.dto.EvaluateTaskDTO;
import org.springblade.modules.evaluate.entity.EvaluateTaskEntity;
import org.springblade.modules.evaluate.excel.EvaluateTaskExcel;
import org.springblade.modules.evaluate.service.IEvaluateResultService;
import org.springblade.modules.evaluate.service.IEvaluateTaskService;
import org.springblade.modules.evaluate.vo.EvaluateTaskVO;
import org.springblade.modules.evaluate.wrapper.EvaluateResultWrapper;
import org.springblade.modules.evaluate.wrapper.EvaluateTaskWrapper;
import org.springblade.modules.system.entity.User;
import org.springblade.modules.system.service.IUserService;
import org.springblade.modules.system.vo.UserVO;
import org.springblade.modules.system.wrapper.UserWrapper;
import org.springblade.modules.utils.DateUtils;
import org.springframework.web.bind.annotation.*;
import com.baomidou.mybatisplus.core.conditions.query.QueryWrapper;
import com.baomidou.mybatisplus.core.metadata.IPage;
import org.springblade.modules.evaluate.wrapper.EvaluateTaskWrapper;
import org.springblade.core.boot.ctrl.BladeController;
import org.springblade.core.tool.utils.DateUtil;
import org.springblade.core.excel.util.ExcelUtil;
import org.springblade.core.tool.constant.BladeConstant;
import springfox.documentation.annotations.ApiIgnore;
import java.util.Map;
import java.util.List;
import java.util.Set;
import java.util.stream.Collectors;
import javax.servlet.http.HttpServletResponse;
import javax.validation.Valid;
import java.util.List;
import java.util.Map;
/**
 * 评优任务表 控制器
 *
 * @author aix
 * @since 2023-12-08
 * @since 2024-01-05
 */
@RestController
@AllArgsConstructor
@@ -70,8 +66,6 @@
   private final IEvaluateTaskService evaluateTaskService;
   private final IUserService userService;
   private final IEvaluateResultService evaluateResultService;
   /**
    * 评优任务表 详情
@@ -95,87 +89,59 @@
   }
   /**
    * 公司评优
    * @param userId
    * H5使用-评优任务列表
    * @param evaluateTask
    * @param query
    * @return
    * @return 返回自己是否投票和投票集合
    */
   @GetMapping("/companyList/{userId}")
   public R companyList(@ApiIgnore @PathVariable Long userId, Query query) {
      QueryWrapper<EvaluateTaskEntity> wrapper = new QueryWrapper<>();
      wrapper.eq("evaluate_state",1).eq("type", 0);
      IPage<EvaluateTaskEntity> pages = evaluateTaskService.page(Condition.getPage(query), wrapper);
      return R.data(EvaluateTaskWrapper.build().companyListPageVO(pages,userId));
   @GetMapping("/selfList")
   @ApiOperationSupport(order = 2)
   @ApiOperation(value = "分页", notes = "传入evaluateTask")
   public R<IPage<EvaluateTaskVO>> selfList(EvaluateTaskEntity evaluateTask, Query query) {
      IPage<EvaluateTaskEntity> pages = evaluateTaskService.page(Condition.getPage(query), Condition.getQueryWrapper(evaluateTask));
      return R.data(EvaluateTaskWrapper.build().h5ReferremPageVO(pages));
   }
   @GetMapping("/taskListByPolling")
   @ApiOperationSupport(order = 2)
   @ApiOperation(value = "分页", notes = "传入evaluateTask")
   public R<IPage<EvaluateTaskVO>> taskListByPolling(EvaluateTaskEntity evaluateTask, Query query) {
      QueryWrapper queryWrapper = new QueryWrapper();
      if (null != evaluateTask.getType())
         queryWrapper.eq("type", evaluateTask.getType());
      if (null != evaluateTask.getEvaluateState())
         queryWrapper.eq("evaluate_state", evaluateTask.getEvaluateState());
      User user = userService.getById(AuthUtil.getUser().getUserId());
      queryWrapper.like("polling_persons" , user.getEmployeeType());
      queryWrapper.like("JSON_EXTRACT(vote_person_obj_info, '$[*].participateIn')", user.getId());
      IPage<EvaluateTaskEntity> pages = evaluateTaskService.page(Condition.getPage(query), queryWrapper);
      return R.data(EvaluateTaskWrapper.build().h5CandidatePageVO(pages));
   }
   /**
    * 个人评优
    * @param userId
    * @param query
    * 根据部门id获取用户列表
    * @param query 分页
    * @param user 用户参数
    * @return
    */
   @GetMapping("/taskList/{deptId}/{userId}")
   public R taskList(@ApiIgnore @PathVariable Long deptId,@ApiIgnore @PathVariable Long userId, Query query) {
      QueryWrapper<EvaluateTaskEntity> wrapper = new QueryWrapper<>();
      wrapper.or().like("candidate_num",deptId).or().like("candidate_num",userId);
      IPage<EvaluateTaskEntity> pages = evaluateTaskService.page(Condition.getPage(query), wrapper);
   @GetMapping("/userList")
   @ApiOperation(value = "分页", notes = "传入user")
   public R<IPage<UserVO>> userList(Query query,User user) {
      QueryWrapper<User> queryWrapper = Condition.getQueryWrapper(user);
      IPage<User> pages = userService.page(Condition.getPage(query), queryWrapper);
      return R.data(UserWrapper.build().pageVO(pages));
   }
      // 处理获取当前部门的用户 type为0时
      List<EvaluateTaskVO> records = EvaluateTaskWrapper.build().listVO(pages.getRecords());
      for (EvaluateTaskVO vo: records) {
         if (vo.getType() == 0) {
            List<CandidateJsonObj> candidateJsonObjs = JSONArray.parseArray(JSON.toJSONString(vo.getCandidateNum()),CandidateJsonObj.class);
            QueryWrapper<User> userQueryWrapper = new QueryWrapper<>();
            userQueryWrapper.like("dept_id", deptId);
            List<User> users = userService.list(userQueryWrapper);
            for (CandidateJsonObj obj:candidateJsonObjs) {
               if (deptId.equals(obj.getDeptId()) && obj.getUsers().size() > 0) {
                  //处理自己部门用户
                  List<Object> commonItems = obj.getUsers().stream()
                     .filter(item1 -> users.stream()
                        .anyMatch(item2 -> item1.getId().equals(item2.getId())))
                     .collect(Collectors.toList());
                  vo.setSelfCandidate(commonItems);
                  break;
               } else if(deptId.equals(obj.getDeptId()) && obj.getUsers().size() == 0) {
                  vo.setSelfCandidate(users);
                  break;
               }
            }
            //是否评论完成
            QueryWrapper<EvaluateResultEntity> resultEntityQueryWrapper = new QueryWrapper<>();
            resultEntityQueryWrapper.eq("score_user_id", userId);
            resultEntityQueryWrapper.eq("type", 0);
            resultEntityQueryWrapper.eq("evaluate_task_id", vo.getId());
            long reqCount = evaluateResultService.count(resultEntityQueryWrapper);
            vo.setIsEvaluateOk(reqCount > 0);
            if (reqCount > 0) {
               vo.setEvaluateResultVO(EvaluateResultWrapper.build().entityVO(evaluateResultService.getOne(resultEntityQueryWrapper)));
            }
         } else {
            //是否评论完成
            QueryWrapper<EvaluateResultEntity> resultEntityQueryWrapper = new QueryWrapper<>();
            resultEntityQueryWrapper.eq("score_user_id", userId);
            resultEntityQueryWrapper.eq("type", 1);
            resultEntityQueryWrapper.eq("evaluate_task_id", vo.getId());
            long reqCount = evaluateResultService.count(resultEntityQueryWrapper);
            vo.setIsEvaluateOk(reqCount > 0);
            if (reqCount > 0) {
               vo.setEvaluateResultVO(EvaluateResultWrapper.build().entityVO(evaluateResultService.getOne(resultEntityQueryWrapper)));
            }
         }
      }
      IPage<EvaluateTaskVO> pageVo = new Page<>(pages.getCurrent(), pages.getSize(), pages.getTotal());
      pageVo.setRecords(records);
      return R.data(pageVo);
   /**
    * 员工列表 不分页
    * @param user
    * @return
    */
   @GetMapping("/userListBy")
   @ApiOperation(value = "分页", notes = "传入user")
   public R<List<UserVO>> userListBy(User user) {
      QueryWrapper<User> queryWrapper = Condition.getQueryWrapper(user);
      List<User> list = userService.list(queryWrapper);
      return R.data(UserWrapper.build().listVO(list));
   }
   /**
@@ -195,8 +161,9 @@
   @PostMapping("/save")
   @ApiOperationSupport(order = 4)
   @ApiOperation(value = "新增", notes = "传入evaluateTask")
   public R save(@Valid @RequestBody EvaluateTaskEntity evaluateTask) {
      return R.status(evaluateTaskService.save(evaluateTask));
   public R save(@Valid @RequestBody EvaluateTaskDTO dto) {
      evaluateTaskService.saveTaskAndCategory(dto);
      return R.data(dto);
   }
   /**
@@ -205,8 +172,8 @@
   @PostMapping("/update")
   @ApiOperationSupport(order = 5)
   @ApiOperation(value = "修改", notes = "传入evaluateTask")
   public R update(@Valid @RequestBody EvaluateTaskEntity evaluateTask) {
      return R.status(evaluateTaskService.updateById(evaluateTask));
   public R update(@Valid @RequestBody EvaluateTaskDTO evaluateTask) {
      return R.status(evaluateTaskService.updateTaskAndCategory(evaluateTask));
   }
   /**
@@ -216,6 +183,10 @@
   @ApiOperationSupport(order = 6)
   @ApiOperation(value = "新增或修改", notes = "传入evaluateTask")
   public R submit(@Valid @RequestBody EvaluateTaskEntity evaluateTask) {
      // 如果是小于当前日期 修改状态
      if (null != evaluateTask.getEvaluateCutoffTimeStart() && DateUtils.isBeforeNow(evaluateTask.getEvaluateCutoffTimeStart())) {
         evaluateTask.setEvaluateState(1);
      }
      return R.status(evaluateTaskService.saveOrUpdate(evaluateTask));
   }