BaseClassCourseController.java 17 KB

123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263646566676869707172737475767778798081828384858687888990919293949596979899100101102103104105106107108109110111112113114115116117118119120121122123124125126127128129130131132133134135136137138139140141142143144145146147148149150151152153154155156157158159160161162163164165166167168169170171172173174175176177178179180181182183184185186187188189190191192193194195196197198199200201202203204205206207208209210211212213214215216217218219220221222223224225226227228229230231232233234235236237238239240241242243244245246247248249250251252253254255256257258259260261262263264265266267268269270271272273274275276277278279280281282283284285286287288289290291292293294295296297298299300301302303304305306307308309310311312313314315316317318319320
  1. package com.xjrsoft.module.base.controller;
  2. import cn.dev33.satoken.annotation.SaCheckPermission;
  3. import cn.hutool.core.bean.BeanUtil;
  4. import com.alibaba.excel.EasyExcel;
  5. import com.alibaba.excel.support.ExcelTypeEnum;
  6. import com.baomidou.mybatisplus.core.conditions.query.QueryWrapper;
  7. import com.baomidou.mybatisplus.extension.plugins.pagination.Page;
  8. import com.github.yulichang.wrapper.MPJLambdaWrapper;
  9. import com.xjrsoft.common.model.result.RT;
  10. import com.xjrsoft.common.page.ConventPage;
  11. import com.xjrsoft.common.page.PageOutput;
  12. import com.xjrsoft.common.utils.VoToColumnUtil;
  13. import com.xjrsoft.module.base.dto.AddBaseClassCourseDto;
  14. import com.xjrsoft.module.base.dto.BaseClassCourseListDto;
  15. import com.xjrsoft.module.base.dto.BaseClassCoursePageDto;
  16. import com.xjrsoft.module.base.dto.ClassCourseReuseDto;
  17. import com.xjrsoft.module.base.dto.UpdateBaseClassCourseDto;
  18. import com.xjrsoft.module.base.entity.BaseClass;
  19. import com.xjrsoft.module.base.entity.BaseClassCourse;
  20. import com.xjrsoft.module.base.entity.BaseCourseSubject;
  21. import com.xjrsoft.module.base.entity.BaseSemester;
  22. import com.xjrsoft.module.base.entity.ClassCourseTextbook;
  23. import com.xjrsoft.module.base.entity.CourseBookInfo;
  24. import com.xjrsoft.module.base.service.IBaseClassCourseService;
  25. import com.xjrsoft.module.base.service.IBaseClassService;
  26. import com.xjrsoft.module.base.service.IBaseCourseSubjectService;
  27. import com.xjrsoft.module.base.service.IBaseSemesterService;
  28. import com.xjrsoft.module.base.vo.BaseClassCourseExcelVo;
  29. import com.xjrsoft.module.base.vo.BaseClassCourseExportListVo;
  30. import com.xjrsoft.module.base.vo.BaseClassCourseListVo;
  31. import com.xjrsoft.module.base.vo.BaseClassCoursePageVo;
  32. import com.xjrsoft.module.base.vo.BaseClassCourseVo;
  33. import com.xjrsoft.module.textbook.entity.Textbook;
  34. import com.xjrsoft.module.textbook.service.ITextbookService;
  35. import io.swagger.annotations.Api;
  36. import io.swagger.annotations.ApiOperation;
  37. import lombok.AllArgsConstructor;
  38. import org.slf4j.Logger;
  39. import org.slf4j.LoggerFactory;
  40. import org.springframework.http.ResponseEntity;
  41. import org.springframework.web.bind.annotation.DeleteMapping;
  42. import org.springframework.web.bind.annotation.GetMapping;
  43. import org.springframework.web.bind.annotation.PostMapping;
  44. import org.springframework.web.bind.annotation.PutMapping;
  45. import org.springframework.web.bind.annotation.RequestBody;
  46. import org.springframework.web.bind.annotation.RequestMapping;
  47. import org.springframework.web.bind.annotation.RequestParam;
  48. import org.springframework.web.bind.annotation.RestController;
  49. import org.springframework.web.multipart.MultipartFile;
  50. import javax.validation.Valid;
  51. import java.io.ByteArrayOutputStream;
  52. import java.io.IOException;
  53. import java.util.ArrayList;
  54. import java.util.Date;
  55. import java.util.HashMap;
  56. import java.util.List;
  57. import java.util.Map;
  58. /**
  59. * @title: 班级课程
  60. * @Author brealinxx
  61. * @Date: 2024-06-04
  62. * @Version 1.0
  63. */
  64. @RestController
  65. @RequestMapping("/base" + "/baseClassCourse")
  66. @Api(value = "/base" + "/baseClassCourse", tags = "班级课程代码")
  67. @AllArgsConstructor
  68. public class BaseClassCourseController {
  69. private static final Logger log = LoggerFactory.getLogger(BaseClassCourseController.class);
  70. private final IBaseClassCourseService baseClassCourseService;
  71. private final IBaseCourseSubjectService subjectService;
  72. private final ITextbookService textbookService;
  73. private final IBaseClassService classService;
  74. private final IBaseSemesterService semesterService;
  75. @GetMapping(value = "/page")
  76. @ApiOperation(value = "班级课程列表(分页)")
  77. @SaCheckPermission("baseclasscourse:detail")
  78. public RT<PageOutput<BaseClassCoursePageVo>> page(@Valid BaseClassCoursePageDto dto) {
  79. if(dto.getSemester() == null || dto.getSemester() == 0){
  80. Page<BaseClassCoursePageVo> page = new Page<>();
  81. page.setRecords(new ArrayList<>());
  82. return RT.ok(ConventPage.getPageOutput(page, BaseClassCoursePageVo.class));
  83. }
  84. Page<BaseClassCoursePageVo> page = baseClassCourseService.getPage(new Page<>(dto.getLimit(), dto.getSize()), dto);
  85. PageOutput<BaseClassCoursePageVo> pageOutput = ConventPage.getPageOutput(page, BaseClassCoursePageVo.class);
  86. return RT.ok(pageOutput);
  87. }
  88. @GetMapping(value = "/list")
  89. @ApiOperation(value = "单个班级班级课程列表")
  90. @SaCheckPermission("baseclasscourse:detail")
  91. public RT<List<BaseClassCourseListVo>> page(@Valid BaseClassCourseListDto dto) {
  92. MPJLambdaWrapper<BaseClassCourse> baseClassCourseMPJLambdaWrapper = new MPJLambdaWrapper<>();
  93. baseClassCourseMPJLambdaWrapper
  94. .select(BaseClassCourse::getCourseId)
  95. .selectAs(BaseClass::getName, BaseClassCourseListVo::getClassIdCn)
  96. .selectAs(BaseCourseSubject::getName, BaseClassCourseListVo::getCourseIdCn)
  97. .selectAs(Textbook::getBookName, BaseClassCourseListVo::getTextbookIdCn)
  98. .selectAs(BaseSemester::getName, BaseClassCourseListVo::getBaseSemesterIdCn)
  99. .select(BaseClassCourse.class, x -> VoToColumnUtil.fieldsToColumns(BaseClassCourseListVo.class).contains(x.getProperty()))
  100. .leftJoin(BaseClass.class, BaseClass::getId, BaseClassCourse::getClassId)
  101. .leftJoin(BaseCourseSubject.class, BaseCourseSubject::getId, BaseClassCourse::getCourseId)
  102. .leftJoin(Textbook.class, Textbook::getId, BaseClassCourse::getTextbookId)
  103. .leftJoin(BaseSemester.class, BaseSemester::getId, BaseClassCourse::getBaseSemesterId)
  104. .eq(dto.getBaseSemesterId() != null && dto.getBaseSemesterId() > 0, BaseClassCourse::getBaseSemesterId, dto.getBaseSemesterId())
  105. .eq(dto.getClassId() != null && dto.getClassId() > 0, BaseClassCourse::getClassId, dto.getClassId())
  106. ;
  107. List<BaseClassCourseListVo> baseClassCourseListVoList = baseClassCourseService.selectJoinList(BaseClassCourseListVo.class, baseClassCourseMPJLambdaWrapper);
  108. return RT.ok(baseClassCourseListVoList);
  109. }
  110. @GetMapping("/getSemesterTree")
  111. @ApiOperation("获取年级树结构")
  112. @SaCheckPermission("baseclasscourse:detail")
  113. public RT<Map<String, Map<String, Object>>> semesterTree() {
  114. Map<String, Map<String, Object>> tree = baseClassCourseService.getSemesterTree();
  115. return RT.ok(tree);
  116. }
  117. @GetMapping(value = "/info")
  118. @ApiOperation(value = "根据id查询班级课程信息")
  119. @SaCheckPermission("baseclasscourse:detail")
  120. public RT<BaseClassCourseVo> info(@RequestParam Long id) {
  121. BaseClassCourse baseClassCourse = baseClassCourseService.getById(id);
  122. if (baseClassCourse == null) {
  123. return RT.error("找不到此数据!");
  124. }
  125. return RT.ok(BeanUtil.toBean(baseClassCourse, BaseClassCourseVo.class));
  126. }
  127. @GetMapping("/getAllCoursesAndTextbooks")
  128. @ApiOperation(value = "获取所有课程教材")
  129. @SaCheckPermission("baseclasscourse:detail")
  130. public RT<List<CourseBookInfo>> getAllCoursesAndTextbooks(@RequestParam(required = false) Long[] classIds, @RequestParam(required = false) Long subjectGroupId, @RequestParam(required = false) Long semester) {
  131. List<CourseBookInfo> data = baseClassCourseService.getAllCourseBook(classIds, subjectGroupId, semester);
  132. return RT.ok(data);
  133. }
  134. @GetMapping("/getAllSelectedCoursesAndTextbooks")
  135. @ApiOperation(value = "获取所有以选择课程教材")
  136. @SaCheckPermission("baseclasscourse:detail")
  137. public RT<List<CourseBookInfo>> getAllSelectedCoursesAndTextbooks(@RequestParam(required = false) Long[] classIds, @RequestParam(required = false) Long semester) {
  138. List<CourseBookInfo> data = baseClassCourseService.getSelectedCourseBook(classIds, semester);
  139. return RT.ok(data);
  140. }
  141. @PostMapping("/updateAddCoursesAndTextbooks")
  142. @ApiOperation(value = "更新增加课程教材")
  143. @SaCheckPermission("baseclasscourse:detail")
  144. public RT<Boolean> updateAddCoursesAndTextbooks(@Valid @RequestBody ClassCourseTextbook dto) {
  145. return RT.ok(baseClassCourseService.updateAddCourseBook(dto));
  146. }
  147. @PostMapping("/updateRemoveCoursesAndTextbooks")
  148. @ApiOperation(value = "更新减少课程教材")
  149. @SaCheckPermission("baseclasscourse:detail")
  150. public RT<Boolean> updateRemoveCoursesAndTextbooks(@Valid ClassCourseTextbook list) {
  151. boolean isSuccess = true;
  152. for (Long classId : list.getClassIds()) {
  153. for (Long i = 0L; i < list.getCourseId().length; i++) {
  154. baseClassCourseService.updateRemoveCourseBook(classId, list.getCourseId()[Math.toIntExact(i)], list.getTextbookId()[Math.toIntExact(i)]);
  155. }
  156. }
  157. return RT.ok(isSuccess);
  158. }
  159. @PostMapping("/insertClassCourseTextbookCombinations")
  160. @ApiOperation(value = "复用课程教材")
  161. @SaCheckPermission("baseclasscourse:detail")
  162. public RT<Boolean> insertClassCourseTextbookCombinations(@Valid @RequestBody ClassCourseReuseDto dto) {
  163. return RT.ok(baseClassCourseService.duplicateCourseBook(dto));
  164. }
  165. @PostMapping
  166. @ApiOperation(value = "新增班级课程")
  167. @SaCheckPermission("baseclasscourse:add")
  168. public RT<Boolean> add(@Valid @RequestBody AddBaseClassCourseDto dto) {
  169. BaseClassCourse baseClassCourse = BeanUtil.toBean(dto, BaseClassCourse.class);
  170. boolean isSuccess = baseClassCourseService.save(baseClassCourse);
  171. return RT.ok(isSuccess);
  172. }
  173. @PutMapping
  174. @ApiOperation(value = "修改班级课程")
  175. @SaCheckPermission("baseclasscourse:edit")
  176. public RT<Boolean> update(@Valid @RequestBody UpdateBaseClassCourseDto dto) {
  177. BaseClassCourse baseClassCourse = BeanUtil.toBean(dto, BaseClassCourse.class);
  178. return RT.ok(baseClassCourseService.updateById(baseClassCourse));
  179. }
  180. @DeleteMapping
  181. @ApiOperation(value = "删除班级课程")
  182. @SaCheckPermission("baseclasscourse:delete")
  183. public RT<Boolean> delete(@Valid @RequestBody List<Long> ids) {
  184. return RT.ok(baseClassCourseService.removeBatchByIds(ids));
  185. }
  186. @PostMapping("/import")
  187. @ApiOperation(value = "导入")
  188. public RT<Boolean> importData(@RequestParam MultipartFile file) throws IOException {
  189. List<BaseClassCourseExcelVo> savedDataList = EasyExcel.read(file.getInputStream()).headRowNumber(3).head(BaseClassCourseExcelVo.class).sheet().doReadSync();
  190. List<BaseClassCourse> baseClassCourses = new ArrayList<>();
  191. List<String> duplicateLogs = new ArrayList<>();
  192. List<String> errorLogs = new ArrayList<>();
  193. List<BaseClass> classList = classService.list(new QueryWrapper<BaseClass>());
  194. Map<String, Long> classMap = new HashMap<>();
  195. for (BaseClass baseClass : classList) {
  196. classMap.put(baseClass.getName(), baseClass.getId());
  197. }
  198. List<BaseCourseSubject> courseSubjectList = subjectService.list(new QueryWrapper<BaseCourseSubject>());
  199. Map<String, Long> courseSubjectMap = new HashMap<>();
  200. for (BaseCourseSubject baseCourseSubject : courseSubjectList) {
  201. courseSubjectMap.put(baseCourseSubject.getName(), baseCourseSubject.getId());
  202. }
  203. List<Textbook> textbookList = textbookService.list(new QueryWrapper<Textbook>());
  204. Map<String, Long> textbookMap = new HashMap<>();
  205. for (Textbook textbook : textbookList) {
  206. textbookMap.put(textbook.getBookName(), textbook.getId());
  207. }
  208. List<BaseSemester> semesterList = semesterService.list(new QueryWrapper<BaseSemester>());
  209. Map<String, Long> semesterMap = new HashMap<>();
  210. for (BaseSemester baseSemester : semesterList) {
  211. semesterMap.put(baseSemester.getName(), baseSemester.getId());
  212. }
  213. for (BaseClassCourseExcelVo vo : savedDataList) {
  214. if(vo.getClassName() == null){
  215. continue;
  216. }
  217. if(vo.getTextbookName() != null){
  218. try {
  219. Long classId = classMap.get(vo.getClassName());
  220. Long courseId = courseSubjectMap.get(vo.getCourseName());
  221. Long textbookId = textbookMap.get(vo.getTextbookName());
  222. Long baseSemesterId = semesterMap.get(vo.getSemester());
  223. if (baseClassCourseService.checkExits(classId, courseId, textbookId)) {
  224. continue;
  225. }
  226. if (classId != null && courseId != null && textbookId != null && baseSemesterId != null) {
  227. BaseClassCourse baseClassCourse = new BaseClassCourse();
  228. baseClassCourse.setClassId(classId);
  229. baseClassCourse.setCourseId(courseId);
  230. baseClassCourse.setTextbookId(textbookId);
  231. baseClassCourse.setCreateDate(new Date());
  232. baseClassCourse.setDeleteMark(0);
  233. baseClassCourse.setBaseSemesterId(baseSemesterId);
  234. baseClassCourses.add(baseClassCourse);
  235. }
  236. } catch (NumberFormatException e) {
  237. errorLogs.add(String.format("[无法解析输入的信息] 班级: %s, 班级: %s, 教材: %s", vo.getClassName(), vo.getCourseName(), vo.getTextbookName()));
  238. } catch (Exception e) {
  239. errorLogs.add(String.format("[意外错误(检查输入的名称是否正确且存在,输入错误可能返回 null)] 班级: %s, 课程: %s, 教材: %s - 错误信息:%s", vo.getClassName(), vo.getCourseName(), vo.getTextbookName(), e.getMessage()));
  240. }
  241. }else{
  242. Long classId = classMap.get(vo.getClassName());
  243. Long courseId = courseSubjectMap.get(vo.getCourseName());
  244. Long baseSemesterId = semesterMap.get(vo.getSemester());
  245. if (baseClassCourseService.checkExitsWithoutTextbook(classId, courseId)) {
  246. continue;
  247. }
  248. BaseClassCourse baseClassCourse = new BaseClassCourse();
  249. baseClassCourse.setClassId(classId);
  250. baseClassCourse.setCourseId(courseId);
  251. baseClassCourse.setCreateDate(new Date());
  252. baseClassCourse.setDeleteMark(0);
  253. baseClassCourse.setBaseSemesterId(baseSemesterId);
  254. baseClassCourse.setCreateDate(new Date());
  255. baseClassCourses.add(baseClassCourse);
  256. }
  257. }
  258. Boolean result = baseClassCourseService.saveBatch(baseClassCourses);
  259. if (!duplicateLogs.isEmpty() || !errorLogs.isEmpty()) {
  260. String detailedMessage = String.format("[导入完成但存在问题] 问题: %s. 其他错误: %s", String.join("; ", duplicateLogs), String.join("; ", errorLogs));
  261. return RT.error(400, detailedMessage);
  262. }
  263. return RT.ok(result);
  264. }
  265. @GetMapping("/export")
  266. @ApiOperation(value = "导出")
  267. public ResponseEntity<byte[]> exportData() {
  268. MPJLambdaWrapper<BaseClassCourse> baseClassCourseMPJLambdaWrapper = new MPJLambdaWrapper<>();
  269. baseClassCourseMPJLambdaWrapper
  270. .select(BaseClassCourse::getCourseId)
  271. .selectAs(BaseClass::getName, BaseClassCourseExportListVo::getClassIdCn)
  272. .selectAs(BaseCourseSubject::getName, BaseClassCourseExportListVo::getCourseIdCn)
  273. .selectAs(Textbook::getBookName, BaseClassCourseExportListVo::getTextbookIdCn)
  274. .selectAs(BaseSemester::getName, BaseClassCourseExportListVo::getBaseSemesterIdCn)
  275. .select(BaseClassCourse.class, x -> VoToColumnUtil.fieldsToColumns(BaseClassCourseExportListVo.class).contains(x.getProperty()))
  276. .leftJoin(BaseClass.class, BaseClass::getId, BaseClassCourse::getClassId)
  277. .leftJoin(BaseCourseSubject.class, BaseCourseSubject::getId, BaseClassCourse::getCourseId)
  278. .leftJoin(Textbook.class, Textbook::getId, BaseClassCourse::getTextbookId)
  279. .leftJoin(BaseSemester.class, BaseSemester::getId, BaseClassCourse::getBaseSemesterId)
  280. ;
  281. List<BaseClassCourseExportListVo> customerList = baseClassCourseService.selectJoinList(BaseClassCourseExportListVo.class, baseClassCourseMPJLambdaWrapper);
  282. ByteArrayOutputStream bot = new ByteArrayOutputStream();
  283. EasyExcel.write(bot, BaseClassCourseExportListVo.class).automaticMergeHead(false).excelType(ExcelTypeEnum.XLSX).sheet().doWrite(customerList);
  284. return RT.fileStream(bot.toByteArray(), "BaseClassCourse" + ExcelTypeEnum.XLSX.getValue());
  285. }
  286. }