BandingTaskClassController.java 12 KB

123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263646566676869707172737475767778798081828384858687888990919293949596979899100101102103104105106107108109110111112113114115116117118119120121122123124125126127128129130131132133134135136137138139140141142143144145146147148149150151152153154155156157158159160161162163164165166167168169170171172173174175176177178179180181182183184185186187188189190191192193194195196197198199200201202203204205206207208209210211212213214215216217218219220221222223224225226227228229230231232233234235236237238239240241242243244245246247248249250251252253254255256257258259260261262263264265266267268269270271272273
  1. package com.xjrsoft.module.banding.controller;
  2. import cn.dev33.satoken.annotation.SaCheckPermission;
  3. import cn.hutool.core.bean.BeanUtil;
  4. import com.alibaba.excel.EasyExcel;
  5. import com.alibaba.excel.support.ExcelTypeEnum;
  6. import com.baomidou.mybatisplus.core.conditions.query.QueryWrapper;
  7. import com.github.yulichang.wrapper.MPJLambdaWrapper;
  8. import com.xjrsoft.common.annotation.XjrLog;
  9. import com.xjrsoft.common.model.result.RT;
  10. import com.xjrsoft.common.utils.VoToColumnUtil;
  11. import com.xjrsoft.module.banding.dto.AddBandingTaskClassDto;
  12. import com.xjrsoft.module.banding.dto.BandingTaskClassListDto;
  13. import com.xjrsoft.module.banding.dto.BandingTaskClassPageDto;
  14. import com.xjrsoft.module.banding.dto.BandingTaskClassStudentPageDto;
  15. import com.xjrsoft.module.banding.dto.ChangeClassDto;
  16. import com.xjrsoft.module.banding.dto.ChangeClassStatusDto;
  17. import com.xjrsoft.module.banding.dto.StudentDto;
  18. import com.xjrsoft.module.banding.dto.SureBandingTaskDto;
  19. import com.xjrsoft.module.banding.dto.UpdateBandingClassDto;
  20. import com.xjrsoft.module.banding.entity.BandingTask;
  21. import com.xjrsoft.module.banding.entity.BandingTaskClass;
  22. import com.xjrsoft.module.banding.entity.BandingTaskClassStudent;
  23. import com.xjrsoft.module.banding.service.IBandingTaskClassService;
  24. import com.xjrsoft.module.banding.service.IBandingTaskClassStudentService;
  25. import com.xjrsoft.module.banding.service.IBandingTaskService;
  26. import com.xjrsoft.module.banding.vo.BandingTaskClassExcelVo;
  27. import com.xjrsoft.module.banding.vo.BandingTaskClassPageVo;
  28. import com.xjrsoft.module.banding.vo.BandingTaskClassStudentListVo;
  29. import com.xjrsoft.module.banding.vo.BandingTaskClassSureListVo;
  30. import com.xjrsoft.module.banding.vo.BandingTaskClassVo;
  31. import com.xjrsoft.module.student.dto.BaseNewStudentPageDto;
  32. import io.swagger.annotations.Api;
  33. import io.swagger.annotations.ApiOperation;
  34. import lombok.AllArgsConstructor;
  35. import org.springframework.http.ResponseEntity;
  36. import org.springframework.web.bind.annotation.DeleteMapping;
  37. import org.springframework.web.bind.annotation.GetMapping;
  38. import org.springframework.web.bind.annotation.PostMapping;
  39. import org.springframework.web.bind.annotation.PutMapping;
  40. import org.springframework.web.bind.annotation.RequestBody;
  41. import org.springframework.web.bind.annotation.RequestMapping;
  42. import org.springframework.web.bind.annotation.RequestParam;
  43. import org.springframework.web.bind.annotation.RestController;
  44. import org.springframework.web.multipart.MultipartFile;
  45. import javax.validation.Valid;
  46. import java.io.ByteArrayOutputStream;
  47. import java.io.IOException;
  48. import java.util.ArrayList;
  49. import java.util.Date;
  50. import java.util.List;
  51. import java.util.Map;
  52. /**
  53. * @title: 新生分班任务
  54. * @Author dzx
  55. * @Date: 2024-07-01
  56. * @Version 1.0
  57. */
  58. @RestController
  59. @RequestMapping("/banding" + "/bandingTaskClass")
  60. @Api(value = "/banding" + "/bandingTaskClass",tags = "新生分班任务班级配置代码")
  61. @AllArgsConstructor
  62. public class BandingTaskClassController {
  63. private final IBandingTaskService taskService;
  64. private final IBandingTaskClassService bandingTaskClassService;
  65. private final IBandingTaskClassStudentService classStudentService;
  66. @GetMapping(value = "/list")
  67. @ApiOperation(value="新生分班任务班级配置列表")
  68. @SaCheckPermission("bandingtask:detail")
  69. @XjrLog(value = "新生分班任务班级配置列表")
  70. public RT<List<BandingTaskClassPageVo>> list(@Valid BandingTaskClassPageDto dto){
  71. List<BandingTaskClassPageVo> list = bandingTaskClassService.getList(dto);
  72. return RT.ok(list);
  73. }
  74. @GetMapping(value = "/class-student")
  75. @ApiOperation(value="分班后的学生列表")
  76. @SaCheckPermission("bandingtask:detail")
  77. @XjrLog(value = "分班后的学生列表")
  78. public RT<List<BandingTaskClassStudentListVo>> classStudent(@Valid BandingTaskClassStudentPageDto dto){
  79. List<BandingTaskClassStudentListVo> list = bandingTaskClassService.classStudent(dto);
  80. return RT.ok(list);
  81. }
  82. @GetMapping(value = "/class-sure")
  83. @ApiOperation(value="分班确认列表")
  84. @SaCheckPermission("bandingtask:detail")
  85. @XjrLog(value = "分班确认列表")
  86. public RT<List<BandingTaskClassSureListVo>> classSure(@Valid BandingTaskClassStudentPageDto dto){
  87. List<BandingTaskClassSureListVo> list = bandingTaskClassService.getClassSure(dto);
  88. return RT.ok(list);
  89. }
  90. @GetMapping(value = "/info")
  91. @ApiOperation(value="根据id查询新生分班任务信息")
  92. @SaCheckPermission("bandingTaskClass:detail")
  93. @XjrLog(value = "根据id查询新生分班任务信息")
  94. public RT<BandingTaskClassVo> info(@RequestParam Long id){
  95. BandingTaskClass bandingTaskClass = bandingTaskClassService.getById(id);
  96. if (bandingTaskClass == null) {
  97. return RT.error("找不到此数据!");
  98. }
  99. return RT.ok(BeanUtil.toBean(bandingTaskClass, BandingTaskClassVo.class));
  100. }
  101. @PostMapping
  102. @ApiOperation(value = "新增新生分班")
  103. @SaCheckPermission("bandingTaskClass:add")
  104. @XjrLog(value = "新增新生分班")
  105. public RT<Boolean> add(@Valid @RequestBody List<AddBandingTaskClassDto> dtoList){
  106. List<BandingTaskClass> dataList = new ArrayList<>();
  107. List<String> errorList = new ArrayList<>();
  108. for (AddBandingTaskClassDto dto : dtoList) {
  109. BandingTask task = taskService.getById(dto.getBandingTaskId());
  110. if(dto.getSortCode() != null){
  111. List<BandingTaskClass> list = bandingTaskClassService.list(
  112. new QueryWrapper<BandingTaskClass>().lambda()
  113. .eq(BandingTaskClass::getSortCode, dto.getSortCode())
  114. .eq(BandingTaskClass::getBandingTaskId, dto.getBandingTaskId())
  115. );
  116. if(!list.isEmpty()){
  117. errorList.add(dto.getName());
  118. }
  119. }
  120. BandingTaskClass bandingTaskClass = BeanUtil.toBean(dto, BandingTaskClass.class);
  121. bandingTaskClass.setCreateDate(new Date());
  122. bandingTaskClass.setStatus(task.getStatus());
  123. dataList.add(bandingTaskClass);
  124. }
  125. if(!errorList.isEmpty()){
  126. return RT.error(errorList.toString().replace("[", "").replace("]", "") + ",分班排序重复");
  127. }
  128. boolean isSuccess = bandingTaskClassService.saveBatch(dataList);
  129. return RT.ok(isSuccess);
  130. }
  131. @PutMapping
  132. @ApiOperation(value = "批量新增或者修改新生分班")
  133. @SaCheckPermission("bandingTaskClass:edit")
  134. @XjrLog(value = "批量新增或者修改新生分班")
  135. public RT<Boolean> update(@Valid @RequestBody List<UpdateBandingClassDto> dtoList){
  136. Boolean isSuccess = bandingTaskClassService.saveClass(dtoList);
  137. return RT.ok(isSuccess);
  138. }
  139. @DeleteMapping
  140. @ApiOperation(value = "删除新生分班")
  141. @SaCheckPermission("bandingTaskClass:delete")
  142. @XjrLog(value = "删除新生分班")
  143. public RT<Boolean> delete(@Valid @RequestBody List<Long> ids){
  144. if(!ids.isEmpty()){
  145. classStudentService.remove(
  146. new QueryWrapper<BandingTaskClassStudent>().lambda()
  147. .in(BandingTaskClassStudent::getBandingTaskClassId, ids)
  148. );
  149. }
  150. return RT.ok(bandingTaskClassService.delete(ids));
  151. }
  152. @PostMapping("/import")
  153. @ApiOperation(value = "导入")
  154. @XjrLog(value = "导入")
  155. public RT<Boolean> importData(@RequestParam Long bandingTaskId, @RequestParam MultipartFile file) throws IOException {
  156. List<Map<Integer, Object>> excelDataList = EasyExcel.read(file.getInputStream()).sheet().headRowNumber(3).doReadSync();
  157. Boolean result = bandingTaskClassService.importData(bandingTaskId, excelDataList);
  158. return RT.ok(result);
  159. }
  160. @PostMapping("/export-query")
  161. @ApiOperation(value = "导出学生列表")
  162. @XjrLog(value = "导出学生列表")
  163. public ResponseEntity<byte[]> exportData(@Valid @RequestBody BandingTaskClassStudentPageDto dto) {
  164. List<BandingTaskClassStudentListVo> listVos = bandingTaskClassService.classStudent(dto);
  165. List<BandingTaskClassExcelVo> list = BeanUtil.copyToList(listVos, BandingTaskClassExcelVo.class);
  166. ByteArrayOutputStream bot = new ByteArrayOutputStream();
  167. EasyExcel.write(bot, BandingTaskClassExcelVo.class).automaticMergeHead(false).excelType(ExcelTypeEnum.XLSX).sheet().doWrite(list);
  168. return RT.fileStream(bot.toByteArray(), "banding" + ExcelTypeEnum.XLSX.getValue());
  169. }
  170. @PostMapping("/reset")
  171. @ApiOperation(value = "重置功能")
  172. @SaCheckPermission("bandingTaskClass:add")
  173. @XjrLog(value = "重置功能")
  174. public RT<Boolean> reset(@Valid @RequestBody SureBandingTaskDto dto){
  175. boolean isSuccess = bandingTaskClassService.reset(dto.getBandingTaskId());
  176. return RT.ok(isSuccess);
  177. }
  178. @PostMapping("/change-class")
  179. @ApiOperation(value = "调整班级")
  180. @SaCheckPermission("bandingTaskClass:change-class")
  181. @XjrLog(value = "调整班级")
  182. public RT<Boolean> changeClass(@Valid @RequestBody ChangeClassDto dto){
  183. boolean isSuccess = classStudentService.changeClass(dto);
  184. return RT.ok(isSuccess);
  185. }
  186. @PostMapping("/remove-student")
  187. @ApiOperation(value = "移出学生")
  188. @XjrLog(value = "移出学生")
  189. @SaCheckPermission("bandingTaskClass:remove-student")
  190. public RT<Boolean> removeStudent(@Valid @RequestBody ChangeClassDto dto){
  191. boolean isSuccess = classStudentService.removeStudent(dto);
  192. return RT.ok(isSuccess);
  193. }
  194. @PostMapping("/insert-student")
  195. @ApiOperation(value = "移入学生")
  196. @SaCheckPermission("bandingTaskClass:insert-student")
  197. @XjrLog(value = "移入学生")
  198. public RT<Boolean> insertStudent(@Valid @RequestBody ChangeClassDto dto){
  199. boolean isSuccess = classStudentService.insertStudent(dto);
  200. return RT.ok(isSuccess);
  201. }
  202. @GetMapping("/satisfy-student")
  203. @ApiOperation(value = "满足学生")
  204. @SaCheckPermission("bandingTaskClass:satisfy-student")
  205. @XjrLog(value = "满足学生")
  206. public RT<List<BaseNewStudentPageDto>> satisfyStudent(@Valid StudentDto dto){
  207. List<BaseNewStudentPageDto> list = classStudentService.satisfyStudent(dto);
  208. return RT.ok(list);
  209. }
  210. @GetMapping("/surplus-student")
  211. @ApiOperation(value = "剩余学生")
  212. @SaCheckPermission("bandingTaskClass:surplus-student")
  213. @XjrLog(value = "剩余学生")
  214. public RT<List<BaseNewStudentPageDto>> surplusStudent(@Valid StudentDto dto){
  215. List<BaseNewStudentPageDto> list = classStudentService.surplusStudent(dto);
  216. return RT.ok(list);
  217. }
  218. @GetMapping("/classListParam")
  219. @ApiOperation(value = "根据专业和年级查询班级")
  220. @SaCheckPermission("bandingTaskClass:surplus-student")
  221. @XjrLog(value = "根据专业和年级查询班级")
  222. public RT<List<BandingTaskClassVo>> classListParam(@Valid BandingTaskClassListDto dto){
  223. List<BandingTaskClassVo> list = bandingTaskClassService.selectJoinList(BandingTaskClassVo.class,
  224. new MPJLambdaWrapper<BandingTaskClass>()
  225. .select(BandingTaskClass::getId)
  226. .select(BandingTaskClass.class, x -> VoToColumnUtil.fieldsToColumns(BandingTaskClass.class).contains(x.getProperty()))
  227. .leftJoin(BandingTask.class, BandingTask::getId, BandingTaskClass::getBandingTaskId)
  228. .eq(BandingTask::getGradeId, dto.getGradeId())
  229. .eq(BandingTaskClass::getMajorSetId, dto.getMajorSetId())
  230. );
  231. return RT.ok(list);
  232. }
  233. @PostMapping(value = "/change-status")
  234. @ApiOperation(value="修改状态")
  235. @SaCheckPermission("officebuild:detail")
  236. @XjrLog(value = "修改状态")
  237. public RT<Boolean> changeStatus(@Valid @RequestBody ChangeClassStatusDto dto) throws Exception {
  238. BandingTaskClass taskClass = bandingTaskClassService.getById(dto.getId());
  239. taskClass.setStatus(dto.getStatus());
  240. bandingTaskClassService.updateById(taskClass);
  241. return RT.ok(true);
  242. }
  243. }