车间能级提升-智能设备管理系统
zhuguifei
2025-05-26 bbfd68648872621be182fd51f3a56a09cd21e09e
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
125
126
127
128
129
130
131
132
133
134
135
136
137
138
package org.dromara.eims.controller;
 
import java.util.ArrayList;
import java.util.List;
 
import lombok.RequiredArgsConstructor;
import jakarta.servlet.http.HttpServletResponse;
import jakarta.validation.constraints.*;
import cn.dev33.satoken.annotation.SaCheckPermission;
import org.dromara.common.excel.core.ExcelResult;
import org.dromara.eims.domain.vo.EimsEquImportVo;
import org.dromara.eims.domain.vo.EimsEquVo;
import org.dromara.eims.domain.vo.EimsFixtureImportVo;
import org.dromara.eims.listener.EimsEquImportListener;
import org.dromara.eims.listener.EimsFixtureImportListener;
import org.springframework.http.MediaType;
import org.springframework.web.bind.annotation.*;
import org.springframework.validation.annotation.Validated;
import org.dromara.common.idempotent.annotation.RepeatSubmit;
import org.dromara.common.log.annotation.Log;
import org.dromara.common.web.core.BaseController;
import org.dromara.common.mybatis.core.page.PageQuery;
import org.dromara.common.core.domain.R;
import org.dromara.common.core.validate.AddGroup;
import org.dromara.common.core.validate.EditGroup;
import org.dromara.common.log.enums.BusinessType;
import org.dromara.common.excel.utils.ExcelUtil;
import org.dromara.eims.domain.vo.EimsFixtureVo;
import org.dromara.eims.domain.bo.EimsFixtureBo;
import org.dromara.eims.service.IEimsFixtureService;
import org.dromara.common.mybatis.core.page.TableDataInfo;
import org.springframework.web.multipart.MultipartFile;
 
/**
 * 工具(治具)台账
 *
 * @author zhuguifei
 * @date 2025-02-14
 */
@Validated
@RequiredArgsConstructor
@RestController
@RequestMapping("/eims/fixture")
public class EimsFixtureController extends BaseController {
 
    private final IEimsFixtureService eimsFixtureService;
 
    /**
     * 查询工具(治具)台账列表
     */
    @SaCheckPermission("eims:fixture:list")
    @GetMapping("/list")
    public TableDataInfo<EimsFixtureVo> list(EimsFixtureBo bo, PageQuery pageQuery) {
        return eimsFixtureService.queryPageList(bo, pageQuery);
    }
 
    /**
     * 导出工具(治具)台账列表
     */
    @SaCheckPermission("eims:fixture:export")
    @Log(title = "工具(治具)台账", businessType = BusinessType.EXPORT)
    @PostMapping("/export")
    public void export(EimsFixtureBo bo, HttpServletResponse response) {
        List<EimsFixtureVo> list = eimsFixtureService.queryList(bo);
        ExcelUtil.exportExcel(list, "工具(治具)台账", EimsFixtureVo.class, response);
    }
 
    /**
     * 获取工具(治具)台账详细信息
     *
     * @param id 主键
     */
    @SaCheckPermission("eims:fixture:query")
    @GetMapping("/{id}")
    public R<EimsFixtureVo> getInfo(@NotNull(message = "主键不能为空")
                                     @PathVariable Long id) {
        return R.ok(eimsFixtureService.queryById(id));
    }
 
    /**
     * 新增工具(治具)台账
     */
    @SaCheckPermission("eims:fixture:add")
    @Log(title = "工具(治具)台账", businessType = BusinessType.INSERT)
    @RepeatSubmit()
    @PostMapping()
    public R<Void> add(@Validated(AddGroup.class) @RequestBody EimsFixtureBo bo) {
        return toAjax(eimsFixtureService.insertByBo(bo));
    }
 
    /**
     * 修改工具(治具)台账
     */
    @SaCheckPermission("eims:fixture:edit")
    @Log(title = "工具(治具)台账", businessType = BusinessType.UPDATE)
    @RepeatSubmit()
    @PutMapping()
    public R<Void> edit(@Validated(EditGroup.class) @RequestBody EimsFixtureBo bo) {
        return toAjax(eimsFixtureService.updateByBo(bo));
    }
 
    /**
     * 删除工具(治具)台账
     *
     * @param ids 主键串
     */
    @SaCheckPermission("eims:fixture:remove")
    @Log(title = "工具(治具)台账", businessType = BusinessType.DELETE)
    @DeleteMapping("/{ids}")
    public R<Void> remove(@NotEmpty(message = "主键不能为空")
                          @PathVariable Long[] ids) {
        return toAjax(eimsFixtureService.deleteWithValidByIds(List.of(ids), true));
    }
 
    /**
     * 导入数据
     *
     * @param file          导入文件
     * @param updateSupport 是否更新已存在数据
     */
    @Log(title = "工具管理", businessType = BusinessType.IMPORT)
    @SaCheckPermission("eims:fixture:import")
    @PostMapping(value = "/importData", consumes = MediaType.MULTIPART_FORM_DATA_VALUE)
    public R<Void> importData(@RequestPart("file") MultipartFile file, boolean updateSupport) throws Exception {
        ExcelResult<EimsFixtureImportVo> result = ExcelUtil.importExcel(file.getInputStream(), EimsFixtureImportVo.class, new EimsFixtureImportListener(updateSupport));
        return R.ok(result.getAnalysis());
    }
 
    /**
     * 获取导入模板
     */
    @PostMapping("/importTemplate")
    public void importTemplate(HttpServletResponse response) {
        ExcelUtil.exportExcel(new ArrayList<>(), "设备数据", EimsFixtureVo.class, response);
    }
 
 
}