BaseStudentCadreController.java 14 KB

123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263646566676869707172737475767778798081828384858687888990919293949596979899100101102103104105106107108109110111112113114115116117118119120121122123124125126127128129130131132133134135136137138139140141142143144145146147148149150151152153154155156157158159160161162163164165166167168169170171172173174175176177178179180181182183184185186187188189190191192193194195196197198199200201202203204205206207208209210211212213214215216217218219220221222223224225226227228229230231232233234235236237238239240241242243244245246247248249250251252253254255256257258259260
  1. package com.xjrsoft.module.student.controller;
  2. import cn.dev33.satoken.annotation.SaCheckPermission;
  3. import cn.dev33.satoken.stp.StpUtil;
  4. import cn.hutool.core.bean.BeanUtil;
  5. import cn.hutool.core.util.ObjectUtil;
  6. import cn.hutool.core.util.StrUtil;
  7. import com.alibaba.excel.EasyExcel;
  8. import com.alibaba.excel.support.ExcelTypeEnum;
  9. import com.baomidou.mybatisplus.core.metadata.IPage;
  10. import com.baomidou.mybatisplus.core.metadata.OrderItem;
  11. import com.baomidou.mybatisplus.core.toolkit.Wrappers;
  12. import com.github.yulichang.toolkit.MPJWrappers;
  13. import com.github.yulichang.wrapper.MPJLambdaWrapper;
  14. import com.xjrsoft.common.enums.StudentCadreLevelEnum;
  15. import com.xjrsoft.common.model.result.R;
  16. import com.xjrsoft.common.model.result.RT;
  17. import com.xjrsoft.common.page.ConventPage;
  18. import com.xjrsoft.common.page.PageOutput;
  19. import com.xjrsoft.common.utils.VoToColumnUtil;
  20. import com.xjrsoft.module.base.entity.BaseClass;
  21. import com.xjrsoft.module.base.mapper.BaseClassMapper;
  22. import com.xjrsoft.module.student.dto.AddBaseStudentCadreDto;
  23. import com.xjrsoft.module.student.dto.BaseStudentCadrePageDto;
  24. import com.xjrsoft.module.student.dto.UpdateBaseStudentCadreDto;
  25. import com.xjrsoft.module.student.entity.BaseStudent;
  26. import com.xjrsoft.module.student.entity.BaseStudentCadre;
  27. import com.xjrsoft.module.student.entity.BaseStudentPost;
  28. import com.xjrsoft.module.student.entity.BaseStudentSchoolRoll;
  29. import com.xjrsoft.module.student.mapper.BaseStudentSchoolRollMapper;
  30. import com.xjrsoft.module.student.service.IBaseStudentCadreService;
  31. import com.xjrsoft.module.student.vo.BaseStudentCadrePageVo;
  32. import com.xjrsoft.module.student.vo.BaseStudentCadreVo;
  33. import com.xjrsoft.module.teacher.entity.XjrUser;
  34. import io.swagger.annotations.Api;
  35. import io.swagger.annotations.ApiOperation;
  36. import lombok.AllArgsConstructor;
  37. import org.springframework.http.ResponseEntity;
  38. import org.springframework.web.bind.annotation.DeleteMapping;
  39. import org.springframework.web.bind.annotation.GetMapping;
  40. import org.springframework.web.bind.annotation.PostMapping;
  41. import org.springframework.web.bind.annotation.PutMapping;
  42. import org.springframework.web.bind.annotation.RequestBody;
  43. import org.springframework.web.bind.annotation.RequestMapping;
  44. import org.springframework.web.bind.annotation.RequestParam;
  45. import org.springframework.web.bind.annotation.RestController;
  46. import javax.validation.Valid;
  47. import java.io.ByteArrayOutputStream;
  48. import java.util.ArrayList;
  49. import java.util.List;
  50. /**
  51. * @title: 学生干部管理
  52. * @Author dzx
  53. * @Date: 2023-11-14
  54. * @Version 1.0
  55. */
  56. @RestController
  57. @RequestMapping("/student" + "/basestudentcadre")
  58. @Api(value = "/student" + "/basestudentcadre",tags = "学生干部管理代码")
  59. @AllArgsConstructor
  60. public class BaseStudentCadreController {
  61. private final IBaseStudentCadreService baseStudentCadreService;
  62. private final BaseStudentSchoolRollMapper baseStudentSchoolRollMapper;
  63. private final BaseClassMapper baseClassMapper;
  64. @GetMapping(value = "/classlist")
  65. @ApiOperation(value="获取班主任管理的班级")
  66. @SaCheckPermission("basestudentcadre:detail")
  67. public RT<List<BaseClass>> classList(){
  68. List<BaseClass> pageOutput = baseClassMapper.selectJoinList(BaseClass.class, new MPJLambdaWrapper<BaseClass>()
  69. .disableSubLogicDel()
  70. .eq(BaseClass::getTeacherId, StpUtil.getLoginIdAsLong())
  71. );
  72. return RT.ok(pageOutput);
  73. }
  74. @GetMapping(value = "/mobliepage")
  75. @ApiOperation(value="学生干部管理列表(移动端分页)")
  76. @SaCheckPermission("basestudentcadre:detail")
  77. public RT<PageOutput<BaseStudentCadrePageVo>> mobliepage(@Valid BaseStudentCadrePageDto dto){
  78. // 如果未传班级id和职务id,
  79. if(!StrUtil.equals(dto.getLevel(), StudentCadreLevelEnum.CLASS.getCode()) && ObjectUtil.isEmpty(dto.getPostId())){
  80. PageOutput<BaseStudentCadrePageVo> result = ConventPage.getPageOutputNull(BaseStudentCadrePageVo.class);
  81. return RT.ok(result);
  82. }
  83. IPage<BaseStudentCadrePageVo> page = baseStudentCadreService.selectJoinListPage(ConventPage.getPage(dto), BaseStudentCadrePageVo.class,
  84. MPJWrappers.<BaseStudentCadre>lambdaJoin()
  85. .like(StrUtil.isNotBlank(dto.getUserName()), XjrUser::getName, dto.getUserName())
  86. .eq(ObjectUtil.isNotEmpty(dto.getClassId()), BaseStudentCadre::getClassId, dto.getClassId())
  87. .eq(ObjectUtil.isNotEmpty(dto.getPostId()), BaseStudentCadre::getPostId, dto.getPostId())
  88. .eq(ObjectUtil.isNotEmpty(dto.getLevel()), BaseStudentPost::getLevel, dto.getLevel())
  89. .eq(ObjectUtil.isNotEmpty(dto.getPost()), BaseStudentPost::getPost, dto.getPost())
  90. .eq(StrUtil.equals(dto.getLevel(), StudentCadreLevelEnum.CLASS.getCode()), BaseClass::getTeacherId, StpUtil.getLoginIdAsLong())
  91. .between(ObjectUtil.isNotNull(dto.getStartTimeStart()) && ObjectUtil.isNotNull(dto.getStartTimeEnd()), BaseStudentCadre::getStartTime,dto.getStartTimeStart(),dto.getStartTimeEnd())
  92. .between(ObjectUtil.isNotNull(dto.getEndTimeStart()) && ObjectUtil.isNotNull(dto.getEndTimeEnd()), BaseStudentCadre::getEndTime,dto.getEndTimeStart(),dto.getEndTimeEnd())
  93. .orderByDesc(BaseStudentCadre::getId)
  94. .selectAs(BaseStudent::getStudentId, BaseStudentCadrePageVo::getStudentId)
  95. .selectAs(XjrUser::getName, BaseStudentCadrePageVo::getUserName)
  96. .selectAs(BaseClass::getName, BaseStudentCadrePageVo::getClassName)
  97. .selectAs(BaseStudentPost::getPost, BaseStudentCadrePageVo::getPost)
  98. .selectAs(BaseStudentPost::getLevel, BaseStudentCadrePageVo::getLevel)
  99. .select(BaseStudentCadre::getId)
  100. .select(BaseStudentCadre.class,x -> VoToColumnUtil.fieldsToColumns(BaseStudentCadrePageVo.class).contains(x.getProperty()))
  101. .innerJoin(XjrUser.class, XjrUser::getId, BaseStudentCadre::getUserId)
  102. .innerJoin(BaseStudent.class, BaseStudent::getUserId, BaseStudentCadre::getUserId)
  103. .innerJoin(BaseStudentPost.class, BaseStudentPost::getId, BaseStudentCadre::getPostId)
  104. .leftJoin(BaseClass.class, BaseClass::getId, BaseStudentCadre::getClassId)
  105. .leftJoin(BaseStudentSchoolRoll.class, BaseStudentSchoolRoll::getUserId, BaseStudentCadre::getUserId)).setSize(15);
  106. PageOutput<BaseStudentCadrePageVo> pageOutput = ConventPage.getPageOutput(page, BaseStudentCadrePageVo.class);
  107. return RT.ok(pageOutput);
  108. }
  109. @GetMapping(value = "/page")
  110. @ApiOperation(value="学生干部管理列表(分页)")
  111. @SaCheckPermission("basestudentcadre:detail")
  112. public RT<PageOutput<BaseStudentCadrePageVo>> page(@Valid BaseStudentCadrePageDto dto){
  113. // 如果未传班级id和职务id,
  114. if(!StrUtil.equals(dto.getLevel(), StudentCadreLevelEnum.CLASS.getCode()) && ObjectUtil.isEmpty(dto.getPostId())){
  115. PageOutput<BaseStudentCadrePageVo> result = ConventPage.getPageOutputNull(BaseStudentCadrePageVo.class);
  116. return RT.ok(result);
  117. }
  118. IPage<BaseStudentCadrePageVo> page = baseStudentCadreService.selectJoinListPage(ConventPage.getPage(dto), BaseStudentCadrePageVo.class,
  119. MPJWrappers.<BaseStudentCadre>lambdaJoin()
  120. .like(StrUtil.isNotBlank(dto.getUserName()), XjrUser::getName, dto.getUserName())
  121. .eq(ObjectUtil.isNotEmpty(dto.getClassId()), BaseStudentCadre::getClassId, dto.getClassId())
  122. .eq(ObjectUtil.isNotEmpty(dto.getPostId()), BaseStudentCadre::getPostId, dto.getPostId())
  123. .eq(ObjectUtil.isNotEmpty(dto.getLevel()), BaseStudentPost::getLevel, dto.getLevel())
  124. .eq(ObjectUtil.isNotEmpty(dto.getPost()), BaseStudentPost::getPost, dto.getPost())
  125. .eq(StrUtil.equals(dto.getLevel(), StudentCadreLevelEnum.CLASS.getCode()), BaseClass::getTeacherId, StpUtil.getLoginIdAsLong())
  126. .orderByDesc(BaseStudentCadre::getId)
  127. .selectAs(BaseStudent::getStudentId, BaseStudentCadrePageVo::getStudentId)
  128. .selectAs(XjrUser::getName, BaseStudentCadrePageVo::getUserName)
  129. .selectAs(BaseClass::getName, BaseStudentCadrePageVo::getClassName)
  130. .selectAs(BaseStudentPost::getPost, BaseStudentCadrePageVo::getPost)
  131. .selectAs(BaseStudentPost::getLevel, BaseStudentCadrePageVo::getLevel)
  132. .select(BaseStudentCadre::getId)
  133. .select(BaseStudentCadre.class,x -> VoToColumnUtil.fieldsToColumns(BaseStudentCadrePageVo.class).contains(x.getProperty()))
  134. .innerJoin(XjrUser.class, XjrUser::getId, BaseStudentCadre::getUserId)
  135. .innerJoin(BaseStudent.class, BaseStudent::getUserId, BaseStudentCadre::getUserId)
  136. .innerJoin(BaseStudentPost.class, BaseStudentPost::getId, BaseStudentCadre::getPostId)
  137. .leftJoin(BaseClass.class, BaseClass::getId, BaseStudentCadre::getClassId)
  138. .leftJoin(BaseStudentSchoolRoll.class, BaseStudentSchoolRoll::getUserId, BaseStudentCadre::getUserId)
  139. );
  140. PageOutput<BaseStudentCadrePageVo> pageOutput = ConventPage.getPageOutput(page, BaseStudentCadrePageVo.class);
  141. return RT.ok(pageOutput);
  142. }
  143. @GetMapping(value = "/info")
  144. @ApiOperation(value="根据id查询学生干部管理信息")
  145. @SaCheckPermission("basestudentcadre:detail")
  146. public RT<BaseStudentCadreVo> info(@RequestParam Long id){
  147. BaseStudentCadre baseStudentCadre = baseStudentCadreService.getById(id);
  148. if (baseStudentCadre == null) {
  149. return RT.error("找不到此数据!");
  150. }
  151. return RT.ok(BeanUtil.toBean(baseStudentCadre, BaseStudentCadreVo.class));
  152. }
  153. @PostMapping
  154. @ApiOperation(value = "新增学生干部管理(批量新增)")
  155. @SaCheckPermission("basestudentcadre:add")
  156. public RT<Boolean> add(@Valid @RequestBody List<AddBaseStudentCadreDto> dto){
  157. //循环判定,是否已经存在于数据库,并查询出班级id
  158. List<AddBaseStudentCadreDto> addDtoList = new ArrayList<>();
  159. for (AddBaseStudentCadreDto baseStudentCadreDto : dto) {
  160. BaseStudentCadre one = baseStudentCadreService.getOne(
  161. Wrappers.lambdaQuery(BaseStudentCadre.class)
  162. .eq(BaseStudentCadre::getUserId, baseStudentCadreDto.getUserId())
  163. .eq(BaseStudentCadre::getPostId, baseStudentCadreDto.getPostId())
  164. );
  165. BaseStudentSchoolRoll baseStudentSchoolRoll = baseStudentSchoolRollMapper.selectOne(Wrappers.lambdaQuery(BaseStudentSchoolRoll.class).eq(BaseStudentSchoolRoll::getUserId, baseStudentCadreDto.getUserId()));
  166. if(ObjectUtil.isNotNull(one)){
  167. continue;
  168. }
  169. if(ObjectUtil.isNotNull(baseStudentSchoolRoll)){
  170. baseStudentCadreDto.setClassId(baseStudentSchoolRoll.getClassId());
  171. }
  172. addDtoList.add(baseStudentCadreDto);
  173. }
  174. List<BaseStudentCadre> baseStudentCadreList = BeanUtil.copyToList(addDtoList, BaseStudentCadre.class);
  175. boolean isSuccess = baseStudentCadreService.addAll(baseStudentCadreList);
  176. return RT.ok(isSuccess);
  177. }
  178. @PostMapping("/addone")
  179. @ApiOperation(value = "新增学生干部管理(单个添加)")
  180. @SaCheckPermission("basestudentcadre:insert")
  181. public RT<Boolean> addOne(@Valid @RequestBody AddBaseStudentCadreDto dto){
  182. //判定,是否已经存在于数据库,并查询出班级id
  183. BaseStudentCadre one = baseStudentCadreService.getOne(
  184. Wrappers.lambdaQuery(BaseStudentCadre.class)
  185. .eq(BaseStudentCadre::getUserId, dto.getUserId())
  186. .eq(BaseStudentCadre::getPostId, dto.getPostId())
  187. );
  188. if(ObjectUtil.isNotNull(one)){
  189. RT.ok("该学生已有该职务,无法重复添加");
  190. }
  191. BaseStudentSchoolRoll baseStudentSchoolRoll = baseStudentSchoolRollMapper.selectOne(Wrappers.lambdaQuery(BaseStudentSchoolRoll.class).eq(BaseStudentSchoolRoll::getUserId, dto.getUserId()));
  192. if(ObjectUtil.isNotNull(baseStudentSchoolRoll)){
  193. dto.setClassId(baseStudentSchoolRoll.getClassId());
  194. }
  195. BaseStudentCadre baseStudentCadre = BeanUtil.toBean(dto, BaseStudentCadre.class);
  196. boolean isSuccess = baseStudentCadreService.addOne(baseStudentCadre);
  197. return RT.ok(isSuccess);
  198. }
  199. @PutMapping("/editStatus")
  200. @ApiOperation(value = "修改学生干部状态(离职、复职)")
  201. @SaCheckPermission("basestudentcadre:edit")
  202. public RT<Boolean> editStatus(@Valid @RequestBody UpdateBaseStudentCadreDto dto){
  203. if(ObjectUtil.isNull(dto) || ObjectUtil.isNull(dto.getId()) || ObjectUtil.isNull(dto.getId()) || ObjectUtil.isNull(dto.getLeaveTime())){
  204. return RT.error("请传入id、status和leaveTime");
  205. }
  206. BaseStudentCadre baseStudentCadre = BeanUtil.toBean(dto, BaseStudentCadre.class);
  207. return RT.ok(baseStudentCadreService.updateById(baseStudentCadre));
  208. }
  209. @PutMapping
  210. @ApiOperation(value = "修改学生干部管理")
  211. @SaCheckPermission("basestudentcadre:edit")
  212. public RT<Boolean> update(@Valid @RequestBody UpdateBaseStudentCadreDto dto){
  213. BaseStudentCadre baseStudentCadre = BeanUtil.toBean(dto, BaseStudentCadre.class);
  214. return RT.ok(baseStudentCadreService.updateById(baseStudentCadre));
  215. }
  216. @DeleteMapping
  217. @ApiOperation(value = "删除学生干部管理")
  218. @SaCheckPermission("basestudentcadre:delete")
  219. public RT<Boolean> delete(@Valid @RequestBody List<Long> ids){
  220. return RT.ok(baseStudentCadreService.removeBatchByIds(ids));
  221. }
  222. @GetMapping("/export")
  223. @ApiOperation(value = "导出")
  224. public ResponseEntity<byte[]> exportData(@Valid BaseStudentCadrePageDto dto, @RequestParam(defaultValue = "false") Boolean isTemplate) {
  225. List<BaseStudentCadrePageVo> customerList = isTemplate != null && isTemplate ? new ArrayList<>() : ((PageOutput<BaseStudentCadrePageVo>) page(dto).getData()).getList();
  226. ByteArrayOutputStream bot = new ByteArrayOutputStream();
  227. EasyExcel.write(bot, BaseStudentCadrePageVo.class).automaticMergeHead(false).excelType(ExcelTypeEnum.XLSX).sheet().doWrite(customerList);
  228. return RT.fileStream(bot.toByteArray(), "BaseStudentCadre" + ExcelTypeEnum.XLSX.getValue());
  229. }
  230. }