BaseStudentCadreController.java 8.2 KB

123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263646566676869707172737475767778798081828384858687888990919293949596979899100101102103104105106107108109110111112113114115116117118119120121122123124125126127128129130131132133134135136137138139140141142143144145146147148149150151152153
  1. package com.xjrsoft.module.student.controller;
  2. import cn.dev33.satoken.annotation.SaCheckPermission;
  3. import cn.hutool.core.bean.BeanUtil;
  4. import cn.hutool.core.util.ObjectUtil;
  5. import cn.hutool.core.util.StrUtil;
  6. import com.alibaba.excel.EasyExcel;
  7. import com.alibaba.excel.support.ExcelTypeEnum;
  8. import com.baomidou.mybatisplus.core.metadata.IPage;
  9. import com.github.yulichang.wrapper.MPJLambdaWrapper;
  10. import com.xjrsoft.common.model.result.RT;
  11. import com.xjrsoft.common.page.ConventPage;
  12. import com.xjrsoft.common.page.PageOutput;
  13. import com.xjrsoft.common.utils.VoToColumnUtil;
  14. import com.xjrsoft.module.base.entity.BaseClass;
  15. import com.xjrsoft.module.base.entity.BaseGrade;
  16. import com.xjrsoft.module.base.entity.BaseMajorSet;
  17. import com.xjrsoft.module.erpModel.caseErpPurchase.entity.CaseErpApply;
  18. import com.xjrsoft.module.organization.entity.Department;
  19. import com.xjrsoft.module.student.dto.AddBaseStudentCadreDto;
  20. import com.xjrsoft.module.student.dto.BaseStudentCadrePageDto;
  21. import com.xjrsoft.module.student.dto.UpdateBaseStudentCadreDto;
  22. import com.xjrsoft.module.student.entity.BaseStudent;
  23. import com.xjrsoft.module.student.entity.BaseStudentCadre;
  24. import com.xjrsoft.module.student.entity.BaseStudentPost;
  25. import com.xjrsoft.module.student.entity.BaseStudentSchoolRoll;
  26. import com.xjrsoft.module.student.service.IBaseStudentCadreService;
  27. import com.xjrsoft.module.student.vo.BaseStudentCadrePageVo;
  28. import com.xjrsoft.module.student.vo.BaseStudentCadreVo;
  29. import com.xjrsoft.module.teacher.entity.XjrUser;
  30. import io.swagger.annotations.Api;
  31. import io.swagger.annotations.ApiOperation;
  32. import lombok.AllArgsConstructor;
  33. import org.springframework.http.ResponseEntity;
  34. import org.springframework.web.bind.annotation.DeleteMapping;
  35. import org.springframework.web.bind.annotation.GetMapping;
  36. import org.springframework.web.bind.annotation.PostMapping;
  37. import org.springframework.web.bind.annotation.PutMapping;
  38. import org.springframework.web.bind.annotation.RequestBody;
  39. import org.springframework.web.bind.annotation.RequestMapping;
  40. import org.springframework.web.bind.annotation.RequestParam;
  41. import org.springframework.web.bind.annotation.RestController;
  42. import javax.validation.Valid;
  43. import java.io.ByteArrayOutputStream;
  44. import java.util.ArrayList;
  45. import java.util.List;
  46. /**
  47. * @title: 学生干部管理
  48. * @Author dzx
  49. * @Date: 2023-11-14
  50. * @Version 1.0
  51. */
  52. @RestController
  53. @RequestMapping("/student" + "/basestudentcadre")
  54. @Api(value = "/student" + "/basestudentcadre",tags = "学生干部管理代码")
  55. @AllArgsConstructor
  56. public class BaseStudentCadreController {
  57. private final IBaseStudentCadreService baseStudentCadreService;
  58. @GetMapping(value = "/page")
  59. @ApiOperation(value="学生干部管理列表(分页)")
  60. @SaCheckPermission("basestudentcadre:detail")
  61. public RT<PageOutput<BaseStudentCadrePageVo>> page(@Valid BaseStudentCadrePageDto dto){
  62. MPJLambdaWrapper<BaseStudentCadre> queryWrapper = new MPJLambdaWrapper<>();
  63. queryWrapper.disableLogicDel()
  64. .like(StrUtil.isNotBlank(dto.getUserName()), XjrUser::getName, dto.getUserName())
  65. .eq(ObjectUtil.isNotEmpty(dto.getOrgId()), BaseStudentCadre::getOrgId, dto.getOrgId())
  66. .eq(ObjectUtil.isNotEmpty(dto.getClassId()), BaseStudentCadre::getClassId, dto.getClassId())
  67. .eq(ObjectUtil.isNotEmpty(dto.getPostId()), BaseStudentCadre::getPostId, dto.getPostId())
  68. .eq(ObjectUtil.isNotEmpty(dto.getGradeId()), BaseStudentSchoolRoll::getGradeId, dto.getGradeId())
  69. .eq(ObjectUtil.isNotEmpty(dto.getMajorSetId()), BaseStudentSchoolRoll::getMajorSetId, dto.getMajorSetId())
  70. .eq(ObjectUtil.isNotEmpty(dto.getLevel()), BaseStudentPost::getLevel, dto.getLevel())
  71. .between(ObjectUtil.isNotNull(dto.getStartTimeStart()) && ObjectUtil.isNotNull(dto.getStartTimeEnd()), BaseStudentCadre::getStartTime,dto.getStartTimeStart(),dto.getStartTimeEnd())
  72. .between(ObjectUtil.isNotNull(dto.getEndTimeStart()) && ObjectUtil.isNotNull(dto.getEndTimeEnd()), BaseStudentCadre::getEndTime,dto.getEndTimeStart(),dto.getEndTimeEnd())
  73. .orderByDesc(BaseStudentCadre::getId)
  74. .selectAs(BaseStudent::getStudentId, BaseStudentCadre::getStudentId)
  75. .selectAs(XjrUser::getName, BaseStudentCadre::getUserName)
  76. .selectAs(BaseClass::getName, BaseStudentCadre::getClassName)
  77. .selectAs(BaseStudentPost::getPost, BaseStudentCadre::getPost)
  78. .selectAs(BaseStudentPost::getLevel, BaseStudentCadre::getLevel)
  79. .selectAs(Department::getName, BaseStudentCadre::getOrgName)
  80. .selectAs(XjrUser::getMobile, BaseStudentCadre::getMobile)
  81. .selectAs(BaseMajorSet::getName, BaseStudentCadre::getMajorSetName)
  82. .selectAs(BaseGrade::getName, BaseStudentCadre::getGradeName)
  83. .select(BaseStudentCadre.class,x -> VoToColumnUtil.fieldsToColumns(BaseStudentCadrePageVo.class).contains(x.getProperty()))
  84. .innerJoin(XjrUser.class, XjrUser::getId, BaseStudentCadre::getUserId)
  85. .innerJoin(BaseStudent.class, BaseStudent::getUserId, BaseStudentCadre::getUserId)
  86. .innerJoin(BaseStudentPost.class, BaseStudentPost::getId, BaseStudentCadre::getPostId)
  87. .innerJoin(BaseClass.class, BaseClass::getId, BaseStudentCadre::getClassId)
  88. .innerJoin(BaseStudentSchoolRoll.class, BaseStudentSchoolRoll::getUserId, BaseStudentCadre::getUserId)
  89. .innerJoin(Department.class, Department::getId, BaseClass::getOrgId)
  90. .leftJoin(BaseMajorSet.class, BaseMajorSet::getId, BaseStudentSchoolRoll::getMajorSetId)
  91. .leftJoin(BaseGrade.class, BaseGrade::getId, BaseStudentSchoolRoll::getGradeId);
  92. IPage<BaseStudentCadre> page = baseStudentCadreService.page(ConventPage.getPage(dto), queryWrapper);
  93. PageOutput<BaseStudentCadrePageVo> pageOutput = ConventPage.getPageOutput(page, BaseStudentCadrePageVo.class);
  94. return RT.ok(pageOutput);
  95. }
  96. @GetMapping(value = "/info")
  97. @ApiOperation(value="根据id查询学生干部管理信息")
  98. @SaCheckPermission("basestudentcadre:detail")
  99. public RT<BaseStudentCadreVo> info(@RequestParam Long id){
  100. BaseStudentCadre baseStudentCadre = baseStudentCadreService.getById(id);
  101. if (baseStudentCadre == null) {
  102. return RT.error("找不到此数据!");
  103. }
  104. return RT.ok(BeanUtil.toBean(baseStudentCadre, BaseStudentCadreVo.class));
  105. }
  106. @PostMapping
  107. @ApiOperation(value = "新增学生干部管理")
  108. @SaCheckPermission("basestudentcadre:add")
  109. public RT<Boolean> add(@Valid @RequestBody AddBaseStudentCadreDto dto){
  110. BaseStudentCadre baseStudentCadre = BeanUtil.toBean(dto, BaseStudentCadre.class);
  111. boolean isSuccess = baseStudentCadreService.save(baseStudentCadre);
  112. return RT.ok(isSuccess);
  113. }
  114. @PutMapping
  115. @ApiOperation(value = "修改学生干部管理")
  116. @SaCheckPermission("basestudentcadre:edit")
  117. public RT<Boolean> update(@Valid @RequestBody UpdateBaseStudentCadreDto dto){
  118. BaseStudentCadre baseStudentCadre = BeanUtil.toBean(dto, BaseStudentCadre.class);
  119. return RT.ok(baseStudentCadreService.updateById(baseStudentCadre));
  120. }
  121. @DeleteMapping
  122. @ApiOperation(value = "删除学生干部管理")
  123. @SaCheckPermission("basestudentcadre:delete")
  124. public RT<Boolean> delete(@Valid @RequestBody List<Long> ids){
  125. return RT.ok(baseStudentCadreService.removeBatchByIds(ids));
  126. }
  127. @GetMapping("/export")
  128. @ApiOperation(value = "导出")
  129. public ResponseEntity<byte[]> exportData(@Valid BaseStudentCadrePageDto dto, @RequestParam(defaultValue = "false") Boolean isTemplate) {
  130. List<BaseStudentCadrePageVo> customerList = isTemplate != null && isTemplate ? new ArrayList<>() : ((PageOutput<BaseStudentCadrePageVo>) page(dto).getData()).getList();
  131. ByteArrayOutputStream bot = new ByteArrayOutputStream();
  132. EasyExcel.write(bot, BaseStudentCadrePageVo.class).automaticMergeHead(false).excelType(ExcelTypeEnum.XLSX).sheet().doWrite(customerList);
  133. return RT.fileStream(bot.toByteArray(), "BaseStudentCadre" + ExcelTypeEnum.XLSX.getValue());
  134. }
  135. }