yangys
2025-08-29 b7af95d487f49490de16f9636147e5a40911e157
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
package org.springblade.mdm.machineback.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.springblade.core.excel.util.ExcelUtil;
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.machine.MachineService;
import org.springblade.mdm.basesetting.machine.entity.Machine;
import org.springblade.mdm.basesetting.producedivision.entity.MdmDept;
import org.springblade.mdm.basesetting.producedivision.service.MdmDeptService;
import org.springblade.mdm.gkw.programnode.service.MachineFileService;
import org.springblade.mdm.machineback.service.MachineBackFileService;
import org.springblade.mdm.machineback.vo.MachineBackFileExcelVO;
import org.springblade.mdm.machineback.vo.MachineBackFileQueryVO;
import org.springblade.mdm.machineback.vo.MachineBackFileVO;
import org.springblade.system.pojo.entity.Dept;
import org.springframework.beans.BeanUtils;
import org.springframework.beans.factory.annotation.Autowired;
import org.springframework.web.bind.annotation.*;
 
import java.util.ArrayList;
import java.util.List;
import java.util.stream.Collectors;
 
@Slf4j
@RestController
@RequestMapping("/machineback/file")
@Tag(name = "机床回传文件", description = "机床回传文件")
public class MachineBackFileController {
 
    @Autowired
    private MachineBackFileService service;
    @Autowired
    private MachineFileService machineFileService;
    @Autowired
    private MachineService machineService;
    @Autowired
    private MdmDeptService mdmDeptService;
    /**
     * 接收
     */
    @Operation(summary = "接收", description = "接收文件")
    @PostMapping("/accept")
    public R<Void> accept(@RequestParam String ids) {
        service.accept(ids);
        return R.success();
    }
 
    /**
     *拒绝,就是删除
     */
    @Operation(summary = "拒绝", description = "拒绝")
    @PostMapping("/reject")
    public R<Void> reject(@RequestParam String ids) {
        try {
            service.reject(ids);
        } catch (Exception e) {
            log.error("拒绝异常",e);
            return R.fail(e.getMessage());
        }
        return R.status(true);
    }
 
    /**
     * 分页
     */
    @Operation(summary = "分页查询", description = "名称或编码")
    @GetMapping("/page")
    public R<IPage<MachineBackFileVO>> page(MachineBackFileQueryVO query) {
        List<Long> deptIds = new ArrayList<>();
        if("workshop".equals(query.getNodeType()) || "seg".equals(query.getNodeType())) {
            //节点为车间、工段
            MdmDept dept = mdmDeptService.getById(query.getNodeId());
 
            String idStr = dept.getAncestors()+","+dept.getId();
            List<MdmDept> depts = mdmDeptService.lambdaQuery().likeRight(MdmDept::getParentId, query.getNodeId()).list();
            deptIds.addAll(depts.stream().map(MdmDept::getId).toList());
            deptIds.add(dept.getId());
            //+本车间
            //Func.toStrList(",",idStr)
            query.setDeptIds(deptIds);
        }else if("machine".equals(query.getNodeType())){
            Machine machine = machineService.getById(query.getNodeId());
            query.setMachineCode(machine.getCode());
        }else if("dir".equals(query.getNodeType())){
            query.setMachineCode(query.getMachineCode());
        }
        IPage<MachineBackFileVO> pages = machineFileService.machineBackFilePageQuery(query);
        return R.data(pages);
    }
    /**
     * 分页
     */
    @Operation(summary = "导出Excel", description = "导出Excel")
    @GetMapping("/export-excel")
    public void exportExcel(MachineBackFileQueryVO query, HttpServletResponse response) {
        query.setCurrent(1);
        query.setSize(Integer.MAX_VALUE);
 
        //IPage<MachineBackFileVO> pages = service.pageQuery(query);
        IPage<MachineBackFileVO> pages = machineFileService.machineBackFilePageQuery(query);
        List<MachineBackFileExcelVO> list = new ArrayList<>();
        pages.getRecords().forEach(m ->{
            MachineBackFileExcelVO excelVO = new MachineBackFileExcelVO();
            BeanUtils.copyProperties(m, excelVO);
            excelVO.setCureStatus(m.getIsCured()==1?"已固化":"未固化");
            list.add(excelVO);
        });
        ExcelUtil.export(response, "机床回传文件" + DateUtil.time(), "机床回传文件表", list, MachineBackFileExcelVO.class);
    }
}