QuestionController.java 7.6 KB

123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263646566676869707172737475767778798081828384858687888990919293949596979899100101102103104105106107108109110111112113114115116117118119120121122123124125126127128129130131132133134135136137138139140141142143144145146147148149150151152153154155156157158159160161162163164165166167168169170171172173174175176177178179180181182183184185186187
  1. package com.zhongzheng.controller.bank;
  2. import java.time.LocalDateTime;
  3. import java.time.format.DateTimeFormatter;
  4. import java.util.ArrayList;
  5. import java.util.List;
  6. import java.util.Arrays;
  7. import cn.hutool.core.bean.BeanUtil;
  8. import cn.hutool.core.lang.Validator;
  9. import cn.hutool.http.HttpStatus;
  10. import com.github.pagehelper.PageInfo;
  11. import com.zhongzheng.common.core.domain.entity.SysUser;
  12. import com.zhongzheng.common.core.domain.model.LoginUser;
  13. import com.zhongzheng.common.core.page.TableDataInfo;
  14. import com.zhongzheng.common.utils.ServletUtils;
  15. import com.zhongzheng.common.utils.poi.ExcelUtil;
  16. import com.zhongzheng.framework.web.service.TokenService;
  17. import com.zhongzheng.modules.bank.bo.QuestionAddBo;
  18. import com.zhongzheng.modules.bank.bo.QuestionBusinessQueryBo;
  19. import com.zhongzheng.modules.bank.bo.QuestionEditBo;
  20. import com.zhongzheng.modules.bank.bo.QuestionQueryBo;
  21. import com.zhongzheng.modules.bank.domain.Exam;
  22. import com.zhongzheng.modules.bank.domain.Question;
  23. import com.zhongzheng.modules.bank.domain.QuestionBusiness;
  24. import com.zhongzheng.modules.bank.service.IQuestionBusinessService;
  25. import com.zhongzheng.modules.bank.service.IQuestionService;
  26. import com.zhongzheng.modules.bank.vo.QuestionBusinessVo;
  27. import com.zhongzheng.modules.bank.vo.QuestionExport;
  28. import com.zhongzheng.modules.bank.vo.QuestionImport;
  29. import com.zhongzheng.modules.bank.vo.QuestionVo;
  30. import com.zhongzheng.modules.goods.vo.GoodsVo;
  31. import com.zhongzheng.modules.user.vo.UserSubscribeErrorImport;
  32. import lombok.RequiredArgsConstructor;
  33. import org.springframework.security.access.prepost.PreAuthorize;
  34. import org.springframework.beans.factory.annotation.Autowired;
  35. import org.springframework.web.bind.annotation.GetMapping;
  36. import org.springframework.web.bind.annotation.PostMapping;
  37. import org.springframework.web.bind.annotation.PutMapping;
  38. import org.springframework.web.bind.annotation.DeleteMapping;
  39. import org.springframework.web.bind.annotation.PathVariable;
  40. import org.springframework.web.bind.annotation.RequestBody;
  41. import org.springframework.web.bind.annotation.RequestMapping;
  42. import org.springframework.web.bind.annotation.RestController;
  43. import com.zhongzheng.common.annotation.Log;
  44. import com.zhongzheng.common.core.controller.BaseController;
  45. import com.zhongzheng.common.core.domain.AjaxResult;
  46. import com.zhongzheng.common.enums.BusinessType;
  47. import io.swagger.annotations.Api;
  48. import io.swagger.annotations.ApiOperation;
  49. import org.springframework.web.multipart.MultipartFile;
  50. /**
  51. * 题库题目Controller
  52. *
  53. * @author hjl
  54. * @date 2021-10-21
  55. */
  56. @Api(value = "题库题目控制器", tags = {"题库题目管理"})
  57. @RequiredArgsConstructor(onConstructor_ = @Autowired)
  58. @RestController
  59. @RequestMapping("/bank/question")
  60. public class QuestionController extends BaseController {
  61. private final IQuestionService iQuestionService;
  62. private final IQuestionBusinessService iQuestionBusinessService;
  63. @Autowired
  64. private TokenService tokenService;
  65. /**
  66. * 查询题库题目列表
  67. */
  68. @ApiOperation("查询题库题目列表")
  69. @PreAuthorize("@ss.hasPermi('system:question:list')")
  70. @GetMapping("/list")
  71. public TableDataInfo<QuestionVo> list(QuestionQueryBo bo) {
  72. startPage();
  73. List<QuestionVo> list = iQuestionService.selectList(bo);
  74. return getDataTable(list);
  75. }
  76. /**
  77. * 导出题库题目列表
  78. */
  79. /* @ApiOperation("导出题库题目列表")
  80. @PreAuthorize("@ss.hasPermi('system:question:export')")
  81. @Log(title = "题库题目", businessType = BusinessType.EXPORT)
  82. @GetMapping("/export")
  83. public AjaxResult<QuestionVo> export(QuestionQueryBo bo) {
  84. List<QuestionVo> list = iQuestionService.queryList(bo);
  85. ExcelUtil<QuestionVo> util = new ExcelUtil<QuestionVo>(QuestionVo.class);
  86. return util.exportExcel(list, "题库题目");
  87. }*/
  88. /**
  89. * 获取题库题目详细信息
  90. */
  91. @ApiOperation("获取题库题目详细信息")
  92. @PreAuthorize("@ss.hasPermi('system:question:query')")
  93. @GetMapping("/{questionId}")
  94. public AjaxResult<QuestionVo> getInfo(@PathVariable("questionId" ) Long questionId) {
  95. return AjaxResult.success(iQuestionService.queryById(questionId));
  96. }
  97. /**
  98. * 新增题库题目
  99. */
  100. @ApiOperation("新增题库题目")
  101. @PreAuthorize("@ss.hasPermi('system:question:add')")
  102. @Log(title = "题库题目", businessType = BusinessType.INSERT)
  103. @PostMapping()
  104. public AjaxResult<Question> add(@RequestBody QuestionAddBo bo) {
  105. return AjaxResult.success(iQuestionService.insertByAddBo(bo));
  106. }
  107. /**
  108. * 修改题库题目
  109. */
  110. @ApiOperation("修改题库题目")
  111. @PreAuthorize("@ss.hasPermi('system:question:edit')")
  112. @Log(title = "题库题目", businessType = BusinessType.UPDATE)
  113. @PostMapping("/edit")
  114. public AjaxResult<Void> edit(@RequestBody QuestionEditBo bo) {
  115. return toAjax(iQuestionService.updateByEditBo(bo) ? 1 : 0);
  116. }
  117. /**
  118. * 删除题库题目
  119. */
  120. /*@ApiOperation("删除题库题目")
  121. @PreAuthorize("@ss.hasPermi('system:question:remove')")
  122. @Log(title = "题库题目" , businessType = BusinessType.DELETE)
  123. @DeleteMapping("/{questionIds}")
  124. public AjaxResult<Void> remove(@PathVariable Long[] questionIds) {
  125. return toAjax(iQuestionService.deleteWithValidByIds(Arrays.asList(questionIds), true) ? 1 : 0);
  126. }*/
  127. /**
  128. * 查询题目业务层次关系列表
  129. */
  130. @ApiOperation("查询题目业务层次关系列表")
  131. @PreAuthorize("@ss.hasPermi('system:business:list')")
  132. @GetMapping("/business/list")
  133. public TableDataInfo<QuestionBusiness> businessList(QuestionBusinessQueryBo bo) {
  134. startPage();
  135. bo.setType(QuestionBusiness.TYPE_QUESTION);
  136. List<QuestionBusiness> list = iQuestionBusinessService.getListById(bo);
  137. return getDataTable(list);
  138. }
  139. @Log(title = "题目管理", businessType = BusinessType.IMPORT)
  140. @ApiOperation("导入题目模板")
  141. @PreAuthorize("@ss.hasPermi('system:question:import')")
  142. @PostMapping("/importData")
  143. public AjaxResult importData(MultipartFile file, boolean updateSupport) throws Exception
  144. {
  145. ExcelUtil<QuestionImport> util = new ExcelUtil<QuestionImport>(QuestionImport.class);
  146. List<QuestionImport> questionList = util.importExcel(file.getInputStream());
  147. LoginUser loginUser = tokenService.getLoginUser(ServletUtils.getRequest());
  148. String operName = loginUser.getUsername();
  149. List<QuestionImport> errorList = iQuestionService.importQuestion(questionList, updateSupport, operName);
  150. if(Validator.isNotEmpty(errorList)&&errorList.size()>0){
  151. List<QuestionExport> errorListExport = new ArrayList<>();
  152. for(QuestionImport qi : errorList){
  153. QuestionExport item = BeanUtil.toBean(qi, QuestionExport.class);
  154. errorListExport.add(item);
  155. }
  156. ExcelUtil<QuestionExport> util1 = new ExcelUtil<QuestionExport>(QuestionExport.class);
  157. String timeStr= LocalDateTime.now().format(DateTimeFormatter.ofPattern("yyyy-MM-dd"));
  158. return util.exportEasyExcel(util1.exportEasyData(errorListExport), "导出错误数据"+timeStr);
  159. }else{
  160. return AjaxResult.success();
  161. }
  162. }
  163. @Log(title = "导入题目Word模板", businessType = BusinessType.IMPORT)
  164. @ApiOperation("导入题目Word模板")
  165. @PreAuthorize("@ss.hasPermi('system:question:import')")
  166. @PostMapping("/importWordData")
  167. public AjaxResult importWordData(MultipartFile file, Long eduId, Long projectId, Long businessId, Long subjectId) throws Exception
  168. {
  169. iQuestionService.importWordQuestion(file);
  170. return AjaxResult.success();
  171. }
  172. }