From d4daa1ea31db6fd421c0e86bab178a9f3b512141 Mon Sep 17 00:00:00 2001
From: xiangpei <xiangpei@timesnew.cn>
Date: 星期一, 23 九月 2024 18:02:54 +0800
Subject: [PATCH] 使用新导入
---
src/main/java/com/mindskip/xzs/service/impl/SubjectServiceImpl.java | 77 +++++++++++++++++++++++++++++++++++---
1 files changed, 70 insertions(+), 7 deletions(-)
diff --git a/src/main/java/com/mindskip/xzs/service/impl/SubjectServiceImpl.java b/src/main/java/com/mindskip/xzs/service/impl/SubjectServiceImpl.java
index 32014ce..26791e9 100644
--- a/src/main/java/com/mindskip/xzs/service/impl/SubjectServiceImpl.java
+++ b/src/main/java/com/mindskip/xzs/service/impl/SubjectServiceImpl.java
@@ -1,25 +1,42 @@
package com.mindskip.xzs.service.impl;
+import com.github.pagehelper.PageHelper;
+import com.github.pagehelper.PageInfo;
+import com.mindskip.xzs.base.RestResponse;
+import com.mindskip.xzs.context.WebContext;
import com.mindskip.xzs.domain.Subject;
+import com.mindskip.xzs.domain.SubjectDept;
+import com.mindskip.xzs.domain.enums.RoleEnum;
+import com.mindskip.xzs.domain.form.AddSubjectForm;
+import com.mindskip.xzs.domain.form.EditSubjectForm;
+import com.mindskip.xzs.repository.BaseMapper;
+import com.mindskip.xzs.repository.DepartmentMapper;
+import com.mindskip.xzs.repository.SubjectDeptMapper;
import com.mindskip.xzs.repository.SubjectMapper;
import com.mindskip.xzs.service.SubjectService;
import com.mindskip.xzs.viewmodel.admin.education.SubjectPageRequestVM;
-import com.github.pagehelper.PageHelper;
-import com.github.pagehelper.PageInfo;
-import org.springframework.beans.factory.annotation.Autowired;
+import org.apache.commons.lang3.ObjectUtils;
import org.springframework.stereotype.Service;
+import org.springframework.transaction.annotation.Transactional;
+import java.util.ArrayList;
import java.util.List;
+import java.util.stream.Collectors;
@Service
public class SubjectServiceImpl extends BaseServiceImpl<Subject> implements SubjectService {
private final SubjectMapper subjectMapper;
+ private final WebContext webContext;
+ private final DepartmentMapper departmentMapper;
+ private final SubjectDeptMapper subjectDeptMapper;
- @Autowired
- public SubjectServiceImpl(SubjectMapper subjectMapper) {
- super(subjectMapper);
+ public SubjectServiceImpl(BaseMapper<Subject> baseMapper, SubjectMapper subjectMapper, WebContext webContext, DepartmentMapper departmentMapper, SubjectDeptMapper subjectDeptMapper) {
+ super(baseMapper);
this.subjectMapper = subjectMapper;
+ this.webContext = webContext;
+ this.departmentMapper = departmentMapper;
+ this.subjectDeptMapper = subjectDeptMapper;
}
@Override
@@ -39,7 +56,10 @@
@Override
public List<Subject> allSubject() {
- return subjectMapper.allSubject();
+ // 鍙煡鑷繁閮ㄩ棬鐨勮鐩�
+ List<Integer> deptIds = webContext.getAdminDeptIds();
+ Boolean admin = RoleEnum.ADMIN.getCode().equals(webContext.getCurrentUser().getRole());
+ return subjectMapper.allSubject(deptIds, admin);
}
@Override
@@ -64,4 +84,47 @@
return subjectMapper.selectByIds(ids);
}
+ @Override
+ public List<Subject> listByDeptId(Integer deptId) {
+ return subjectMapper.listByDeptId(deptId);
+ }
+
+ @Override
+ @Transactional(rollbackFor = Exception.class)
+ public RestResponse add(AddSubjectForm form) {
+ Subject subject = new Subject();
+ subject.setName(form.getSubjectName());
+ subject.setDeleted(false);
+ try {
+ subjectMapper.insert(subject);
+ } catch (Exception e) {
+ return RestResponse.fail(500, "绉戠洰鍚嶄笉鑳介噸澶�");
+ }
+
+ SubjectDept subjectDept = new SubjectDept();
+ subjectDept.setDeptId(form.getDeptId());
+ subjectDept.setSubjectId(subject.getId());
+ List<SubjectDept> s = new ArrayList<>(1);
+ s.add(subjectDept);
+ subjectDeptMapper.add(s);
+ return RestResponse.ok();
+ }
+
+ @Override
+ @Transactional(rollbackFor = Exception.class)
+ public void edit(EditSubjectForm form) {
+ if (ObjectUtils.isNotEmpty(form.getDeptId())) {
+ // 鍒犻櫎鍘熷厛鐨勮鐩紝鍐嶆柊澧�
+ subjectDeptMapper.deleteByDeptId(form.getDeptId());
+ List<SubjectDept> toAddList = form.getSubjectIds().stream().map(subjectId -> {
+ SubjectDept subjectDept = new SubjectDept();
+ subjectDept.setDeptId(form.getDeptId());
+ subjectDept.setSubjectId(subjectId);
+ return subjectDept;
+ }).collect(Collectors.toList());
+ if (ObjectUtils.isNotEmpty(toAddList)) {
+ subjectDeptMapper.add(toAddList);
+ }
+ }
+ }
}
--
Gitblit v1.8.0