123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263646566676869707172737475767778798081828384858687888990919293949596979899100101102103104105106107108109110111112113114115116117118119120121122123124125126127128129130131132133134135136137138139140141142143144145146147148149150151152153154155156157158159160161162163164165166167168169170171172173174175176177178179180181182183184185186187188189190191192193194195196197198199200201202203204205206207208209210211212213214215216217218219220221222223224225226227228229230231232233234235236237238239240241 |
- package com.qmth.distributed.print.api;
- import cn.hutool.core.date.DateUtil;
- import com.alibaba.fastjson.JSONArray;
- import com.alibaba.fastjson.JSONObject;
- import com.baomidou.mybatisplus.core.conditions.query.QueryWrapper;
- import com.baomidou.mybatisplus.extension.plugins.pagination.Page;
- import com.deepoove.poi.XWPFTemplate;
- import com.qmth.boot.api.constant.ApiConstant;
- import com.qmth.boot.api.exception.ApiException;
- import com.qmth.distributed.print.business.bean.dto.report.*;
- import com.qmth.distributed.print.business.bean.result.ScoreResult;
- import com.qmth.distributed.print.business.bean.result.report.ReportResult;
- import com.qmth.distributed.print.business.bean.result.report.word.CourseBasicBean;
- import com.qmth.distributed.print.business.bean.result.report.word.CourseReportBean;
- import com.qmth.distributed.print.business.entity.TRBasicInfo;
- import com.qmth.distributed.print.business.entity.TRExamStudent;
- import com.qmth.distributed.print.business.service.PrintCommonService;
- import com.qmth.distributed.print.business.service.TRBasicInfoService;
- import com.qmth.distributed.print.business.service.TRExamStudentService;
- import com.qmth.teachcloud.common.annotation.OperationLogDetail;
- import com.qmth.teachcloud.common.contant.SystemConstant;
- import com.qmth.teachcloud.common.entity.BasicSchool;
- import com.qmth.teachcloud.common.entity.SysConfig;
- import com.qmth.teachcloud.common.entity.SysUser;
- import com.qmth.teachcloud.common.enums.ImportTemplateEnum;
- import com.qmth.teachcloud.common.enums.log.CustomizedOperationTypeEnum;
- import com.qmth.teachcloud.common.service.CommonCacheService;
- import com.qmth.teachcloud.common.service.FileUploadService;
- import com.qmth.teachcloud.common.util.FileUtil;
- import com.qmth.teachcloud.common.util.ResultUtil;
- import com.qmth.teachcloud.common.util.ServletUtil;
- import com.qmth.teachcloud.mark.entity.MarkPaper;
- import com.qmth.teachcloud.mark.service.MarkPaperService;
- import io.swagger.annotations.*;
- import org.apache.commons.io.FileUtils;
- import org.springframework.transaction.annotation.Transactional;
- import org.springframework.util.CollectionUtils;
- import org.springframework.validation.BindingResult;
- import org.springframework.web.bind.annotation.*;
- import javax.annotation.Resource;
- import javax.validation.Valid;
- import javax.validation.constraints.Max;
- import javax.validation.constraints.Min;
- import java.io.File;
- import java.io.FileInputStream;
- import java.io.IOException;
- import java.io.InputStream;
- import java.util.*;
- /**
- * <p>
- * 报告基本情况表 前端控制器
- * </p>
- *
- * @author wangliang
- * @since 2024-02-18
- */
- @Api(tags = "课程目标达成度-报告基本情况Controller")
- @RestController
- @RequestMapping(ApiConstant.DEFAULT_URI_PREFIX + SystemConstant.PREFIX_URL_COURSE_DEGREE)
- public class TRBasicInfoController {
- @Resource
- PrintCommonService printCommonService;
- @Resource
- MarkPaperService markPaperService;
- @Resource
- TRBasicInfoService trBasicInfoService;
- @Resource
- TRExamStudentService trExamStudentService;
- @Resource
- CommonCacheService commonCacheService;
- @Resource
- FileUploadService fileUploadService;
- @ApiOperation(value = "报告管理列表")
- @RequestMapping(value = "/report/list", method = RequestMethod.POST)
- @OperationLogDetail(customizedOperationType = CustomizedOperationTypeEnum.SEARCH)
- @ApiResponses({@ApiResponse(code = 200, message = "分页查询", response = ScoreResult.class)})
- public Object reportList(@ApiParam(value = "考试ID", required = true) @RequestParam Long examId,
- @ApiParam(value = "课程编码") @RequestParam(required = false) String courseCode,
- @ApiParam(value = "分页页码", required = true) @RequestParam @Min(SystemConstant.PAGE_NUMBER_MIN) Integer pageNumber,
- @ApiParam(value = "分页数", required = true) @RequestParam @Min(SystemConstant.PAGE_SIZE_MIN) @Max(SystemConstant.PAGE_SIZE_MAX) Integer pageSize) {
- return ResultUtil.ok(printCommonService.scoreList(new Page<>(pageNumber, pageSize), examId, courseCode));
- }
- @ApiOperation(value = "查看报告")
- @RequestMapping(value = "/report/view", method = RequestMethod.POST)
- @OperationLogDetail(customizedOperationType = CustomizedOperationTypeEnum.SEARCH)
- @ApiResponses({@ApiResponse(code = 200, message = "查看报告", response = ReportResult.class)})
- @Transactional
- public Object reportView(@ApiParam(value = "考试id", required = true) @RequestParam Long examId,
- @ApiParam(value = "科目编码", required = true) @RequestParam String courseCode,
- @ApiParam(value = "试卷编号", required = true) @RequestParam String paperNumber) {
- MarkPaper markPaper = markPaperService.getByExamIdAndPaperNumber(examId, paperNumber);
- Objects.requireNonNull(markPaper, "未找到科目信息");
- SysUser sysUser = (SysUser) ServletUtil.getRequestUser();
- TRBasicInfo trBasicInfo = trBasicInfoService.getOne(new QueryWrapper<TRBasicInfo>().lambda().eq(TRBasicInfo::getExamId, examId).eq(TRBasicInfo::getCourseCode, courseCode).eq(TRBasicInfo::getPaperNumber, paperNumber));
- if (Objects.isNull(trBasicInfo)) {
- trBasicInfo = trBasicInfoService.getReportView(trBasicInfo, markPaper, sysUser.getId());
- } else {
- ReportCourseBasicInfoDto reportCourseBasicInfoDto = new ReportCourseBasicInfoDto(trBasicInfo);
- ReportCourseEvaluationSpreadDto reportCourseEvaluationSpreadDto = Objects.nonNull(trBasicInfo.getCourseEvaluationSpread()) ? JSONObject.parseObject(trBasicInfo.getCourseEvaluationSpread(), ReportCourseEvaluationSpreadDto.class) : null;
- ReportCourseEvaluationResultDto reportCourseEvaluationResultDto = Objects.nonNull(trBasicInfo.getCourseEvaluationResult()) ? JSONObject.parseObject(trBasicInfo.getCourseEvaluationResult(), ReportCourseEvaluationResultDto.class) : null;
- ReportCourseEvaluationResultDetailDto reportCourseEvaluationResultDetailDto = null;
- List<TRExamStudent> trExamStudentList = trExamStudentService.list(new QueryWrapper<TRExamStudent>().lambda().eq(TRExamStudent::getrBasicInfoId, trBasicInfo.getId()));
- if (!CollectionUtils.isEmpty(trExamStudentList)) {
- List<ReportExamStudentDto> examStudentList = new ArrayList<>(trExamStudentList.size());
- for (TRExamStudent trExamStudent : trExamStudentList) {
- examStudentList.add(new ReportExamStudentDto(trExamStudent));
- }
- reportCourseEvaluationResultDetailDto = new ReportCourseEvaluationResultDetailDto(examStudentList);
- }
- trBasicInfo.setReportResult(new ReportResult(new ReportCommonDto(examId, courseCode, markPaper.getCourseName(), paperNumber), reportCourseBasicInfoDto, reportCourseEvaluationSpreadDto, reportCourseEvaluationResultDto, reportCourseEvaluationResultDetailDto));
- }
- trBasicInfo.updateInfo(sysUser.getId());
- //课程目标达成评价明细结果-课程目标达成评价值图
- trBasicInfoService.saveOrUpdate(trBasicInfo);
- return ResultUtil.ok(trBasicInfo.getReportResult());
- }
- @ApiOperation(value = "保存报告")
- @RequestMapping(value = "/report/save", method = RequestMethod.POST)
- @OperationLogDetail(customizedOperationType = CustomizedOperationTypeEnum.UPDATE)
- @ApiResponses({@ApiResponse(code = 200, message = "保存报告", response = Object.class)})
- @Transactional
- public Object reportSave(@ApiParam(value = "保存报告结构", required = true) @Valid @RequestBody TRBasicInfo trBasicInfo, BindingResult bindingResult) {
- if (bindingResult.hasErrors()) {
- return ResultUtil.error(bindingResult.getAllErrors().get(0).getDefaultMessage());
- }
- SysUser sysUser = (SysUser) ServletUtil.getRequestUser();
- TRBasicInfo trBasicInfoDb = trBasicInfoService.getOne(new QueryWrapper<TRBasicInfo>().lambda().eq(TRBasicInfo::getExamId, trBasicInfo.getExamId()).eq(TRBasicInfo::getCourseCode, trBasicInfo.getCourseCode()).eq(TRBasicInfo::getPaperNumber, trBasicInfo.getPaperNumber()));
- if (Objects.isNull(trBasicInfoDb)) {
- trBasicInfoDb = new TRBasicInfo(trBasicInfo, sysUser.getId());
- MarkPaper markPaper = markPaperService.getByExamIdAndPaperNumber(trBasicInfo.getExamId(), trBasicInfo.getPaperNumber());
- Objects.requireNonNull(markPaper, "未找到科目信息");
- trBasicInfoDb = trBasicInfoService.getReportView(trBasicInfoDb, markPaper, sysUser.getId());
- } else {
- trBasicInfoDb.updateInfo(trBasicInfo, sysUser.getId());
- }
- return ResultUtil.ok(trBasicInfoService.saveOrUpdate(trBasicInfoDb));
- }
- @ApiOperation(value = "导出报告")
- @RequestMapping(value = "/report/export", method = RequestMethod.POST)
- @OperationLogDetail(customizedOperationType = CustomizedOperationTypeEnum.EXPORT)
- @ApiResponses({@ApiResponse(code = 200, message = "下载成功", response = Object.class)})
- public void reportExport(@ApiParam(value = "考试id", required = true) @RequestParam Long examId,
- @ApiParam(value = "科目编码", required = true) @RequestParam String courseCode,
- @ApiParam(value = "试卷编号", required = true) @RequestParam String paperNumber) throws IOException {
- File txtFileTemp = null, fileTemp = null;
- try {
- Long schoolId = Long.valueOf(ServletUtil.getRequestHeaderSchoolId().toString());
- BasicSchool basicSchool = commonCacheService.schoolCache(schoolId);
- TRBasicInfo trBasicInfo = trBasicInfoService.getOne(new QueryWrapper<TRBasicInfo>().lambda().eq(TRBasicInfo::getExamId, examId).eq(TRBasicInfo::getCourseCode, courseCode).eq(TRBasicInfo::getPaperNumber, paperNumber));
- Objects.requireNonNull(trBasicInfo, "没有报告信息");
- Objects.requireNonNull(trBasicInfo.getCourseEvaluationResult(), "没有课程目标信息");
- Objects.requireNonNull(trBasicInfo.getCourseEvaluationResultDetail(), "没有课程考生信息");
- //评价样本的基本信息
- String period = Objects.nonNull(trBasicInfo.getPeriod()) ? trBasicInfo.getPeriod() : null;
- String credit = Objects.nonNull(trBasicInfo.getCredit()) ? trBasicInfo.getCredit() : null;
- period = Objects.nonNull(credit) ? period + "/" + credit : period;
- ReportCourseEvaluationResultDto reportCourseEvaluationResultDto = JSONObject.parseObject(trBasicInfo.getCourseEvaluationResult(), ReportCourseEvaluationResultDto.class);
- CourseBasicBean courseBasicBean = new CourseBasicBean(trBasicInfo.getCourseName(),
- trBasicInfo.getCourseCode(), null, trBasicInfo.getCourseType(),
- period, null, null, trBasicInfo.getDirector(),
- DateUtil.format(new Date(trBasicInfo.getCreateTime()), SystemConstant.DEFAULT_DATE_PATTERN),
- "测试:我们的目标是没有目标", reportCourseEvaluationResultDto.getTargetList().size());
- CourseReportBean courseReportBean = new CourseReportBean(trBasicInfo.getOpenTime() + "《" + trBasicInfo.getCourseName() + "》", courseBasicBean);
- JSONObject jsonObject = JSONObject.parseObject(trBasicInfo.getCourseEvaluationResultDetail());
- List<CourseTargetWordDto> courseTargetWordDtoList = JSONArray.parseArray(jsonObject.get("targetWordMap").toString(), CourseTargetWordDto.class);
- List<CourseTargetWebDto> courseTargetWebDtoList = JSONArray.parseArray(jsonObject.get("targetWebMap").toString(), CourseTargetWebDto.class);
- //table1-课程目标目标与毕业要求指标点的对应关系
- List<String> header2_1List = new ArrayList<>(Arrays.asList("课程目标", "支撑毕业要求")), header2_2List = new ArrayList<>();
- header2_2List.addAll(header2_1List);
- header2_1List.add("考核/评价环节及目标分值");
- courseReportBean.setCourseTargetTable1(trBasicInfoService.buildWordTable1(courseTargetWordDtoList, header2_1List, header2_2List));
- //table2-课程目标达成评价依据
- courseReportBean.setCourseTargetTable2(trBasicInfoService.buildWordTable2(courseTargetWordDtoList, courseTargetWebDtoList, header2_1List, header2_2List));
- //table3-课程课后作业考核/评价内容及目标分值
- courseReportBean.setCourseTargetTable3(trBasicInfoService.buildWordTable3(courseTargetWordDtoList));
- //table4-课程期末考试考核/评价内容及目标分值
- courseReportBean.setCourseTargetTable4(trBasicInfoService.buildWordTable4(courseTargetWordDtoList));
- //examstudent-课程目标达成评价依据-考生
- courseReportBean.setExamStudentTable1(trBasicInfoService.buildWordTable5(trBasicInfo, courseReportBean));
- InputStream inputStream = null;
- txtFileTemp = SystemConstant.getFileTempVar(SystemConstant.WORD_PREFIX);
- SysConfig sysConfig = commonCacheService.addSysConfigCache(schoolId, SystemConstant.SCHOOL_COURSE_DEGREE_TEMPLATE);
- if (Objects.isNull(sysConfig)) {
- inputStream = FileUtil.getStream("static/" + ImportTemplateEnum.STATIC_COURSE_DEGREE_REPORT.getTemplateName());
- } else {
- fileTemp = fileUploadService.downloadFile(Long.parseLong(sysConfig.getConfigValue()), fileTemp.getName());
- inputStream = FileUtil.getStream(fileTemp.getPath());
- }
- FileUtils.copyInputStreamToFile(inputStream, txtFileTemp);
- XWPFTemplate template = XWPFTemplate.compile(txtFileTemp.getAbsolutePath()).render(courseReportBean);
- template.writeToFile(txtFileTemp.getAbsolutePath());
- // 导出
- String fileName = Objects.nonNull(basicSchool) ? basicSchool.getName() + "_" + ImportTemplateEnum.STATIC_COURSE_DEGREE_REPORT.getFileName() + "_" + courseReportBean.getTitle1() + SystemConstant.WORD_PREFIX : ImportTemplateEnum.STATIC_COURSE_DEGREE_REPORT.getFileName() + "_" + courseReportBean.getTitle1() + SystemConstant.WORD_PREFIX;
- FileUtil.outputFile(ServletUtil.getResponse(), new FileInputStream(txtFileTemp), fileName);
- // XWPFTemplate template = XWPFTemplate.compile("/Users/king/git/teachcloud-server/distributed-print/src/main/resources/static/course_degree_report.docx").render(courseReportBean);
- // template.writeToFile("/Users/king/Downloads/demo_course_degree_report.docx");
- } catch (Exception e) {
- if (e instanceof ApiException) {
- ResultUtil.error((ApiException) e, ((ApiException) e).getCode(), e.getMessage());
- } else {
- ResultUtil.error(e.getMessage());
- }
- } finally {
- if (Objects.nonNull(txtFileTemp)) {
- txtFileTemp.delete();
- }
- if (Objects.nonNull(fileTemp)) {
- fileTemp.delete();
- }
- }
- }
- }
|