TextbookController.java 14 KB

123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263646566676869707172737475767778798081828384858687888990919293949596979899100101102103104105106107108109110111112113114115116117118119120121122123124125126127128129130131132133134135136137138139140141142143144145146147148149150151152153154155156157158159160161162163164165166167168169170171172173174175176177178179180181182183184185186187188189190191192193194195196197198199200201202203204205206207208209210211212213214215216217218219220221222223224225226227228229230231232233234235236237238239240241242243244245246247248249250251252253254255256257258259260261262263264265266267268269270271272273274275276277278279280281282283284285286287288289290291
  1. package com.xjrsoft.module.textbook.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.metadata.IPage;
  7. import com.github.yulichang.wrapper.MPJLambdaWrapper;
  8. import com.xjrsoft.common.enums.TextbookTypeEnum;
  9. import com.xjrsoft.common.exception.MyException;
  10. import com.xjrsoft.common.model.result.R;
  11. import com.xjrsoft.common.model.result.RT;
  12. import com.xjrsoft.common.page.ConventPage;
  13. import com.xjrsoft.common.page.PageOutput;
  14. import com.xjrsoft.common.utils.VoToColumnUtil;
  15. import com.xjrsoft.module.base.entity.BaseCourseSubject;
  16. import com.xjrsoft.module.generator.entity.ImportConfig;
  17. import com.xjrsoft.module.student.entity.BaseClassMajorSet;
  18. import com.xjrsoft.module.textbook.dto.*;
  19. import com.xjrsoft.module.textbook.entity.Textbook;
  20. import com.xjrsoft.module.textbook.entity.TextbookClassRelation;
  21. import com.xjrsoft.module.textbook.entity.TextbookStudentClaim;
  22. import com.xjrsoft.module.textbook.service.ITextbookService;
  23. import com.xjrsoft.module.textbook.service.ITextbookStudentClaimService;
  24. import com.xjrsoft.module.textbook.vo.*;
  25. import com.xjrsoft.module.veb.util.ImportExcelUtil;
  26. import io.swagger.annotations.Api;
  27. import io.swagger.annotations.ApiOperation;
  28. import lombok.AllArgsConstructor;
  29. import org.apache.poi.ss.usermodel.Sheet;
  30. import org.apache.poi.ss.usermodel.Workbook;
  31. import org.apache.poi.xssf.usermodel.XSSFWorkbook;
  32. import org.springframework.http.ResponseEntity;
  33. import org.springframework.web.bind.annotation.*;
  34. import org.springframework.web.multipart.MultipartFile;
  35. import javax.validation.Valid;
  36. import java.io.ByteArrayOutputStream;
  37. import java.io.IOException;
  38. import java.net.URLEncoder;
  39. import java.nio.charset.StandardCharsets;
  40. import java.text.ParseException;
  41. import java.util.ArrayList;
  42. import java.util.Arrays;
  43. import java.util.List;
  44. /**
  45. * @title: 教材管理
  46. * @Author dzx
  47. * @Date: 2023-12-25
  48. * @Version 1.0
  49. */
  50. @RestController
  51. @RequestMapping("/textbook" + "/textbook")
  52. @Api(value = "/textbook" + "/textbook",tags = "教材管理代码")
  53. @AllArgsConstructor
  54. public class TextbookController {
  55. private final ITextbookService textbookService;
  56. private final ITextbookStudentClaimService textbookStudentClaimService;
  57. @GetMapping(value = "/page")
  58. @ApiOperation(value="教材管理列表(分页)")
  59. @SaCheckPermission("textbook:detail")
  60. public RT<PageOutput<TextbookPageVo>> page(@Valid TextbookPageDto dto){
  61. IPage<TextbookPageVo> page = textbookService.pageRubAndHand(dto);
  62. PageOutput<TextbookPageVo> pageOutput = ConventPage.getPageOutput(page, TextbookPageVo.class);
  63. return RT.ok(pageOutput);
  64. }
  65. @GetMapping(value = "/page-consumption")
  66. @ApiOperation(value="学生确认领取教材列表(分页,学生收费用)")
  67. @SaCheckPermission("textbook:detail")
  68. public RT<PageOutput<TextbookConsumptionPageVo>> pageConsumption(@Valid TextbookConsumptionPageDto dto){
  69. MPJLambdaWrapper<TextbookStudentClaim> textbookMPJLambdaWrapper = new MPJLambdaWrapper<>();
  70. textbookMPJLambdaWrapper
  71. .select(TextbookStudentClaim::getId)
  72. .selectAs(Textbook::getId,TextbookConsumptionPageVo::getTextbookId)
  73. .selectAs(BaseCourseSubject::getName, TextbookConsumptionPageVo::getCourseSubjectIdCn)
  74. .select(Textbook.class, x -> VoToColumnUtil.fieldsToColumns(TextbookConsumptionPageVo.class).contains(x.getProperty()))
  75. .leftJoin(Textbook.class, Textbook::getId, TextbookStudentClaim::getTextbookId)
  76. .leftJoin(BaseCourseSubject.class, BaseCourseSubject::getId, Textbook::getCourseSubjectId)
  77. .eq(dto.getBaseSemesterId() != null && dto.getBaseSemesterId() > 0, TextbookStudentClaim::getBaseSemesterId, dto.getBaseSemesterId())
  78. .eq(dto.getStudentUserId() != null && dto.getStudentUserId() > 0,TextbookStudentClaim::getStudentUserId, dto.getStudentUserId())
  79. ;
  80. IPage<TextbookConsumptionPageVo> page = textbookStudentClaimService.selectJoinListPage(ConventPage.getPage(dto),TextbookConsumptionPageVo.class,textbookMPJLambdaWrapper);
  81. for(TextbookConsumptionPageVo t : page.getRecords()){
  82. if((t.getTextbookType() != null) && !t.getTextbookType().isEmpty()){
  83. t.setTextbookTypeCn(TextbookTypeEnum.getValue(t.getTextbookType()));
  84. }
  85. }
  86. PageOutput<TextbookConsumptionPageVo> pageOutput = ConventPage.getPageOutput(page, TextbookConsumptionPageVo.class);
  87. return RT.ok(pageOutput);
  88. }
  89. @GetMapping(value = "/List-subscription")
  90. @ApiOperation(value="教材管理列表(不分页,教材征订用)")
  91. @SaCheckPermission("textbook:detail")
  92. public RT<List<TextbookSubscriptionListVo>> listSubscription(@Valid TextbookSubscriptionListDto dto){
  93. List<TextbookSubscriptionListVo> list = textbookService.getSubscriptionListByClass(dto);
  94. return RT.ok(list);
  95. }
  96. @GetMapping(value = "/info-detail")
  97. @ApiOperation(value="根据id查询教材管理信息")
  98. @SaCheckPermission("textbook:detail")
  99. public RT<TextbookVo> info(@RequestParam Long id){
  100. Textbook textbook = textbookService.getById(id);
  101. if (textbook == null) {
  102. return RT.ok(new TextbookVo());
  103. }
  104. return RT.ok(BeanUtil.toBean(textbook, TextbookVo.class));
  105. }
  106. @GetMapping(value = "/info-byissn")
  107. @ApiOperation(value="根据isnn查询教材管理信息")
  108. @SaCheckPermission("textbook:detail")
  109. public RT<TextbookVo> infoByissn(@RequestParam String issn){
  110. TextbookVo textbook = textbookService.getInfoByissn(issn);
  111. return RT.ok(textbook);
  112. }
  113. @GetMapping(value = "/info-subscription-list")
  114. @ApiOperation(value="教材管理-详情-征订记录")
  115. @SaCheckPermission("textbook:detail")
  116. public RT<List<TextbookSubscriptionRecordVo>> subscriptionList(@RequestParam Long id){
  117. List<TextbookSubscriptionRecordVo> result = textbookService.subscriptionList(id);
  118. if (result == null) {
  119. return RT.ok(new ArrayList<>());
  120. }
  121. return RT.ok(result);
  122. }
  123. @GetMapping(value = "/info-warehouse-list")
  124. @ApiOperation(value="教材管理-详情-入库记录")
  125. @SaCheckPermission("textbook:detail")
  126. public RT<List<TextbookWarehouseRecordListVo>> warehouseList(@RequestParam Long id){
  127. List<TextbookWarehouseRecordListVo> result = textbookService.warehouseList(id);
  128. if (result == null) {
  129. return RT.ok(new ArrayList<>());
  130. }
  131. return RT.ok(result);
  132. }
  133. @GetMapping(value = "/info-issue-list")
  134. @ApiOperation(value="教材管理-详情-出库记录")
  135. @SaCheckPermission("textbook:detail")
  136. public RT<List<TextbookIssueRecordListVo>> issueList(@RequestParam Long id){
  137. List<TextbookIssueRecordListVo> result = textbookService.issueList(id);
  138. if (result == null) {
  139. return RT.ok(new ArrayList<>());
  140. }
  141. return RT.ok(result);
  142. }
  143. @GetMapping(value = "/info-claim-list")
  144. @ApiOperation(value="教材管理-详情-领取记录")
  145. @SaCheckPermission("textbook:detail")
  146. public RT<List<WfTextbookClaimListVo>> claimList(@RequestParam Long id){
  147. List<WfTextbookClaimListVo> result = textbookService.claimList(id);
  148. if (result == null) {
  149. return RT.ok(new ArrayList<>());
  150. }
  151. return RT.ok(result);
  152. }
  153. @PostMapping
  154. @ApiOperation(value = "新增教材管理")
  155. @SaCheckPermission("textbook:add")
  156. public RT<Boolean> add(@Valid @RequestBody AddTextbookDto dto) throws ParseException {
  157. Textbook textbook = BeanUtil.toBean(dto, Textbook.class);
  158. boolean isSuccess = textbookService.addRubAndHand(textbook);
  159. return RT.ok(isSuccess);
  160. }
  161. @PutMapping
  162. @ApiOperation(value = "修改教材管理")
  163. @SaCheckPermission("textbook:edit")
  164. public RT<Boolean> update(@Valid @RequestBody UpdateTextbookDto dto) throws ParseException {
  165. Textbook textbook = BeanUtil.toBean(dto, Textbook.class);
  166. return RT.ok(textbookService.updateRubAndHand(textbook));
  167. }
  168. @DeleteMapping
  169. @ApiOperation(value = "删除教材管理")
  170. @SaCheckPermission("textbook:delete")
  171. public RT<Boolean> delete(@Valid @RequestBody List<Long> ids){
  172. return RT.ok(textbookService.delete(ids));
  173. }
  174. // @GetMapping("/export")
  175. // @ApiOperation(value = "导出")
  176. // public ResponseEntity<byte[]> exportData(@Valid TextbookPageDto dto, @RequestParam(defaultValue = "false") Boolean isTemplate) {
  177. // List<TextbookPageVo> customerList = isTemplate != null && isTemplate ? new ArrayList<>() : ((PageOutput<TextbookPageVo>) page(dto).getData()).getList();
  178. // ByteArrayOutputStream bot = new ByteArrayOutputStream();
  179. // EasyExcel.write(bot, TextbookPageVo.class).automaticMergeHead(false).excelType(ExcelTypeEnum.XLSX).sheet().doWrite(customerList);
  180. //
  181. // return RT.fileStream(bot.toByteArray(), "Textbook" + ExcelTypeEnum.XLSX.getValue());
  182. // }
  183. @PostMapping("/textbook-standing-export-query")
  184. @ApiOperation(value = "台账条件导出")
  185. public ResponseEntity<byte[]> textbookStandingExportQuery(@Valid @RequestBody TextbookStandingExportQuerytDto dto) {
  186. // @GetMapping("/textbook-standing-export-query")
  187. // @ApiOperation(value = "台账条件导出")
  188. // public ResponseEntity<byte[]> textbookStandingExportQuery(@Valid TextbookStandingExportQuerytDto dto) {
  189. List<TextbookStandingExportQueryVo> customerList = textbookService.listTextbookStandingExportQuery(dto);
  190. ByteArrayOutputStream bot = new ByteArrayOutputStream();
  191. EasyExcel.write(bot, TextbookStandingExportQueryVo.class).automaticMergeHead(false).excelType(ExcelTypeEnum.XLSX).sheet().doWrite(customerList);
  192. return RT.fileStream(bot.toByteArray(), "TextbookStanding" + ExcelTypeEnum.XLSX.getValue());
  193. }
  194. @PostMapping("/textbook-subscription-export-query")
  195. @ApiOperation(value = "教材征订记录条件导出")
  196. public ResponseEntity<byte[]> textbookSubscriptionExportQuery(@Valid @RequestBody TextbookSubscriptionExportQueryDto dto) {
  197. // @GetMapping("/textbook-subscription-export-query")
  198. // @ApiOperation(value = "教材征订记录条件导出")
  199. // public ResponseEntity<byte[]> textbookSubscriptionExportQuery(@Valid TextbookSubscriptionExportQueryDto dto) {
  200. ByteArrayOutputStream bot = textbookService.listTextbookSubscriptionExportQuery(dto);
  201. return RT.fileStream(bot.toByteArray(), "TextbookSubscription" + ExcelTypeEnum.XLSX.getValue());
  202. }
  203. @PostMapping("/textbook-claim-export-query")
  204. @ApiOperation(value = "教材发放记录条件导出")
  205. public ResponseEntity<byte[]> textbookClaimExportQuery(@Valid @RequestBody TextbookClaimExportQueryDto dto) {
  206. // @GetMapping("/textbook-claim-export-query")
  207. // @ApiOperation(value = "教材发放记录条件导出")
  208. // public ResponseEntity<byte[]> textbookClaimExportQuery(@Valid TextbookClaimExportQueryDto dto) {
  209. ByteArrayOutputStream bot = textbookService.listTextbookClaimExportQuery(dto);
  210. return RT.fileStream(bot.toByteArray(), "TextbookClaim" + ExcelTypeEnum.XLSX.getValue());
  211. }
  212. // @PostMapping("/excel-import")
  213. // @ApiOperation(value = "excel教材导入")
  214. // @SaCheckPermission("coursetable:excelimport")
  215. // public R excelImport( @RequestParam("file") MultipartFile file) throws IOException {
  216. // InputStream inputStream = file.getInputStream();
  217. // return R.ok(textbookService.excelImport(inputStream));
  218. // }
  219. @PostMapping("/textbook-import")
  220. @ApiOperation(value = "教材信息导入")
  221. public RT<Boolean> textbook(@RequestParam MultipartFile file) throws IOException, IllegalAccessException {
  222. String result = textbookService.textbook(file);
  223. if (!result.isEmpty()) {
  224. throw new MyException(result);
  225. }
  226. return RT.ok("全部成功", true);
  227. }
  228. @PostMapping("/textbook-template-download")
  229. @ApiOperation(value = "教材信息模板下载")
  230. public ResponseEntity<byte[]> textbookTemplate() throws IOException {
  231. // @GetMapping("/textbook-template")
  232. // @ApiOperation(value = "教材信息模板下载")
  233. // public ResponseEntity<byte[]> textbookTemplate() throws IOException {
  234. TextbookImportDto obj = new TextbookImportDto();
  235. // 开始写入
  236. Workbook workbook = new XSSFWorkbook();
  237. // 创建一个工作表(sheet)
  238. String sheetName = "sheet1";
  239. Sheet sheet = workbook.createSheet(sheetName);
  240. List<ImportConfig> importConfigs = ImportExcelUtil.allFields(obj);
  241. // 标题
  242. String title = "教材信息导入模板";
  243. ImportExcelUtil.createCautionHead(workbook, sheet, 0, title, importConfigs.size() - 1, 36);
  244. // 提示必填
  245. String content = "说明:红底为必填项,白底为非必填项;只有教材分类为教材时才需要填写学科组和对应课程,学科组和课程必须是系统中已添加的信息,且学科组和课程已建立绑定关系;导入时请将示例数据删除,避免导入失败!";
  246. ImportExcelUtil.createCautionHead(workbook, sheet, 1, content, importConfigs.size() - 1, 12);
  247. // 表头
  248. ImportExcelUtil.createHead(workbook, sheet, importConfigs, 2);
  249. //写入文件
  250. ByteArrayOutputStream bot = new ByteArrayOutputStream();
  251. workbook.write(bot);
  252. String fileName = "教材信息导入模板";
  253. fileName = URLEncoder.encode(fileName, StandardCharsets.UTF_8);
  254. return R.fileStream(bot.toByteArray(), fileName + ExcelTypeEnum.XLSX.getValue());
  255. }
  256. }