TextbookController.java 15 KB

123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263646566676869707172737475767778798081828384858687888990919293949596979899100101102103104105106107108109110111112113114115116117118119120121122123124125126127128129130131132133134135136137138139140141142143144145146147148149150151152153154155156157158159160161162163164165166167168169170171172173174175176177178179180181182183184185186187188189190191192193194195196197198199200201202203204205206207208209210211212213214215216217218219220221222223224225226227228229230231232233234235236237238239240241242243244245246247248249250251252253254255256257258259260261262263264265266267268269270271272273274275276277278279280281282283284285286287288289290291292293294295296297298299300301
  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.conditions.query.LambdaQueryWrapper;
  7. import com.baomidou.mybatisplus.core.metadata.IPage;
  8. import com.baomidou.mybatisplus.extension.plugins.pagination.Page;
  9. import com.github.yulichang.wrapper.MPJLambdaWrapper;
  10. import com.xjrsoft.common.enums.DeleteMark;
  11. import com.xjrsoft.common.enums.TextbookTypeEnum;
  12. import com.xjrsoft.common.model.result.R;
  13. import com.xjrsoft.common.model.result.RT;
  14. import com.xjrsoft.common.page.ConventPage;
  15. import com.xjrsoft.common.page.PageOutput;
  16. import com.xjrsoft.common.utils.VoToColumnUtil;
  17. import com.xjrsoft.module.base.entity.BaseClassCourse;
  18. import com.xjrsoft.module.base.entity.BaseCourseSubject;
  19. import com.xjrsoft.module.student.entity.BaseClassMajorSet;
  20. import com.xjrsoft.module.student.service.IBaseClassMajorSetService;
  21. import com.xjrsoft.module.textbook.dto.*;
  22. import com.xjrsoft.module.textbook.entity.Textbook;
  23. import com.xjrsoft.module.textbook.entity.TextbookClassRelation;
  24. import com.xjrsoft.module.textbook.entity.TextbookStudentClaim;
  25. import com.xjrsoft.module.textbook.service.ITextbookService;
  26. import com.xjrsoft.module.textbook.service.ITextbookStudentClaimService;
  27. import com.xjrsoft.module.textbook.vo.*;
  28. import io.swagger.annotations.Api;
  29. import io.swagger.annotations.ApiOperation;
  30. import lombok.AllArgsConstructor;
  31. import org.springframework.http.ResponseEntity;
  32. import org.springframework.web.bind.annotation.*;
  33. import org.springframework.web.multipart.MultipartFile;
  34. import javax.validation.Valid;
  35. import java.io.ByteArrayOutputStream;
  36. import java.io.IOException;
  37. import java.io.InputStream;
  38. import java.text.ParseException;
  39. import java.text.ParsePosition;
  40. import java.text.SimpleDateFormat;
  41. import java.time.LocalDate;
  42. import java.time.ZoneId;
  43. import java.util.ArrayList;
  44. import java.util.Arrays;
  45. import java.util.Date;
  46. import java.util.List;
  47. /**
  48. * @title: 教材管理
  49. * @Author dzx
  50. * @Date: 2023-12-25
  51. * @Version 1.0
  52. */
  53. @RestController
  54. @RequestMapping("/textbook" + "/textbook")
  55. @Api(value = "/textbook" + "/textbook",tags = "教材管理代码")
  56. @AllArgsConstructor
  57. public class TextbookController {
  58. private final ITextbookService textbookService;
  59. private final ITextbookStudentClaimService textbookStudentClaimService;
  60. private final IBaseClassMajorSetService baseClassMajorSetService;
  61. @GetMapping(value = "/page")
  62. @ApiOperation(value="教材管理列表(分页)")
  63. @SaCheckPermission("textbook:detail")
  64. public RT<PageOutput<TextbookPageVo>> page(@Valid TextbookPageDto dto){
  65. Page<TextbookPageVo> page = textbookService.getPage(new Page<>(dto.getLimit(), dto.getSize()), dto);
  66. PageOutput<TextbookPageVo> pageOutput = ConventPage.getPageOutput(page, TextbookPageVo.class);
  67. return RT.ok(pageOutput);
  68. }
  69. @GetMapping(value = "/page-subscription")
  70. @ApiOperation(value="教材管理列表(分页,教材征订用)")
  71. @SaCheckPermission("textbook:detail")
  72. public RT<PageOutput<TextbookSubscriptionListVo>> pageSubscription(@Valid TextbookSubscriptionListDto dto){
  73. IPage<TextbookSubscriptionListVo> page = textbookService.getSubscriptionPageByClass(dto);
  74. PageOutput<TextbookSubscriptionListVo> pageOutput = ConventPage.getPageOutput(page, TextbookSubscriptionListVo.class);
  75. return RT.ok(pageOutput);
  76. }
  77. @GetMapping(value = "/page-consumption")
  78. @ApiOperation(value="学生确认领取教材列表(分页,学生收费用)")
  79. @SaCheckPermission("textbook:detail")
  80. public RT<PageOutput<TextbookConsumptionPageVo>> pageConsumption(@Valid TextbookConsumptionPageDto dto){
  81. MPJLambdaWrapper<TextbookStudentClaim> textbookMPJLambdaWrapper = new MPJLambdaWrapper<>();
  82. textbookMPJLambdaWrapper
  83. .select(TextbookStudentClaim::getId)
  84. .selectAs(Textbook::getId,TextbookConsumptionPageVo::getTextbookId)
  85. .selectAs(BaseCourseSubject::getName, TextbookConsumptionPageVo::getCourseSubjectIdCn)
  86. .select(Textbook.class, x -> VoToColumnUtil.fieldsToColumns(TextbookConsumptionPageVo.class).contains(x.getProperty()))
  87. .leftJoin(Textbook.class, Textbook::getId, TextbookStudentClaim::getTextbookId)
  88. .leftJoin(BaseCourseSubject.class, BaseCourseSubject::getId, Textbook::getCourseSubjectId)
  89. .eq(dto.getBaseSemesterId() != null && dto.getBaseSemesterId() > 0, TextbookStudentClaim::getBaseSemesterId, dto.getBaseSemesterId())
  90. .eq(dto.getStudentUserId() != null && dto.getStudentUserId() > 0,TextbookStudentClaim::getStudentUserId, dto.getStudentUserId())
  91. ;
  92. IPage<TextbookConsumptionPageVo> page = textbookStudentClaimService.selectJoinListPage(ConventPage.getPage(dto),TextbookConsumptionPageVo.class,textbookMPJLambdaWrapper);
  93. for(TextbookConsumptionPageVo t : page.getRecords()){
  94. if(t.getTextbookType() != null && !t.getTextbookType().equals("")){
  95. t.setTextbookTypeCn(TextbookTypeEnum.getValue(t.getTextbookType()));
  96. }
  97. }
  98. PageOutput<TextbookConsumptionPageVo> pageOutput = ConventPage.getPageOutput(page, TextbookConsumptionPageVo.class);
  99. return RT.ok(pageOutput);
  100. }
  101. @GetMapping(value = "/List-subscription")
  102. @ApiOperation(value="教材管理列表(不分页,教材征订用)")
  103. @SaCheckPermission("textbook:detail")
  104. public RT<List<TextbookSubscriptionListVo>> listSubscription(@Valid TextbookSubscriptionListDto dto){
  105. List<String> classIdList = new ArrayList<>();
  106. if(dto.getClassIds() != null && !dto.getClassIds().equals("")){
  107. String[] classIdArr = dto.getClassIds().split(",");
  108. classIdList = Arrays.asList(classIdArr);
  109. }
  110. MPJLambdaWrapper<Textbook> textbookMPJLambdaWrapper = new MPJLambdaWrapper<>();
  111. textbookMPJLambdaWrapper
  112. .select(Textbook::getId)
  113. .selectAs(Textbook::getId,TextbookSubscriptionListVo::getTextbookId)
  114. .selectAs(BaseCourseSubject::getName, TextbookSubscriptionListVo::getCourseName)
  115. .selectSum(BaseClassMajorSet::getTotalStudent, TextbookSubscriptionListVo::getStudentSubscriptionNumber)
  116. .select(Textbook.class, x -> VoToColumnUtil.fieldsToColumns(TextbookSubscriptionListVo.class).contains(x.getProperty()))
  117. .leftJoin(TextbookClassRelation.class, TextbookClassRelation::getTextbookId, Textbook::getId)
  118. .leftJoin(BaseClassMajorSet.class, BaseClassMajorSet::getClassId, TextbookClassRelation::getClassId)
  119. .leftJoin(BaseCourseSubject.class, BaseCourseSubject::getId, Textbook::getCourseSubjectId)
  120. .in(!classIdList.isEmpty(),TextbookClassRelation::getClassId, classIdList)
  121. .groupBy(Textbook::getId)
  122. ;
  123. List<TextbookSubscriptionListVo> list = textbookService.selectJoinList(TextbookSubscriptionListVo.class,textbookMPJLambdaWrapper);
  124. return RT.ok(list);
  125. }
  126. @GetMapping(value = "/info-detail")
  127. @ApiOperation(value="根据id查询教材管理信息")
  128. @SaCheckPermission("textbook:detail")
  129. public RT info(@RequestParam Long id){
  130. Textbook textbook = textbookService.getById(id);
  131. if (textbook == null) {
  132. return RT.ok();
  133. }
  134. textbook.setTextbookClassRelationList(textbookService.getClassRelation(textbook.getId()));
  135. return RT.ok(BeanUtil.toBean(textbook, TextbookVo.class));
  136. }
  137. @GetMapping(value = "/info-byissn")
  138. @ApiOperation(value="根据isnn查询教材管理信息")
  139. @SaCheckPermission("textbook:detail")
  140. public RT<TextbookVo> infoByissn(@RequestParam String issn){
  141. TextbookVo textbook = textbookService.getInfoByissn(issn);
  142. if (textbook == null) {
  143. return RT.ok();
  144. }
  145. return RT.ok(textbook);
  146. }
  147. @GetMapping(value = "/info-subscription-list")
  148. @ApiOperation(value="教材管理-详情-征订记录")
  149. @SaCheckPermission("textbook:detail")
  150. public RT<List<TextbookSubscriptionRecordVo>> subscriptionList(@RequestParam Long id){
  151. List<TextbookSubscriptionRecordVo> result = textbookService.subscriptionList(id);
  152. if (result == null) {
  153. return RT.ok(new ArrayList<>());
  154. }
  155. return RT.ok(result);
  156. }
  157. @GetMapping(value = "/info-warehouse-list")
  158. @ApiOperation(value="教材管理-详情-入库记录")
  159. @SaCheckPermission("textbook:detail")
  160. public RT<List<TextbookWarehouseRecordListVo>> warehouseList(@RequestParam Long id){
  161. List<TextbookWarehouseRecordListVo> result = textbookService.warehouseList(id);
  162. if (result == null) {
  163. return RT.ok(new ArrayList<>());
  164. }
  165. return RT.ok(result);
  166. }
  167. @GetMapping(value = "/info-issue-list")
  168. @ApiOperation(value="教材管理-详情-出库记录")
  169. @SaCheckPermission("textbook:detail")
  170. public RT<List<TextbookIssueRecordListVo>> issueList(@RequestParam Long id){
  171. List<TextbookIssueRecordListVo> result = textbookService.issueList(id);
  172. if (result == null) {
  173. return RT.ok(new ArrayList<>());
  174. }
  175. return RT.ok(result);
  176. }
  177. @GetMapping(value = "/info-claim-list")
  178. @ApiOperation(value="教材管理-详情-领取记录")
  179. @SaCheckPermission("textbook:detail")
  180. public RT<List<WfTextbookClaimListVo>> claimList(@RequestParam Long id){
  181. List<WfTextbookClaimListVo> result = textbookService.claimList(id);
  182. if (result == null) {
  183. return RT.ok(new ArrayList<>());
  184. }
  185. return RT.ok(result);
  186. }
  187. @PostMapping
  188. @ApiOperation(value = "新增教材管理")
  189. @SaCheckPermission("textbook:add")
  190. public RT<Boolean> add(@Valid @RequestBody AddTextbookDto dto) throws ParseException {
  191. String publishingDateStr = dto.getPublishingDate();
  192. Textbook textbook = BeanUtil.toBean(dto, Textbook.class);
  193. if(publishingDateStr != null && !"".equals(publishingDateStr)){
  194. SimpleDateFormat sdf = new SimpleDateFormat("yyyy-MM-dd");
  195. textbook.setPublishingDate(sdf.parse(publishingDateStr));
  196. }
  197. boolean isSuccess = textbookService.add(textbook);
  198. return RT.ok(isSuccess);
  199. }
  200. @PutMapping
  201. @ApiOperation(value = "修改教材管理")
  202. @SaCheckPermission("textbook:edit")
  203. public RT<Boolean> update(@Valid @RequestBody UpdateTextbookDto dto) throws ParseException {
  204. String publishingDateStr = dto.getPublishingDate();
  205. Textbook textbook = BeanUtil.toBean(dto, Textbook.class);
  206. if(publishingDateStr != null && !"".equals(publishingDateStr)){
  207. SimpleDateFormat sdf = new SimpleDateFormat("yyyy-MM-dd");
  208. textbook.setPublishingDate(sdf.parse(publishingDateStr));
  209. }
  210. return RT.ok(textbookService.update(textbook));
  211. }
  212. @DeleteMapping
  213. @ApiOperation(value = "删除教材管理")
  214. @SaCheckPermission("textbook:delete")
  215. public RT<Boolean> delete(@Valid @RequestBody List<Long> ids){
  216. return RT.ok(textbookService.delete(ids));
  217. }
  218. @GetMapping("/export")
  219. @ApiOperation(value = "导出")
  220. public ResponseEntity<byte[]> exportData(@Valid TextbookPageDto dto, @RequestParam(defaultValue = "false") Boolean isTemplate) {
  221. List<TextbookPageVo> customerList = isTemplate != null && isTemplate ? new ArrayList<>() : ((PageOutput<TextbookPageVo>) page(dto).getData()).getList();
  222. ByteArrayOutputStream bot = new ByteArrayOutputStream();
  223. EasyExcel.write(bot, TextbookPageVo.class).automaticMergeHead(false).excelType(ExcelTypeEnum.XLSX).sheet().doWrite(customerList);
  224. return RT.fileStream(bot.toByteArray(), "Textbook" + ExcelTypeEnum.XLSX.getValue());
  225. }
  226. @PostMapping("deliver-warehouse")
  227. @ApiOperation(value = "教材管理入库")
  228. @SaCheckPermission("textbook:add")
  229. public RT<Boolean> deliverWarehouse(@Valid @RequestBody AddTextbookWarehouseRecordDto dto){
  230. Boolean isSuccess = textbookService.deliverWarehouse(dto);
  231. return RT.ok(isSuccess);
  232. }
  233. @PostMapping("/textbook-standing-export-query")
  234. @ApiOperation(value = "台账条件导出")
  235. public ResponseEntity<byte[]> textbookStandingExportQuery(@Valid @RequestBody TextbookStandingExportQuerytDto dto) {
  236. // @GetMapping("/textbook-standing-export-query")
  237. // @ApiOperation(value = "台账条件导出")
  238. // public ResponseEntity<byte[]> textbookStandingExportQuery(@Valid TextbookStandingExportQuerytDto dto) {
  239. List<TextbookStandingExportQueryVo> customerList = textbookService.listTextbookStandingExportQuery(dto);
  240. ByteArrayOutputStream bot = new ByteArrayOutputStream();
  241. EasyExcel.write(bot, TextbookStandingExportQueryVo.class).automaticMergeHead(false).excelType(ExcelTypeEnum.XLSX).sheet().doWrite(customerList);
  242. return RT.fileStream(bot.toByteArray(), "TextbookStanding" + ExcelTypeEnum.XLSX.getValue());
  243. }
  244. @PostMapping("/textbook-subscription-export-query")
  245. @ApiOperation(value = "教材征订记录条件导出")
  246. public ResponseEntity<byte[]> textbookSubscriptionExportQuery(@Valid @RequestBody TextbookSubscriptionExportQueryDto dto) {
  247. // @GetMapping("/textbook-subscription-export-query")
  248. // @ApiOperation(value = "教材征订记录条件导出")
  249. // public ResponseEntity<byte[]> textbookSubscriptionExportQuery(@Valid TextbookSubscriptionExportQueryDto dto) {
  250. ByteArrayOutputStream bot = textbookService.listTextbookSubscriptionExportQuery(dto);
  251. return RT.fileStream(bot.toByteArray(), "TextbookSubscription" + ExcelTypeEnum.XLSX.getValue());
  252. }
  253. @PostMapping("/textbook-claim-export-query")
  254. @ApiOperation(value = "教材发放记录条件导出")
  255. public ResponseEntity<byte[]> textbookClaimExportQuery(@Valid @RequestBody TextbookClaimExportQueryDto dto) {
  256. // @GetMapping("/textbook-claim-export-query")
  257. // @ApiOperation(value = "教材发放记录条件导出")
  258. // public ResponseEntity<byte[]> textbookClaimExportQuery(@Valid TextbookClaimExportQueryDto dto) {
  259. ByteArrayOutputStream bot = textbookService.listTextbookClaimExportQuery(dto);
  260. return RT.fileStream(bot.toByteArray(), "TextbookClaim" + ExcelTypeEnum.XLSX.getValue());
  261. }
  262. @PostMapping("/excel-import")
  263. @ApiOperation(value = "excel教材导入")
  264. @SaCheckPermission("coursetable:excelimport")
  265. public R excelImport( @RequestParam("file") MultipartFile file) throws IOException {
  266. InputStream inputStream = file.getInputStream();
  267. return R.ok(textbookService.excelImport(inputStream));
  268. }
  269. }