package com.xjrsoft.module.student.controller; import cn.dev33.satoken.annotation.SaCheckPermission; import cn.hutool.core.bean.BeanUtil; import com.alibaba.excel.EasyExcel; import com.alibaba.excel.support.ExcelTypeEnum; import com.baomidou.mybatisplus.core.conditions.query.LambdaQueryWrapper; import com.baomidou.mybatisplus.core.metadata.IPage; import com.xjrsoft.common.annotation.XjrLog; import com.xjrsoft.common.model.result.RT; import com.xjrsoft.common.page.ConventPage; import com.xjrsoft.common.page.PageOutput; import com.xjrsoft.common.utils.VoToColumnUtil; import com.xjrsoft.module.student.dto.AddPbCseFeeitem2Dto; import com.xjrsoft.module.student.dto.PbCseFeeitem2PageDto; import com.xjrsoft.module.student.dto.UpdatePbCseFeeitem2Dto; import com.xjrsoft.module.student.entity.PbCseFeeitem2; import com.xjrsoft.module.student.service.IPbCseFeeitem2Service; import com.xjrsoft.module.student.vo.PbCseFeeitem2PageVo; import com.xjrsoft.module.student.vo.PbCseFeeitem2Vo; import io.swagger.annotations.Api; import io.swagger.annotations.ApiOperation; import lombok.AllArgsConstructor; import org.springframework.http.ResponseEntity; import org.springframework.web.bind.annotation.*; import org.springframework.web.multipart.MultipartFile; import javax.validation.Valid; import java.io.ByteArrayOutputStream; import java.io.IOException; import java.util.ArrayList; import java.util.List; /** * @title: * @Author szs * @Date: 2024-04-01 * @Version 1.0 */ @RestController @RequestMapping("/student" + "/pbCseFeeitem2") @Api(value = "/student" + "/pbCseFeeitem2", tags = "代码") @AllArgsConstructor public class PbCseFeeitem2Controller { private final IPbCseFeeitem2Service pbCseFeeitem2Service; @GetMapping(value = "/page") @ApiOperation(value = "列表(分页)") @SaCheckPermission("pbcsefeeitem2:detail") @XjrLog(value = "列表(分页)") public RT> page(@Valid PbCseFeeitem2PageDto dto) { LambdaQueryWrapper queryWrapper = new LambdaQueryWrapper<>(); queryWrapper //.orderByDesc(PbCseFeeitem2::getId) .select(PbCseFeeitem2.class, x -> VoToColumnUtil.fieldsToColumns(PbCseFeeitem2PageVo.class).contains(x.getProperty())); IPage page = pbCseFeeitem2Service.page(ConventPage.getPage(dto), queryWrapper); PageOutput pageOutput = ConventPage.getPageOutput(page, PbCseFeeitem2PageVo.class); return RT.ok(pageOutput); } @GetMapping(value = "/info") @ApiOperation(value = "根据id查询信息") @SaCheckPermission("pbcsefeeitem2:detail") @XjrLog(value = "根据id查询信息", saveResponseData = true) public RT info(@RequestParam Long id) { PbCseFeeitem2 pbCseFeeitem2 = pbCseFeeitem2Service.getById(id); if (pbCseFeeitem2 == null) { return RT.error("找不到此数据!"); } return RT.ok(BeanUtil.toBean(pbCseFeeitem2, PbCseFeeitem2Vo.class)); } @PostMapping @ApiOperation(value = "新增") @SaCheckPermission("pbcsefeeitem2:add") @XjrLog(value = "新增", saveResponseData = true) public RT add(@Valid @RequestBody AddPbCseFeeitem2Dto dto) { PbCseFeeitem2 pbCseFeeitem2 = BeanUtil.toBean(dto, PbCseFeeitem2.class); boolean isSuccess = pbCseFeeitem2Service.save(pbCseFeeitem2); return RT.ok(isSuccess); } @PutMapping @ApiOperation(value = "修改") @SaCheckPermission("pbcsefeeitem2:edit") @XjrLog(value = "修改", saveResponseData = true) public RT update(@Valid @RequestBody UpdatePbCseFeeitem2Dto dto) { PbCseFeeitem2 pbCseFeeitem2 = BeanUtil.toBean(dto, PbCseFeeitem2.class); return RT.ok(pbCseFeeitem2Service.updateById(pbCseFeeitem2)); } @DeleteMapping @ApiOperation(value = "删除") @SaCheckPermission("pbcsefeeitem2:delete") @XjrLog(value = "删除", saveResponseData = true) public RT delete(@Valid @RequestBody List ids) { return RT.ok(pbCseFeeitem2Service.removeBatchByIds(ids)); } @PostMapping("/import") @ApiOperation(value = "导入") @XjrLog(value = "导入", saveRequestData = false, saveResponseData = true) public RT importData(@RequestParam MultipartFile file) throws IOException { List savedDataList = EasyExcel.read(file.getInputStream()).head(PbCseFeeitem2PageVo.class).sheet().doReadSync(); Boolean result = pbCseFeeitem2Service.saveBatch(BeanUtil.copyToList(savedDataList, PbCseFeeitem2.class)); return RT.ok(result); } @GetMapping("/export") @ApiOperation(value = "导出") @XjrLog(value = "导出") public ResponseEntity exportData(@Valid PbCseFeeitem2PageDto dto, @RequestParam(defaultValue = "false") Boolean isTemplate) { List customerList = isTemplate != null && isTemplate ? new ArrayList<>() : page(dto).getData().getList(); ByteArrayOutputStream bot = new ByteArrayOutputStream(); EasyExcel.write(bot, PbCseFeeitem2PageVo.class).automaticMergeHead(false).excelType(ExcelTypeEnum.XLSX).sheet().doWrite(customerList); return RT.fileStream(bot.toByteArray(), "PbCseFeeitem2" + ExcelTypeEnum.XLSX.getValue()); } }