shiyunteng
5 天以前 1eb6f4824c270de1a3d0bf766d44f1abb2c7f55d
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
96
97
98
99
100
101
102
103
104
105
106
107
108
109
110
111
112
113
114
115
116
117
118
119
120
121
122
123
124
package com.by4cloud.platformx.device.controller;
 
import cn.hutool.core.util.StrUtil;
import cn.hutool.core.util.ArrayUtil;
import cn.hutool.core.collection.CollUtil;
import com.baomidou.mybatisplus.core.conditions.query.LambdaQueryWrapper;
import com.baomidou.mybatisplus.core.toolkit.Wrappers;
import com.baomidou.mybatisplus.extension.plugins.pagination.Page;
import com.by4cloud.platformx.common.core.util.R;
import com.by4cloud.platformx.common.log.annotation.SysLog;
import com.by4cloud.platformx.device.entity.WorkOrder;
import com.by4cloud.platformx.device.service.WorkOrderService;
import org.springframework.security.access.prepost.PreAuthorize;
import com.by4cloud.platformx.common.excel.annotation.ResponseExcel;
import io.swagger.v3.oas.annotations.security.SecurityRequirement;
import org.springdoc.api.annotations.ParameterObject;
import org.springframework.http.HttpHeaders;
import io.swagger.v3.oas.annotations.tags.Tag;
import io.swagger.v3.oas.annotations.Operation;
import lombok.RequiredArgsConstructor;
import org.springframework.web.bind.annotation.*;
 
import java.util.List;
import java.util.Objects;
 
/**
 * 工单
 *
 * @author syt
 * @date 2025-04-22 16:01:37
 */
@RestController
@RequiredArgsConstructor
@RequestMapping("/workOrder" )
@Tag(description = "workOrder" , name = "工单管理" )
@SecurityRequirement(name = HttpHeaders.AUTHORIZATION)
public class WorkOrderController {
 
    private final  WorkOrderService workOrderService;
 
    /**
     * 分页查询
     * @param page 分页对象
     * @param workOrder 工单
     * @return
     */
    @Operation(summary = "分页查询" , description = "分页查询" )
    @GetMapping("/page" )
    @PreAuthorize("@pms.hasPermission('device_workOrder_view')" )
    public R getWorkOrderPage(@ParameterObject Page page, @ParameterObject WorkOrder workOrder) {
        LambdaQueryWrapper<WorkOrder> wrapper = Wrappers.lambdaQuery();
        wrapper.like(StrUtil.isNotBlank(workOrder.getWoCode()),WorkOrder::getWoCode,workOrder.getWoCode());
        wrapper.like(StrUtil.isNotBlank(workOrder.getWoDesc()),WorkOrder::getWoDesc,workOrder.getWoDesc());
        wrapper.eq(Objects.nonNull(workOrder.getWoStatus()),WorkOrder::getWoStatus,workOrder.getWoStatus());
        wrapper.orderByDesc(WorkOrder::getCreateTime);
        return R.ok(workOrderService.page(page, wrapper));
    }
 
 
    /**
     * 通过id查询工单
     * @param id id
     * @return R
     */
    @Operation(summary = "通过id查询" , description = "通过id查询" )
    @GetMapping("/{id}" )
    @PreAuthorize("@pms.hasPermission('device_workOrder_view')" )
    public R getById(@PathVariable("id" ) Long id) {
        return R.ok(workOrderService.getById(id));
    }
 
    /**
     * 新增工单
     * @param workOrder 工单
     * @return R
     */
    @Operation(summary = "新增工单" , description = "新增工单" )
    @SysLog("新增工单" )
    @PostMapping
    @PreAuthorize("@pms.hasPermission('device_workOrder_add')" )
    public R save(@RequestBody WorkOrder workOrder) {
        return workOrderService.saveNew(workOrder);
    }
 
    /**
     * 修改工单
     * @param workOrder 工单
     * @return R
     */
    @Operation(summary = "修改工单" , description = "修改工单" )
    @SysLog("修改工单" )
    @PutMapping
    @PreAuthorize("@pms.hasPermission('device_workOrder_edit')" )
    public R updateById(@RequestBody WorkOrder workOrder) {
        return workOrderService.updateByIdNew(workOrder);
    }
 
    /**
     * 通过id删除工单
     * @param ids id列表
     * @return R
     */
    @Operation(summary = "通过id删除工单" , description = "通过id删除工单" )
    @SysLog("通过id删除工单" )
    @DeleteMapping
    @PreAuthorize("@pms.hasPermission('device_workOrder_del')" )
    public R removeById(@RequestBody Long[] ids) {
        return R.ok(workOrderService.removeBatchByIds(CollUtil.toList(ids)));
    }
 
 
    /**
     * 导出excel 表格
     * @param workOrder 查询条件
        * @param ids 导出指定ID
     * @return excel 文件流
     */
    @ResponseExcel
    @GetMapping("/export")
    @PreAuthorize("@pms.hasPermission('device_workOrder_export')" )
    public List<WorkOrder> export(WorkOrder workOrder,Long[] ids) {
        return workOrderService.list(Wrappers.lambdaQuery(workOrder).in(ArrayUtil.isNotEmpty(ids), WorkOrder::getId, ids));
    }
}