春风项目四线(合箱线、总装线)
wujian
2024-09-10 51b05b093fa15dd477981372f67ae7b3b2747733
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
161
162
163
164
165
166
167
168
169
170
171
172
173
174
175
176
177
178
179
180
181
182
183
184
185
186
187
188
189
190
191
192
193
194
195
196
197
198
199
200
201
202
203
204
205
206
207
208
209
210
211
212
213
214
215
216
217
218
219
220
221
222
223
224
225
226
227
228
229
230
231
232
233
234
235
236
237
238
239
240
241
242
243
244
245
246
247
248
249
250
251
252
253
254
255
256
257
258
259
260
261
262
263
264
265
266
267
268
269
270
271
272
273
274
275
276
277
278
279
280
281
282
283
package com.jcdm.main.om.productionOrde.controller;
 
import cn.hutool.core.collection.CollUtil;
import cn.hutool.core.util.ObjectUtil;
import cn.hutool.core.util.StrUtil;
import com.jcdm.common.annotation.Log;
import com.jcdm.common.core.controller.BaseController;
import com.jcdm.common.core.domain.AjaxResult;
import com.jcdm.common.core.page.TableDataInfo;
import com.jcdm.common.enums.BusinessType;
import com.jcdm.common.exception.ServiceException;
import com.jcdm.common.utils.poi.ExcelUtil;
import com.jcdm.main.bs.modelNumber.domain.BsModelNumber;
import com.jcdm.main.bs.modelNumber.service.IBsModelNumberService;
import com.jcdm.main.bs.orderScheduling.domain.BsOrderScheduling;
import com.jcdm.main.bs.orderScheduling.service.IBsOrderSchedulingService;
import com.jcdm.main.om.productionOrde.domain.OmProductionOrdeInfo;
import com.jcdm.main.om.productionOrde.service.IOmProductionOrdeInfoService;
import com.jcdm.main.webservice.service.ReceivingServices;
import org.apache.commons.lang3.StringUtils;
import org.springframework.beans.factory.annotation.Autowired;
import org.springframework.security.access.prepost.PreAuthorize;
import org.springframework.web.bind.annotation.*;
 
import javax.servlet.http.HttpServletResponse;
import java.time.LocalDateTime;
import java.time.format.DateTimeFormatter;
import java.util.Comparator;
import java.util.List;
import java.util.stream.Collectors;
 
import static org.apache.commons.lang3.SystemUtils.getUserName;
 
/**
 * 生产工单Controller
 * 
 * @author ruimin
 * @date 2023-12-11
 */
@RestController
@RequestMapping("/om/productionOrde")
public class OmProductionOrdeInfoController extends BaseController
{
    @Autowired
    private IOmProductionOrdeInfoService omProductionOrdeInfoService;
 
    @Autowired
    private IBsOrderSchedulingService bsOrderSchedulingService;
 
    @Autowired
    private IBsModelNumberService bsModelNumberService;
 
    /**
     * 查询生产工单列表
     */
    @PreAuthorize("@ss.hasPermi('om:productionOrde:list')")
    @GetMapping("/list")
    public TableDataInfo list(OmProductionOrdeInfo omProductionOrdeInfo)
    {
        startPage();
        if (StrUtil.isNotBlank(omProductionOrdeInfo.getEngineNo())){
            BsOrderScheduling bsOrderScheduling = bsOrderSchedulingService.selectBsOrderSchedulingSNCode(omProductionOrdeInfo.getEngineNo());
            if (ObjectUtil.isNotEmpty(bsOrderScheduling)){
                String orderNo = bsOrderScheduling.getOrderNo();
                if (StrUtil.isNotBlank(orderNo)){
                    omProductionOrdeInfo.setWorkOrderNo(orderNo);
                }
            }
        }
        List<OmProductionOrdeInfo> list = omProductionOrdeInfoService.selectOmProductionOrdeInfoList(omProductionOrdeInfo);
        return getDataTable(list);
    }
 
    /**
     * 导出生产工单列表
     */
    @PreAuthorize("@ss.hasPermi('om:productionOrde:export')")
    @Log(title = "生产工单", businessType = BusinessType.EXPORT)
    @PostMapping("/export")
    public void export(HttpServletResponse response, OmProductionOrdeInfo omProductionOrdeInfo)
    {
        List<OmProductionOrdeInfo> list = omProductionOrdeInfoService.selectOmProductionOrdeInfoList(omProductionOrdeInfo);
        ExcelUtil<OmProductionOrdeInfo> util = new ExcelUtil<OmProductionOrdeInfo>(OmProductionOrdeInfo.class);
        util.exportExcel(response, list, "生产工单数据");
    }
 
    /**
     * 获取生产工单详细信息
     */
    @PreAuthorize("@ss.hasPermi('om:productionOrde:query')")
    @GetMapping(value = "/{id}")
    public AjaxResult getInfo(@PathVariable("id") Long id)
    {
        return success(omProductionOrdeInfoService.selectOmProductionOrdeInfoById(id));
    }
 
    /**
     * 获取生产工单详细信息
     */
    @PreAuthorize("@ss.hasPermi('om:productionOrde:query')")
    @GetMapping("/ids/{ids}")
    public AjaxResult getInfo(@PathVariable Long[] ids)
    {
        List<OmProductionOrdeInfo> omProductionOrdeInfos = omProductionOrdeInfoService.selectOmProductionOrderListById(ids);
        if (CollUtil.isNotEmpty(omProductionOrdeInfos)){
            List<String> collect = omProductionOrdeInfos.stream().map(OmProductionOrdeInfo::getProductCode).distinct().collect(Collectors.toList());
            if (CollUtil.isNotEmpty(collect)){
                if (collect.size()>1){
                    return error("存在多个不同的产品编号,请检查");
                }
            }
            List<String> collect1 = omProductionOrdeInfos.stream().map(OmProductionOrdeInfo::getOrderStatus).distinct().collect(Collectors.toList());
            if (CollUtil.isNotEmpty(collect1)){
                if (collect1.size()>1){
                    return error("存在多个不同的工单状态,请检查");
                }
            }
        }
        return success(omProductionOrdeInfoService.selectOmProductionOrdeInfoByIds(ids));
    }
 
    /**
     * 新增生产工单
     */
    @PreAuthorize("@ss.hasPermi('om:productionOrde:add')")
    @Log(title = "生产工单", businessType = BusinessType.INSERT)
    @PostMapping
    public AjaxResult add(@RequestBody OmProductionOrdeInfo omProductionOrdeInfo)
    {
        return toAjax(omProductionOrdeInfoService.insertOmProductionOrdeInfo(omProductionOrdeInfo));
    }
 
    /**
     * 生成按钮
     */
    @PostMapping("/orderSchedulingForBoxCode")
    public AjaxResult addOrderSchedulingForBoxCode(@RequestBody OmProductionOrdeInfo omProductionOrdeInfo)
    {
 
        //获取当前时间
        LocalDateTime date= LocalDateTime.now();
        //创建日期时间对象格式化器,日期格式类似: 2023-05-23 22:18:38
        DateTimeFormatter formatter= DateTimeFormatter.ofPattern("yyyy-MM-dd HH:mm:ss");
        //将时间转化为对应格式的字符串
        String fomateDate=date.format(formatter).toString();
 
        Integer startCode = Integer.parseInt(omProductionOrdeInfo.getStartCode());//开始编号
 
        String dateTimeRule = omProductionOrdeInfo.getDateTimeRule();
 
        //校验编号重复
        BsModelNumber bsModelNumberCheck = new BsModelNumber();
        bsModelNumberCheck.setModel(omProductionOrdeInfo.getTypeZ());
        bsModelNumberCheck.setModelDate(dateTimeRule);
        List<BsModelNumber> numbers = bsModelNumberService.selectBsModelNumberList(bsModelNumberCheck);
        BsModelNumber bsModelNumber = new BsModelNumber();
        Integer maxNum = 0;
        if (CollUtil.isNotEmpty(numbers)){
            bsModelNumber = numbers.get(0);
            String maxnumValue = bsModelNumber.getMaxnumValue();
            if (StrUtil.isNotBlank(maxnumValue)){
                maxNum = Integer.parseInt(maxnumValue);
            }
        }
        if (startCode<=maxNum){
            return AjaxResult.error("编号重复,请检查!");
        }
        Long[] id=omProductionOrdeInfo.getIdNums();
        List<OmProductionOrdeInfo> omProductionOrdeInfoList = omProductionOrdeInfoService.selectOmProductionOrderListById(id);
        if (CollUtil.isNotEmpty(omProductionOrdeInfoList)){
            omProductionOrdeInfoList.forEach(x -> {
                if (ObjectUtil.isNotNull(x.getWorkOrderNo())){
                    long l = Long.parseLong(x.getWorkOrderNo());
                    x.setWorkOrderNoLong(l);
                }
            });
            List<OmProductionOrdeInfo> sortList = omProductionOrdeInfoList.stream().sorted(Comparator.comparing(OmProductionOrdeInfo::getWorkOrderNoLong)).collect(Collectors.toList());
            for (OmProductionOrdeInfo ProductionOrde : sortList) {
                Integer planQty = Math.toIntExact(ProductionOrde.getPlanQty());//计划数量
                if(planQty>0) {
                    for (int i = 0; i < planQty; i++) {
                        String engineNo = omProductionOrdeInfo.getTypeZ() + " " + dateTimeRule + StringUtils.leftPad(String.valueOf(startCode), 3, "0");
                        BsOrderScheduling bsOrderScheduling = new BsOrderScheduling();
                        bsOrderScheduling.setOrderNo(ProductionOrde.getWorkOrderNo());
                        bsOrderScheduling.setWorkingHours(String.valueOf(i+1));
                        bsOrderScheduling.setModel(ProductionOrde.getTypeZ());
                        bsOrderScheduling.setEngineNo(engineNo);
                        bsOrderScheduling.setProductionStatus("1");
                        bsOrderScheduling.setOperator(getUserName());
                        bsOrderScheduling.setOperateTime(fomateDate);
                        bsOrderScheduling.setProductType(ProductionOrde.getTypeL());//产品类型
                        bsOrderScheduling.setWhetherOrPrint("0");
                        bsOrderSchedulingService.insertBsOrderScheduling(bsOrderScheduling);
                        startCode++;
                    }
                }
                //更新工单状态
                ProductionOrde.setOrderStatus("2");
                omProductionOrdeInfoService.updateOmProductionOrdeInfo(ProductionOrde);
            }
        }
        //新增机型序号
        if (ObjectUtil.isNotNull(bsModelNumber.getId())){
            bsModelNumber.setMaxnumValue((startCode - 1) + "");
            bsModelNumber.setSaveTime(fomateDate);
            bsModelNumber.setLastNumber((startCode - 1) + "");
            bsModelNumberService.updateBsModelNumber(bsModelNumber);
        } else {
            BsModelNumber bsModelNumberSave = new BsModelNumber();
            bsModelNumberSave.setModel(omProductionOrdeInfo.getTypeZ());
            bsModelNumberSave.setModelDate(dateTimeRule);
            bsModelNumberSave.setMaxnumValue((startCode - 1) + "");
            bsModelNumberSave.setSaveTime(fomateDate);
            bsModelNumberSave.setLastNumber((startCode - 1) + "");
            bsModelNumberService.insertBsModelNumber(bsModelNumberSave);
        }
        return toAjax(1);
    }
 
    /**
     * 修改生产工单
     */
    @PreAuthorize("@ss.hasPermi('om:productionOrde:edit')")
    @Log(title = "生产工单", businessType = BusinessType.UPDATE)
    @PutMapping
    public AjaxResult edit(@RequestBody OmProductionOrdeInfo omProductionOrdeInfo)
    {
        return toAjax(omProductionOrdeInfoService.updateOmProductionOrdeInfo(omProductionOrdeInfo));
    }
 
    /**
     * 删除生产工单
     */
    @PreAuthorize("@ss.hasPermi('om:productionOrde:remove')")
    @Log(title = "生产工单", businessType = BusinessType.DELETE)
    @DeleteMapping("/{ids}")
    public AjaxResult remove(@PathVariable Long[] ids)
    {
        return toAjax(omProductionOrdeInfoService.deleteOmProductionOrdeInfoByIds(ids));
    }
 
    /**
     * table列上移下移
     */
    @Log(title = "生产工单", businessType = BusinessType.DELETE)
    @GetMapping("/upDownMove")
    public AjaxResult upDownMove(OmProductionOrdeInfo omProductionOrdeInfo)
    {
        return omProductionOrdeInfoService.upDownMove(omProductionOrdeInfo);
    }
 
    /**
     * 接收工单
     */
    @PreAuthorize("@ss.hasPermi('om:productionOrde:receive')")
    @GetMapping("/getProductionNotice")
    public AjaxResult getProductionNotice(OmProductionOrdeInfo omProductionOrdeInfo)
    {
        String factory = omProductionOrdeInfo.getWorkshopCode();
        String productionNotice = omProductionOrdeInfo.getProductionNotice();
        if (StrUtil.isBlank(productionNotice)){
            throw new ServiceException("请输入生产通知单号");
        }
        if (StrUtil.isBlank(factory)){
            throw new ServiceException("请选择工厂编号");
        }
        OmProductionOrdeInfo queryProductOrder = new OmProductionOrdeInfo();
        queryProductOrder.setWorkshopCode(factory);
        queryProductOrder.setProductionNotice(productionNotice);
        List<OmProductionOrdeInfo> omProductionOrdeInfos = omProductionOrdeInfoService.selectOmProductionOrdeInfoList(queryProductOrder);
        if(CollUtil.isEmpty(omProductionOrdeInfos)){
            try {
                logger.info("接收工单号:,{}",productionNotice);
                ReceivingServices.insertWebserviceData(factory,productionNotice);
            } catch (Exception e) {
                return error("接收失败!请检查通知单号");
            }
        }else {
            return warn("该通知单已经接收完毕,不能重复接收!");
        }
        return AjaxResult.success("接收成功!");
    }
}