|  |  |  | 
|---|
|  |  |  | import io.swagger.annotations.ApiOperation; | 
|---|
|  |  |  | import org.springframework.beans.BeanUtils; | 
|---|
|  |  |  | import org.springframework.beans.factory.annotation.Autowired; | 
|---|
|  |  |  | import org.springframework.util.StringUtils; | 
|---|
|  |  |  | import org.springframework.web.bind.annotation.*; | 
|---|
|  |  |  |  | 
|---|
|  |  |  | import java.util.ArrayList; | 
|---|
|  |  |  | import java.util.List; | 
|---|
|  |  |  | import java.util.Map; | 
|---|
|  |  |  | import java.util.stream.Collectors; | 
|---|
|  |  |  |  | 
|---|
|  |  |  | /** | 
|---|
|  |  |  | * <p> | 
|---|
|  |  |  | 
|---|
|  |  |  | @Autowired | 
|---|
|  |  |  | private ITStudyService studyService; | 
|---|
|  |  |  |  | 
|---|
|  |  |  | @Autowired | 
|---|
|  |  |  | private ICategoryService categoryService; | 
|---|
|  |  |  |  | 
|---|
|  |  |  | @PostMapping("/subjectList") | 
|---|
|  |  |  | @ApiOperation(value = "列表查询", tags = {"题目管理"}) | 
|---|
|  |  |  | public R<PageInfo<SubjectVO>> subjectList(@RequestBody SubjectQuery query) { | 
|---|
|  |  |  | PageInfo<SubjectVO> res = new PageInfo<>(query.getPageNumber(), query.getPageSize()); | 
|---|
|  |  |  | List<SubjectVO> list =  subjectService.listAll(query); | 
|---|
|  |  |  | List<Integer> integers = new ArrayList<>(); | 
|---|
|  |  |  | int type=0; | 
|---|
|  |  |  | if (StringUtils.hasLength(query.getCategoryName())) { | 
|---|
|  |  |  | // 查询分类id包含的 | 
|---|
|  |  |  | List<Integer> collect = categoryService.lambdaQuery().eq(TCategory::getState, 1) | 
|---|
|  |  |  | .eq(TCategory::getType, 1) | 
|---|
|  |  |  | .like(TCategory::getName, query.getCategoryName()).list() | 
|---|
|  |  |  | .stream().map(TCategory::getId).collect(Collectors.toList());// 查询分类id包含的 | 
|---|
|  |  |  | List<Integer> collect2 = categoryService.lambdaQuery().eq(TCategory::getState, 1) | 
|---|
|  |  |  | .eq(TCategory::getType, 2) | 
|---|
|  |  |  | .like(TCategory::getName, query.getCategoryName()).list() | 
|---|
|  |  |  | .stream().map(TCategory::getId).collect(Collectors.toList()); | 
|---|
|  |  |  | collect.addAll(collect2); | 
|---|
|  |  |  | if (collect2.isEmpty()) { | 
|---|
|  |  |  | if (collect.isEmpty()) { | 
|---|
|  |  |  | collect.add(-1); | 
|---|
|  |  |  | } | 
|---|
|  |  |  | type=1; | 
|---|
|  |  |  | integers = collect; | 
|---|
|  |  |  | }else{ | 
|---|
|  |  |  | type=2; | 
|---|
|  |  |  | integers = collect2; | 
|---|
|  |  |  | } | 
|---|
|  |  |  | } | 
|---|
|  |  |  |  | 
|---|
|  |  |  | query.setIds(integers); | 
|---|
|  |  |  | List<SubjectVO> list =  subjectService.listAll(query,type,res); | 
|---|
|  |  |  | Map<Integer, String> categoryMap = categoryService.list(null).stream() | 
|---|
|  |  |  | .collect(Collectors.toMap(TCategory::getId, TCategory::getName)); | 
|---|
|  |  |  | for (SubjectVO subjectVO : list) { | 
|---|
|  |  |  | if (subjectVO.getFirstCategory()!=null&&subjectVO.getSecondCategory()!=null){ | 
|---|
|  |  |  | String byId1 = categoryMap.get(subjectVO.getFirstCategory()); | 
|---|
|  |  |  | String byId2 = categoryMap.get(subjectVO.getSecondCategory()); | 
|---|
|  |  |  | if (byId1!=null&& byId2!=null){ | 
|---|
|  |  |  | subjectVO.setCategoryName(byId1+"-"+byId2); | 
|---|
|  |  |  | } | 
|---|
|  |  |  | } | 
|---|
|  |  |  | //            StringBuilder stringBuilder = new StringBuilder(""); | 
|---|
|  |  |  | //            for (String s : subjectVO.getType().split(",")) { | 
|---|
|  |  |  | //                switch (s) { | 
|---|
|  |  |  | 
|---|
|  |  |  | subjectVO.setType(subjectVO.getType()); | 
|---|
|  |  |  | } | 
|---|
|  |  |  | res.setRecords(list); | 
|---|
|  |  |  | res.setTotal(list.size()); | 
|---|
|  |  |  | return R.ok(res); | 
|---|
|  |  |  | } | 
|---|
|  |  |  | @PostMapping("/add") | 
|---|
|  |  |  | 
|---|
|  |  |  | public R update(@RequestBody SubjectDTO dto) { | 
|---|
|  |  |  | TSubject tSubject = new TSubject(); | 
|---|
|  |  |  | // 判断当前题目有没有被使用 | 
|---|
|  |  |  | R<Object> week = getObjectR(dto.getId()); | 
|---|
|  |  |  | if (week != null) return week; | 
|---|
|  |  |  | //        R<Object> week = getObjectR(dto.getId()); | 
|---|
|  |  |  | //        if (week != null) return week; | 
|---|
|  |  |  | BeanUtils.copyProperties(dto,tSubject); | 
|---|
|  |  |  | subjectService.updateById(tSubject); | 
|---|
|  |  |  | return R.ok("编辑成功"); | 
|---|
|  |  |  | 
|---|
|  |  |  | if (s.equals(String.valueOf(id))) { | 
|---|
|  |  |  | Integer week = tStudyListen.getWeek(); | 
|---|
|  |  |  | Integer day = tStudyListen.getDay(); | 
|---|
|  |  |  | return R.fail("操作失败,当前题目在" + "周目" + week + "、" + "day" + day + "、" + "听音选图中使用"); | 
|---|
|  |  |  | return R.failUpdate("操作失败,当前题目在" + "周目" + week + "、" + "day" + day + "、" + "听音选图中使用"); | 
|---|
|  |  |  | } | 
|---|
|  |  |  | } | 
|---|
|  |  |  | } | 
|---|
|  |  |  | 
|---|
|  |  |  | if (s.equals(String.valueOf(id))) { | 
|---|
|  |  |  | Integer week = tStudyListen.getWeek(); | 
|---|
|  |  |  | Integer day = tStudyListen.getDay(); | 
|---|
|  |  |  | return R.fail("操作失败,当前题目在" + "周目" + week + "、" + "day" + day + "、" + "看图选音中使用"); | 
|---|
|  |  |  | return R.failUpdate("操作失败,当前题目在" + "周目" + week + "、" + "day" + day + "、" + "看图选音中使用"); | 
|---|
|  |  |  | } | 
|---|
|  |  |  | } | 
|---|
|  |  |  | } | 
|---|
|  |  |  | 
|---|
|  |  |  | if (s.equals(String.valueOf(id))) { | 
|---|
|  |  |  | Integer week = tStudyListen.getWeek(); | 
|---|
|  |  |  | Integer day = tStudyListen.getDay(); | 
|---|
|  |  |  | return R.fail("操作失败,当前题目在" + "周目" + week + "、" + "day" + day + "、" + "归纳排除中使用"); | 
|---|
|  |  |  | return R.failUpdate("操作失败,当前题目在" + "周目" + week + "、" + "day" + day + "、" + "归纳排除中使用"); | 
|---|
|  |  |  | } | 
|---|
|  |  |  | } | 
|---|
|  |  |  | } | 
|---|
|  |  |  | 
|---|
|  |  |  | if (subject.equals(id) || answerSubject.equals(id)) { | 
|---|
|  |  |  | Integer week = tStudyListen.getWeek(); | 
|---|
|  |  |  | Integer day = tStudyListen.getDay(); | 
|---|
|  |  |  | return R.fail("操作失败,当前题目在" + "周目" + week + "、" + "day" + day + "、" + "有问有答中使用"); | 
|---|
|  |  |  | return R.failUpdate("操作失败,当前题目在" + "周目" + week + "、" + "day" + day + "、" + "有问有答中使用"); | 
|---|
|  |  |  | } | 
|---|
|  |  |  | } | 
|---|
|  |  |  | } | 
|---|
|  |  |  | 
|---|
|  |  |  | if (s.equals(String.valueOf(id))) { | 
|---|
|  |  |  | Integer week = tStudyListen.getWeek(); | 
|---|
|  |  |  | Integer day = tStudyListen.getDay(); | 
|---|
|  |  |  | return R.fail("操作失败,当前题目在" + "周目" + week + "、" + "day" + day + "、" + "音图相配中使用"); | 
|---|
|  |  |  | return R.failUpdate("操作失败,当前题目在" + "周目" + week + "、" + "day" + day + "、" + "音图相配中使用"); | 
|---|
|  |  |  | } | 
|---|
|  |  |  | } | 
|---|
|  |  |  | } | 
|---|
|  |  |  | 
|---|
|  |  |  | } | 
|---|
|  |  |  |  | 
|---|
|  |  |  | @PostMapping("/getInfo") | 
|---|
|  |  |  | @ApiOperation(value = "查看详情", tags = {"题目管理"}) | 
|---|
|  |  |  | //    @ApiOperation(value = "查看详情", tags = {"题目管理"}) | 
|---|
|  |  |  | public R<SubjectDTO> getInfo(@RequestParam("id") Integer id) { | 
|---|
|  |  |  | TSubject byId = subjectService.getById(id); | 
|---|
|  |  |  | SubjectDTO subjectDTO = new SubjectDTO(); | 
|---|
|  |  |  | 
|---|
|  |  |  | return R.ok(subjectDTO); | 
|---|
|  |  |  | } | 
|---|
|  |  |  | @PostMapping("/updateState/{id}/{state}") | 
|---|
|  |  |  | @ApiOperation(value = "修改状态", tags = {"题目管理"}) | 
|---|
|  |  |  | //    @ApiOperation(value = "修改状态", tags = {"题目管理"}) | 
|---|
|  |  |  | @ApiImplicitParams({ | 
|---|
|  |  |  | @ApiImplicitParam(name = "id", value = "题目id", required = true), | 
|---|
|  |  |  | @ApiImplicitParam(name = "state", value = "1上架2下架3删除", required = true), | 
|---|