package cn.lihu.jh.module.queue.controller.admin.sequence; import org.springframework.web.bind.annotation.*; import jakarta.annotation.Resource; import org.springframework.validation.annotation.Validated; import org.springframework.security.access.prepost.PreAuthorize; import io.swagger.v3.oas.annotations.tags.Tag; import io.swagger.v3.oas.annotations.Parameter; import io.swagger.v3.oas.annotations.Operation; import jakarta.validation.constraints.*; import jakarta.validation.*; import jakarta.servlet.http.*; import java.util.*; import java.io.IOException; import cn.lihu.jh.framework.common.pojo.PageParam; import cn.lihu.jh.framework.common.pojo.PageResult; import cn.lihu.jh.framework.common.pojo.CommonResult; import cn.lihu.jh.framework.common.util.object.BeanUtils; import static cn.lihu.jh.framework.common.pojo.CommonResult.success; import cn.lihu.jh.framework.excel.core.util.ExcelUtils; import cn.lihu.jh.framework.apilog.core.annotation.ApiAccessLog; import static cn.lihu.jh.framework.apilog.core.enums.OperateTypeEnum.*; import cn.lihu.jh.module.queue.controller.admin.sequence.vo.*; import cn.lihu.jh.module.queue.dal.dataobject.sequence.SequenceDO; import cn.lihu.jh.module.queue.service.sequence.SequenceService; @Tag(name = "管理后台 - 当天序号") @RestController @RequestMapping("/queue/sequence") @Validated public class SequenceController { @Resource private SequenceService sequenceService; @PostMapping("/create") @Operation(summary = "创建当天序号") @PreAuthorize("@ss.hasPermission('queue:sequence:create')") public CommonResult createSequence(@Valid @RequestBody SequenceSaveReqVO createReqVO) { return success(sequenceService.createSequence(createReqVO)); } @PutMapping("/update") @Operation(summary = "更新当天序号") @PreAuthorize("@ss.hasPermission('queue:sequence:update')") public CommonResult updateSequence(@Valid @RequestBody SequenceSaveReqVO updateReqVO) { sequenceService.updateSequence(updateReqVO); return success(true); } @DeleteMapping("/delete") @Operation(summary = "删除当天序号") @Parameter(name = "id", description = "编号", required = true) @PreAuthorize("@ss.hasPermission('queue:sequence:delete')") public CommonResult deleteSequence(@RequestParam("id") Integer id) { sequenceService.deleteSequence(id); return success(true); } @GetMapping("/get") @Operation(summary = "获得当天序号") @Parameter(name = "id", description = "编号", required = true, example = "1024") @PreAuthorize("@ss.hasPermission('queue:sequence:query')") public CommonResult getSequence(@RequestParam("id") Integer id) { SequenceDO sequence = sequenceService.getSequence(id); return success(BeanUtils.toBean(sequence, SequenceRespVO.class)); } @GetMapping("/page") @Operation(summary = "获得当天序号分页") @PreAuthorize("@ss.hasPermission('queue:sequence:query')") public CommonResult> getSequencePage(@Valid SequencePageReqVO pageReqVO) { PageResult pageResult = sequenceService.getSequencePage(pageReqVO); return success(BeanUtils.toBean(pageResult, SequenceRespVO.class)); } @GetMapping("/export-excel") @Operation(summary = "导出当天序号 Excel") @PreAuthorize("@ss.hasPermission('queue:sequence:export')") @ApiAccessLog(operateType = EXPORT) public void exportSequenceExcel(@Valid SequencePageReqVO pageReqVO, HttpServletResponse response) throws IOException { pageReqVO.setPageSize(PageParam.PAGE_SIZE_NONE); List list = sequenceService.getSequencePage(pageReqVO).getList(); // 导出 Excel ExcelUtils.write(response, "当天序号.xls", "数据", SequenceRespVO.class, BeanUtils.toBean(list, SequenceRespVO.class)); } }