yangys
2025-09-07 56f5157ae8dba22eb30fb6c7cb132f80b7161932
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
139
140
141
142
143
144
145
146
147
148
149
150
151
152
153
154
155
156
157
158
159
160
package org.springblade.mdm.basesetting.producedivision.controller;
 
import com.baomidou.mybatisplus.core.metadata.IPage;
import io.swagger.v3.oas.annotations.Operation;
import io.swagger.v3.oas.annotations.tags.Tag;
import jakarta.servlet.http.HttpServletResponse;
import lombok.extern.slf4j.Slf4j;
import org.apache.commons.io.IOUtils;
import org.apache.commons.lang3.StringUtils;
import org.springblade.core.mp.support.Query;
import org.springblade.core.oss.OssTemplate;
import org.springblade.core.tool.api.IResultCode;
import org.springblade.core.tool.api.R;
import org.springblade.core.tool.utils.DateUtil;
import org.springblade.core.tool.utils.Func;
import org.springblade.mdm.basesetting.producedivision.entity.ProduceDivision;
import org.springblade.mdm.basesetting.producedivision.entity.QinzheFgb;
import org.springblade.mdm.basesetting.producedivision.service.ProduceDivisionService;
import org.springblade.mdm.basesetting.producedivision.vo.ImportResult;
import org.springblade.mdm.basesetting.producedivision.vo.ProduceDivisionVO;
import org.springblade.mdm.basesetting.producedivision.vo.ProduceDivisionViewVO;
import org.springblade.mdm.commons.service.ParamService;
import org.springblade.mdm.program.vo.DncSendBackData;
import org.springframework.beans.factory.annotation.Autowired;
import org.springframework.web.bind.annotation.*;
import org.springframework.web.multipart.MultipartFile;
 
import java.io.IOException;
import java.io.InputStream;
import java.util.Collections;
import java.util.List;
 
@Slf4j
@RestController
@RequestMapping("/producedivision")
@Tag(name = "主制分工表", description = "主制分工表")
public class ProduceDivisionController {
 
    @Autowired
    private ProduceDivisionService service;
    @Autowired
    private ParamService paramService;
    @Autowired
    private OssTemplate ossTemplate;
    /**
     * 新增
     */
    @PostMapping("/save")
    @Operation(summary = "新增", description = "主制计划表")
    public R<Boolean> save(@RequestBody ProduceDivisionVO vo) {
        try {
            service.saveDivision(vo);
            return R.success();
        }catch(Exception e) {
            return R.fail(e.getMessage());
        }
 
    }
 
    /**
     * 修改
     */
    @Operation(summary = "修改", description = "主制计划表")
    @PostMapping("/update")
    public R<Boolean> update(@RequestBody ProduceDivisionVO vo) {
 
        return R.<Boolean>status(service.updateDivision(vo));
    }
 
    /**
     * 删除
     */
    @Operation(summary = "删除", description = "删除")
    @PostMapping("/remove")
    public R<Void> remove(@RequestParam String ids) {
        try {
            return R.status(service.removeBatchByIds(Func.toLongList(ids)));
        } catch (Exception e) {
            log.error("删除异常",e);
            return R.fail(e.getMessage());
        }
    }
 
    /**
     * 分页
     */
    @Operation(summary = "分页查询", description = "姓名")
    @GetMapping("/page")
    public R<IPage<ProduceDivisionViewVO>> page(String name, Query query) {
 
        IPage<ProduceDivisionViewVO> pages = service.pageQuery(name,query);
        return R.data(pages);
    }
 
    @Operation(summary = "导入分工表", description = "导入分工表")
    @PostMapping("/import-division")
    public R<ImportResult> importDivision(@RequestParam MultipartFile file) {
        try {
            return R.data(service.importDivision(file));
        }catch(Exception e) {
            log.error("导入异常",e);
            return R.fail(e.getMessage());
        }
    }
    @Operation(summary = "下载分工表导入模板", description = "下载分工表导入模板")
    @GetMapping("/download-template")
    public void downloadTemplate(HttpServletResponse response) {
        String PARAMKEY = "DIVISION_TEMPLATE";
 
        try {
            String filename = "divisiontemplate.xlsx";
            response.setHeader("Content-Disposition", "attachment; filename="+filename);
            response.setContentType("application/octet-stream");
            String ossName  = paramService.getParamValue(PARAMKEY,"");
            try(InputStream ins = ossTemplate.statFileStream(ossName);){
                IOUtils.copy(ins,response.getOutputStream());
            }
 
        } catch (Exception e) {
            log.error("导出分工表模板异常", e);
        }
    }
    @Operation(summary = "任务计划查询分工表id", description = "任务计划g根据零组件号查询职责表id")
    @GetMapping("/select-by-drawingno")
    public R<ProduceDivision> selectByDrawingNo(@RequestParam String drawingNo) {
        try {
            ProduceDivision div = service.getByDrawingNoWithQinzhe(drawingNo);
            return R.data(div);
        } catch (Exception e) {
            log.error("根据零件号获取职责表异常",e);
            return R.fail(new IResultCode() {
                @Override
                public String getMessage() {
                    return e.getMessage();
                }
 
                @Override
                public int getCode() {
                    return 201;
                }
            });
        }
    }
 
    @Operation(summary = "任务计划选择主管工艺", description = "任务计划选择主管工艺")
    @GetMapping("/select-programmer")
    public R<List<ProduceDivisionViewVO>> selectProgrammer(@RequestParam String programmer) {
        if(StringUtils.isBlank(programmer)){
            return R.data(Collections.emptyList());
        }
        try {
 
            String p = programmer.trim();
            return R.data(service.queryProgrammer(programmer));
        } catch (Exception e) {
            log.error("获取零件号异常",e);
            return R.fail(e.getMessage());
        }
    }
}