/* * Copyright (c) 2018-2028, Chill Zhuang All rights reserved. * * Redistribution and use in source and binary forms, with or without * modification, are permitted provided that the following conditions are met: * * Redistributions of source code must retain the above copyright notice, * this list of conditions and the following disclaimer. * Redistributions in binary form must reproduce the above copyright * notice, this list of conditions and the following disclaimer in the * documentation and/or other materials provided with the distribution. * Neither the name of the dreamlu.net developer nor the names of its * contributors may be used to endorse or promote products derived from * this software without specific prior written permission. * Author: Chill 庄骞 (smallchill@163.com) */ 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 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.mp.support.Condition; import org.springblade.core.mp.support.Query; import org.springblade.core.tool.api.R; 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.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.system.entity.User; import org.springblade.modules.system.service.IUserService; 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; /** * 评优任务表 控制器 * * @author aix * @since 2023-12-08 */ @RestController @AllArgsConstructor @RequestMapping("evaluate/evaluateTask") @Api(value = "评优任务表", tags = "评优任务表接口") public class EvaluateTaskController extends BladeController { private final IEvaluateTaskService evaluateTaskService; private final IUserService userService; private final IEvaluateResultService evaluateResultService; /** * 评优任务表 详情 */ @GetMapping("/detail") @ApiOperationSupport(order = 1) @ApiOperation(value = "详情", notes = "传入evaluateTask") public R detail(EvaluateTaskEntity evaluateTask) { EvaluateTaskEntity detail = evaluateTaskService.getOne(Condition.getQueryWrapper(evaluateTask)); return R.data(EvaluateTaskWrapper.build().entityVO(detail)); } /** * 评优任务表 分页 */ @GetMapping("/list") @ApiOperationSupport(order = 2) @ApiOperation(value = "分页", notes = "传入evaluateTask") public R> list(@ApiIgnore @RequestParam Map evaluateTask, Query query) { IPage pages = evaluateTaskService.page(Condition.getPage(query), Condition.getQueryWrapper(evaluateTask, EvaluateTaskEntity.class)); return R.data(EvaluateTaskWrapper.build().pageVO(pages)); } /** * 公司评优 * @param userId * @param query * @return */ @GetMapping("/companyList/{userId}") public R companyList(@ApiIgnore @PathVariable Long userId, Query query) { QueryWrapper wrapper = new QueryWrapper<>(); wrapper.eq("evaluate_state",1).eq("type", 0); IPage pages = evaluateTaskService.page(Condition.getPage(query), wrapper); return R.data(EvaluateTaskWrapper.build().companyListPageVO(pages,userId)); } /** * 个人评优 * @param userId * @param query * @return */ @GetMapping("/taskList/{deptId}/{userId}") public R taskList(@ApiIgnore @PathVariable Long deptId,@ApiIgnore @PathVariable Long userId, Query query) { QueryWrapper wrapper = new QueryWrapper<>(); wrapper.or().like("candidate_num",deptId).or().like("candidate_num",userId); IPage pages = evaluateTaskService.page(Condition.getPage(query), wrapper); // 处理获取当前部门的用户 type为0时 List records = EvaluateTaskWrapper.build().listVO(pages.getRecords()); for (EvaluateTaskVO vo: records) { if (vo.getType() == 0) { List candidateJsonObjs = JSONArray.parseArray(JSON.toJSONString(vo.getCandidateNum()),CandidateJsonObj.class); QueryWrapper userQueryWrapper = new QueryWrapper<>(); userQueryWrapper.like("dept_id", deptId); List users = userService.list(userQueryWrapper); for (CandidateJsonObj obj:candidateJsonObjs) { if (deptId.equals(obj.getDeptId()) && obj.getUsers().size() > 0) { //处理自己部门用户 List 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 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 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 pageVo = new Page<>(pages.getCurrent(), pages.getSize(), pages.getTotal()); pageVo.setRecords(records); return R.data(pageVo); } /** * 评优任务表 自定义分页 */ @GetMapping("/page") @ApiOperationSupport(order = 3) @ApiOperation(value = "分页", notes = "传入evaluateTask") public R> page(EvaluateTaskVO evaluateTask, Query query) { IPage pages = evaluateTaskService.selectEvaluateTaskPage(Condition.getPage(query), evaluateTask); return R.data(pages); } /** * 评优任务表 新增 */ @PostMapping("/save") @ApiOperationSupport(order = 4) @ApiOperation(value = "新增", notes = "传入evaluateTask") public R save(@Valid @RequestBody EvaluateTaskEntity evaluateTask) { return R.status(evaluateTaskService.save(evaluateTask)); } /** * 评优任务表 修改 */ @PostMapping("/update") @ApiOperationSupport(order = 5) @ApiOperation(value = "修改", notes = "传入evaluateTask") public R update(@Valid @RequestBody EvaluateTaskEntity evaluateTask) { return R.status(evaluateTaskService.updateById(evaluateTask)); } /** * 评优任务表 新增或修改 */ @PostMapping("/submit") @ApiOperationSupport(order = 6) @ApiOperation(value = "新增或修改", notes = "传入evaluateTask") public R submit(@Valid @RequestBody EvaluateTaskEntity evaluateTask) { return R.status(evaluateTaskService.saveOrUpdate(evaluateTask)); } /** * 评优任务表 删除 */ @PostMapping("/remove") @ApiOperationSupport(order = 7) @ApiOperation(value = "逻辑删除", notes = "传入ids") public R remove(@ApiParam(value = "主键集合", required = true) @RequestParam String ids) { return R.status(evaluateTaskService.deleteLogic(Func.toLongList(ids))); } /** * 导出数据 */ @GetMapping("/export-evaluateTask") @ApiOperationSupport(order = 9) @ApiOperation(value = "导出数据", notes = "传入evaluateTask") public void exportEvaluateTask(@ApiIgnore @RequestParam Map evaluateTask, BladeUser bladeUser, HttpServletResponse response) { QueryWrapper queryWrapper = Condition.getQueryWrapper(evaluateTask, EvaluateTaskEntity.class); //if (!AuthUtil.isAdministrator()) { // queryWrapper.lambda().eq(EvaluateTask::getTenantId, bladeUser.getTenantId()); //} queryWrapper.lambda().eq(EvaluateTaskEntity::getIsDeleted, BladeConstant.DB_NOT_DELETED); List list = evaluateTaskService.exportEvaluateTask(queryWrapper); ExcelUtil.export(response, "评优任务表数据" + DateUtil.time(), "评优任务表数据表", list, EvaluateTaskExcel.class); } }