TextbookController.java 12 KB

123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263646566676869707172737475767778798081828384858687888990919293949596979899100101102103104105106107108109110111112113114115116117118119120121122123124125126127128129130131132133134135136137138139140141142143144145146147148149150151152153154155156157158159160161162163164165166167168169170171172173174175176177178179180181182183184185186187188189190191192193194195196197198199200201202203204205206207208209210211212213214215216217218219220221222223224225226227228229230231232233234235236237238239240241242243244245246247248249250251252253254255256257258259260261262263264265266267268269270271272273274275276277278279280281282283284285286287288289290291292293294295
  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.extension.plugins.pagination.Page;
  8. import com.xjrsoft.common.model.result.R;
  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.module.base.entity.BaseSemester;
  13. import com.xjrsoft.module.base.service.IBaseSemesterService;
  14. import com.xjrsoft.module.textbook.dto.*;
  15. import com.xjrsoft.module.textbook.entity.Textbook;
  16. import com.xjrsoft.module.textbook.service.ITextbookService;
  17. import com.xjrsoft.module.textbook.vo.*;
  18. import io.swagger.annotations.Api;
  19. import io.swagger.annotations.ApiOperation;
  20. import lombok.AllArgsConstructor;
  21. import org.springframework.http.ResponseEntity;
  22. import org.springframework.web.bind.annotation.*;
  23. import org.springframework.web.multipart.MultipartFile;
  24. import javax.validation.Valid;
  25. import java.io.ByteArrayOutputStream;
  26. import java.io.IOException;
  27. import java.io.InputStream;
  28. import java.util.ArrayList;
  29. import java.util.List;
  30. /**
  31. * @title: 教材管理
  32. * @Author dzx
  33. * @Date: 2023-12-25
  34. * @Version 1.0
  35. */
  36. @RestController
  37. @RequestMapping("/textbook" + "/textbook")
  38. @Api(value = "/textbook" + "/textbook",tags = "教材管理代码")
  39. @AllArgsConstructor
  40. public class TextbookController {
  41. private final ITextbookService textbookService;
  42. private final IBaseSemesterService baseSemesterService;
  43. @GetMapping(value = "/page")
  44. @ApiOperation(value="教材管理列表(分页)")
  45. @SaCheckPermission("textbook:detail")
  46. public RT<PageOutput<TextbookPageVo>> page(@Valid TextbookPageDto dto){
  47. Page<TextbookPageVo> page = textbookService.getPage(new Page<>(dto.getLimit(), dto.getSize()), dto);
  48. PageOutput<TextbookPageVo> pageOutput = ConventPage.getPageOutput(page, TextbookPageVo.class);
  49. return RT.ok(pageOutput);
  50. }
  51. @GetMapping(value = "/info-detail")
  52. @ApiOperation(value="根据id查询教材管理信息")
  53. @SaCheckPermission("textbook:detail")
  54. public RT<TextbookVo> info(@RequestParam Long id){
  55. Textbook textbook = textbookService.getById(id);
  56. if (textbook == null) {
  57. return RT.ok();
  58. }
  59. textbook.setTextbookClassRelationList(textbookService.getClassRelation(textbook.getId()));
  60. return RT.ok(BeanUtil.toBean(textbook, TextbookVo.class));
  61. }
  62. @GetMapping(value = "/info-byissn")
  63. @ApiOperation(value="根据isnn查询教材管理信息")
  64. @SaCheckPermission("textbook:detail")
  65. public RT<TextbookVo> infoByissn(@RequestParam String issn){
  66. TextbookVo textbook = textbookService.getInfoByissn(issn);
  67. if (textbook == null) {
  68. return RT.ok();
  69. }
  70. return RT.ok(textbook);
  71. }
  72. @GetMapping(value = "/info-subscription-list")
  73. @ApiOperation(value="教材管理-详情-征订记录")
  74. @SaCheckPermission("textbook:detail")
  75. public RT<List<TextbookSubscriptionRecordVo>> subscriptionList(@RequestParam Long id){
  76. List<TextbookSubscriptionRecordVo> result = textbookService.subscriptionList(id);
  77. if (result == null) {
  78. return RT.ok(new ArrayList<>());
  79. }
  80. return RT.ok(result);
  81. }
  82. @GetMapping(value = "/info-warehouse-list")
  83. @ApiOperation(value="教材管理-详情-入库记录")
  84. @SaCheckPermission("textbook:detail")
  85. public RT<List<TextbookWarehouseRecordListVo>> warehouseList(@RequestParam Long id){
  86. List<TextbookWarehouseRecordListVo> result = textbookService.warehouseList(id);
  87. if (result == null) {
  88. return RT.ok(new ArrayList<>());
  89. }
  90. return RT.ok(result);
  91. }
  92. @GetMapping(value = "/info-issue-list")
  93. @ApiOperation(value="教材管理-详情-出库记录")
  94. @SaCheckPermission("textbook:detail")
  95. public RT<List<TextbookIssueRecordListVo>> issueList(@RequestParam Long id){
  96. List<TextbookIssueRecordListVo> result = textbookService.issueList(id);
  97. if (result == null) {
  98. return RT.ok(new ArrayList<>());
  99. }
  100. return RT.ok(result);
  101. }
  102. @GetMapping(value = "/info-claim-list")
  103. @ApiOperation(value="教材管理-详情-领取记录")
  104. @SaCheckPermission("textbook:detail")
  105. public RT<List<WfTextbookClaimListVo>> claimList(@RequestParam Long id){
  106. List<WfTextbookClaimListVo> result = textbookService.claimList(id);
  107. if (result == null) {
  108. return RT.ok(new ArrayList<>());
  109. }
  110. return RT.ok(result);
  111. }
  112. @PostMapping
  113. @ApiOperation(value = "新增教材管理")
  114. @SaCheckPermission("textbook:add")
  115. public RT<Boolean> add(@Valid @RequestBody AddTextbookDto dto){
  116. Textbook textbook = BeanUtil.toBean(dto, Textbook.class);
  117. boolean isSuccess = textbookService.add(textbook);
  118. return RT.ok(isSuccess);
  119. }
  120. @PutMapping
  121. @ApiOperation(value = "修改教材管理")
  122. @SaCheckPermission("textbook:edit")
  123. public RT<Boolean> update(@Valid @RequestBody UpdateTextbookDto dto){
  124. Textbook textbook = BeanUtil.toBean(dto, Textbook.class);
  125. return RT.ok(textbookService.update(textbook));
  126. }
  127. @DeleteMapping
  128. @ApiOperation(value = "删除教材管理")
  129. @SaCheckPermission("textbook:delete")
  130. public RT<Boolean> delete(@Valid @RequestBody List<Long> ids){
  131. return RT.ok(textbookService.delete(ids));
  132. }
  133. @GetMapping("/export")
  134. @ApiOperation(value = "导出")
  135. public ResponseEntity<byte[]> exportData(@Valid TextbookPageDto dto, @RequestParam(defaultValue = "false") Boolean isTemplate) {
  136. List<TextbookPageVo> customerList = isTemplate != null && isTemplate ? new ArrayList<>() : ((PageOutput<TextbookPageVo>) page(dto).getData()).getList();
  137. ByteArrayOutputStream bot = new ByteArrayOutputStream();
  138. EasyExcel.write(bot, TextbookPageVo.class).automaticMergeHead(false).excelType(ExcelTypeEnum.XLSX).sheet().doWrite(customerList);
  139. return RT.fileStream(bot.toByteArray(), "Textbook" + ExcelTypeEnum.XLSX.getValue());
  140. }
  141. @PostMapping("deliver-warehouse")
  142. @ApiOperation(value = "教材管理入库")
  143. @SaCheckPermission("textbook:add")
  144. public RT<Boolean> deliverWarehouse(@Valid @RequestBody AddTextbookWarehouseRecordDto dto){
  145. Boolean isSuccess = textbookService.deliverWarehouse(dto);
  146. return RT.ok(isSuccess);
  147. }
  148. @PostMapping("/textbook-standing-export-query")
  149. @ApiOperation(value = "台账条件导出")
  150. public ResponseEntity<byte[]> textbookStandingExportQuery(@Valid @RequestBody TextbookStandingExportQuerytDto dto) {
  151. // @GetMapping("/textbook-standing-export-query")
  152. // @ApiOperation(value = "台账条件导出")
  153. // public ResponseEntity<byte[]> textbookStandingExportQuery(@Valid TextbookStandingExportQuerytDto dto) {
  154. List<TextbookStandingExportQueryVo> customerList = textbookService.listTextbookStandingExportQuery(dto);
  155. ByteArrayOutputStream bot = new ByteArrayOutputStream();
  156. EasyExcel.write(bot, TextbookStandingExportQueryVo.class).automaticMergeHead(false).excelType(ExcelTypeEnum.XLSX).sheet().doWrite(customerList);
  157. return RT.fileStream(bot.toByteArray(), "TextbookStanding" + ExcelTypeEnum.XLSX.getValue());
  158. }
  159. @PostMapping("/textbook-subscription-export-query")
  160. @ApiOperation(value = "教材征订记录条件导出")
  161. public ResponseEntity<byte[]> textbookSubscriptionExportQuery(@Valid @RequestBody TextbookSubscriptionExportQueryDto dto) {
  162. // @GetMapping("/textbook-subscription-export-query")
  163. // @ApiOperation(value = "教材征订记录条件导出")
  164. // public ResponseEntity<byte[]> textbookSubscriptionExportQuery(@Valid TextbookSubscriptionExportQueryDto dto) {
  165. List<TextbookSubscriptionExportQueryVo> customerList = textbookService.listTextbookSubscriptionExportQuery(dto);
  166. ByteArrayOutputStream bot = new ByteArrayOutputStream();
  167. // 设置动态头
  168. String baseSemesterCn = "";
  169. if(dto.getBaseSemesterId() != null){
  170. LambdaQueryWrapper<BaseSemester> baseSemesterLambdaQueryWrapper = new LambdaQueryWrapper<>();
  171. baseSemesterLambdaQueryWrapper
  172. .eq(BaseSemester::getId, dto.getBaseSemesterId());
  173. BaseSemester baseSemester = baseSemesterService.getOne(baseSemesterLambdaQueryWrapper);
  174. if(baseSemester != null){
  175. baseSemesterCn = baseSemester.getName();
  176. }
  177. }
  178. String headTitle = "重庆市铜梁职业教育中心" + baseSemesterCn + "教材征订表";
  179. List<List<String>> headList = new ArrayList<>();
  180. // List<String> head0 = new ArrayList<>();
  181. // head0.add("个人信息");
  182. // head0.add("用户名");
  183. // List<String> head1 = new ArrayList<>();
  184. // head1.add("个人信息");
  185. // head1.add("年龄");
  186. // List<String> head2 = new ArrayList<>();
  187. // head2.add("个人信息");
  188. // head2.add("地址");
  189. headList.add(new ArrayList<String>(){{
  190. add(headTitle);
  191. add("国际标准刊号");
  192. }});
  193. headList.add(new ArrayList<String>(){{
  194. add(headTitle);
  195. add("书名");
  196. }});
  197. headList.add(new ArrayList<String>(){{
  198. add(headTitle);
  199. add("出版社");
  200. }});
  201. headList.add(new ArrayList<String>(){{
  202. add(headTitle);
  203. add("主编");
  204. }});
  205. headList.add(new ArrayList<String>(){{
  206. add(headTitle);
  207. add("估价(元)");
  208. }});
  209. headList.add(new ArrayList<String>(){{
  210. add(headTitle);
  211. add("是否为规划教材");
  212. }});
  213. headList.add(new ArrayList<String>(){{
  214. add(headTitle);
  215. add("对应课程");
  216. }});
  217. headList.add(new ArrayList<String>(){{
  218. add(headTitle);
  219. add("使用年级");
  220. }});
  221. headList.add(new ArrayList<String>(){{
  222. add(headTitle);
  223. add("使用班级");
  224. }});
  225. headList.add(new ArrayList<String>(){{
  226. add(headTitle);
  227. add("学生用书征订数量");
  228. }});
  229. headList.add(new ArrayList<String>(){{
  230. add(headTitle);
  231. add("教师教材用书征订数量");
  232. }});
  233. headList.add(new ArrayList<String>(){{
  234. add(headTitle);
  235. add("教师教参用书征订数量");
  236. }});
  237. headList.add(new ArrayList<String>(){{
  238. add(headTitle);
  239. add("学科组名称");
  240. }});
  241. headList.add(new ArrayList<String>(){{
  242. add(headTitle);
  243. add("有无配套教学资源");
  244. }});
  245. headList.add(new ArrayList<String>(){{
  246. add(headTitle);
  247. add("备注");
  248. }});
  249. EasyExcel.write(bot, TextbookSubscriptionExportQueryVo.class).automaticMergeHead(true).excelType(ExcelTypeEnum.XLSX).head(headList).sheet().doWrite(customerList);
  250. return RT.fileStream(bot.toByteArray(), "TextbookSubscription" + ExcelTypeEnum.XLSX.getValue());
  251. }
  252. @PostMapping("/textbook-claim-export-query")
  253. @ApiOperation(value = "教材发放记录条件导出")
  254. public ResponseEntity<byte[]> textbookClaimExportQuery(@Valid @RequestBody TextbookClaimExportQueryDto dto) {
  255. // @GetMapping("/textbook-claim-export-query")
  256. // @ApiOperation(value = "教材发放记录条件导出")
  257. // public ResponseEntity<byte[]> textbookClaimExportQuery(@Valid TextbookClaimExportQueryDto dto) {
  258. ByteArrayOutputStream bot = textbookService.listTextbookClaimExportQuery(dto);
  259. return RT.fileStream(bot.toByteArray(), "TextbookClaim" + ExcelTypeEnum.XLSX.getValue());
  260. }
  261. @PostMapping("/excel-import")
  262. @ApiOperation(value = "excel教材导入")
  263. @SaCheckPermission("coursetable:excelimport")
  264. public R excelImport( @RequestParam("file") MultipartFile file) throws IOException {
  265. InputStream inputStream = file.getInputStream();
  266. return R.ok(textbookService.excelImport(inputStream));
  267. }
  268. }