PbCseFeeitem2Controller.java 5.2 KB

123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263646566676869707172737475767778798081828384858687888990919293949596979899100101102103104105106107108109110111112113114115116117118119120121122
  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.xjrsoft.common.annotation.XjrLog;
  9. import com.xjrsoft.common.model.result.RT;
  10. import com.xjrsoft.common.page.ConventPage;
  11. import com.xjrsoft.common.page.PageOutput;
  12. import com.xjrsoft.common.utils.VoToColumnUtil;
  13. import com.xjrsoft.module.student.dto.AddPbCseFeeitem2Dto;
  14. import com.xjrsoft.module.student.dto.PbCseFeeitem2PageDto;
  15. import com.xjrsoft.module.student.dto.UpdatePbCseFeeitem2Dto;
  16. import com.xjrsoft.module.student.entity.PbCseFeeitem2;
  17. import com.xjrsoft.module.student.service.IPbCseFeeitem2Service;
  18. import com.xjrsoft.module.student.vo.PbCseFeeitem2PageVo;
  19. import com.xjrsoft.module.student.vo.PbCseFeeitem2Vo;
  20. import io.swagger.annotations.Api;
  21. import io.swagger.annotations.ApiOperation;
  22. import lombok.AllArgsConstructor;
  23. import org.springframework.http.ResponseEntity;
  24. import org.springframework.web.bind.annotation.*;
  25. import org.springframework.web.multipart.MultipartFile;
  26. import javax.validation.Valid;
  27. import java.io.ByteArrayOutputStream;
  28. import java.io.IOException;
  29. import java.util.ArrayList;
  30. import java.util.List;
  31. /**
  32. * @title:
  33. * @Author szs
  34. * @Date: 2024-04-01
  35. * @Version 1.0
  36. */
  37. @RestController
  38. @RequestMapping("/student" + "/pbCseFeeitem2")
  39. @Api(value = "/student" + "/pbCseFeeitem2", tags = "代码")
  40. @AllArgsConstructor
  41. public class PbCseFeeitem2Controller {
  42. private final IPbCseFeeitem2Service pbCseFeeitem2Service;
  43. @GetMapping(value = "/page")
  44. @ApiOperation(value = "列表(分页)")
  45. @SaCheckPermission("pbcsefeeitem2:detail")
  46. @XjrLog(value = "列表(分页)")
  47. public RT<PageOutput<PbCseFeeitem2PageVo>> page(@Valid PbCseFeeitem2PageDto dto) {
  48. LambdaQueryWrapper<PbCseFeeitem2> queryWrapper = new LambdaQueryWrapper<>();
  49. queryWrapper
  50. //.orderByDesc(PbCseFeeitem2::getId)
  51. .select(PbCseFeeitem2.class, x -> VoToColumnUtil.fieldsToColumns(PbCseFeeitem2PageVo.class).contains(x.getProperty()));
  52. IPage<PbCseFeeitem2> page = pbCseFeeitem2Service.page(ConventPage.getPage(dto), queryWrapper);
  53. PageOutput<PbCseFeeitem2PageVo> pageOutput = ConventPage.getPageOutput(page, PbCseFeeitem2PageVo.class);
  54. return RT.ok(pageOutput);
  55. }
  56. @GetMapping(value = "/info")
  57. @ApiOperation(value = "根据id查询信息")
  58. @SaCheckPermission("pbcsefeeitem2:detail")
  59. @XjrLog(value = "根据id查询信息", saveResponseData = true)
  60. public RT<PbCseFeeitem2Vo> info(@RequestParam Long id) {
  61. PbCseFeeitem2 pbCseFeeitem2 = pbCseFeeitem2Service.getById(id);
  62. if (pbCseFeeitem2 == null) {
  63. return RT.error("找不到此数据!");
  64. }
  65. return RT.ok(BeanUtil.toBean(pbCseFeeitem2, PbCseFeeitem2Vo.class));
  66. }
  67. @PostMapping
  68. @ApiOperation(value = "新增")
  69. @SaCheckPermission("pbcsefeeitem2:add")
  70. @XjrLog(value = "新增", saveResponseData = true)
  71. public RT<Boolean> add(@Valid @RequestBody AddPbCseFeeitem2Dto dto) {
  72. PbCseFeeitem2 pbCseFeeitem2 = BeanUtil.toBean(dto, PbCseFeeitem2.class);
  73. boolean isSuccess = pbCseFeeitem2Service.save(pbCseFeeitem2);
  74. return RT.ok(isSuccess);
  75. }
  76. @PutMapping
  77. @ApiOperation(value = "修改")
  78. @SaCheckPermission("pbcsefeeitem2:edit")
  79. @XjrLog(value = "修改", saveResponseData = true)
  80. public RT<Boolean> update(@Valid @RequestBody UpdatePbCseFeeitem2Dto dto) {
  81. PbCseFeeitem2 pbCseFeeitem2 = BeanUtil.toBean(dto, PbCseFeeitem2.class);
  82. return RT.ok(pbCseFeeitem2Service.updateById(pbCseFeeitem2));
  83. }
  84. @DeleteMapping
  85. @ApiOperation(value = "删除")
  86. @SaCheckPermission("pbcsefeeitem2:delete")
  87. @XjrLog(value = "删除", saveResponseData = true)
  88. public RT<Boolean> delete(@Valid @RequestBody List<Long> ids) {
  89. return RT.ok(pbCseFeeitem2Service.removeBatchByIds(ids));
  90. }
  91. @PostMapping("/import")
  92. @ApiOperation(value = "导入")
  93. @XjrLog(value = "导入", saveRequestData = false, saveResponseData = true)
  94. public RT<Boolean> importData(@RequestParam MultipartFile file) throws IOException {
  95. List<PbCseFeeitem2PageVo> savedDataList = EasyExcel.read(file.getInputStream()).head(PbCseFeeitem2PageVo.class).sheet().doReadSync();
  96. Boolean result = pbCseFeeitem2Service.saveBatch(BeanUtil.copyToList(savedDataList, PbCseFeeitem2.class));
  97. return RT.ok(result);
  98. }
  99. @GetMapping("/export")
  100. @ApiOperation(value = "导出")
  101. @XjrLog(value = "导出")
  102. public ResponseEntity<byte[]> exportData(@Valid PbCseFeeitem2PageDto dto, @RequestParam(defaultValue = "false") Boolean isTemplate) {
  103. List<PbCseFeeitem2PageVo> customerList = isTemplate != null && isTemplate ? new ArrayList<>() : page(dto).getData().getList();
  104. ByteArrayOutputStream bot = new ByteArrayOutputStream();
  105. EasyExcel.write(bot, PbCseFeeitem2PageVo.class).automaticMergeHead(false).excelType(ExcelTypeEnum.XLSX).sheet().doWrite(customerList);
  106. return RT.fileStream(bot.toByteArray(), "PbCseFeeitem2" + ExcelTypeEnum.XLSX.getValue());
  107. }
  108. }