BaseClassCourseController.java 11 KB

123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263646566676869707172737475767778798081828384858687888990919293949596979899100101102103104105106107108109110111112113114115116117118119120121122123124125126127128129130131132133134135136137138139140141142143144145146147148149150151152153154155156157158159160161162163164165166167168169170171172173174175176177178179180181182183184185186187188189190191192193194195196197198199200201202203204205206207208209210211212213214215216217218219220221
  1. package com.xjrsoft.module.base.controller;
  2. import cn.hutool.core.bean.BeanUtil;
  3. import com.baomidou.mybatisplus.extension.plugins.pagination.Page;
  4. import com.xjrsoft.common.handler.FormContentStyleStrategy;
  5. import com.xjrsoft.common.page.ConventPage;
  6. import com.xjrsoft.common.page.PageOutput;
  7. import com.xjrsoft.common.model.result.RT;
  8. import com.xjrsoft.module.base.dto.AddBaseClassCourseDto;
  9. import com.xjrsoft.module.base.dto.UpdateBaseClassCourseDto;
  10. import cn.dev33.satoken.annotation.SaCheckPermission;
  11. import com.alibaba.excel.EasyExcel;
  12. import com.xjrsoft.module.base.entity.ClassCourseTextbook;
  13. import com.xjrsoft.module.base.entity.CourseBookInfo;
  14. import com.xjrsoft.module.base.entity.ExportBaseClassCourseVo;
  15. import com.xjrsoft.module.base.service.impl.BaseCourseSubjectServiceImpl;
  16. import com.xjrsoft.module.textbook.service.impl.TextbookServiceImpl;
  17. import org.apache.ibatis.annotations.Param;
  18. import org.slf4j.Logger;
  19. import org.slf4j.LoggerFactory;
  20. import org.springframework.web.multipart.MultipartFile;
  21. import java.io.IOException;
  22. import com.alibaba.excel.support.ExcelTypeEnum;
  23. import org.springframework.http.ResponseEntity;
  24. import java.io.ByteArrayOutputStream;
  25. import java.util.*;
  26. import com.xjrsoft.module.base.dto.BaseClassCoursePageDto;
  27. import com.xjrsoft.module.base.entity.BaseClassCourse;
  28. import com.xjrsoft.module.base.service.IBaseClassCourseService;
  29. import com.xjrsoft.module.base.vo.BaseClassCoursePageVo;
  30. import com.xjrsoft.module.base.vo.BaseClassCourseVo;
  31. import io.swagger.annotations.Api;
  32. import io.swagger.annotations.ApiOperation;
  33. import lombok.AllArgsConstructor;
  34. import org.springframework.web.bind.annotation.*;
  35. import javax.validation.Valid;
  36. import java.util.stream.Collectors;
  37. /**
  38. * @title: 班级课程
  39. * @Author brealinxx
  40. * @Date: 2024-06-04
  41. * @Version 1.0
  42. */
  43. @RestController
  44. @RequestMapping("/base" + "/baseClassCourse")
  45. @Api(value = "/base" + "/baseClassCourse",tags = "班级课程代码")
  46. @AllArgsConstructor
  47. public class BaseClassCourseController {
  48. private static final Logger log = LoggerFactory.getLogger(BaseClassCourseController.class);
  49. private final IBaseClassCourseService baseClassCourseService;
  50. private final BaseCourseSubjectServiceImpl baseCourseSubjectServiceImpl;
  51. private final TextbookServiceImpl textbookServiceImpl;
  52. @GetMapping(value = "/page")
  53. @ApiOperation(value="班级课程列表(分页)")
  54. @SaCheckPermission("baseclasscourse:detail")
  55. public RT<PageOutput<BaseClassCoursePageVo>> page(@Valid BaseClassCoursePageDto dto){
  56. Page<BaseClassCoursePageVo> page = baseClassCourseService.getPage(new Page<>(dto.getLimit(), dto.getSize()), dto);
  57. PageOutput<BaseClassCoursePageVo> pageOutput = ConventPage.getPageOutput(page, BaseClassCoursePageVo.class);
  58. return RT.ok(pageOutput);
  59. }
  60. @GetMapping("/getSemesterTree")
  61. @ApiOperation("获取年级树结构")
  62. @SaCheckPermission("baseclasscourse:detail")
  63. public RT<Map<String, Map<String, Object>>> semesterTree(){
  64. Map<String, Map<String, Object>> tree = baseClassCourseService.getSemesterTree();
  65. return RT.ok(tree);
  66. }
  67. @GetMapping(value = "/info")
  68. @ApiOperation(value="根据id查询班级课程信息")
  69. @SaCheckPermission("baseclasscourse:detail")
  70. public RT<BaseClassCourseVo> info(@RequestParam Long id){
  71. BaseClassCourse baseClassCourse = baseClassCourseService.getById(id);
  72. if (baseClassCourse == null) {
  73. return RT.error("找不到此数据!");
  74. }
  75. return RT.ok(BeanUtil.toBean(baseClassCourse, BaseClassCourseVo.class));
  76. }
  77. @GetMapping("/getAllCoursesAndTextbooks")
  78. @ApiOperation(value="获取所有课程教材")
  79. @SaCheckPermission("baseclasscourse:detail")
  80. public RT<List<CourseBookInfo>> getAllCoursesAndTextbooks(@RequestParam(required = false) Long[] classIds, @RequestParam(required = false) Long subjectGroupId, @RequestParam Long semester) {
  81. List<CourseBookInfo> data = baseClassCourseService.getAllCourseBook(classIds, subjectGroupId, semester);
  82. return RT.ok(data);
  83. }
  84. @GetMapping("/getAllSelectedCoursesAndTextbooks")
  85. @ApiOperation(value="获取所有以选择课程教材")
  86. @SaCheckPermission("baseclasscourse:detail")
  87. public RT<List<CourseBookInfo>> getAllSelectedCoursesAndTextbooks(@RequestParam(required = false) Long[] classIds, @RequestParam(required = false) Long semester) {
  88. List<CourseBookInfo> data = baseClassCourseService.getSelectedCourseBook(classIds, semester);
  89. return RT.ok(data);
  90. }
  91. @GetMapping("/updateAddCoursesAndTextbooks")
  92. @ApiOperation(value="更新增加课程教材")
  93. @SaCheckPermission("baseclasscourse:detail")
  94. public RT updateAddCoursesAndTextbooks(@Valid ClassCourseTextbook list) {
  95. for (Long classId : list.getClassId()){
  96. for (Long i = 0L ;i < list.getCourseId().length; i++){
  97. baseClassCourseService.updateAddCourseBook(classId, list.getCourseId()[Math.toIntExact(i)], list.getTextbookId()[Math.toIntExact(i)]);
  98. }
  99. }
  100. return RT.ok();
  101. }
  102. @GetMapping("/updateRemoveCoursesAndTextbooks")
  103. @ApiOperation(value="更新减少课程教材")
  104. @SaCheckPermission("baseclasscourse:detail")
  105. public RT updateRemoveCoursesAndTextbooks(@Valid ClassCourseTextbook list) {
  106. for (Long classId : list.getClassId()){
  107. for (Long i = 0L ;i < list.getCourseId().length; i++){
  108. baseClassCourseService.updateRemoveCourseBook(classId, list.getCourseId()[Math.toIntExact(i)], list.getTextbookId()[Math.toIntExact(i)]);
  109. }
  110. }
  111. return RT.ok();
  112. }
  113. @GetMapping("/insertClassCourseTextbookCombinations")
  114. @ApiOperation(value="复用课程教材")
  115. @SaCheckPermission("baseclasscourse:detail")
  116. public RT insertClassCourseTextbookCombinations(@RequestParam Long newClassId, @RequestParam Long[] sourceClassIds, @RequestParam Long semester) {
  117. // baseClassCourseService.markExistingRecordsAsDeleted(newClassId, sourceClassId);
  118. for (Long sourceId : sourceClassIds){
  119. baseClassCourseService.duplicateCourseBook(newClassId, sourceId, semester);
  120. }
  121. return RT.ok();
  122. }
  123. @PostMapping
  124. @ApiOperation(value = "新增班级课程")
  125. @SaCheckPermission("baseclasscourse:add")
  126. public RT<Boolean> add(@Valid @RequestBody AddBaseClassCourseDto dto){
  127. BaseClassCourse baseClassCourse = BeanUtil.toBean(dto, BaseClassCourse.class);
  128. boolean isSuccess = baseClassCourseService.save(baseClassCourse);
  129. return RT.ok(isSuccess);
  130. }
  131. @PutMapping
  132. @ApiOperation(value = "修改班级课程")
  133. @SaCheckPermission("baseclasscourse:edit")
  134. public RT<Boolean> update(@Valid @RequestBody UpdateBaseClassCourseDto dto){
  135. BaseClassCourse baseClassCourse = BeanUtil.toBean(dto, BaseClassCourse.class);
  136. return RT.ok(baseClassCourseService.updateById(baseClassCourse));
  137. }
  138. @DeleteMapping
  139. @ApiOperation(value = "删除班级课程")
  140. @SaCheckPermission("baseclasscourse:delete")
  141. public RT<Boolean> delete(@Valid @RequestBody List<Long> ids){
  142. return RT.ok(baseClassCourseService.removeBatchByIds(ids));
  143. }
  144. @PostMapping("/import")
  145. @ApiOperation(value = "导入")
  146. public RT<Boolean> importData(@RequestParam MultipartFile file) throws IOException {
  147. List<BaseClassCoursePageVo> savedDataList = EasyExcel.read(file.getInputStream()).headRowNumber(3).head(BaseClassCoursePageVo.class).sheet().doReadSync();
  148. List<BaseClassCourse> baseClassCourses = new ArrayList<>();
  149. List<String> duplicateLogs = new ArrayList<>();
  150. List<String> errorLogs = new ArrayList<>();
  151. for (BaseClassCoursePageVo vo : savedDataList) {
  152. try {
  153. Long classId = Long.parseLong(baseClassCourseService.GetClassIdByName(vo.getClassName()).toString());
  154. Long courseId = Long.parseLong(baseClassCourseService.GetCourseIdByName(vo.getCourseName()).toString());
  155. Long textbookId = Long.parseLong(baseClassCourseService.GetTextbookIdByName(vo.getTextbookName()).toString());
  156. if (baseClassCourseService.checkExits(classId, courseId, textbookId)) {
  157. duplicateLogs.add(String.format("[输入的信息重复添加] 班级: %s, 课程: %s, 教材: %s", vo.getClassName(), vo.getCourseName(), vo.getTextbookName()));
  158. continue;
  159. }
  160. if (classId != null && courseId != null && textbookId != null) {
  161. BaseClassCourse baseClassCourse = new BaseClassCourse();
  162. baseClassCourse.setClassId(classId);
  163. baseClassCourse.setCourseId(courseId);
  164. baseClassCourse.setTextbookId(textbookId);
  165. baseClassCourse.setCreateDate(new Date());
  166. baseClassCourse.setDeleteMark(0);
  167. baseClassCourses.add(baseClassCourse);
  168. }
  169. } catch (NumberFormatException e) {
  170. errorLogs.add(String.format("[无法解析输入的信息] 班级: %s, 班级: %s, 教材: %s", vo.getClassName(), vo.getCourseName(), vo.getTextbookName()));
  171. } catch (Exception e) {
  172. errorLogs.add(String.format("[意外错误(检查输入的名称是否正确且存在,输入错误可能返回 null)] 班级: %s, 课程: %s, 教材: %s - 错误信息:%s", vo.getClassName(), vo.getCourseName(), vo.getTextbookName(), e.getMessage()));
  173. }
  174. }
  175. Boolean result = baseClassCourseService.saveBatch(baseClassCourses);
  176. if (!duplicateLogs.isEmpty() || !errorLogs.isEmpty()) {
  177. String detailedMessage = String.format("[导入完成但存在问题] 问题: %s. 其他错误: %s", String.join("; ", duplicateLogs), String.join("; ", errorLogs));
  178. return RT.error(400, detailedMessage);
  179. }
  180. return RT.ok(result);
  181. }
  182. @GetMapping("/export")
  183. @ApiOperation(value = "导出")
  184. public ResponseEntity<byte[]> exportData(@Valid BaseClassCoursePageDto dto, @RequestParam(defaultValue = "false") Boolean isTemplate) {
  185. List<BaseClassCoursePageVo> customerList = isTemplate != null && isTemplate ? new ArrayList<>() : ((PageOutput<BaseClassCoursePageVo>) page(dto).getData()).getList();
  186. ByteArrayOutputStream bot = new ByteArrayOutputStream();
  187. EasyExcel.write(bot, BaseClassCoursePageVo.class).automaticMergeHead(false).excelType(ExcelTypeEnum.XLSX).sheet().doWrite(customerList);
  188. return RT.fileStream(bot.toByteArray(), "BaseClassCourse" + ExcelTypeEnum.XLSX.getValue());
  189. }
  190. }