From 2cc5a1afe8296d148f0a32989395d538e5323a8e Mon Sep 17 00:00:00 2001
From: hdy <1105738590@qq.com>
Date: 星期四, 18 一月 2024 16:22:55 +0800
Subject: [PATCH] Merge remote-tracking branch 'origin/master'

---
 jcdm-main/src/main/java/com/jcdm/main/om/productionOrde/controller/OmProductionOrdeInfoController.java |   91 +++++++++++++++++++++++++++++++++++++++++++++
 1 files changed, 91 insertions(+), 0 deletions(-)

diff --git a/jcdm-main/src/main/java/com/jcdm/main/om/productionOrde/controller/OmProductionOrdeInfoController.java b/jcdm-main/src/main/java/com/jcdm/main/om/productionOrde/controller/OmProductionOrdeInfoController.java
index 63a195d..3357f1e 100644
--- a/jcdm-main/src/main/java/com/jcdm/main/om/productionOrde/controller/OmProductionOrdeInfoController.java
+++ b/jcdm-main/src/main/java/com/jcdm/main/om/productionOrde/controller/OmProductionOrdeInfoController.java
@@ -1,9 +1,20 @@
 package com.jcdm.main.om.productionOrde.controller;
 
+import java.text.SimpleDateFormat;
+import java.time.LocalDateTime;
+import java.time.format.DateTimeFormatter;
+import java.util.Date;
 import java.util.List;
 import javax.servlet.http.HttpServletResponse;
+
+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.security.access.prepost.PreAuthorize;
 import org.springframework.beans.factory.annotation.Autowired;
 import org.springframework.web.bind.annotation.GetMapping;
@@ -21,6 +32,8 @@
 import com.jcdm.common.utils.poi.ExcelUtil;
 import com.jcdm.common.core.page.TableDataInfo;
 
+import static org.apache.commons.lang3.SystemUtils.getUserName;
+
 /**
  * 鐢熶骇宸ュ崟Controller
  * 
@@ -33,6 +46,12 @@
 {
     @Autowired
     private IOmProductionOrdeInfoService omProductionOrdeInfoService;
+
+    @Autowired
+    private IBsOrderSchedulingService bsOrderSchedulingService;
+
+    @Autowired
+    private IBsModelNumberService bsModelNumberService;
 
     /**
      * 鏌ヨ鐢熶骇宸ュ崟鍒楄〃
@@ -81,6 +100,57 @@
     }
 
     /**
+     * 鏂板鐢熶骇宸ュ崟
+     */
+    @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());//寮�濮嬬紪鍙�
+        Integer planQty = Math.toIntExact(omProductionOrdeInfo.getPlanQty());//璁″垝鏁伴噺
+        String dateTimeRule = omProductionOrdeInfo.getDateTimeRule();
+
+        String engineNo = "";
+        if(planQty>0) {
+            for (int i = 0; i < planQty; i++) {
+                engineNo = omProductionOrdeInfo.getTypeZ() + " " + dateTimeRule + StringUtils.leftPad(String.valueOf(startCode), 3, "0");
+                BsOrderScheduling bsOrderScheduling = new BsOrderScheduling();
+                bsOrderScheduling.setOrderNo(omProductionOrdeInfo.getWorkOrderNo());
+                bsOrderScheduling.setModel(omProductionOrdeInfo.getTypeZ());
+                bsOrderScheduling.setEngineNo(engineNo);
+                bsOrderScheduling.setProductionStatus("1");
+                bsOrderScheduling.setOperator(getUserName());
+                bsOrderScheduling.setOperateTime(fomateDate);
+                bsOrderScheduling.setProductType(omProductionOrdeInfo.getTypeL());//浜у搧绫诲瀷
+                bsOrderScheduling.setWhetherOrPrint("0");
+                bsOrderSchedulingService.insertBsOrderScheduling(bsOrderScheduling);
+                startCode++;
+            }
+
+            //鏂板鏈哄瀷搴忓彿
+            BsModelNumber bsModelNumber = new BsModelNumber();
+            bsModelNumber.setModel(omProductionOrdeInfo.getTypeZ());
+            bsModelNumber.setModelDate(dateTimeRule);
+            bsModelNumber.setMaxnumValue((startCode - 1) + "");
+            bsModelNumber.setSaveTime(fomateDate);
+            bsModelNumber.setLastNumber((startCode - 1) + "");
+            bsModelNumberService.insertBsModelNumber(bsModelNumber);
+        }
+        //鏇存柊宸ュ崟鐘舵��
+        omProductionOrdeInfo.setOrderStatus("2");
+        return toAjax(omProductionOrdeInfoService.updateOmProductionOrdeInfo(omProductionOrdeInfo));
+
+
+    }
+
+    /**
      * 淇敼鐢熶骇宸ュ崟
      */
     @PreAuthorize("@ss.hasPermi('om:productionOrde:edit')")
@@ -111,4 +181,25 @@
     {
         return omProductionOrdeInfoService.upDownMove(omProductionOrdeInfo);
     }
+
+    /**
+     * 鎺ユ敹宸ュ崟
+     */
+    @PreAuthorize("@ss.hasPermi('om:productionOrde:receive')")
+    @GetMapping("/getProductionNotice")
+    public AjaxResult getProductionNotice(OmProductionOrdeInfo omProductionOrdeInfo)
+    {
+        String productionNotice = omProductionOrdeInfo.getProductionNotice();
+        List<OmProductionOrdeInfo> omProductionOrdeInfos = omProductionOrdeInfoService.selectOmProductionOrdeInfoList(omProductionOrdeInfo);
+        if(omProductionOrdeInfos.size() == 0){
+            try {
+                ReceivingServices.insertWebserviceData(productionNotice);
+            } catch (Exception e) {
+                return error("鎺ユ敹澶辫触锛佽妫�鏌ラ�氱煡鍗曞彿");
+            }
+        }else {
+            return warn("璇ラ�氱煡鍗曞凡缁忔帴鏀跺畬姣曪紝涓嶈兘閲嶅鎺ユ敹锛�");
+        }
+        return AjaxResult.success("鎺ユ敹鎴愬姛锛�");
+    }
 }

--
Gitblit v1.9.3