PbCseFeeobjupdateController.java 8.7 KB

123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263646566676869707172737475767778798081828384858687888990919293949596979899100101102103104105106107108109110111112113114115116117118119120121122123124125126127128129130131132133134135136137138139140141142143144145146147148149150151152153154155156157158159160161162163164165166167168169170171172173174175176177178179180181182183184185186187188
  1. package com.xjrsoft.module.student.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.LambdaQueryWrapper;
  7. import com.baomidou.mybatisplus.core.metadata.IPage;
  8. import com.baomidou.mybatisplus.core.toolkit.Wrappers;
  9. import com.xjrsoft.common.annotation.XjrLog;
  10. import com.xjrsoft.common.enums.DeleteMark;
  11. import com.xjrsoft.common.enums.EnrollTypeEnum;
  12. import com.xjrsoft.common.model.result.RT;
  13. import com.xjrsoft.common.page.ConventPage;
  14. import com.xjrsoft.common.page.PageOutput;
  15. import com.xjrsoft.common.utils.TreeUtil;
  16. import com.xjrsoft.common.utils.VoToColumnUtil;
  17. import com.xjrsoft.module.base.entity.BaseGrade;
  18. import com.xjrsoft.module.base.service.IBaseGradeService;
  19. import com.xjrsoft.module.student.dto.*;
  20. import com.xjrsoft.module.student.entity.PbCseFeeobjupdate;
  21. import com.xjrsoft.module.student.service.IPbCseFeeobjupdateService;
  22. import com.xjrsoft.module.student.vo.*;
  23. import io.swagger.annotations.Api;
  24. import io.swagger.annotations.ApiOperation;
  25. import lombok.AllArgsConstructor;
  26. import org.springframework.http.ResponseEntity;
  27. import org.springframework.web.bind.annotation.*;
  28. import org.springframework.web.multipart.MultipartFile;
  29. import javax.validation.Valid;
  30. import java.io.ByteArrayOutputStream;
  31. import java.io.IOException;
  32. import java.util.ArrayList;
  33. import java.util.List;
  34. /**
  35. * @title:
  36. * @Author szs
  37. * @Date: 2024-03-29
  38. * @Version 1.0
  39. */
  40. @RestController
  41. @RequestMapping("/student" + "/pbCseFeeobjupdate")
  42. @Api(value = "/student" + "/pbCseFeeobjupdate", tags = "攀宝学生信息")
  43. @AllArgsConstructor
  44. public class PbCseFeeobjupdateController {
  45. private final IPbCseFeeobjupdateService pbCseFeeobjupdateService;
  46. private final IBaseGradeService baseGradeService;
  47. @GetMapping(value = "/grade-enrolltype-tree")
  48. @ApiOperation(value = "年级招生类型树")
  49. @XjrLog(value = "年级招生类型树")
  50. public RT<List<GradeEnrolltypeTreeVo>> gradeEnrolltypeTree() {
  51. List<BaseGrade> baseGradeList = baseGradeService.list(
  52. Wrappers.<BaseGrade>query().lambda()
  53. .eq(BaseGrade::getDeleteMark, DeleteMark.NODELETE));
  54. List<GradeEnrolltypeTreeVo> voList = new ArrayList<>();
  55. for (BaseGrade baseGrade : baseGradeList) {
  56. voList.add(new GradeEnrolltypeTreeVo() {{
  57. setId(baseGrade.getId().toString());
  58. setName(baseGrade.getName());
  59. }});
  60. voList.add(new GradeEnrolltypeTreeVo() {{
  61. setId(baseGrade.getId().toString() + "_" + EnrollTypeEnum.SPRING_ENROLLMENT.getCode());
  62. setName(EnrollTypeEnum.SPRING_ENROLLMENT.getValue());
  63. setParentId(baseGrade.getId().toString());
  64. }});
  65. voList.add(new GradeEnrolltypeTreeVo() {{
  66. setId(baseGrade.getId().toString() + "_" + EnrollTypeEnum.AUTUMN_ENROLLMENT.getCode());
  67. setName(EnrollTypeEnum.AUTUMN_ENROLLMENT.getValue());
  68. setParentId(baseGrade.getId().toString());
  69. }});
  70. }
  71. List<GradeEnrolltypeTreeVo> treeVoList = TreeUtil.build(voList);
  72. return RT.ok(treeVoList);
  73. }
  74. @GetMapping(value = "/enrollment-statistics")
  75. @ApiOperation(value = "招生统计")
  76. @SaCheckPermission("pbcsefeeobjupdate:detail")
  77. @XjrLog(value = "招生统计", saveResponseData = true)
  78. public RT<EnrollmentStatisticsInfoVo> getEnrollmentStatisticsInfo(@Valid EnrollmentStatisticsInfoDto dto) {
  79. EnrollmentStatisticsInfoVo enrollmentStatisticsInfoVo = pbCseFeeobjupdateService.getLastEnrollmentStatisticsInfo(dto);
  80. return RT.ok(enrollmentStatisticsInfoVo);
  81. }
  82. @GetMapping(value = "/enrollment-statistics-calendar")
  83. @ApiOperation(value = "招生统计每日动态数据")
  84. @SaCheckPermission("pbcsefeeobjupdate:detail")
  85. @XjrLog(value = "招生统计每日动态数据", saveResponseData = true)
  86. public RT<EnrollmentStatisticsCalendarInfoVo> getEnrollmentStatisticsCalendarInfo(@Valid EnrollmentStatisticsCalendarInfoDto dto) {
  87. EnrollmentStatisticsCalendarInfoVo enrollmentStatisticsCalendarInfoVo = pbCseFeeobjupdateService.getLastEnrollmentStatisticsCalendarInfo(dto);
  88. return RT.ok(enrollmentStatisticsCalendarInfoVo);
  89. }
  90. @GetMapping(value = "/enrollment-statistics-graduation")
  91. @ApiOperation(value = "招生统计毕业学校数据")
  92. @SaCheckPermission("pbcsefeeobjupdate:detail")
  93. @XjrLog(value = "招生统计毕业学校数据", saveResponseData = true)
  94. public RT<EnrollmentStatisticsGraduationInfoVo> getEnrollmentStatisticsGraduationInfo(@Valid EnrollmentStatisticsGraduationInfoDto dto) {
  95. EnrollmentStatisticsGraduationInfoVo enrollmentStatisticsGraduationInfoVo = pbCseFeeobjupdateService.getLastEnrollmentStatisticsGraduationInfo(dto);
  96. return RT.ok(enrollmentStatisticsGraduationInfoVo);
  97. }
  98. @GetMapping(value = "/page")
  99. @ApiOperation(value = "列表(分页)")
  100. @SaCheckPermission("pbcsefeeobjupdate:detail")
  101. @XjrLog(value = "列表(分页)")
  102. public RT<PageOutput<PbCseFeeobjupdatePageVo>> page(@Valid PbCseFeeobjupdatePageDto dto) {
  103. LambdaQueryWrapper<PbCseFeeobjupdate> queryWrapper = new LambdaQueryWrapper<>();
  104. queryWrapper
  105. .select(PbCseFeeobjupdate.class, x -> VoToColumnUtil.fieldsToColumns(PbCseFeeobjupdatePageVo.class).contains(x.getProperty()))
  106. .orderByDesc(PbCseFeeobjupdate::getCratetime)
  107. ;
  108. IPage<PbCseFeeobjupdate> page = pbCseFeeobjupdateService.page(ConventPage.getPage(dto), queryWrapper);
  109. PageOutput<PbCseFeeobjupdatePageVo> pageOutput = ConventPage.getPageOutput(page, PbCseFeeobjupdatePageVo.class);
  110. return RT.ok(pageOutput);
  111. }
  112. @GetMapping(value = "/info")
  113. @ApiOperation(value = "根据id查询信息")
  114. @SaCheckPermission("pbcsefeeobjupdate:detail")
  115. @XjrLog(value = "根据id查询信息", saveResponseData = true)
  116. public RT<PbCseFeeobjupdateVo> info(@RequestParam Long id) {
  117. PbCseFeeobjupdate pbCseFeeobjupdate = pbCseFeeobjupdateService.getById(id);
  118. if (pbCseFeeobjupdate == null) {
  119. return RT.error("找不到此数据!");
  120. }
  121. return RT.ok(BeanUtil.toBean(pbCseFeeobjupdate, PbCseFeeobjupdateVo.class));
  122. }
  123. @PostMapping
  124. @ApiOperation(value = "新增")
  125. @SaCheckPermission("pbcsefeeobjupdate:add")
  126. @XjrLog(value = "新增", saveResponseData = true)
  127. public RT<Boolean> add(@Valid @RequestBody AddPbCseFeeobjupdateDto dto) {
  128. PbCseFeeobjupdate pbCseFeeobjupdate = BeanUtil.toBean(dto, PbCseFeeobjupdate.class);
  129. boolean isSuccess = pbCseFeeobjupdateService.save(pbCseFeeobjupdate);
  130. return RT.ok(isSuccess);
  131. }
  132. @PutMapping
  133. @ApiOperation(value = "修改")
  134. @SaCheckPermission("pbcsefeeobjupdate:edit")
  135. @XjrLog(value = "修改", saveResponseData = true)
  136. public RT<Boolean> update(@Valid @RequestBody UpdatePbCseFeeobjupdateDto dto) {
  137. PbCseFeeobjupdate pbCseFeeobjupdate = BeanUtil.toBean(dto, PbCseFeeobjupdate.class);
  138. return RT.ok(pbCseFeeobjupdateService.updateById(pbCseFeeobjupdate));
  139. }
  140. @DeleteMapping
  141. @ApiOperation(value = "删除")
  142. @SaCheckPermission("pbcsefeeobjupdate:delete")
  143. @XjrLog(value = "删除", saveResponseData = true)
  144. public RT<Boolean> delete(@Valid @RequestBody List<Long> ids) {
  145. return RT.ok(pbCseFeeobjupdateService.removeBatchByIds(ids));
  146. }
  147. @PostMapping("/import")
  148. @ApiOperation(value = "导入")
  149. @XjrLog(value = "导入", saveRequestData = false, saveResponseData = true)
  150. public RT<Boolean> importData(@RequestParam MultipartFile file) throws IOException {
  151. List<PbCseFeeobjupdatePageVo> savedDataList = EasyExcel.read(file.getInputStream()).head(PbCseFeeobjupdatePageVo.class).sheet().doReadSync();
  152. Boolean result = pbCseFeeobjupdateService.saveBatch(BeanUtil.copyToList(savedDataList, PbCseFeeobjupdate.class));
  153. return RT.ok(result);
  154. }
  155. @GetMapping("/export")
  156. @ApiOperation(value = "导出")
  157. @XjrLog(value = "导出")
  158. public ResponseEntity<byte[]> exportData(@Valid PbCseFeeobjupdatePageDto dto, @RequestParam(defaultValue = "false") Boolean isTemplate) {
  159. List<PbCseFeeobjupdatePageVo> customerList = isTemplate != null && isTemplate ? new ArrayList<>() : page(dto).getData().getList();
  160. ByteArrayOutputStream bot = new ByteArrayOutputStream();
  161. EasyExcel.write(bot, PbCseFeeobjupdatePageVo.class).automaticMergeHead(false).excelType(ExcelTypeEnum.XLSX).sheet().doWrite(customerList);
  162. return RT.fileStream(bot.toByteArray(), "PbCseFeeobjupdate" + ExcelTypeEnum.XLSX.getValue());
  163. }
  164. }