/* * 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.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 lombok.AllArgsConstructor; 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.evaluate.dto.EvaluateTaskDTO; import org.springblade.modules.evaluate.entity.EvaluateTaskEntity; import org.springblade.modules.evaluate.excel.EvaluateTaskExcel; import org.springblade.modules.evaluate.service.IEvaluateTaskService; import org.springblade.modules.evaluate.vo.EvaluateTaskVO; 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 springfox.documentation.annotations.ApiIgnore; import javax.servlet.http.HttpServletResponse; import javax.validation.Valid; import java.util.List; import java.util.Map; /** * 评优任务表 控制器 * * @author aix * @since 2024-01-05 */ @RestController @AllArgsConstructor @RequestMapping("evaluate/evaluateTask") @Api(value = "评优任务表", tags = "评优任务表接口") public class EvaluateTaskController extends BladeController { private final IEvaluateTaskService evaluateTaskService; private final IUserService userService; /** * 评优任务表 详情 */ @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)); } /** * H5使用-评优任务列表 * @param evaluateTask * @param query * @return 返回自己是否投票和投票集合 */ @GetMapping("/selfList") @ApiOperationSupport(order = 2) @ApiOperation(value = "分页", notes = "传入evaluateTask") public R> selfList(EvaluateTaskEntity evaluateTask, Query query) { IPage 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> taskListByPolling(EvaluateTaskEntity evaluateTask, Query query) { QueryWrapper queryWrapper = new QueryWrapper(); if (null != evaluateTask.getType()) queryWrapper.eq("type", evaluateTask.getType()); 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 pages = evaluateTaskService.page(Condition.getPage(query), queryWrapper); return R.data(EvaluateTaskWrapper.build().h5CandidatePageVO(pages)); } /** * 根据部门id获取用户列表 * @param query 分页 * @param user 用户参数 * @return */ @GetMapping("/userList") @ApiOperation(value = "分页", notes = "传入user") public R> userList(Query query,User user) { QueryWrapper queryWrapper = Condition.getQueryWrapper(user); IPage pages = userService.page(Condition.getPage(query), queryWrapper); return R.data(UserWrapper.build().pageVO(pages)); } /** * 员工列表 不分页 * @param user * @return */ @GetMapping("/userListBy") @ApiOperation(value = "分页", notes = "传入user") public R> userListBy(User user) { QueryWrapper queryWrapper = Condition.getQueryWrapper(user); List list = userService.list(queryWrapper); return R.data(UserWrapper.build().listVO(list)); } /** * 评优任务表 自定义分页 */ @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 EvaluateTaskDTO dto) { evaluateTaskService.saveTaskAndCategory(dto); return R.data(dto); } /** * 评优任务表 修改 */ @PostMapping("/update") @ApiOperationSupport(order = 5) @ApiOperation(value = "修改", notes = "传入evaluateTask") public R update(@Valid @RequestBody EvaluateTaskDTO evaluateTask) { return R.status(evaluateTaskService.updateTaskAndCategory(evaluateTask)); } /** * 评优任务表 新增或修改 */ @PostMapping("/submit") @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)); } /** * 评优任务表 删除 */ @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); } }