eight
2024-11-07 134d92dab4033035e8ebe80b5d7c03468b40db38
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
24
25
26
27
28
29
30
31
32
33
34
35
36
37
38
39
40
41
42
43
44
45
46
47
48
49
50
51
52
53
54
55
56
57
58
59
60
61
62
63
64
65
66
67
68
69
70
71
72
73
74
75
76
77
78
79
80
81
82
83
84
85
86
87
88
89
90
91
92
93
94
95
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));
    }
 
}