package com.xjrsoft.module.student.controller; import cn.hutool.core.bean.BeanUtil; import cn.hutool.core.util.ObjectUtil; import cn.hutool.core.util.StrUtil; import com.baomidou.mybatisplus.core.conditions.query.LambdaQueryWrapper; import com.baomidou.mybatisplus.core.metadata.IPage; import com.baomidou.mybatisplus.core.toolkit.Wrappers; import com.xjrsoft.common.constant.GlobalConstant; import com.baomidou.mybatisplus.core.toolkit.StringPool; import com.xjrsoft.common.page.ConventPage; import com.xjrsoft.common.page.PageOutput; import com.xjrsoft.common.model.result.RT; import com.xjrsoft.common.utils.VoToColumnUtil; import com.xjrsoft.module.student.dto.AddBaseStudentCadreDto; import com.xjrsoft.module.student.dto.UpdateBaseStudentCadreDto; import cn.dev33.satoken.annotation.SaCheckPermission; import com.alibaba.excel.EasyExcel; import com.alibaba.excel.support.ExcelTypeEnum; import org.springframework.http.ResponseEntity; import java.io.ByteArrayOutputStream; import java.util.ArrayList; import com.xjrsoft.module.student.dto.BaseStudentCadrePageDto; import com.xjrsoft.module.student.entity.BaseStudentCadre; import com.xjrsoft.module.student.service.IBaseStudentCadreService; import com.xjrsoft.module.student.vo.BaseStudentCadrePageVo; import com.xjrsoft.module.student.vo.BaseStudentCadreVo; import io.swagger.annotations.Api; import io.swagger.annotations.ApiOperation; import lombok.AllArgsConstructor; import org.springframework.web.bind.annotation.*; import javax.validation.Valid; import javax.validation.constraints.NotNull; import java.util.List; /** * @title: 学生干部管理 * @Author dzx * @Date: 2023-11-09 * @Version 1.0 */ @RestController @RequestMapping("/student" + "/basestudentcadre") @Api(value = "/student" + "/basestudentcadre",tags = "学生干部管理代码") @AllArgsConstructor public class BaseStudentCadreController { private final IBaseStudentCadreService baseStudentCadreService; @GetMapping(value = "/page") @ApiOperation(value="学生干部管理列表(分页)") @SaCheckPermission("basestudentcadre:detail") public RT> page(@Valid BaseStudentCadrePageDto dto){ LambdaQueryWrapper queryWrapper = new LambdaQueryWrapper<>(); queryWrapper .orderByDesc(BaseStudentCadre::getId) .select(BaseStudentCadre.class,x -> VoToColumnUtil.fieldsToColumns(BaseStudentCadrePageVo.class).contains(x.getProperty())); IPage page = baseStudentCadreService.page(ConventPage.getPage(dto), queryWrapper); PageOutput pageOutput = ConventPage.getPageOutput(page, BaseStudentCadrePageVo.class); return RT.ok(pageOutput); } @GetMapping(value = "/info") @ApiOperation(value="根据id查询学生干部管理信息") @SaCheckPermission("basestudentcadre:detail") public RT info(@RequestParam Long id){ BaseStudentCadre baseStudentCadre = baseStudentCadreService.getById(id); if (baseStudentCadre == null) { return RT.error("找不到此数据!"); } return RT.ok(BeanUtil.toBean(baseStudentCadre, BaseStudentCadreVo.class)); } @PostMapping @ApiOperation(value = "新增学生干部管理") @SaCheckPermission("basestudentcadre:add") public RT add(@Valid @RequestBody AddBaseStudentCadreDto dto){ BaseStudentCadre baseStudentCadre = BeanUtil.toBean(dto, BaseStudentCadre.class); boolean isSuccess = baseStudentCadreService.save(baseStudentCadre); return RT.ok(isSuccess); } @PutMapping @ApiOperation(value = "修改学生干部管理") @SaCheckPermission("basestudentcadre:edit") public RT update(@Valid @RequestBody UpdateBaseStudentCadreDto dto){ BaseStudentCadre baseStudentCadre = BeanUtil.toBean(dto, BaseStudentCadre.class); return RT.ok(baseStudentCadreService.updateById(baseStudentCadre)); } @DeleteMapping @ApiOperation(value = "删除学生干部管理") @SaCheckPermission("basestudentcadre:delete") public RT delete(@Valid @RequestBody List ids){ return RT.ok(baseStudentCadreService.removeBatchByIds(ids)); } @GetMapping("/export") @ApiOperation(value = "导出") public ResponseEntity exportData(@Valid BaseStudentCadrePageDto dto, @RequestParam(defaultValue = "false") Boolean isTemplate) { List customerList = isTemplate != null && isTemplate ? new ArrayList<>() : ((PageOutput) page(dto).getData()).getList(); ByteArrayOutputStream bot = new ByteArrayOutputStream(); EasyExcel.write(bot, BaseStudentCadrePageVo.class).automaticMergeHead(false).excelType(ExcelTypeEnum.XLSX).sheet().doWrite(customerList); return RT.fileStream(bot.toByteArray(), "BaseStudentCadre" + ExcelTypeEnum.XLSX.getValue()); } }