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<Integer> createSequence(@Valid @RequestBody SequenceSaveReqVO createReqVO) {
|
return success(sequenceService.createSequence(createReqVO));
|
}
|
|
@PutMapping("/update")
|
@Operation(summary = "更新当天序号")
|
@PreAuthorize("@ss.hasPermission('queue:sequence:update')")
|
public CommonResult<Boolean> 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<Boolean> 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<SequenceRespVO> 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<PageResult<SequenceRespVO>> getSequencePage(@Valid SequencePageReqVO pageReqVO) {
|
PageResult<SequenceDO> 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<SequenceDO> list = sequenceService.getSequencePage(pageReqVO).getList();
|
// 导出 Excel
|
ExcelUtils.write(response, "当天序号.xls", "数据", SequenceRespVO.class,
|
BeanUtils.toBean(list, SequenceRespVO.class));
|
}
|
|
}
|