QuestionModuleController.java 5.5 KB

123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263646566676869707172737475767778798081828384858687888990919293949596979899100101102103104105106107108109110111112113114115116117118119120121122123124125126127128129130131132133134135136137138139140141142143
  1. package com.zhongzheng.controller.bank;
  2. import java.util.List;
  3. import java.util.Arrays;
  4. import com.zhongzheng.modules.bank.bo.*;
  5. import com.zhongzheng.modules.bank.domain.QuestionBusiness;
  6. import com.zhongzheng.modules.bank.service.IQuestionBusinessService;
  7. import com.zhongzheng.modules.bank.service.IQuestionModuleChapterService;
  8. import com.zhongzheng.modules.bank.service.IQuestionModuleService;
  9. import com.zhongzheng.modules.bank.vo.ExamQuestionVo;
  10. import com.zhongzheng.modules.bank.vo.QuestionChapterVo;
  11. import com.zhongzheng.modules.bank.vo.QuestionModuleVo;
  12. import lombok.RequiredArgsConstructor;
  13. import org.springframework.security.access.prepost.PreAuthorize;
  14. import org.springframework.beans.factory.annotation.Autowired;
  15. import org.springframework.web.bind.annotation.GetMapping;
  16. import org.springframework.web.bind.annotation.PostMapping;
  17. import org.springframework.web.bind.annotation.PutMapping;
  18. import org.springframework.web.bind.annotation.DeleteMapping;
  19. import org.springframework.web.bind.annotation.PathVariable;
  20. import org.springframework.web.bind.annotation.RequestBody;
  21. import org.springframework.web.bind.annotation.RequestMapping;
  22. import org.springframework.web.bind.annotation.RestController;
  23. import com.zhongzheng.common.annotation.Log;
  24. import com.zhongzheng.common.core.controller.BaseController;
  25. import com.zhongzheng.common.core.domain.AjaxResult;
  26. import com.zhongzheng.common.enums.BusinessType;
  27. import com.zhongzheng.common.utils.poi.ExcelUtil;
  28. import com.zhongzheng.common.core.page.TableDataInfo;
  29. import io.swagger.annotations.Api;
  30. import io.swagger.annotations.ApiOperation;
  31. /**
  32. * 题目模块Controller
  33. *
  34. * @author hjl
  35. * @date 2021-10-25
  36. */
  37. @Api(value = "题目模块控制器", tags = {"题目模块管理"})
  38. @RequiredArgsConstructor(onConstructor_ = @Autowired)
  39. @RestController
  40. @RequestMapping("/bank/module")
  41. public class QuestionModuleController extends BaseController {
  42. private final IQuestionModuleService iQuestionModuleService;
  43. private final IQuestionBusinessService iQuestionBusinessService;
  44. private final IQuestionModuleChapterService iQuestionModuleChapterService;
  45. /**
  46. * 查询题目模块列表
  47. */
  48. @ApiOperation("查询题目模块列表")
  49. @PreAuthorize("@ss.hasPermi('system:module:list')")
  50. @GetMapping("/list")
  51. public TableDataInfo<QuestionModuleVo> list(QuestionModuleQueryBo bo) {
  52. startPage();
  53. List<QuestionModuleVo> list = iQuestionModuleService.queryList(bo);
  54. return getDataTable(list);
  55. }
  56. /**
  57. * 导出题目模块列表
  58. */
  59. /*@ApiOperation("导出题目模块列表")
  60. @PreAuthorize("@ss.hasPermi('system:module:export')")
  61. @Log(title = "题目模块", businessType = BusinessType.EXPORT)
  62. @GetMapping("/export")
  63. public AjaxResult<QuestionModuleVo> export(QuestionModuleQueryBo bo) {
  64. List<QuestionModuleVo> list = iQuestionModuleService.queryList(bo);
  65. ExcelUtil<QuestionModuleVo> util = new ExcelUtil<QuestionModuleVo>(QuestionModuleVo.class);
  66. return util.exportExcel(list, "题目模块");
  67. }*/
  68. /**
  69. * 获取题目模块详细信息
  70. */
  71. @ApiOperation("获取题目模块详细信息")
  72. @PreAuthorize("@ss.hasPermi('system:module:query')")
  73. @GetMapping("/{questionModuleId}")
  74. public AjaxResult<QuestionModuleVo> getInfo(@PathVariable("questionModuleId" ) Long questionModuleId) {
  75. return AjaxResult.success(iQuestionModuleService.queryById(questionModuleId));
  76. }
  77. /**
  78. * 新增题目模块
  79. */
  80. @ApiOperation("新增题目模块")
  81. @PreAuthorize("@ss.hasPermi('system:module:add')")
  82. @Log(title = "题目模块", businessType = BusinessType.INSERT)
  83. @PostMapping()
  84. public AjaxResult<Void> add(@RequestBody QuestionModuleAddBo bo) {
  85. return toAjax(iQuestionModuleService.insertByAddBo(bo) ? 1 : 0);
  86. }
  87. /**
  88. * 修改题目模块
  89. */
  90. @ApiOperation("修改题目模块")
  91. @PreAuthorize("@ss.hasPermi('system:module:edit')")
  92. @Log(title = "题目模块", businessType = BusinessType.UPDATE)
  93. @PostMapping("/edit")
  94. public AjaxResult<Void> edit(@RequestBody QuestionModuleEditBo bo) {
  95. return toAjax(iQuestionModuleService.updateByEditBo(bo) ? 1 : 0);
  96. }
  97. /**
  98. * 删除题目模块
  99. */
  100. /* @ApiOperation("删除题目模块")
  101. @PreAuthorize("@ss.hasPermi('system:module:remove')")
  102. @Log(title = "题目模块" , businessType = BusinessType.DELETE)
  103. @DeleteMapping("/{questionModuleIds}")
  104. public AjaxResult<Void> remove(@PathVariable Long[] questionModuleIds) {
  105. return toAjax(iQuestionModuleService.deleteWithValidByIds(Arrays.asList(questionModuleIds), true) ? 1 : 0);
  106. }*/
  107. /**
  108. * 查询题目业务层次关系列表
  109. */
  110. @ApiOperation("查询业务层次关系列表")
  111. @PreAuthorize("@ss.hasPermi('system:business:list')")
  112. @GetMapping("/business/list")
  113. public TableDataInfo<QuestionBusiness> businessList(QuestionBusinessQueryBo bo) {
  114. startPage();
  115. bo.setType(QuestionBusiness.TYPE_QUESTION_MODULE);
  116. List<QuestionBusiness> list = iQuestionBusinessService.getListById(bo);
  117. return getDataTable(list);
  118. }
  119. /**
  120. * 查询题目业务层次关系列表
  121. */
  122. @ApiOperation("查询关联章卷列表")
  123. @PreAuthorize("@ss.hasPermi('system:business:list')")
  124. @GetMapping("/chapter/list")
  125. public AjaxResult<List<QuestionChapterVo>> questionList(QuestionModuleChapterQueryBo bo) {
  126. List<QuestionChapterVo> list = iQuestionModuleChapterService.getList(bo);
  127. return AjaxResult.success(list);
  128. }
  129. }