From b9df2fc5c64a1d989991655a9e42e4d1f2ec4075 Mon Sep 17 00:00:00 2001
From: hdy <1105738590@qq.com>
Date: 星期四, 06 三月 2025 18:18:11 +0800
Subject: [PATCH] 修改

---
 billion-main/src/main/java/com/billion/main/plcServer/sub/OPCUaSubscription.java |  335 +++++++++++++++++++++++++++++++++++++++++++------------
 1 files changed, 261 insertions(+), 74 deletions(-)

diff --git a/billion-main/src/main/java/com/billion/main/plcServer/sub/OPCUaSubscription.java b/billion-main/src/main/java/com/billion/main/plcServer/sub/OPCUaSubscription.java
index 1ab1bbf..aa650f9 100644
--- a/billion-main/src/main/java/com/billion/main/plcServer/sub/OPCUaSubscription.java
+++ b/billion-main/src/main/java/com/billion/main/plcServer/sub/OPCUaSubscription.java
@@ -1,14 +1,23 @@
 package com.billion.main.plcServer.sub;
 
+import com.billion.common.utils.StringUtils;
 import com.billion.main.bs.domain.BsBomChildInfo;
 import com.billion.main.bs.service.IBsBomChildInfoService;
 import com.billion.main.constant.Constants;
+import com.billion.main.da.domain.DaCollectionParamConf;
+import com.billion.main.da.domain.DaMaterialCollection;
+import com.billion.main.da.domain.DaParamCollection;
+import com.billion.main.da.domain.DaStationCollection;
+import com.billion.main.da.service.IDaCollectionParamConfService;
+import com.billion.main.da.service.IDaMaterialCollectionService;
 import com.billion.main.da.service.IDaParamCollectionService;
 import com.billion.main.da.service.IDaStationCollectionService;
 import com.billion.main.om.domain.OmOrderScheduling;
 import com.billion.main.om.domain.OmProductionOrderInfo;
 import com.billion.main.om.service.IOmOrderSchedulingService;
 import com.billion.main.om.service.IOmProductionOrderInfoService;
+import com.billion.main.sys.domain.SysCount;
+import com.billion.main.sys.service.ISysCountService;
 import com.kangaroohy.milo.model.ReadWriteEntity;
 import com.kangaroohy.milo.runner.subscription.SubscriptionCallback;
 import com.kangaroohy.milo.service.MiloService;
@@ -16,8 +25,9 @@
 import org.springframework.stereotype.Component;
 
 import java.time.LocalDateTime;
-import java.util.ArrayList;
+import java.util.Date;
 import java.util.List;
+import java.util.Objects;
 import java.util.concurrent.CompletableFuture;
 @Slf4j
 @Component
@@ -27,21 +37,31 @@
     public IDaStationCollectionService daStationCollectionService;
     public IOmProductionOrderInfoService omProductionOrderInfoService;
     public IOmOrderSchedulingService omOrderSchedulingService;
-    public IBsBomChildInfoService bomChildInfoService;
+    public IBsBomChildInfoService bsBomChildInfoService;
+    public IDaCollectionParamConfService daCollectionParamConfService;
+    public IDaMaterialCollectionService daMaterialCollectionService;
+    public ISysCountService sysCountService;
+
 
     public OPCUaSubscription(MiloService miloService,
                              IDaParamCollectionService daParamCollectionService,
                              IDaStationCollectionService daStationCollectionService,
                              IOmProductionOrderInfoService omProductionOrderInfoService,
                              IOmOrderSchedulingService omOrderSchedulingService,
-                             IBsBomChildInfoService bomChildInfoService
+                             IBsBomChildInfoService bsBomChildInfoService,
+                             IDaCollectionParamConfService daCollectionParamConfService,
+                             IDaMaterialCollectionService daMaterialCollectionService,
+                             ISysCountService sysCountService
                              ) {
         OPCUaSubscription.miloService = miloService;
         this.daParamCollectionService = daParamCollectionService;
         this.daStationCollectionService = daStationCollectionService;
         this.omProductionOrderInfoService = omProductionOrderInfoService;
         this.omOrderSchedulingService = omOrderSchedulingService;
-        this.bomChildInfoService = bomChildInfoService;
+        this.bsBomChildInfoService = bsBomChildInfoService;
+        this.daCollectionParamConfService = daCollectionParamConfService;
+        this.daMaterialCollectionService = daMaterialCollectionService;
+        this.sysCountService = sysCountService;
     }
     @Override
     public void onSubscribe(String identifier, Object value) {
@@ -71,12 +91,12 @@
                     miloService.writeToOpcUa(ReadWriteEntity.builder().identifier(thoroughfare + "." + device + ".RecordDataDone").value("0").build());
                 //璇锋眰杩涚珯
                 } else if (Constants.ONE.equals(valueString)){
-                    //棣栧伐绔�
-                    if(Constants.C005.equals(device)){
+                    //1.1//棣栧伐绔�
+                    if(Constants.C005.equals(device) || Constants.OP005.equals(device) || Constants.P010.equals(device)){
                         miloService.writeToOpcUa(ReadWriteEntity.builder().identifier(thoroughfare + "." + device + ".RecordDataDone").value("11").build());
                     }
-                    //闄ら宸ョ珯鎵�鏈夊伐绔�
-                    else if(Constants.PLC.contains(device) && Constants.OP310.contains(device)){
+                    ///////闄ら宸ョ珯鎵�鏈夊伐绔�
+                    else if(Constants.PLC1.contains(device) && Constants.OP310.contains(device)){
                         //鏍¢獙SFCCode鏄惁瀛樺湪
                         Object SFCCode = miloService.readFromOpcUa(thoroughfare + "." + device + ".SFCCode").getValue();
                         Object PalletID = miloService.readFromOpcUa(thoroughfare + "." + device + ".PalletID").getValue();
@@ -93,32 +113,129 @@
                             //涓嬪彂閰嶆柟
                             formula(thoroughfare, device, bsbomChildInfo);
                             miloService.writeToOpcUa(ReadWriteEntity.builder().identifier(thoroughfare + "." + device + ".RecordDataDone").value("11").build());
+
                         }
                     }
-                //
-                //
                 //鍑虹珯淇濆瓨鏁版嵁
                 } else if (Constants.TWO.equals(valueString)) {
-                    //棣栧姛绔�
-                    if(Constants.C005.equals(device)){
-                        // 鍒ゆ柇鎺ュ崟鏄惁鎴愬姛
-                        OmOrderScheduling omOrderScheduling = new OmOrderScheduling();
-                        List<OmOrderScheduling> omOrderSchedulinglist = new ArrayList<>();
+                    OmProductionOrderInfo omProductionOrderInfo = new OmProductionOrderInfo();
+                    OmOrderScheduling omOrderScheduling = new OmOrderScheduling();
+                    Object SFCCode = miloService.readFromOpcUa(thoroughfare + "." + device + ".SFCCode").getValue();
+                    //涓婄嚎宸ヤ綅
+                    if(Constants.ONLINE.contains(device)){
                         Object workOrderNumber = miloService.readFromOpcUa(thoroughfare + "." + device + ".WorkOrderNumber").getValue();
-                        Object PalletID = miloService.readFromOpcUa(thoroughfare + "." + device + ".PalletID").getValue();
-                        Object SFCCode = miloService.readFromOpcUa(thoroughfare + "." + device + ".SFCCode").getValue();
-                        //鎵樼洏缁戝畾SFCCode鍜屽伐鍗�
+                        Object nowQty = miloService.readFromOpcUa(thoroughfare + "." + device + ".PalletID").getValue();
                         omOrderScheduling.setWorkOrderNo(workOrderNumber.toString());
-                        omOrderScheduling.setRemarks(PalletID.toString());
+                        omOrderScheduling.setNowQty((Long) nowQty);
                         omOrderScheduling.setSfcCode(SFCCode.toString());
-                        omOrderSchedulinglist.add(omOrderScheduling);
-                        omOrderSchedulingService.saveBatch(omOrderSchedulinglist);
-                        // 缂哄皯淇濆瓨鏁版嵁鐨勬柟娉�
+                        //鎵樼洏缁戝畾SFCCode鍜屽伐鍗曞拰浜х嚎
+                        if(Constants.OP005.equals(device)){
+                            omOrderScheduling.setRemarks("Body");
+                        }
+                        if(Constants.C005.equals(device)){
+                            omOrderScheduling.setRemarks("Head");
+                        }
+                        omOrderSchedulingService.insertOmOrderScheduling(omOrderScheduling);
+                    }else if(Constants.OFFLINE.contains(device)){
+                        if(Constants.C070.equals(device)){
+                            omOrderScheduling.setRemarks("Head");
+                            omOrderScheduling.setSfcCode(SFCCode.toString());
+                            List<OmOrderScheduling> omOrderSchedulingList = omOrderSchedulingService.selectOmOrderSchedulingList(omOrderScheduling);
+                            Object nowQty = omOrderSchedulingList.get(0).getNowQty();
+                            Object WorkOrderNumber = omOrderSchedulingList.get(0).getWorkOrderNo();
+                            omProductionOrderInfo.setWorkOrderNo(WorkOrderNumber.toString());
+                            List<OmProductionOrderInfo> omProductionOrderInfoList = omProductionOrderInfoService.selectOmProductionOrderInfoList(omProductionOrderInfo);
+                            Object headQty = omProductionOrderInfoList.get(0).getHeadQty();
+                            if (nowQty == headQty){
+                                omProductionOrderInfoList.get(0).setHeadStatus("3");
 
-                        miloService.writeToOpcUa(ReadWriteEntity.builder().identifier(thoroughfare + "." + device + ".RecordDataDone").value("21").build());
-                    }else if(Constants.PLC.contains(device) && Constants.OP310.contains(device)){
 
+                                omProductionOrderInfoService.updateOmProductionOrderInfo(omProductionOrderInfoList.get(0));
+                            }
+                        } else if (Constants.OP310.equals(device)) {
+                            omOrderScheduling.setRemarks("Body");
+                            omOrderScheduling.setSfcCode(SFCCode.toString());
+                            List<OmOrderScheduling> omOrderSchedulingList = omOrderSchedulingService.selectOmOrderSchedulingList(omOrderScheduling);
+                            Object nowQty = omOrderSchedulingList.get(0).getNowQty();
+                            Object WorkOrderNumber = omOrderSchedulingList.get(0).getWorkOrderNo();
+                            omProductionOrderInfo.setWorkOrderNo(WorkOrderNumber.toString());
+                            List<OmProductionOrderInfo> omProductionOrderInfoList = omProductionOrderInfoService.selectOmProductionOrderInfoList(omProductionOrderInfo);
+                            Object bodyQty = omProductionOrderInfoList.get(0).getBodyQty();
+                            if (nowQty == bodyQty){
+                                omProductionOrderInfoList.get(0).setBodyStatus("3");
+
+
+                                omProductionOrderInfoService.updateOmProductionOrderInfo(omProductionOrderInfoList.get(0));
+                            }
+                        }
+                    } else if (Constants.P010.equals(device)) {
+                        Object workOrderNumber = miloService.readFromOpcUa(thoroughfare + "." + device + ".WorkOrderNumber").getValue();
+                        Object nowQty = miloService.readFromOpcUa(thoroughfare + "." + device + ".PalletID").getValue();
+                        omOrderScheduling.setWorkOrderNo(workOrderNumber.toString());
+                        omOrderScheduling.setNowQty((Long) nowQty);
+                        omOrderScheduling.setSfcCode(SFCCode.toString());
+                        omOrderScheduling.setRemarks("Pre");
+                        omOrderSchedulingService.insertOmOrderScheduling(omOrderScheduling);
+                        List<OmOrderScheduling> omOrderSchedulingList = omOrderSchedulingService.selectOmOrderSchedulingList(omOrderScheduling);
+                        Object WorkOrderNumber = omOrderSchedulingList.get(0).getWorkOrderNo();
+                        omProductionOrderInfo.setWorkOrderNo(WorkOrderNumber.toString());
+                        List<OmProductionOrderInfo> omProductionOrderInfoList = omProductionOrderInfoService.selectOmProductionOrderInfoList(omProductionOrderInfo);
+                        Object preQty = omProductionOrderInfoList.get(0).getPreQty();
+                        if (nowQty == preQty){
+                            omProductionOrderInfoList.get(0).setPreStatus("3");
+
+
+                            omProductionOrderInfoService.updateOmProductionOrderInfo(omProductionOrderInfoList.get(0));
+
+                        }
                     }
+                    //鏌ヨdescriptive瀛楁绛変簬1鐨勯噰闆嗛」淇濆瓨鍒版壂鐮佷繚瀛樺埌da_material_collection琛ㄩ噷
+                    DaCollectionParamConf daCollectionParamConf1 = new DaCollectionParamConf();
+                    daCollectionParamConf1.setProcessesCode(device);
+                    daCollectionParamConf1.setDescriptive("1");
+                    List<DaCollectionParamConf> daCollectionParamConfList1 = daCollectionParamConfService.selectDaCollectionParamConfList(daCollectionParamConf1);
+                    for (DaCollectionParamConf conf : daCollectionParamConfList1) {
+                        String gatherAddress = conf.getGatherAddress();
+                        Object valueObj = miloService.readFromOpcUa(gatherAddress).getValue(); // 鑾峰彇鍘熷鍊煎璞♀��:ml-citation{ref="4" data="citationList"}
+                        if (valueObj == null || StringUtils.isEmpty(valueObj.toString())) {
+                            log.warn("閲囬泦鍦板潃{}杩斿洖绌哄�硷紝璺宠繃瀛樺偍", gatherAddress);
+                            continue; // 缁堟褰撳墠寰幆杩唬鈥�:ml-citation{ref="1,2" data="citationList"}
+                        }
+                        DaMaterialCollection materialCollection = new DaMaterialCollection();
+                        materialCollection.setSfcCode(SFCCode.toString());
+                        materialCollection.setLocationCode(device);
+                        materialCollection.setParamName(conf.getParameterSetName());
+                        materialCollection.setParamValue((String) miloService.readFromOpcUa(gatherAddress).getValue());
+                        materialCollection.setCollectTime(new Date());
+                        daMaterialCollectionService.insertDaMaterialCollection(materialCollection);
+                    }
+                    //鏌ヨdescriptive瀛楁绛変簬2鐨勯噰闆嗛」淇濆瓨鍒版壂鐮佷繚瀛樺埌da_param_collection琛ㄩ噷
+                    DaCollectionParamConf daCollectionParamConf2 = new DaCollectionParamConf();
+                    daCollectionParamConf2.setProcessesCode(device);
+                    daCollectionParamConf2.setDescriptive("2");
+                    List<DaCollectionParamConf> daCollectionParamConfList2 = daCollectionParamConfService.selectDaCollectionParamConfList(daCollectionParamConf2);
+                    for (DaCollectionParamConf conf : daCollectionParamConfList2) {
+                        String gatherAddress = conf.getGatherAddress();
+                        Object valueObj = miloService.readFromOpcUa(gatherAddress).getValue(); // 鑾峰彇鍘熷鍊煎璞♀��:ml-citation{ref="4" data="citationList"}
+                        if (valueObj == null || StringUtils.isEmpty(valueObj.toString())) {
+                            log.warn("閲囬泦鍦板潃{}杩斿洖绌哄�硷紝璺宠繃瀛樺偍", gatherAddress);
+                            continue; // 缁堟褰撳墠寰幆杩唬鈥�:ml-citation{ref="1,2" data="citationList"}
+                        }
+                        DaParamCollection paramCollection = new DaParamCollection();
+                        paramCollection.setSfcCode(SFCCode.toString());
+                        paramCollection.setLocationCode(device);
+                        paramCollection.setParamName(conf.getParameterSetName());
+                        paramCollection.setParamValue((String) miloService.readFromOpcUa(gatherAddress).getValue());
+                        paramCollection.setCollectionTime(new Date());
+                        daParamCollectionService.insertDaParamCollection(paramCollection);
+                    }
+                    DaStationCollection daStationCollection = new DaStationCollection();
+                    daStationCollection.setLocationCode(device);
+                    daStationCollection.setSfcCode(SFCCode.toString());
+                    daStationCollection.setInboundTime((Date) miloService.readFromOpcUa(thoroughfare + "." + device + ".StartTime").getValue());
+                    daStationCollection.setOutboundTime((Date) miloService.readFromOpcUa(thoroughfare + "." + device + ".StopTime").getValue());
+                    daStationCollectionService.insertDaStationCollection(daStationCollection);
+                    miloService.writeToOpcUa(ReadWriteEntity.builder().identifier(thoroughfare + "." + device + ".RecordDataDone").value("21").build());
                 }
             }
         }
@@ -133,86 +250,156 @@
         if (Constants.WorkOrderRequest.equals(tab)) {
             if (Constants.ZERO.equals(valueString)) {
                 miloService.writeToOpcUa(ReadWriteEntity.builder().identifier(thoroughfare + "." + device + ".WorkOrderRequestDone").value("0").build());
-            } else if (Constants.ONE.equals(valueString)) {
-                // 鏌ヨ鏁版嵁搴撹幏鍙栫鍚堟潯浠剁殑璁㈠崟淇℃伅
-                OmProductionOrderInfo getEarliestOrder = omProductionOrderInfoService.getEarliestOrder();
-                if (getEarliestOrder != null) {
-                    //鍒ゆ柇褰撳墠涓嬪彂鏁伴噺
-                    if(getEarliestOrder.getRemarks() >= getEarliestOrder.getPlanQty()){
-                        //鏇存柊宸ュ崟鐘舵��
-                        omProductionOrderInfoService.updateOrderStatus5();
-                        //鏌ヨ鏂版弧瓒崇殑宸ュ崟
-                        OmProductionOrderInfo getEarliestOrder2 = omProductionOrderInfoService.getEarliestOrder();
-                        if (getEarliestOrder2 != null) {
-                            // 灏嗘暟鎹啓鍏ュ埌鍦板潃鍧椾腑
-                            miloService.writeToOpcUa(ReadWriteEntity.builder().identifier(thoroughfare + "." + device + ".WorkOrderNumber").value(getEarliestOrder2.getWorkOrderNo()).build());
-                            miloService.writeToOpcUa(ReadWriteEntity.builder().identifier(thoroughfare + "." + device + ".ProductionPlan").value(String.valueOf(getEarliestOrder2.getPlanQty())).build());
-                            miloService.writeToOpcUa(ReadWriteEntity.builder().identifier(thoroughfare + "." + device + ".EngineType").value(getEarliestOrder2.getEngineType()).build());
+            }else if (Constants.ONE.equals(valueString)){
+                if (Constants.OP005.equals(device)){
+                    // 鏌ヨ鏁版嵁搴撹幏鍙栫鍚堟潯浠剁殑璁㈠崟淇℃伅
+                    OmProductionOrderInfo getBodyOrder = omProductionOrderInfoService.getBodyOrder();
+                    if (getBodyOrder != null) {
+                        //鍒ゆ柇褰撳墠涓嬪彂鏁伴噺鏄惁婊¤冻璁″垝鏁伴噺
+                            //鏇存柊宸ュ崟鐘舵��
+                            miloService.writeToOpcUa(ReadWriteEntity.builder().identifier(thoroughfare + "." + device + ".WorkOrderNumber").value(getBodyOrder.getWorkOrderNo()).build());
+                            miloService.writeToOpcUa(ReadWriteEntity.builder().identifier(thoroughfare + "." + device + ".ProductionPlan").value(String.valueOf(getBodyOrder.getPlanQty())).build());
+                            miloService.writeToOpcUa(ReadWriteEntity.builder().identifier(thoroughfare + "." + device + ".EngineType").value(getBodyOrder.getEngineType()).build());
                             //鐢熸垚sn鐮�
-                            OmProductionOrderInfo serialNumber = omProductionOrderInfoService.getSerialNumber();
+                            SysCount serialNumber = sysCountService.getSerialNumber();
                             String A3 = String.valueOf(LocalDateTime.now().getYear()).substring(2);
-                            if(A3.equals(String.valueOf(serialNumber.getRemarks()))){
-                                String A1 = getEarliestOrder2.getEngineType();//鑾峰彇浜у搧鍨嬪彿
-                                String A2 = "3";
+                            //鍒ゆ柇鏄惁璺ㄥ勾
+                            if(A3.equals(String.valueOf(serialNumber.getYear()))){
+                                String A1 = getBodyOrder.getEngineType();//鑾峰彇浜у搧鍨嬪彿
+                                String A2 = "3";//鍥哄畾浜х嚎
                                 String A4 = MONTH[LocalDateTime.now().getMonthValue() - 1];// 鑾峰彇褰撳墠鏈堜唤锛�1-12锛�
-                                String A5 = String.format("%05d", serialNumber.getPlanQty());
+                                String A5 = String.format("%05d", serialNumber.getSerialNumber());
                                 String SFCCode = A1 + A2 + A3+ A4 + A5;
                                 miloService.writeToOpcUa(ReadWriteEntity.builder().identifier(thoroughfare + "." + device + ".SFCCode").value(SFCCode).build());
-                                omProductionOrderInfoService.updateSerialNumber();
+                                miloService.writeToOpcUa(ReadWriteEntity.builder().identifier(thoroughfare + "." + device + ".MESSFCCode").value(SFCCode).build());
+                                sysCountService.updateSerialNumber();
                             }else{
-                                OmProductionOrderInfo newNumber = omProductionOrderInfoService.updateYear();
-                                String A1 = getEarliestOrder2.getEngineType();//鑾峰彇浜у搧鍨嬪彿
+                                sysCountService.clean();
+                                sysCountService.updateYear();
+                                String A1 = getBodyOrder.getEngineType();//鑾峰彇浜у搧鍨嬪彿
                                 String A2 = "3";
+                                String newA3 = String.valueOf(LocalDateTime.now().getYear()).substring(2);
                                 String A4 = MONTH[LocalDateTime.now().getMonthValue() - 1];// 鑾峰彇褰撳墠鏈堜唤锛�1-12锛�
-                                String A5 = String.format("%05d", newNumber.getPlanQty());
-                                String SFCCode = A1 + A2 + A3+ A4 + A5;
+                                String A5 = String.format("%05d", sysCountService.getSerialNumber().getSerialNumber());
+                                String SFCCode = A1 + A2 + newA3+ A4 + A5;
                                 miloService.writeToOpcUa(ReadWriteEntity.builder().identifier(thoroughfare + "." + device + ".SFCCode").value(SFCCode).build());
-                                omProductionOrderInfoService.updateSerialNumber();
+                                miloService.writeToOpcUa(ReadWriteEntity.builder().identifier(thoroughfare + "." + device + ".MESSFCCode").value(SFCCode).build());
+                                sysCountService.updateSerialNumber();
                             }
                             // 鏇存柊 WorkOrderRequestDone 鍦板潃鍧�
-                            miloService.writeToOpcUa(ReadWriteEntity.builder().identifier(thoroughfare + "." + device + ".WorkOrderRequestDone").value("11").build());
                             BsBomChildInfo bsbomChildInfo= new BsBomChildInfo();
                             bsbomChildInfo.setLocationCode(device);
-                            bsbomChildInfo.setBomCode(getEarliestOrder2.getWorkOrderNo());
+                            bsbomChildInfo.setBomCode(getBodyOrder.getWorkOrderNo());
                             //鍙戜笅宸ヨ壓閰嶆柟
                             formula(thoroughfare, device, bsbomChildInfo);
-                            omProductionOrderInfoService.updateOrderStatus2();
-
-                        }
-                    } else if (getEarliestOrder.getRemarks() < getEarliestOrder.getPlanQty()) {
+                            omProductionOrderInfoService.updateBodyStatus1();
+                            //鍒ゆ柇缂镐綋宸ュ崟瀹屾垚
+                            OmProductionOrderInfo getBodyOrder2 = omProductionOrderInfoService.getBodyOrder();
+                            if (Objects.equals(getBodyOrder2.getBodyQty(), getBodyOrder2.getPlanQty())){
+                                omProductionOrderInfoService.updateBodyStatus2();
+                            }
+                            miloService.writeToOpcUa(ReadWriteEntity.builder().identifier(thoroughfare + "." + device + ".PalletID").value(getBodyOrder2.getBodyQty()).build());
+                            miloService.writeToOpcUa(ReadWriteEntity.builder().identifier(thoroughfare + "." + device + ".WorkOrderRequestDone").value("11").build());
+                    }
+                } else if (Constants.C005.equals(device)) {
+                    // 鏌ヨ鏁版嵁搴撹幏鍙栫鍚堟潯浠剁殑璁㈠崟淇℃伅
+                    OmProductionOrderInfo getHeadOrder = omProductionOrderInfoService.getHeadOrder();
+                    if (getHeadOrder != null) {
+                        //鍒ゆ柇褰撳墠涓嬪彂鏁伴噺鏄惁婊¤冻璁″垝鏁伴噺
                         //鏇存柊宸ュ崟鐘舵��
-                        miloService.writeToOpcUa(ReadWriteEntity.builder().identifier(thoroughfare + "." + device + ".WorkOrderNumber").value(getEarliestOrder.getWorkOrderNo()).build());
-                        miloService.writeToOpcUa(ReadWriteEntity.builder().identifier(thoroughfare + "." + device + ".ProductionPlan").value(String.valueOf(getEarliestOrder.getPlanQty())).build());
-                        miloService.writeToOpcUa(ReadWriteEntity.builder().identifier(thoroughfare + "." + device + ".EngineType").value(getEarliestOrder.getEngineType()).build());
+                        miloService.writeToOpcUa(ReadWriteEntity.builder().identifier(thoroughfare + "." + device + ".WorkOrderNumber").value(getHeadOrder.getWorkOrderNo()).build());
+                        miloService.writeToOpcUa(ReadWriteEntity.builder().identifier(thoroughfare + "." + device + ".ProductionPlan").value(String.valueOf(getHeadOrder.getPlanQty())).build());
+                        miloService.writeToOpcUa(ReadWriteEntity.builder().identifier(thoroughfare + "." + device + ".EngineType").value(getHeadOrder.getEngineType()).build());
                         //鐢熸垚sn鐮�
-                        OmProductionOrderInfo serialNumber = omProductionOrderInfoService.getSerialNumber();
+                        SysCount headNumber = sysCountService.getHeadNumber();
                         String A3 = String.valueOf(LocalDateTime.now().getYear()).substring(2);
-                        if(A3.equals(String.valueOf(serialNumber.getRemarks()))){
-                            String A1 = getEarliestOrder.getEngineType();//鑾峰彇浜у搧鍨嬪彿
-                            String A2 = "3";
+                        //鍒ゆ柇鏄惁璺ㄥ勾
+                        if(A3.equals(String.valueOf(headNumber.getYear()))){
+                            String A1 = getHeadOrder.getEngineType();//鑾峰彇浜у搧鍨嬪彿
+                            String A2 = "3";//鍥哄畾浜х嚎
                             String A4 = MONTH[LocalDateTime.now().getMonthValue() - 1];// 鑾峰彇褰撳墠鏈堜唤锛�1-12锛�
-                            String A5 = String.format("%05d", serialNumber.getPlanQty());
+                            String A5 = String.format("%05d", headNumber.getHeadNumber());
                             String SFCCode = A1 + A2 + A3+ A4 + A5;
                             miloService.writeToOpcUa(ReadWriteEntity.builder().identifier(thoroughfare + "." + device + ".SFCCode").value(SFCCode).build());
-                            omProductionOrderInfoService.updateSerialNumber();
+                            miloService.writeToOpcUa(ReadWriteEntity.builder().identifier(thoroughfare + "." + device + ".MESSFCCode").value(SFCCode).build());
+                            sysCountService.updateHeadNumber();
                         }else{
-                            OmProductionOrderInfo newNumber = omProductionOrderInfoService.updateYear();
-                            String A1 = getEarliestOrder.getEngineType();//鑾峰彇浜у搧鍨嬪彿
+                            sysCountService.clean();
+                            sysCountService.updateYear();
+                            String A1 = getHeadOrder.getEngineType();//鑾峰彇浜у搧鍨嬪彿
                             String A2 = "3";
+                            String newA3 = String.valueOf(LocalDateTime.now().getYear()).substring(2);
                             String A4 = MONTH[LocalDateTime.now().getMonthValue() - 1];// 鑾峰彇褰撳墠鏈堜唤锛�1-12锛�
-                            String A5 = String.format("%05d", newNumber.getPlanQty());
-                            String SFCCode = A1 + A2 + A3+ A4 + A5;
+                            String A5 = String.format("%05d", sysCountService.getHeadNumber().getHeadNumber());
+                            String SFCCode = A1 + A2 + newA3+ A4 + A5;
                             miloService.writeToOpcUa(ReadWriteEntity.builder().identifier(thoroughfare + "." + device + ".SFCCode").value(SFCCode).build());
-                            omProductionOrderInfoService.updateSerialNumber();
+                            miloService.writeToOpcUa(ReadWriteEntity.builder().identifier(thoroughfare + "." + device + ".MESSFCCode").value(SFCCode).build());
+                            sysCountService.updateHeadNumber();
                         }
                         // 鏇存柊 WorkOrderRequestDone 鍦板潃鍧�
-                        miloService.writeToOpcUa(ReadWriteEntity.builder().identifier(thoroughfare + "." + device + ".WorkOrderRequestDone").value("11").build());
                         BsBomChildInfo bsbomChildInfo= new BsBomChildInfo();
                         bsbomChildInfo.setLocationCode(device);
-                        bsbomChildInfo.setBomCode(getEarliestOrder.getWorkOrderNo());
+                        bsbomChildInfo.setBomCode(getHeadOrder.getWorkOrderNo());
                         //鍙戜笅宸ヨ壓閰嶆柟
                         formula(thoroughfare, device, bsbomChildInfo);
-                        omProductionOrderInfoService.updateOrderStatus2();
+                        omProductionOrderInfoService.updateHeadStatus1();
+                        //鍒ゆ柇缂镐綋宸ュ崟瀹屾垚
+                        OmProductionOrderInfo getHeadOrder2 = omProductionOrderInfoService.getHeadOrder();
+                        if (Objects.equals(getHeadOrder2.getHeadQty(), getHeadOrder2.getPlanQty())){
+                            omProductionOrderInfoService.updateHeadStatus2();
+                        }
+                        miloService.writeToOpcUa(ReadWriteEntity.builder().identifier(thoroughfare + "." + device + ".PalletID").value(getHeadOrder2.getHeadQty()).build());
+                        miloService.writeToOpcUa(ReadWriteEntity.builder().identifier(thoroughfare + "." + device + ".WorkOrderRequestDone").value("11").build());
+                    }
+                } else if (Constants.P010.equals(device)) {
+                    // 鏌ヨ鏁版嵁搴撹幏鍙栫鍚堟潯浠剁殑璁㈠崟淇℃伅
+                    OmProductionOrderInfo getPreOrder = omProductionOrderInfoService.getPreOrder();
+                    if (getPreOrder != null) {
+                        //鍒ゆ柇褰撳墠涓嬪彂鏁伴噺鏄惁婊¤冻璁″垝鏁伴噺
+                        //鏇存柊宸ュ崟鐘舵��
+                        miloService.writeToOpcUa(ReadWriteEntity.builder().identifier(thoroughfare + "." + device + ".WorkOrderNumber").value(getPreOrder.getWorkOrderNo()).build());
+                        miloService.writeToOpcUa(ReadWriteEntity.builder().identifier(thoroughfare + "." + device + ".ProductionPlan").value(String.valueOf(getPreOrder.getPlanQty())).build());
+                        miloService.writeToOpcUa(ReadWriteEntity.builder().identifier(thoroughfare + "." + device + ".EngineType").value(getPreOrder.getEngineType()).build());
+                        //鐢熸垚sn鐮�
+                        SysCount preNumber = sysCountService.getPreNumber();
+                        String A3 = String.valueOf(LocalDateTime.now().getYear()).substring(2);
+                        if(A3.equals(String.valueOf(preNumber.getYear()))){
+                            String A1 = getPreOrder.getEngineType();//鑾峰彇浜у搧鍨嬪彿
+                            String A2 = "3";
+                            String A4 = MONTH[LocalDateTime.now().getMonthValue() - 1];// 鑾峰彇褰撳墠鏈堜唤锛�1-12锛�
+                            String A5 = String.format("%05d", preNumber.getPreNumber());
+                            String SFCCode = A1 + A2 + A3+ A4 + A5;
+                            miloService.writeToOpcUa(ReadWriteEntity.builder().identifier(thoroughfare + "." + device + ".SFCCode").value(SFCCode).build());
+                            miloService.writeToOpcUa(ReadWriteEntity.builder().identifier(thoroughfare + "." + device + ".MESSFCCode").value(SFCCode).build());
+                            sysCountService.updatePreNumber();
+                        }else{
+                            sysCountService.clean();
+                            sysCountService.updateYear();
+                            String A1 = getPreOrder.getEngineType();//鑾峰彇浜у搧鍨嬪彿
+                            String A2 = "3";
+                            String newA3 = String.valueOf(LocalDateTime.now().getYear()).substring(2);
+                            String A4 = MONTH[LocalDateTime.now().getMonthValue() - 1];// 鑾峰彇褰撳墠鏈堜唤锛�1-12锛�
+                            String A5 = String.format("%05d", sysCountService.getPreNumber().getPreNumber());
+                            String SFCCode = A1 + A2 + newA3+ A4 + A5;
+                            miloService.writeToOpcUa(ReadWriteEntity.builder().identifier(thoroughfare + "." + device + ".SFCCode").value(SFCCode).build());
+                            miloService.writeToOpcUa(ReadWriteEntity.builder().identifier(thoroughfare + "." + device + ".MESSFCCode").value(SFCCode).build());
+                            sysCountService.updateHeadNumber();
+                        }
+
+                        // 鏇存柊 WorkOrderRequestDone 鍦板潃鍧�
+                        BsBomChildInfo bsbomChildInfo= new BsBomChildInfo();
+                        bsbomChildInfo.setLocationCode(device);
+                        bsbomChildInfo.setBomCode(getPreOrder.getWorkOrderNo());
+                        //鍙戜笅宸ヨ壓閰嶆柟
+                        formula(thoroughfare, device, bsbomChildInfo);
+                        omProductionOrderInfoService.updatePreStatus1();
+                        //鍒ゆ柇缂镐綋宸ュ崟瀹屾垚
+                        OmProductionOrderInfo getPreOrder2 = omProductionOrderInfoService.getPreOrder();
+                        if (Objects.equals(getPreOrder2.getPreQty(), getPreOrder2.getPlanQty())){
+                            omProductionOrderInfoService.updatePreStatus2();
+                        }
+                        miloService.writeToOpcUa(ReadWriteEntity.builder().identifier(thoroughfare + "." + device + ".PalletID").value(getPreOrder2.getPreQty()).build());
+                        miloService.writeToOpcUa(ReadWriteEntity.builder().identifier(thoroughfare + "." + device + ".WorkOrderRequestDone").value("11").build());
                     }
                 }
             }
@@ -224,7 +411,7 @@
 
     //鍙戜笅宸ヨ壓閰嶆柟鏂规硶
     private void formula(String thoroughfare, String device, BsBomChildInfo bsbomChildInfo) throws Exception {
-        List<BsBomChildInfo> bomChildList = bomChildInfoService.selectBsBomChildInfoList(bsbomChildInfo);
+        List<BsBomChildInfo> bomChildList = bsBomChildInfoService.selectBsBomChildInfoList(bsbomChildInfo);
         for (int i = 1; i <= bomChildList.size(); i++) {
             // 鐢熸垚 MaterialCode 鑺傜偣
             miloService.writeToOpcUa(ReadWriteEntity.builder().identifier(thoroughfare + "." + device + ".Material1Code"+ i).value(bomChildList.get(i-1).getMaterialCode()).build());

--
Gitblit v1.9.3