TextbookController.java 16 KB

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