package com.artfess.examine.controller; import com.alibaba.fastjson.JSON; import com.alibaba.fastjson.JSONObject; import com.artfess.base.annotation.ApiGroup; import com.artfess.base.constants.ApiGroupConsts; import com.artfess.base.context.BaseContext; import com.artfess.base.controller.BaseController; import com.artfess.base.enums.QuestionStateEnum; import com.artfess.base.enums.ResponseErrorEnums; import com.artfess.base.exception.RequiredException; import com.artfess.base.model.CommonResult; import com.artfess.base.query.PageList; import com.artfess.base.query.QueryFilter; import com.artfess.base.query.QueryOP; import com.artfess.base.util.AuthenticationUtil; import com.artfess.data.vo.UserExamVo; import com.artfess.examine.manager.ExamUserEvaluationManager; import com.artfess.examine.manager.ExamUserRecordManager; import com.artfess.examine.model.ExamUserEvaluation; import com.artfess.examine.model.ExamUserEvaluationDetail; import com.artfess.examine.model.ExamUserRecord; import com.artfess.examine.vo.SettingYearVo; import com.artfess.poi.util.ExcelUtils; import com.artfess.poi.util.FileDownloadUtil; import io.swagger.annotations.Api; import io.swagger.annotations.ApiOperation; import io.swagger.annotations.ApiParam; import lombok.extern.slf4j.Slf4j; import org.springframework.beans.factory.annotation.Autowired; import org.springframework.core.io.ClassPathResource; import org.springframework.util.Assert; import org.springframework.web.bind.annotation.GetMapping; import org.springframework.web.bind.annotation.PathVariable; 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.RequestParam; import org.springframework.web.bind.annotation.RestController; import org.springframework.web.multipart.MultipartFile; import javax.annotation.Resource; import javax.servlet.http.HttpServletRequest; import javax.servlet.http.HttpServletResponse; import java.text.SimpleDateFormat; import java.util.Date; import java.util.HashMap; import java.util.List; import java.util.Map; import java.util.concurrent.atomic.AtomicReference; /** * 年度考生综合评定表 前端控制器 * * @author min.wu * @company 阿特菲斯信息技术有限公司 * @since 2022-11-28 */ @Slf4j @RestController @Api(tags = "基础数据-年度评定") @RequestMapping("/exam/user/evaluation/") @ApiGroup(group = {ApiGroupConsts.GROUP_BIZ}) public class ExamUserEvaluationController extends BaseController { @Autowired private ExamUserRecordManager userRecordManager; @Resource BaseContext baseContext; @PostMapping(value = "/detailPage", produces = {"application/json; charset=utf-8"}) @ApiOperation("详情记录-从年度评定分页界面弹出,入参评定id e.id_,其他参数和我的试卷一样") public PageList detailPage(@ApiParam(name = "queryFilter", value = "分页查询信息") @RequestBody QueryFilter queryFilter) { AtomicReference flag = new AtomicReference<>(); queryFilter.getQuerys().forEach(queryField -> { //如果是模拟训练则只能查看自己创建的试卷 if ("e.id_".equals(queryField.getProperty()) && null == queryField.getValue()) { queryField.setValue("-1"); } }); queryFilter.addFilter("b.paper_type_", "2", QueryOP.EQUAL); queryFilter.addFilter("s.status_", QuestionStateEnum.finish.getType(), QueryOP.EQUAL); return userRecordManager.detailPage(queryFilter); } @GetMapping(value = "/evaluationDetail/{id}", produces = {"application/json; charset=utf-8"}) @ApiOperation("评定详情列表,年度上报(0:未上报、1:已上报)") public CommonResult evaluationDetail(@ApiParam(name = "id", value = "年度评定id") @PathVariable String id) { Map map = new HashMap<>(); List list = this.baseService.evaluationDetail(id); map.put("list", list); String reportStatus = this.baseService.getReportStatus(); map.put("reportStatus", reportStatus); return CommonResult.success(map, ""); } @Override @PostMapping(value = "/query", produces = {"application/json; charset=utf-8"}) @ApiOperation("分页查询结果") public PageList query(@ApiParam(name = "queryFilter", value = "分页查询信息") @RequestBody QueryFilter queryFilter) { return baseService.findByPage(queryFilter); } @PostMapping(value = "/myYearPage", produces = {"application/json; charset=utf-8"}) @ApiOperation("我的年度评定") public PageList myYearPage(@ApiParam(name = "queryFilter", value = "分页查询信息") @RequestBody QueryFilter queryFilter) { queryFilter.addFilter("u.id_", AuthenticationUtil.getCurrentUserId(), QueryOP.EQUAL); queryFilter.getQuerys().removeIf(s -> "s.paper_id_".equals(s.getProperty())); List currentAndChildOrgIds = baseContext.getCurrentAndChildOrgIds(); queryFilter.addFilter("e.create_org_id_", currentAndChildOrgIds, QueryOP.IN); return baseService.myYearPage(queryFilter); } @PostMapping("/addSubject") @ApiOperation("考生添加年度考核课目") public CommonResult addSubject(@ApiParam(name = "model", value = "实体信息") @RequestBody ExamUserEvaluation t) { log.info("考生添加年度考核课目请求参数:{}", JSON.toJSONString(t)); boolean result = baseService.addSubject(t); if (!result) { return new CommonResult<>(ResponseErrorEnums.FAIL_OPTION, "更新实体失败"); } return new CommonResult<>(); } @PostMapping("/delSubject") @ApiOperation("考生删除年度考核课目") public CommonResult delSubject(@ApiParam(name = "model", value = "实体信息") @RequestBody ExamUserEvaluation t) { log.info("考生删除年度考核课目请求参数:{}", JSON.toJSONString(t)); boolean result = baseService.delSubject(t); if (!result) { return new CommonResult<>(ResponseErrorEnums.FAIL_OPTION, "更新实体失败"); } return new CommonResult<>(); } @PostMapping("/settingYear") @ApiOperation("设置年度最终成绩") public CommonResult settingYear(@ApiParam(name = "model", value = "实体信息") @RequestBody SettingYearVo t) { log.info("设置年度最终成绩请求参数:{}", JSON.toJSONString(t)); boolean result = baseService.settingYear(t); if (!result) { return new CommonResult<>(ResponseErrorEnums.FAIL_OPTION, "更新实体失败"); } return new CommonResult<>(); } /** * todo * @param file * @param orgId * @return */ @ApiOperation(value = "成绩导入") @PostMapping("/importExcel") public CommonResult importExcel(@RequestParam("file") MultipartFile file,@RequestParam(value = "orgId", required = false) String orgId) { try { ExcelUtils excelUtil = new ExcelUtils<>(ExamUserEvaluationDetail.class); List list = excelUtil.importExcel(null,file.getInputStream()); boolean result = baseService.importExcel(list, orgId); if(!result) { throw new IllegalArgumentException("导入失败"); } return new CommonResult<>(); } catch (Exception e) { throw new IllegalArgumentException("导入失败," + e.getMessage()); } } /** * 下载导入模板 * * @param response * @return */ @ApiOperation(value = "下载导入模板") @GetMapping("/downModel") public void downTemplate(HttpServletResponse response) { try { ClassPathResource classPathResource = new ClassPathResource("model/userEvaluationDetail.xlsx"); FileDownloadUtil.fileDownload(response, classPathResource.getInputStream(), "线下成绩导入模板.xlsx"); } catch (Exception e) { response.setCharacterEncoding("utf-8"); throw new RequiredException("你所下载的资源不存在"); } } @ApiOperation(value = "成绩导出") @GetMapping("/export") public void export(HttpServletRequest request,HttpServletResponse response, @ApiParam(name = "model", value = "实体信息") @RequestParam(required = false) String orgId) throws Exception { String date = new SimpleDateFormat("yyyyMMddHHmmss").format(new Date()); String fileName = String.format("年度成绩信息-%s", date); baseService.export(orgId, response,fileName); } @PostMapping("/batchSettingYear") @ApiOperation("批量设置年度最终成绩") public CommonResult batchSettingYear(@ApiParam(name = "model", value = "实体信息") @RequestBody SettingYearVo t) { log.info("设置年度最终成绩请求参数:{}", JSON.toJSONString(t)); boolean result = baseService.batchSettingYear(t); if (!result) { return new CommonResult<>(ResponseErrorEnums.FAIL_OPTION, "更新实体失败"); } return new CommonResult<>(); } @PostMapping(value = "/getSubjectInfo", produces = {"application/json; charset=utf-8"}) @ApiOperation("获取当年该岗位要考核的课目(传岗位id就可以)") public CommonResult getSubjectInfo(@ApiParam(name = "model", value = "实体信息") @RequestBody SettingYearVo t) { Assert.hasText(t.getPositionId(), "请先选择岗位"); List list = this.baseService.getSubjectInfo(t); return CommonResult.success(list, ""); } @PostMapping(value = "/getPositionPaper", produces = {"application/json; charset=utf-8"}) @ApiOperation("获取当前年度该课目下所有年度考核所有试卷(传课目id就可以)") public CommonResult getPositionPaper(@ApiParam(name = "model", value = "实体信息") @RequestBody SettingYearVo t) { Assert.hasText(t.getSubjectId(), "请先选择课目"); List list = this.baseService.getPositionPaper(t); return CommonResult.success(list, ""); } @PostMapping(value = "/userQualityAnalyse", produces = {"application/json; charset=utf-8"}) @ApiOperation("人员素质情况分析") public PageList userQualityAnalyse(@ApiParam(name = "queryFilter", value = "分页查询信息") @RequestBody QueryFilter queryFilter) { return baseService.userQualityAnalyse(queryFilter); } /** * 设置考生职业教育分数以及总体评价 */ @PostMapping(value = "/setUserWorkEvaluation", produces = {"application/json; charset=utf-8"}) @ApiOperation("设置考生职业教育分数以及总体评价") public CommonResult setUserWorkEvaluation(@ApiParam(name = "model", value = "实体信息") @RequestBody ExamUserEvaluation t) { log.info("设置考生职业教育分数以及总体评价请求参数:{}", JSON.toJSONString(t)); boolean result = baseService.setUserWorkEvaluation(t); if (!result) { return new CommonResult<>(ResponseErrorEnums.FAIL_OPTION, "更新实体失败"); } return new CommonResult<>(); } }