TextbookController.java 20 KB

123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263646566676869707172737475767778798081828384858687888990919293949596979899100101102103104105106107108109110111112113114115116117118119120121122123124125126127128129130131132133134135136137138139140141142143144145146147148149150151152153154155156157158159160161162163164165166167168169170171172173174175176177178179180181182183184185186187188189190191192193194195196197198199200201202203204205206207208209210211212213214215216217218219220221222223224225226227228229230231232233234235236237238239240241242243244245246247248249250251252253254255256257258259260261262263264265266267268269270271272273274275276277278279280281282283284285286287288289290291292293294295296297298299300301302303304305306307308309310311312313314315316317318319320321322323324325326327328329330331332333334335336337338339340341342343344345346347348349350351352353354355356357358359360361362363364365366367368369370371372373374375376377378379380381382383384385386387388389390391392393394395396397398399400401402403404405406407408409410411412413414415416417418419
  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.TextbookTypeEnum;
  11. import com.xjrsoft.common.model.result.R;
  12. import com.xjrsoft.common.model.result.RT;
  13. import com.xjrsoft.common.page.ConventPage;
  14. import com.xjrsoft.common.page.PageOutput;
  15. import com.xjrsoft.common.utils.VoToColumnUtil;
  16. import com.xjrsoft.module.base.entity.BaseClassCourse;
  17. import com.xjrsoft.module.base.entity.BaseCourseSubject;
  18. import com.xjrsoft.module.base.entity.BaseSemester;
  19. import com.xjrsoft.module.base.service.IBaseSemesterService;
  20. import com.xjrsoft.module.student.entity.BaseClassMajorSet;
  21. import com.xjrsoft.module.textbook.dto.AddTextbookDto;
  22. import com.xjrsoft.module.textbook.dto.AddTextbookWarehouseRecordDto;
  23. import com.xjrsoft.module.textbook.dto.TextbookClaimExportQueryDto;
  24. import com.xjrsoft.module.textbook.dto.TextbookConsumptionPageDto;
  25. import com.xjrsoft.module.textbook.dto.TextbookPageDto;
  26. import com.xjrsoft.module.textbook.dto.TextbookStandingExportQuerytDto;
  27. import com.xjrsoft.module.textbook.dto.TextbookSubscriptionExportQueryDto;
  28. import com.xjrsoft.module.textbook.dto.TextbookSubscriptionListDto;
  29. import com.xjrsoft.module.textbook.dto.UpdateTextbookDto;
  30. import com.xjrsoft.module.textbook.entity.Textbook;
  31. import com.xjrsoft.module.textbook.entity.TextbookClassRelation;
  32. import com.xjrsoft.module.textbook.entity.TextbookStudentClaim;
  33. import com.xjrsoft.module.textbook.service.ITextbookService;
  34. import com.xjrsoft.module.textbook.service.ITextbookStudentClaimService;
  35. import com.xjrsoft.module.textbook.vo.TextbookConsumptionPageVo;
  36. import com.xjrsoft.module.textbook.vo.TextbookIssueRecordListVo;
  37. import com.xjrsoft.module.textbook.vo.TextbookPageVo;
  38. import com.xjrsoft.module.textbook.vo.TextbookStandingExportQueryVo;
  39. import com.xjrsoft.module.textbook.vo.TextbookSubscriptionExportQueryVo;
  40. import com.xjrsoft.module.textbook.vo.TextbookSubscriptionListVo;
  41. import com.xjrsoft.module.textbook.vo.TextbookSubscriptionRecordVo;
  42. import com.xjrsoft.module.textbook.vo.TextbookVo;
  43. import com.xjrsoft.module.textbook.vo.TextbookWarehouseRecordListVo;
  44. import com.xjrsoft.module.textbook.vo.WfTextbookClaimListVo;
  45. import io.swagger.annotations.Api;
  46. import io.swagger.annotations.ApiOperation;
  47. import lombok.AllArgsConstructor;
  48. import org.springframework.http.ResponseEntity;
  49. import org.springframework.web.bind.annotation.DeleteMapping;
  50. import org.springframework.web.bind.annotation.GetMapping;
  51. import org.springframework.web.bind.annotation.PostMapping;
  52. import org.springframework.web.bind.annotation.PutMapping;
  53. import org.springframework.web.bind.annotation.RequestBody;
  54. import org.springframework.web.bind.annotation.RequestMapping;
  55. import org.springframework.web.bind.annotation.RequestParam;
  56. import org.springframework.web.bind.annotation.RestController;
  57. import org.springframework.web.multipart.MultipartFile;
  58. import javax.validation.Valid;
  59. import java.io.ByteArrayOutputStream;
  60. import java.io.IOException;
  61. import java.io.InputStream;
  62. import java.util.ArrayList;
  63. import java.util.Arrays;
  64. import java.util.List;
  65. /**
  66. * @title: 教材管理
  67. * @Author dzx
  68. * @Date: 2023-12-25
  69. * @Version 1.0
  70. */
  71. @RestController
  72. @RequestMapping("/textbook" + "/textbook")
  73. @Api(value = "/textbook" + "/textbook",tags = "教材管理代码")
  74. @AllArgsConstructor
  75. public class TextbookController {
  76. private final ITextbookService textbookService;
  77. private final IBaseSemesterService baseSemesterService;
  78. private final ITextbookStudentClaimService textbookStudentClaimService;
  79. @GetMapping(value = "/page")
  80. @ApiOperation(value="教材管理列表(分页)")
  81. @SaCheckPermission("textbook:detail")
  82. public RT<PageOutput<TextbookPageVo>> page(@Valid TextbookPageDto dto){
  83. Page<TextbookPageVo> page = textbookService.getPage(new Page<>(dto.getLimit(), dto.getSize()), dto);
  84. PageOutput<TextbookPageVo> pageOutput = ConventPage.getPageOutput(page, TextbookPageVo.class);
  85. return RT.ok(pageOutput);
  86. }
  87. @GetMapping(value = "/page-subscription")
  88. @ApiOperation(value="教材管理列表(分页,教材征订用)")
  89. @SaCheckPermission("textbook:detail")
  90. public RT<PageOutput<TextbookSubscriptionListVo>> pageSubscription(@Valid TextbookSubscriptionListDto dto){
  91. List<String> classIdList = new ArrayList<>();
  92. if(dto.getClassIds() != null && !dto.getClassIds().equals("")){
  93. String[] classIdArr = dto.getClassIds().split(",");
  94. classIdList = Arrays.asList(classIdArr);
  95. }
  96. MPJLambdaWrapper<Textbook> textbookMPJLambdaWrapper = new MPJLambdaWrapper<>();
  97. textbookMPJLambdaWrapper
  98. .select(Textbook::getId)
  99. .selectAs(Textbook::getId,TextbookSubscriptionListVo::getTextbookId)
  100. .selectAs(BaseCourseSubject::getName, TextbookSubscriptionListVo::getCourseName)
  101. .selectSum(BaseClassMajorSet::getTotalStudent, TextbookSubscriptionListVo::getStudentSubscriptionNumber)
  102. .select(Textbook.class, x -> VoToColumnUtil.fieldsToColumns(TextbookSubscriptionListVo.class).contains(x.getProperty()))
  103. .leftJoin(BaseClassCourse.class, BaseClassCourse::getCourseId, Textbook::getCourseSubjectId)
  104. .leftJoin(BaseClassMajorSet.class, BaseClassMajorSet::getClassId, BaseClassCourse::getClassId)
  105. .leftJoin(BaseCourseSubject.class, BaseCourseSubject::getId, Textbook::getCourseSubjectId)
  106. .eq(dto.getBaseSemesterId() != null && dto.getBaseSemesterId() > 0, BaseClassCourse::getBaseSemesterId, dto.getBaseSemesterId())
  107. .in(!classIdList.isEmpty(),BaseClassCourse::getClassId, classIdList)
  108. .groupBy(Textbook::getId)
  109. ;
  110. IPage<TextbookSubscriptionListVo> page = textbookService.selectJoinListPage(ConventPage.getPage(dto),TextbookSubscriptionListVo.class,textbookMPJLambdaWrapper);
  111. for(TextbookSubscriptionListVo t : page.getRecords()){
  112. t.setClassIds(dto.getClassIds());
  113. if(t.getTextbookType() != null && !t.getTextbookType().equals("")){
  114. t.setTextbookTypeCn(TextbookTypeEnum.getValue(t.getTextbookType()));
  115. }
  116. }
  117. PageOutput<TextbookSubscriptionListVo> pageOutput = ConventPage.getPageOutput(page, TextbookSubscriptionListVo.class);
  118. return RT.ok(pageOutput);
  119. }
  120. @GetMapping(value = "/page-consumption")
  121. @ApiOperation(value="学生确认领取教材列表(分页,学生收费用)")
  122. @SaCheckPermission("textbook:detail")
  123. public RT<PageOutput<TextbookConsumptionPageVo>> pageConsumption(@Valid TextbookConsumptionPageDto dto){
  124. MPJLambdaWrapper<TextbookStudentClaim> textbookMPJLambdaWrapper = new MPJLambdaWrapper<>();
  125. textbookMPJLambdaWrapper
  126. .select(TextbookStudentClaim::getId)
  127. .selectAs(Textbook::getId,TextbookConsumptionPageVo::getTextbookId)
  128. .selectAs(BaseCourseSubject::getName, TextbookConsumptionPageVo::getCourseSubjectIdCn)
  129. .select(Textbook.class, x -> VoToColumnUtil.fieldsToColumns(TextbookConsumptionPageVo.class).contains(x.getProperty()))
  130. .leftJoin(Textbook.class, Textbook::getId, TextbookStudentClaim::getTextbookId)
  131. .leftJoin(BaseCourseSubject.class, BaseCourseSubject::getId, Textbook::getCourseSubjectId)
  132. .eq(dto.getBaseSemesterId() != null && dto.getBaseSemesterId() > 0, TextbookStudentClaim::getBaseSemesterId, dto.getBaseSemesterId())
  133. .eq(dto.getStudentUserId() != null && dto.getStudentUserId() > 0,TextbookStudentClaim::getStudentUserId, dto.getStudentUserId())
  134. ;
  135. IPage<TextbookConsumptionPageVo> page = textbookStudentClaimService.selectJoinListPage(ConventPage.getPage(dto),TextbookConsumptionPageVo.class,textbookMPJLambdaWrapper);
  136. for(TextbookConsumptionPageVo t : page.getRecords()){
  137. if(t.getTextbookType() != null && !t.getTextbookType().equals("")){
  138. t.setTextbookTypeCn(TextbookTypeEnum.getValue(t.getTextbookType()));
  139. }
  140. }
  141. PageOutput<TextbookConsumptionPageVo> pageOutput = ConventPage.getPageOutput(page, TextbookConsumptionPageVo.class);
  142. return RT.ok(pageOutput);
  143. }
  144. @GetMapping(value = "/List-subscription")
  145. @ApiOperation(value="教材管理列表(不分页,教材征订用)")
  146. @SaCheckPermission("textbook:detail")
  147. public RT<List<TextbookSubscriptionListVo>> ListSubscription(@Valid TextbookSubscriptionListDto dto){
  148. List<String> classIdList = new ArrayList<>();
  149. if(dto.getClassIds() != null && !dto.getClassIds().equals("")){
  150. String[] classIdArr = dto.getClassIds().split(",");
  151. classIdList = Arrays.asList(classIdArr);
  152. }
  153. MPJLambdaWrapper<Textbook> textbookMPJLambdaWrapper = new MPJLambdaWrapper<>();
  154. textbookMPJLambdaWrapper
  155. .select(Textbook::getId)
  156. .selectAs(Textbook::getId,TextbookSubscriptionListVo::getTextbookId)
  157. .selectAs(BaseCourseSubject::getName, TextbookSubscriptionListVo::getCourseName)
  158. .selectSum(BaseClassMajorSet::getTotalStudent, TextbookSubscriptionListVo::getStudentSubscriptionNumber)
  159. .select(Textbook.class, x -> VoToColumnUtil.fieldsToColumns(TextbookSubscriptionListVo.class).contains(x.getProperty()))
  160. .leftJoin(TextbookClassRelation.class, TextbookClassRelation::getTextbookId, Textbook::getId)
  161. .leftJoin(BaseClassMajorSet.class, BaseClassMajorSet::getClassId, TextbookClassRelation::getClassId)
  162. .leftJoin(BaseCourseSubject.class, BaseCourseSubject::getId, Textbook::getCourseSubjectId)
  163. .in(!classIdList.isEmpty(),TextbookClassRelation::getClassId, classIdList)
  164. .groupBy(Textbook::getId)
  165. ;
  166. List<TextbookSubscriptionListVo> list = textbookService.selectJoinList(TextbookSubscriptionListVo.class,textbookMPJLambdaWrapper);
  167. return RT.ok(list);
  168. }
  169. @GetMapping(value = "/info-detail")
  170. @ApiOperation(value="根据id查询教材管理信息")
  171. @SaCheckPermission("textbook:detail")
  172. public RT info(@RequestParam Long id){
  173. Textbook textbook = textbookService.getById(id);
  174. if (textbook == null) {
  175. return RT.ok();
  176. }
  177. textbook.setTextbookClassRelationList(textbookService.getClassRelation(textbook.getId()));
  178. return RT.ok(BeanUtil.toBean(textbook, TextbookVo.class));
  179. }
  180. @GetMapping(value = "/info-byissn")
  181. @ApiOperation(value="根据isnn查询教材管理信息")
  182. @SaCheckPermission("textbook:detail")
  183. public RT<TextbookVo> infoByissn(@RequestParam String issn){
  184. TextbookVo textbook = textbookService.getInfoByissn(issn);
  185. if (textbook == null) {
  186. return RT.ok();
  187. }
  188. return RT.ok(textbook);
  189. }
  190. @GetMapping(value = "/info-subscription-list")
  191. @ApiOperation(value="教材管理-详情-征订记录")
  192. @SaCheckPermission("textbook:detail")
  193. public RT<List<TextbookSubscriptionRecordVo>> subscriptionList(@RequestParam Long id){
  194. List<TextbookSubscriptionRecordVo> result = textbookService.subscriptionList(id);
  195. if (result == null) {
  196. return RT.ok(new ArrayList<>());
  197. }
  198. return RT.ok(result);
  199. }
  200. @GetMapping(value = "/info-warehouse-list")
  201. @ApiOperation(value="教材管理-详情-入库记录")
  202. @SaCheckPermission("textbook:detail")
  203. public RT<List<TextbookWarehouseRecordListVo>> warehouseList(@RequestParam Long id){
  204. List<TextbookWarehouseRecordListVo> result = textbookService.warehouseList(id);
  205. if (result == null) {
  206. return RT.ok(new ArrayList<>());
  207. }
  208. return RT.ok(result);
  209. }
  210. @GetMapping(value = "/info-issue-list")
  211. @ApiOperation(value="教材管理-详情-出库记录")
  212. @SaCheckPermission("textbook:detail")
  213. public RT<List<TextbookIssueRecordListVo>> issueList(@RequestParam Long id){
  214. List<TextbookIssueRecordListVo> result = textbookService.issueList(id);
  215. if (result == null) {
  216. return RT.ok(new ArrayList<>());
  217. }
  218. return RT.ok(result);
  219. }
  220. @GetMapping(value = "/info-claim-list")
  221. @ApiOperation(value="教材管理-详情-领取记录")
  222. @SaCheckPermission("textbook:detail")
  223. public RT<List<WfTextbookClaimListVo>> claimList(@RequestParam Long id){
  224. List<WfTextbookClaimListVo> result = textbookService.claimList(id);
  225. if (result == null) {
  226. return RT.ok(new ArrayList<>());
  227. }
  228. return RT.ok(result);
  229. }
  230. @PostMapping
  231. @ApiOperation(value = "新增教材管理")
  232. @SaCheckPermission("textbook:add")
  233. public RT<Boolean> add(@Valid @RequestBody AddTextbookDto dto){
  234. Textbook textbook = BeanUtil.toBean(dto, Textbook.class);
  235. boolean isSuccess = textbookService.add(textbook);
  236. return RT.ok(isSuccess);
  237. }
  238. @PutMapping
  239. @ApiOperation(value = "修改教材管理")
  240. @SaCheckPermission("textbook:edit")
  241. public RT<Boolean> update(@Valid @RequestBody UpdateTextbookDto dto){
  242. Textbook textbook = BeanUtil.toBean(dto, Textbook.class);
  243. return RT.ok(textbookService.update(textbook));
  244. }
  245. @DeleteMapping
  246. @ApiOperation(value = "删除教材管理")
  247. @SaCheckPermission("textbook:delete")
  248. public RT<Boolean> delete(@Valid @RequestBody List<Long> ids){
  249. return RT.ok(textbookService.delete(ids));
  250. }
  251. @GetMapping("/export")
  252. @ApiOperation(value = "导出")
  253. public ResponseEntity<byte[]> exportData(@Valid TextbookPageDto dto, @RequestParam(defaultValue = "false") Boolean isTemplate) {
  254. List<TextbookPageVo> customerList = isTemplate != null && isTemplate ? new ArrayList<>() : ((PageOutput<TextbookPageVo>) page(dto).getData()).getList();
  255. ByteArrayOutputStream bot = new ByteArrayOutputStream();
  256. EasyExcel.write(bot, TextbookPageVo.class).automaticMergeHead(false).excelType(ExcelTypeEnum.XLSX).sheet().doWrite(customerList);
  257. return RT.fileStream(bot.toByteArray(), "Textbook" + ExcelTypeEnum.XLSX.getValue());
  258. }
  259. @PostMapping("deliver-warehouse")
  260. @ApiOperation(value = "教材管理入库")
  261. @SaCheckPermission("textbook:add")
  262. public RT<Boolean> deliverWarehouse(@Valid @RequestBody AddTextbookWarehouseRecordDto dto){
  263. Boolean isSuccess = textbookService.deliverWarehouse(dto);
  264. return RT.ok(isSuccess);
  265. }
  266. @PostMapping("/textbook-standing-export-query")
  267. @ApiOperation(value = "台账条件导出")
  268. public ResponseEntity<byte[]> textbookStandingExportQuery(@Valid @RequestBody TextbookStandingExportQuerytDto dto) {
  269. // @GetMapping("/textbook-standing-export-query")
  270. // @ApiOperation(value = "台账条件导出")
  271. // public ResponseEntity<byte[]> textbookStandingExportQuery(@Valid TextbookStandingExportQuerytDto dto) {
  272. List<TextbookStandingExportQueryVo> customerList = textbookService.listTextbookStandingExportQuery(dto);
  273. ByteArrayOutputStream bot = new ByteArrayOutputStream();
  274. EasyExcel.write(bot, TextbookStandingExportQueryVo.class).automaticMergeHead(false).excelType(ExcelTypeEnum.XLSX).sheet().doWrite(customerList);
  275. return RT.fileStream(bot.toByteArray(), "TextbookStanding" + ExcelTypeEnum.XLSX.getValue());
  276. }
  277. @PostMapping("/textbook-subscription-export-query")
  278. @ApiOperation(value = "教材征订记录条件导出")
  279. public ResponseEntity<byte[]> textbookSubscriptionExportQuery(@Valid @RequestBody TextbookSubscriptionExportQueryDto dto) {
  280. // @GetMapping("/textbook-subscription-export-query")
  281. // @ApiOperation(value = "教材征订记录条件导出")
  282. // public ResponseEntity<byte[]> textbookSubscriptionExportQuery(@Valid TextbookSubscriptionExportQueryDto dto) {
  283. List<TextbookSubscriptionExportQueryVo> customerList = textbookService.listTextbookSubscriptionExportQuery(dto);
  284. ByteArrayOutputStream bot = new ByteArrayOutputStream();
  285. // 设置动态头
  286. String baseSemesterCn = "";
  287. if(dto.getBaseSemesterId() != null){
  288. LambdaQueryWrapper<BaseSemester> baseSemesterLambdaQueryWrapper = new LambdaQueryWrapper<>();
  289. baseSemesterLambdaQueryWrapper
  290. .eq(BaseSemester::getId, dto.getBaseSemesterId());
  291. BaseSemester baseSemester = baseSemesterService.getOne(baseSemesterLambdaQueryWrapper);
  292. if(baseSemester != null){
  293. baseSemesterCn = baseSemester.getName();
  294. }
  295. }
  296. String headTitle = "重庆市铜梁职业教育中心" + baseSemesterCn + "教材征订表";
  297. List<List<String>> headList = new ArrayList<>();
  298. // List<String> head0 = new ArrayList<>();
  299. // head0.add("个人信息");
  300. // head0.add("用户名");
  301. // List<String> head1 = new ArrayList<>();
  302. // head1.add("个人信息");
  303. // head1.add("年龄");
  304. // List<String> head2 = new ArrayList<>();
  305. // head2.add("个人信息");
  306. // head2.add("地址");
  307. headList.add(new ArrayList<String>(){{
  308. add(headTitle);
  309. add("国际标准刊号");
  310. }});
  311. headList.add(new ArrayList<String>(){{
  312. add(headTitle);
  313. add("书名");
  314. }});
  315. headList.add(new ArrayList<String>(){{
  316. add(headTitle);
  317. add("出版社");
  318. }});
  319. headList.add(new ArrayList<String>(){{
  320. add(headTitle);
  321. add("主编");
  322. }});
  323. headList.add(new ArrayList<String>(){{
  324. add(headTitle);
  325. add("估价(元)");
  326. }});
  327. headList.add(new ArrayList<String>(){{
  328. add(headTitle);
  329. add("是否为规划教材");
  330. }});
  331. headList.add(new ArrayList<String>(){{
  332. add(headTitle);
  333. add("对应课程");
  334. }});
  335. headList.add(new ArrayList<String>(){{
  336. add(headTitle);
  337. add("使用年级");
  338. }});
  339. headList.add(new ArrayList<String>(){{
  340. add(headTitle);
  341. add("使用班级");
  342. }});
  343. headList.add(new ArrayList<String>(){{
  344. add(headTitle);
  345. add("学生用书征订数量");
  346. }});
  347. headList.add(new ArrayList<String>(){{
  348. add(headTitle);
  349. add("教师教材用书征订数量");
  350. }});
  351. headList.add(new ArrayList<String>(){{
  352. add(headTitle);
  353. add("教师教参用书征订数量");
  354. }});
  355. headList.add(new ArrayList<String>(){{
  356. add(headTitle);
  357. add("学科组名称");
  358. }});
  359. headList.add(new ArrayList<String>(){{
  360. add(headTitle);
  361. add("有无配套教学资源");
  362. }});
  363. headList.add(new ArrayList<String>(){{
  364. add(headTitle);
  365. add("备注");
  366. }});
  367. EasyExcel.write(bot, TextbookSubscriptionExportQueryVo.class).automaticMergeHead(true).excelType(ExcelTypeEnum.XLSX).head(headList).sheet().doWrite(customerList);
  368. return RT.fileStream(bot.toByteArray(), "TextbookSubscription" + ExcelTypeEnum.XLSX.getValue());
  369. }
  370. // @PostMapping("/textbook-claim-export-query")
  371. // @ApiOperation(value = "教材发放记录条件导出")
  372. // public ResponseEntity<byte[]> textbookClaimExportQuery(@Valid @RequestBody TextbookClaimExportQueryDto dto) {
  373. @GetMapping("/textbook-claim-export-query")
  374. @ApiOperation(value = "教材发放记录条件导出")
  375. public ResponseEntity<byte[]> textbookClaimExportQuery(@Valid TextbookClaimExportQueryDto dto) {
  376. ByteArrayOutputStream bot = textbookService.listTextbookClaimExportQuery(dto);
  377. return RT.fileStream(bot.toByteArray(), "TextbookClaim" + ExcelTypeEnum.XLSX.getValue());
  378. }
  379. @PostMapping("/excel-import")
  380. @ApiOperation(value = "excel教材导入")
  381. @SaCheckPermission("coursetable:excelimport")
  382. public R excelImport( @RequestParam("file") MultipartFile file) throws IOException {
  383. InputStream inputStream = file.getInputStream();
  384. return R.ok(textbookService.excelImport(inputStream));
  385. }
  386. }