From 309a91cbf61884c5e619a68df818c334d27a5c32 Mon Sep 17 00:00:00 2001
From: 龚焕茏 <2842157468@qq.com>
Date: 星期一, 03 六月 2024 09:30:17 +0800
Subject: [PATCH] fix:用户角色查询条件
---
src/main/java/com/mindskip/xzs/controller/admin/EducationController.java | 57 +++++++++++++++++++++++++++++++++++++++++++++++++++------
1 files changed, 51 insertions(+), 6 deletions(-)
diff --git a/src/main/java/com/mindskip/xzs/controller/admin/EducationController.java b/src/main/java/com/mindskip/xzs/controller/admin/EducationController.java
index f57e9eb..d7ab8b0 100644
--- a/src/main/java/com/mindskip/xzs/controller/admin/EducationController.java
+++ b/src/main/java/com/mindskip/xzs/controller/admin/EducationController.java
@@ -3,29 +3,39 @@
import com.mindskip.xzs.base.BaseApiController;
import com.mindskip.xzs.base.RestResponse;
+import com.mindskip.xzs.domain.ExamPaperSubject;
import com.mindskip.xzs.domain.Subject;
-import com.mindskip.xzs.service.SubjectService;
+import com.mindskip.xzs.domain.SubjectDept;
+import com.mindskip.xzs.domain.vo.SubjectDeptVO;
+import com.mindskip.xzs.repository.SubjectDeptMapper;
+import com.mindskip.xzs.service.*;
import com.mindskip.xzs.utility.PageInfoHelper;
import com.mindskip.xzs.viewmodel.admin.education.SubjectEditRequestVM;
import com.mindskip.xzs.viewmodel.admin.education.SubjectPageRequestVM;
import com.mindskip.xzs.viewmodel.admin.education.SubjectResponseVM;
import com.github.pagehelper.PageInfo;
+import lombok.RequiredArgsConstructor;
+import org.springframework.beans.BeanUtils;
import org.springframework.beans.factory.annotation.Autowired;
+import org.springframework.transaction.annotation.Transactional;
import org.springframework.web.bind.annotation.*;
import javax.validation.Valid;
import java.util.List;
+import java.util.stream.Collectors;
@RestController("AdminEducationController")
@RequestMapping(value = "/api/admin/education")
+@RequiredArgsConstructor
public class EducationController extends BaseApiController {
private final SubjectService subjectService;
+ private final SubjectDeptMapper subjectDeptMapper;
+ private final QuestionSubjectService questionSubjectService;
+ private final ExamPaperSubjectService examPaperSubjectService;
+ private final ExamPaperDepartmentService examPaperDepartmentService;
+ private final ExamPaperService examPaperService;
- @Autowired
- public EducationController(SubjectService subjectService) {
- this.subjectService = subjectService;
- }
@RequestMapping(value = "/subject/list", method = RequestMethod.POST)
public RestResponse<List<Subject>> list() {
@@ -33,13 +43,29 @@
return RestResponse.ok(subjects);
}
+ @RequestMapping(value = "/subject/select/dept/{deptId}", method = RequestMethod.GET)
+ public RestResponse<List<Subject>> listByDeptId(@PathVariable("deptId") Integer deptId) {
+ List<Subject> subjects = subjectService.listByDeptId(deptId);
+ return RestResponse.ok(subjects);
+ }
+
@RequestMapping(value = "/subject/page", method = RequestMethod.POST)
public RestResponse<PageInfo<SubjectResponseVM>> pageList(@RequestBody SubjectPageRequestVM model) {
PageInfo<Subject> pageInfo = subjectService.page(model);
- PageInfo<SubjectResponseVM> page = PageInfoHelper.copyMap(pageInfo, e -> modelMapper.map(e, SubjectResponseVM.class));
+ PageInfo<SubjectResponseVM> page = PageInfoHelper.copyMap(pageInfo, item -> {
+ SubjectResponseVM vo = new SubjectResponseVM();
+ BeanUtils.copyProperties(item, vo);
+ List<SubjectDeptVO> subjectDeptVOS = subjectDeptMapper.deptBySubjectId(item.getId());
+ List<Integer> deptIds = subjectDeptVOS.stream().map(SubjectDeptVO::getDeptId).collect(Collectors.toList());
+ String deptNames = subjectDeptVOS.stream().map(SubjectDeptVO::getDeptName).collect(Collectors.joining("銆�"));
+ vo.setDeptIds(deptIds);
+ vo.setDeptNames(deptNames);
+ return vo;
+ });
return RestResponse.ok(page);
}
+ @Transactional(rollbackFor = Exception.class)
@RequestMapping(value = "/subject/edit", method = RequestMethod.POST)
public RestResponse edit(@RequestBody @Valid SubjectEditRequestVM model) {
Subject subject = modelMapper.map(model, Subject.class);
@@ -49,6 +75,15 @@
} else {
subjectService.updateByIdFilter(subject);
}
+ // 澶勭悊閮ㄩ棬
+ subjectDeptMapper.removeBySubjectId(subject.getId());
+ List<SubjectDept> subjectDeptList = model.getDeptIds().stream().map(deptId -> {
+ SubjectDept subjectDept = new SubjectDept();
+ subjectDept.setSubjectId(subject.getId());
+ subjectDept.setDeptId(deptId);
+ return subjectDept;
+ }).collect(Collectors.toList());
+ subjectDeptMapper.add(subjectDeptList);
return RestResponse.ok();
}
@@ -56,14 +91,24 @@
public RestResponse<SubjectEditRequestVM> select(@PathVariable Integer id) {
Subject subject = subjectService.selectById(id);
SubjectEditRequestVM vm = modelMapper.map(subject, SubjectEditRequestVM.class);
+ List<SubjectDeptVO> subjectDeptVOS = subjectDeptMapper.deptBySubjectId(id);
+ List<Integer> deptIds = subjectDeptVOS.stream().map(SubjectDeptVO::getDeptId).collect(Collectors.toList());
+ vm.setDeptIds(deptIds);
return RestResponse.ok(vm);
}
+
@RequestMapping(value = "/subject/delete/{id}", method = RequestMethod.POST)
public RestResponse delete(@PathVariable Integer id) {
Subject subject = subjectService.selectById(id);
subject.setDeleted(true);
subjectService.updateByIdFilter(subject);
+ questionSubjectService.removeSubjectId(id);
+ Integer[] ids = examPaperSubjectService.getBySubjectId(id)
+ .stream().map(ExamPaperSubject::getExamPaperId).toArray(Integer[]::new);
+ examPaperService.removeByIds(ids);
+ examPaperDepartmentService.removeByExamPaperIds(ids);
+ examPaperSubjectService.removeBySubjectId(id);
return RestResponse.ok();
}
}
--
Gitblit v1.8.0