BaseClassServiceImpl.java 13 KB

123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263646566676869707172737475767778798081828384858687888990919293949596979899100101102103104105106107108109110111112113114115116117118119120121122123124125126127128129130131132133134135136137138139140141142143144145146147148149150151152153154155156157158159160161162163164165166167168169170171172173174175176177178179180181182183184185186187188189190191192193194195196197198199200201202203204205206207208209210211212213214215216217218219220221222223224225226227228229230231232233234235236237238239240241242243244245246247248249250251252253254255256257258259260261262263264265266267268269270271272273274275276277278279280281
  1. package com.xjrsoft.module.base.service.impl;
  2. import cn.dev33.satoken.stp.StpUtil;
  3. import cn.hutool.core.bean.BeanUtil;
  4. import com.baomidou.mybatisplus.core.conditions.query.QueryWrapper;
  5. import com.baomidou.mybatisplus.core.toolkit.Wrappers;
  6. import com.baomidou.mybatisplus.extension.plugins.pagination.Page;
  7. import com.github.yulichang.base.MPJBaseServiceImpl;
  8. import com.github.yulichang.wrapper.MPJLambdaWrapper;
  9. import com.xjrsoft.common.constant.GlobalConstant;
  10. import com.xjrsoft.common.enums.DeleteMark;
  11. import com.xjrsoft.common.enums.EnabledMark;
  12. import com.xjrsoft.common.enums.RoleEnum;
  13. import com.xjrsoft.common.exception.MyException;
  14. import com.xjrsoft.common.utils.RedisUtil;
  15. import com.xjrsoft.module.attendance.dto.AttendanceStatisticDto;
  16. import com.xjrsoft.module.attendance.vo.ClassStatisticsVo;
  17. import com.xjrsoft.module.base.dto.AddBaseClassPageDto;
  18. import com.xjrsoft.module.base.dto.BaseClassPageDto;
  19. import com.xjrsoft.module.base.dto.UpdateBaseClassPageDto;
  20. import com.xjrsoft.module.base.entity.BaseClass;
  21. import com.xjrsoft.module.base.mapper.BaseClassMapper;
  22. import com.xjrsoft.module.base.service.IBaseClassService;
  23. import com.xjrsoft.module.base.vo.BaseClassPageVo;
  24. import com.xjrsoft.module.base.vo.StudentClassVo;
  25. import com.xjrsoft.module.organization.entity.User;
  26. import com.xjrsoft.module.organization.entity.UserDeptRelation;
  27. import com.xjrsoft.module.organization.entity.UserRoleRelation;
  28. import com.xjrsoft.module.organization.entity.UserStudent;
  29. import com.xjrsoft.module.organization.service.IUserRoleRelationService;
  30. import com.xjrsoft.module.organization.service.IUserStudentService;
  31. import com.xjrsoft.module.organization.vo.UserStudentVo;
  32. import com.xjrsoft.module.student.entity.BaseClassMajorSet;
  33. import com.xjrsoft.module.student.entity.BaseStudent;
  34. import com.xjrsoft.module.student.entity.BaseStudentSchoolRoll;
  35. import com.xjrsoft.module.student.entity.BaseStudentUser;
  36. import com.xjrsoft.module.student.service.IBaseClassMajorSetService;
  37. import com.xjrsoft.module.teacher.entity.XjrUser;
  38. import lombok.AllArgsConstructor;
  39. import org.springframework.stereotype.Service;
  40. import java.util.Date;
  41. import java.util.List;
  42. import java.util.concurrent.CompletableFuture;
  43. import java.util.stream.Collectors;
  44. @Service
  45. @AllArgsConstructor
  46. public class BaseClassServiceImpl extends MPJBaseServiceImpl<BaseClassMapper, BaseClass> implements IBaseClassService {
  47. private final IUserStudentService userStudentService;
  48. private final BaseClassMapper baseClassMapper;
  49. private final IBaseClassMajorSetService majorSetService;
  50. private final IUserRoleRelationService roleRelationService;
  51. private final RedisUtil redisUtil;
  52. /**
  53. * 获取家长关联的学生 id 是家长的ID
  54. * @param id
  55. * @return
  56. */
  57. public List<UserStudentVo> getStudents(long id) {
  58. List<Long> studentIds = userStudentService.list(Wrappers.lambdaQuery(UserStudent.class)
  59. .eq(UserStudent::getUserId, id).eq(UserStudent::getStatus, 1))
  60. .stream().map(UserStudent::getStudentId).collect(Collectors.toList());
  61. List<UserStudentVo> list = null;
  62. if (studentIds.size() > 0) {
  63. MPJLambdaWrapper<BaseClass> queryWrapper = new MPJLambdaWrapper<>();
  64. queryWrapper
  65. .disableSubLogicDel()
  66. .rightJoin(BaseStudentSchoolRoll.class, BaseStudentSchoolRoll::getClassId, BaseStudent::getId)
  67. .innerJoin(BaseStudentUser.class, BaseStudentUser::getId, BaseStudentSchoolRoll::getUserId)
  68. .leftJoin(XjrUser.class, XjrUser::getId, BaseClass::getTeacherId)
  69. .in(BaseStudentSchoolRoll::getUserId, studentIds)
  70. .selectAs(BaseClass::getName, UserStudentVo::getClassName)
  71. .selectAs(BaseStudentUser::getName, UserStudentVo::getStudentName)
  72. .selectAs(BaseStudentUser::getId, UserStudentVo::getStudentId)
  73. .selectAs(BaseStudentSchoolRoll::getClassId, UserStudentVo::getClassId)
  74. .selectAs(XjrUser::getName, UserStudentVo::getTeacherName)
  75. .selectAs(XjrUser::getMobile, UserStudentVo::getTeacherMobile)
  76. .selectAs(XjrUser::getId, UserStudentVo::getTeacherId)
  77. .selectAs(BaseStudentUser::getAvatar, UserStudentVo::getAvatar);
  78. list = selectJoinList(UserStudentVo.class, queryWrapper);
  79. }
  80. return list;
  81. }
  82. /**
  83. * 获取学生的班级信息
  84. * @param id
  85. * @return
  86. */
  87. public UserStudentVo getClassInfo(long id) {
  88. MPJLambdaWrapper<BaseClass> queryWrapper = new MPJLambdaWrapper<>();
  89. queryWrapper
  90. .disableSubLogicDel()
  91. .innerJoin(BaseStudentSchoolRoll.class, BaseStudentSchoolRoll::getClassId, BaseStudent::getId)
  92. .innerJoin(BaseStudentUser.class, BaseStudentUser::getId, BaseStudentSchoolRoll::getUserId)
  93. .leftJoin(XjrUser.class, XjrUser::getId, BaseClass::getTeacherId)
  94. .eq(BaseStudentSchoolRoll::getUserId, id)
  95. .selectAs(BaseClass::getName, UserStudentVo::getClassName)
  96. .selectAs(XjrUser::getName, UserStudentVo::getTeacherName)
  97. .selectAs(XjrUser::getMobile, UserStudentVo::getTeacherMobile)
  98. .selectAs(XjrUser::getId, UserStudentVo::getTeacherId)
  99. .selectAs(BaseStudentUser::getName, UserStudentVo::getStudentName)
  100. .selectAs(BaseStudentUser::getId, UserStudentVo::getStudentId)
  101. .selectAs(BaseStudentSchoolRoll::getClassId, UserStudentVo::getClassId)
  102. .selectAs(BaseStudentUser::getAvatar, UserStudentVo::getAvatar);
  103. return selectJoinOne(UserStudentVo.class, queryWrapper);
  104. }
  105. @Override
  106. public Page<BaseClassPageVo> getPage(Page<BaseClassPageVo> page, BaseClassPageDto dto) {
  107. return baseClassMapper.getPage(page, dto);
  108. }
  109. @Override
  110. public List<StudentClassVo> getStudentClass() {
  111. return baseClassMapper.getStudentClass();
  112. }
  113. @Override
  114. public Page<ClassStatisticsVo> getAttendancePage(Page<ClassStatisticsVo> page, AttendanceStatisticDto dto){
  115. return baseClassMapper.getAttendanceClass(page, dto);
  116. };
  117. /**
  118. * 根据教师id查询班级id
  119. * @param teacherId 教师userId
  120. * @return 班主任所负责的班级id
  121. */
  122. @Override
  123. public Long getIdByTeacherId(Long teacherId){
  124. List<BaseClass> list = this.baseMapper.selectList(
  125. new QueryWrapper<BaseClass>().lambda()
  126. .eq(BaseClass::getTeacherId, teacherId)
  127. .eq(BaseClass::getDeleteMark, DeleteMark.NODELETE.getCode())
  128. .eq(BaseClass::getEnabledMark, EnabledMark.ENABLED.getCode())
  129. .orderByDesc(BaseClass::getCreateDate)
  130. );
  131. if(list.isEmpty()){
  132. return null;
  133. }
  134. return list.get(0).getId();
  135. }
  136. @Override
  137. public Boolean addClass(AddBaseClassPageDto dto) {
  138. BaseClass baseClass = BeanUtil.toBean(dto, BaseClass.class);
  139. baseClass.setDeleteMark(DeleteMark.NODELETE.getCode());
  140. baseClass.setCreateDate(new Date());
  141. baseClass.setEnabledMark(EnabledMark.ENABLED.getCode());
  142. baseClass.setCreateUserId(StpUtil.getLoginIdAsLong());
  143. if(baseClass.getTeacherId() != null){
  144. //查询该班主任是否是其他在读班级
  145. long count = this.count(
  146. new QueryWrapper<BaseClass>().lambda()
  147. .eq(BaseClass::getIsGraduate, 1)
  148. .eq(BaseClass::getTeacherId, baseClass.getTeacherId())
  149. .eq(BaseClass::getDeleteMark, DeleteMark.NODELETE.getCode())
  150. .eq(BaseClass::getEnabledMark, EnabledMark.ENABLED.getCode())
  151. );
  152. if(count > 0){
  153. throw new MyException("该老师已是其他在读班级班主任,无法添加");
  154. }
  155. }
  156. boolean isSuccess = this.save(baseClass);
  157. if(isSuccess){
  158. BaseClassMajorSet majorSet = new BaseClassMajorSet();
  159. majorSet.setClassId(baseClass.getId());
  160. majorSet.setMajorSetId(dto.getMajorSetId());
  161. majorSet.setCreateDate(new Date());
  162. majorSetService.save(majorSet);
  163. //给该老师添加班主任角色
  164. if(baseClass.getTeacherId() != null){
  165. long count = roleRelationService.count(
  166. new QueryWrapper<UserRoleRelation>().lambda()
  167. .eq(UserRoleRelation::getUserId, dto.getTeacherId())
  168. .eq(UserRoleRelation::getRoleId, RoleEnum.CLASSTE.getCode())
  169. );
  170. if(count == 0){
  171. roleRelationService.save(
  172. new UserRoleRelation(){{
  173. setRoleId(RoleEnum.CLASSTE.getCode());
  174. setUserId(dto.getTeacherId());
  175. }}
  176. );
  177. CompletableFuture.runAsync(() -> {
  178. List<UserRoleRelation> userRoleRelationList = roleRelationService.list(Wrappers.lambdaQuery(UserRoleRelation.class));
  179. redisUtil.set(GlobalConstant.USER_ROLE_RELATION_CACHE_KEY, userRoleRelationList);
  180. });
  181. }
  182. }
  183. }
  184. return isSuccess;
  185. }
  186. @Override
  187. public Boolean updateClass(UpdateBaseClassPageDto dto) {
  188. BaseClass aClass = this.getById(dto.getId());
  189. //设置了班主任,需要判断新设置的班主任是否已经是其它在读班级的
  190. if(dto.getTeacherId() != null && !dto.getTeacherId().equals(aClass.getTeacherId())){
  191. long count = this.count(
  192. new QueryWrapper<BaseClass>().lambda()
  193. .eq(BaseClass::getIsGraduate, 1)
  194. .eq(BaseClass::getTeacherId, dto.getTeacherId())
  195. .eq(BaseClass::getDeleteMark, DeleteMark.NODELETE.getCode())
  196. .eq(BaseClass::getEnabledMark, EnabledMark.ENABLED.getCode())
  197. .ne(BaseClass::getId, dto.getId())
  198. );
  199. if(count > 0){
  200. throw new MyException("该老师已是其他在读班级班主任,无法添加");
  201. }
  202. }
  203. BaseClass baseClass = BeanUtil.toBean(dto, BaseClass.class);
  204. baseClass.setModifyDate(new Date());
  205. baseClass.setModifyUserId(StpUtil.getLoginIdAsLong());
  206. boolean update = this.updateById(baseClass);
  207. if(update){
  208. BaseClassMajorSet majorSet = majorSetService.getOne(
  209. new QueryWrapper<BaseClassMajorSet>().lambda()
  210. .eq(BaseClassMajorSet::getClassId, baseClass.getId())
  211. );
  212. if(majorSet != null){
  213. majorSet.setClassId(baseClass.getId());
  214. majorSet.setMajorSetId(dto.getMajorSetId());
  215. majorSet.setModifyDate(new Date());
  216. majorSetService.updateById(majorSet);
  217. }
  218. if(baseClass.getTeacherId() != null){
  219. long count = roleRelationService.count(
  220. new QueryWrapper<UserRoleRelation>().lambda()
  221. .eq(UserRoleRelation::getUserId, dto.getTeacherId())
  222. .eq(UserRoleRelation::getRoleId, RoleEnum.CLASSTE.getCode())
  223. );
  224. if(count == 0){
  225. roleRelationService.save(
  226. new UserRoleRelation(){{
  227. setRoleId(RoleEnum.CLASSTE.getCode());
  228. setUserId(dto.getTeacherId());
  229. }}
  230. );
  231. }
  232. }
  233. if((baseClass.getTeacherId() == null && aClass.getTeacherId() != null) || (baseClass.getIsGraduate() != null && baseClass.getIsGraduate() == 2)){
  234. long count = this.count(
  235. new QueryWrapper<BaseClass>().lambda()
  236. .eq(BaseClass::getIsGraduate, 1)
  237. .eq(BaseClass::getTeacherId, aClass.getTeacherId())
  238. .eq(BaseClass::getDeleteMark, DeleteMark.NODELETE.getCode())
  239. .eq(BaseClass::getEnabledMark, EnabledMark.ENABLED.getCode())
  240. .ne(BaseClass::getId, dto.getId())
  241. );
  242. if(count == 0){
  243. roleRelationService.remove(
  244. new QueryWrapper<UserRoleRelation>().lambda()
  245. .eq(UserRoleRelation::getUserId, aClass.getTeacherId())
  246. .eq(UserRoleRelation::getRoleId, RoleEnum.CLASSTE.getCode())
  247. );
  248. }
  249. }
  250. CompletableFuture.runAsync(() -> {
  251. List<UserRoleRelation> userRoleRelationList = roleRelationService.list(Wrappers.lambdaQuery(UserRoleRelation.class));
  252. redisUtil.set(GlobalConstant.USER_ROLE_RELATION_CACHE_KEY, userRoleRelationList);
  253. });
  254. }
  255. return update;
  256. }
  257. }