BandingTaskClassStudentServiceImpl.java 17 KB

123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263646566676869707172737475767778798081828384858687888990919293949596979899100101102103104105106107108109110111112113114115116117118119120121122123124125126127128129130131132133134135136137138139140141142143144145146147148149150151152153154155156157158159160161162163164165166167168169170171172173174175176177178179180181182183184185186187188189190191192193194195196197198199200201202203204205206207208209210211212213214215216217218219220221222223224225226227228229230231232233234235236237238239240241242243244245246247248249250251252253254255256257258259260261262263264265266267268269270271272273274275276277278279280281282283284285286287288289290291292293294295296297298299300301302303304305306307308309310311312313314315316317318319320321322323324325326327328329330331332333334335336337338339340341342343344345346347348349350351
  1. package com.xjrsoft.module.banding.service.impl;
  2. import cn.dev33.satoken.secure.BCrypt;
  3. import cn.dev33.satoken.stp.StpUtil;
  4. import com.baomidou.mybatisplus.core.conditions.query.QueryWrapper;
  5. import com.github.yulichang.base.MPJBaseServiceImpl;
  6. import com.xjrsoft.common.enums.ArchivesStatusEnum;
  7. import com.xjrsoft.common.enums.DeleteMark;
  8. import com.xjrsoft.common.enums.EnabledMark;
  9. import com.xjrsoft.common.enums.RoleEnum;
  10. import com.xjrsoft.common.exception.MyException;
  11. import com.xjrsoft.config.CommonPropertiesConfig;
  12. import com.xjrsoft.module.banding.dto.BandingTaskClassStudentPageDto;
  13. import com.xjrsoft.module.banding.dto.ChangeClassDto;
  14. import com.xjrsoft.module.banding.dto.StudentDto;
  15. import com.xjrsoft.module.banding.entity.BandingTask;
  16. import com.xjrsoft.module.banding.entity.BandingTaskClass;
  17. import com.xjrsoft.module.banding.entity.BandingTaskClassStudent;
  18. import com.xjrsoft.module.banding.mapper.BandingTaskClassMapper;
  19. import com.xjrsoft.module.banding.mapper.BandingTaskClassStudentMapper;
  20. import com.xjrsoft.module.banding.mapper.BandingTaskMapper;
  21. import com.xjrsoft.module.banding.service.IBandingTaskClassStudentService;
  22. import com.xjrsoft.module.banding.vo.BandingTaskClassSureListVo;
  23. import com.xjrsoft.module.base.entity.BaseClass;
  24. import com.xjrsoft.module.base.entity.BaseMajorSet;
  25. import com.xjrsoft.module.base.mapper.BaseMajorSetMapper;
  26. import com.xjrsoft.module.base.service.IBaseClassService;
  27. import com.xjrsoft.module.organization.entity.User;
  28. import com.xjrsoft.module.organization.entity.UserRoleRelation;
  29. import com.xjrsoft.module.organization.service.IUserRoleRelationService;
  30. import com.xjrsoft.module.organization.service.IUserService;
  31. import com.xjrsoft.module.student.dto.BaseNewStudentPageDto;
  32. import com.xjrsoft.module.student.entity.BaseClassMajorSet;
  33. import com.xjrsoft.module.student.entity.BaseNewStudent;
  34. import com.xjrsoft.module.student.entity.BaseStudent;
  35. import com.xjrsoft.module.student.entity.BaseStudentFamily;
  36. import com.xjrsoft.module.student.entity.BaseStudentSchoolRoll;
  37. import com.xjrsoft.module.student.mapper.BaseClassMajorSetMapper;
  38. import com.xjrsoft.module.student.service.IBaseNewStudentService;
  39. import com.xjrsoft.module.student.service.IBaseStudentFamilyService;
  40. import com.xjrsoft.module.student.service.IBaseStudentSchoolRollService;
  41. import com.xjrsoft.module.student.service.IBaseStudentService;
  42. import lombok.AllArgsConstructor;
  43. import org.springframework.stereotype.Service;
  44. import org.springframework.transaction.annotation.Transactional;
  45. import java.time.LocalDate;
  46. import java.time.LocalDateTime;
  47. import java.time.format.DateTimeFormatter;
  48. import java.util.ArrayList;
  49. import java.util.Date;
  50. import java.util.HashMap;
  51. import java.util.List;
  52. import java.util.Map;
  53. import java.util.Set;
  54. import java.util.stream.Collectors;
  55. /**
  56. * @title: 新生分班任务
  57. * @Author dzx
  58. * @Date: 2024-07-01
  59. * @Version 1.0
  60. */
  61. @Service
  62. @AllArgsConstructor
  63. public class BandingTaskClassStudentServiceImpl extends MPJBaseServiceImpl<BandingTaskClassStudentMapper, BandingTaskClassStudent> implements IBandingTaskClassStudentService {
  64. private final BandingTaskClassMapper taskClassMapper;
  65. private final BandingTaskMapper bandingTaskMapper;
  66. private final IBaseNewStudentService newStudentService;
  67. private final IBaseClassService classService;
  68. private final BaseClassMajorSetMapper classMajorSetMapper;
  69. private final CommonPropertiesConfig propertiesConfig;
  70. private final IUserService userService;
  71. private final IUserRoleRelationService roleRelationService;
  72. private final IBaseStudentSchoolRollService schoolRollService;
  73. private final IBaseStudentService studentService;
  74. private final IBaseStudentFamilyService familyService;
  75. private final BaseMajorSetMapper majorSetMapper;
  76. @Override
  77. public Boolean add(BandingTaskClassStudent bandingTaskClass) {
  78. bandingTaskClass.setCreateDate(new Date());
  79. this.baseMapper.insert(bandingTaskClass);
  80. return true;
  81. }
  82. @Override
  83. public Boolean update(BandingTaskClassStudent bandingTaskClass) {
  84. bandingTaskClass.setModifyDate(new Date());
  85. this.baseMapper.updateById(bandingTaskClass);
  86. return true;
  87. }
  88. @Override
  89. @Transactional(rollbackFor = Exception.class)
  90. public Boolean delete(List<Long> ids) {
  91. this.baseMapper.deleteBatchIds(ids);
  92. return true;
  93. }
  94. @Transactional
  95. @Override
  96. public Boolean changeClass(ChangeClassDto dto) {
  97. this.baseMapper.delete(
  98. new QueryWrapper<BandingTaskClassStudent>().lambda()
  99. .in(BandingTaskClassStudent::getNewStudentId, dto.getNewStudentIds())
  100. );
  101. List<BandingTaskClassStudent> dataList = new ArrayList<>();
  102. long createUserId = StpUtil.getLoginIdAsLong();
  103. for (Long newStudentId : dto.getNewStudentIds()) {
  104. dataList.add(
  105. new BandingTaskClassStudent(){{
  106. setCreateDate(new Date());
  107. setNewStudentId(newStudentId);
  108. setBandingTaskClassId(dto.getBandingTaskClassId());
  109. setCreateUserId(createUserId);
  110. setStatus(0);
  111. if(dto.getIsHandle() != null && dto.getIsHandle() == 1){
  112. setStatus(1);
  113. }
  114. }}
  115. );
  116. }
  117. if(!dataList.isEmpty()){
  118. this.saveBatch(dataList);
  119. }
  120. if(dto.getIsHandle() != null && dto.getIsHandle() == 1){
  121. BandingTaskClass taskClass = taskClassMapper.selectById(dto.getBandingTaskClassId());
  122. List<Long> studentIds = dataList.stream().map(BandingTaskClassStudent::getNewStudentId).collect(Collectors.toList());
  123. List<BaseNewStudent> list = newStudentService.list(
  124. new QueryWrapper<BaseNewStudent>().lambda()
  125. .in(BaseNewStudent::getId, studentIds)
  126. );
  127. List<BaseNewStudent> updateList = new ArrayList<>();
  128. for (BaseNewStudent student : list) {
  129. student.setStatus(1);
  130. updateList.add(student);
  131. }
  132. if(!updateList.isEmpty()){
  133. newStudentService.updateBatchById(updateList);
  134. }
  135. {
  136. Date createDate = new Date();
  137. BandingTask bandingTask = bandingTaskMapper.selectById(taskClass.getBandingTaskId());
  138. List<BandingTaskClassSureListVo> classSure = taskClassMapper.getClassSure(new BandingTaskClassStudentPageDto() {{
  139. setBandingTaskId(taskClass.getBandingTaskId());
  140. }});
  141. Map<Long, Integer> classTotal = classSure.stream().collect(Collectors.toMap(BandingTaskClassSureListVo::getId, BandingTaskClassSureListVo::getNumber));
  142. Map<Long, Integer> classBoy = classSure.stream().collect(Collectors.toMap(BandingTaskClassSureListVo::getId, BandingTaskClassSureListVo::getMaleCount));
  143. Map<Long, Integer> classGirl = classSure.stream().collect(Collectors.toMap(BandingTaskClassSureListVo::getId, BandingTaskClassSureListVo::getFemaleCount));
  144. //生成班级数据
  145. Map<Long, Long> classMap = new HashMap<>();
  146. Map<Long, Long> taskClassMajorMap = new HashMap<>();
  147. //查询出需要新增的班级信息
  148. Map<Long, Long> majorDeptMap = majorSetMapper.selectList(
  149. new QueryWrapper<BaseMajorSet>()
  150. ).stream().collect(Collectors.toMap(BaseMajorSet::getId, BaseMajorSet::getDepartmentId));
  151. //先查询是否已经存在这个班级,如果存在就更新,不存在就新增
  152. BaseClass baseClass = classService.getOne(
  153. new QueryWrapper<BaseClass>().lambda()
  154. .eq(BaseClass::getName, taskClass.getName())
  155. .eq(BaseClass::getClassroomId, taskClass.getClassroomId())
  156. .eq(BaseClass::getTeacherId, taskClass.getTeacherId())
  157. .eq(BaseClass::getMajorSetId, taskClass.getMajorSetId())
  158. .eq(BaseClass::getGradeId, bandingTask.getGradeId())
  159. .eq(BaseClass::getEnrollType, bandingTask.getEnrollType())
  160. );
  161. if(baseClass == null){
  162. baseClass = new BaseClass() {{
  163. setName(taskClass.getName());
  164. setClassroomId(taskClass.getClassroomId());
  165. setTeacherId(taskClass.getTeacherId());
  166. setIsGraduate(1);
  167. setMajorSetId(taskClass.getMajorSetId());
  168. setOrgId(majorDeptMap.get(taskClass.getMajorSetId()));
  169. setIsOrderClass(taskClass.getIsOrderClass()==null?0:taskClass.getIsOrderClass().intValue());
  170. setGradeId(bandingTask.getGradeId());
  171. setDeleteMark(DeleteMark.NODELETE.getCode());
  172. setEnrollType(bandingTask.getEnrollType());
  173. setCreateDate(new Date());
  174. }};
  175. classService.save(baseClass);
  176. BaseClassMajorSet majorSet = new BaseClassMajorSet() {{
  177. setCreateDate(createDate);
  178. setMajorSetId(taskClass.getMajorSetId());
  179. setPlanTotalStudent(taskClass.getNumber());
  180. setTotalStudent(classTotal.get(taskClass.getId()));
  181. setBoyNum(classBoy.get(taskClass.getId()));
  182. setGirlNum(classGirl.get(taskClass.getId()));
  183. }};
  184. majorSet.setClassId(baseClass.getId());
  185. classMajorSetMapper.insert(majorSet);
  186. }
  187. classMap.put(taskClass.getId(), baseClass.getId());
  188. taskClassMajorMap.put(taskClass.getId(), taskClass.getMajorSetId());
  189. /**
  190. * 新增学生数据
  191. * 1、新增用户xjr_user
  192. * 2、新增用户与角色的关系xjr_user_role_relation
  193. * 3、新增学生基本信息base_student
  194. * 4、新增学籍信息表base_student_school_roll
  195. * 5、新增家庭信息表base_student_family
  196. */
  197. LocalDateTime now = LocalDateTime.now();
  198. List<String> idNumbers = updateList.stream().map(BaseNewStudent::getCredentialNumber).collect(Collectors.toList());
  199. List<User> students = userService.list(new QueryWrapper<User>().lambda().in(User::getCredentialNumber, idNumbers));
  200. Set<String> userSet = students.stream().map(User::getCredentialNumber).collect(Collectors.toSet());
  201. Map<Long, Long> studentClassRelation = dataList.stream().collect(Collectors.toMap(BandingTaskClassStudent::getNewStudentId, BandingTaskClassStudent::getBandingTaskClassId));
  202. for (BaseNewStudent student : updateList) {
  203. if(userSet.contains(student.getCredentialNumber())){
  204. continue;
  205. }
  206. LocalDate birthDate = getBirthDate(student.getCredentialNumber());
  207. User xjrUser = new User() {{
  208. setCreateDate(now);
  209. setPassword(BCrypt.hashpw(propertiesConfig.getDefaultPassword(), BCrypt.gensalt()));
  210. setName(student.getName());
  211. setUserName(student.getCredentialNumber());
  212. setCredentialNumber(student.getCredentialNumber());
  213. setCredentialType("ZZLS10007");
  214. setMobile(student.getMobile());
  215. setEnabledMark(EnabledMark.DISABLED.getCode());
  216. setGender(student.getGender());
  217. setIsChangePassword(1);
  218. setBirthDate(birthDate.atStartOfDay());
  219. }};
  220. userService.save(xjrUser);
  221. UserRoleRelation userRoleRelation = new UserRoleRelation() {{
  222. setRoleId(RoleEnum.STUDENT.getCode());
  223. setUserId(xjrUser.getId());
  224. }};
  225. roleRelationService.save(userRoleRelation);
  226. BaseStudent baseStudent = new BaseStudent() {{
  227. setUserId(xjrUser.getId());
  228. setCreateDate(now);
  229. setStudentId(student.getCredentialNumber());
  230. if(student.getHeight() != null){
  231. setHeight(student.getHeight().doubleValue());
  232. }
  233. if(student.getWeight() != null){
  234. setWeight(student.getWeight().doubleValue());
  235. }
  236. }};
  237. studentService.save(baseStudent);
  238. BaseStudentSchoolRoll schoolRoll = new BaseStudentSchoolRoll() {{
  239. setUserId(xjrUser.getId());
  240. if(student.getScore() != null){
  241. setGraduatedScore(student.getScore().doubleValue());
  242. }
  243. setGraduatedUniversity(student.getGraduateSchool());
  244. setClassId(classMap.get(studentClassRelation.get(student.getId())));
  245. setMajorSetId(taskClassMajorMap.get(studentClassRelation.get(student.getId())));
  246. setStduyStatus(student.getStduyStatus());
  247. setEnrollType(bandingTask.getEnrollType());
  248. setStudentSource(student.getSource());
  249. setGradeId(bandingTask.getGradeId());
  250. setArchivesStatus(ArchivesStatusEnum.FB2901.getCode());
  251. setCreateDate(now);
  252. }};
  253. schoolRollService.save(schoolRoll);
  254. BaseStudentFamily studentFamily = new BaseStudentFamily() {{
  255. setCreateDate(now);
  256. setUserId(xjrUser.getId());
  257. setTelephone(student.getFamilyMobile());
  258. setAddress(student.getFamilyAddress());
  259. }};
  260. familyService.save(studentFamily);
  261. }
  262. }
  263. }
  264. return true;
  265. }
  266. void createStudentData(Long badingTaskId,List<BandingTaskClassStudent> classStudents, List<BaseNewStudent> updateList){
  267. }
  268. LocalDate getBirthDate(String idCardNumber){
  269. // 获取出生日期前6位,即yyyyMM
  270. String birthdayString = idCardNumber.substring(6, 14);
  271. // 将字符串解析为LocalDate对象
  272. DateTimeFormatter formatter = DateTimeFormatter.ofPattern("yyyyMMdd");
  273. try {
  274. LocalDate parse = LocalDate.parse(birthdayString, formatter);
  275. return parse;
  276. }catch (Exception e){
  277. throw new MyException("身份证号填写错误,无法提取出生日期");
  278. }
  279. }
  280. @Override
  281. public Boolean removeStudent(ChangeClassDto dto) {
  282. this.baseMapper.delete(
  283. new QueryWrapper<BandingTaskClassStudent>().lambda()
  284. .in(BandingTaskClassStudent::getNewStudentId, dto.getNewStudentIds())
  285. .eq(BandingTaskClassStudent::getBandingTaskClassId, dto.getBandingTaskClassId())
  286. );
  287. return true;
  288. }
  289. @Override
  290. public List<BaseNewStudentPageDto> satisfyStudent(StudentDto dto) {
  291. BandingTaskClass taskClass = taskClassMapper.selectById(dto.getBandingTaskClassId());
  292. dto.setBandingTaskId(taskClass.getBandingTaskId());
  293. return this.baseMapper.satisfyStudent(dto);
  294. }
  295. @Override
  296. public List<BaseNewStudentPageDto> surplusStudent(StudentDto dto) {
  297. BandingTaskClass taskClass = taskClassMapper.selectById(dto.getBandingTaskClassId());
  298. dto.setMajorSetId(taskClass.getMajorSetId());
  299. dto.setBandingTaskId(taskClass.getBandingTaskId());
  300. return this.baseMapper.surplusStudent(dto);
  301. }
  302. @Override
  303. public Boolean insertStudent(ChangeClassDto dto) {
  304. List<BandingTaskClassStudent> dataList = new ArrayList<>();
  305. Date createDate = new Date();
  306. for (Long newStudentId : dto.getNewStudentIds()) {
  307. dataList.add(
  308. new BandingTaskClassStudent(){{
  309. setNewStudentId(newStudentId);
  310. setCreateDate(createDate);
  311. setStatus(0);
  312. setBandingTaskClassId(dto.getBandingTaskClassId());
  313. }}
  314. );
  315. }
  316. if(!dataList.isEmpty()){
  317. this.saveBatch(dataList);
  318. }
  319. return true;
  320. }
  321. }