From 19e76055b26c9513e5bfd4e62e34a88b192109dd Mon Sep 17 00:00:00 2001
From: Junjie <540245094@qq.com>
Date: 星期六, 23 十二月 2023 20:45:59 +0800
Subject: [PATCH] #增加日志

---
 src/main/java/com/zy/asrs/service/impl/AgvWorkServiceImpl.java |   94 +++++++++++++++++++++++++++--------------------
 1 files changed, 54 insertions(+), 40 deletions(-)

diff --git a/src/main/java/com/zy/asrs/service/impl/AgvWorkServiceImpl.java b/src/main/java/com/zy/asrs/service/impl/AgvWorkServiceImpl.java
index 47e234e..ac9a84a 100644
--- a/src/main/java/com/zy/asrs/service/impl/AgvWorkServiceImpl.java
+++ b/src/main/java/com/zy/asrs/service/impl/AgvWorkServiceImpl.java
@@ -1,6 +1,8 @@
 package com.zy.asrs.service.impl;
 
 import com.alibaba.fastjson.JSON;
+import com.alibaba.fastjson.JSONArray;
+import com.alibaba.fastjson.JSONObject;
 import com.baomidou.mybatisplus.mapper.EntityWrapper;
 import com.core.common.Cools;
 import com.core.exception.CoolException;
@@ -90,12 +92,10 @@
             //妫�绱㈠簱浣嶏紝閫夋嫨鍚堥�傜殑搴撲綅
             AgvLocMast agvLocMast = agvCommonService.getLocNo(agvWaitPakinList, agvBasDevp.getFloor());
             //鐢熸垚宸ヤ綔妗�
-            //AgvWrkMast wrkMast = createWrkMast(agvBasDevp, agvLocMast, now, userId);
             AgvWrkMast wrkMast = createWrkMast(1,201L,agvBasDevp.getDevNo(),agvLocMast.getLocNo(),agvBasDevp.getBarcode(),now,userId, isConveyor);
             //鏍囪鏄惁涓鸿緭閫佺嚎鍏ュ簱
             wrkMast.setMk(isConveyor ? "Y" : "N");
             //鐢熸垚宸ヤ綔妗f槑缁�
-            //createWrkDetlReWrite(agvWaitPakinList,wrkMast,userId);
             agvWaitPakinList.forEach(wp -> {
                 createWrkDetlReWrite(wp.getMatnr(),wrkMast.getWrkNo(),wp.getOrderNo(),wp.getBatch(),wp.getAnfme(),wp.getSuppCode(),now,userId,wp.getThreeCode(),wp.getDeadTime());
             });
@@ -170,6 +170,11 @@
     public void pickIn(List<AgvWrkMast> agvWrkMastList){
         Date now = new Date();
         agvWrkMastList.forEach(agvWrkMast -> {
+
+            //淇濆瓨鎷f枡鍑哄簱鐨勫伐浣滄。鍜屾槑缁�
+            agvWrkMastLogService.save(agvWrkMast);
+            agvWrkDetlLogService.save(agvWrkMast.getWrkNo());
+
             //淇敼宸ヤ綔鍏�
             agvWrkMast.setWrkSts(201L);
 
@@ -386,7 +391,7 @@
             while (iterator1.hasNext()) {
                 LocDetlAdjustParam.LocDetlAdjust adjust = iterator1.next();
                 if (adjust.getCount() == 0) { continue; }
-                if (locDetl.getMatnr().equals(adjust.getMatnr()) && Cools.eq(locDetl.getBatch(), adjust.getBatch())) {
+                if (locDetl.getMatnr().equals(adjust.getMatnr()) && Cools.eq(locDetl.getBatch(), adjust.getBatch()) && Cools.eq(locDetl.getSuppCode(),adjust.getSuppCode()) && Cools.eq(locDetl.getThreeCode(),adjust.getThreeCode()) && Cools.eq(locDetl.getDeadTime(),adjust.getDeadTime())) {
                     if (!locDetl.getAnfme().equals(adjust.getCount())) {
                         // todo 鐩樼偣璁板綍
                         // 淇敼搴撳瓨
@@ -503,20 +508,20 @@
         if (Cools.isEmpty(wrkMast)){
             throw new CoolException(workNo+"宸ヤ綔妗d笉瀛樺湪");
         }
+        if(!wrkMast.getLocNo().contains("@") || !wrkMast.getSourceLocNo().contains("@")){
+            throw new CoolException("鐩爣搴撲綅鎴栬�呮簮搴撲綅鏆傛湭鍒嗛厤锛屾棤娉曞彇娑�");
+        }
+        //淇敼AGV宸ヤ綔妗g殑宸ヤ綔鐘舵�佷负205.宸ヤ綔瀹屾垚
+        agvWrkMastService.updateWrkStsByWrkNo(wrkMast.getWrkNo(),205);
 
-        if(wrkMast.getWrkSts() > 202){
-            //淇敼AGV宸ヤ綔妗g殑宸ヤ綔鐘舵�佷负205.宸ヤ綔瀹屾垚
-            agvWrkMastService.updateWrkStsByWrkNo(wrkMast.getWrkNo(),205);
-
-            //鍑哄簱浠诲姟 101.鍑哄簱 || 103.鎷f枡鍑哄簱 || 107.鐩樼偣鍑哄簱
-            if(wrkMast.getIoType() == 101 || wrkMast.getIoType() == 103 || wrkMast.getIoType() == 107){
-                //淇敼鍑哄簱绔欑偣鐘舵��
-                agvBasDevpService.updateLocStsAndBarcodeByDevNo(wrkMast.getLocNo(),"F",wrkMast.getBarcode());
-            }
-            //鍑哄簱浠诲姟 110.绌烘澘鍑哄簱
-            if(wrkMast.getIoType() == 110){
-                agvBasDevpService.updateLocStsAndBarcodeByDevNo(wrkMast.getLocNo(),"F",wrkMast.getBarcode());
-            }
+        //鍑哄簱浠诲姟 101.鍑哄簱 || 103.鎷f枡鍑哄簱 || 107.鐩樼偣鍑哄簱
+        if(wrkMast.getIoType() == 101 || wrkMast.getIoType() == 103 || wrkMast.getIoType() == 107){
+            //淇敼鍑哄簱绔欑偣鐘舵��
+            agvBasDevpService.updateLocStsAndBarcodeByDevNo(wrkMast.getLocNo(),"F",wrkMast.getBarcode());
+        }
+        //鍑哄簱浠诲姟 110.绌烘澘鍑哄簱
+        if(wrkMast.getIoType() == 110){
+            agvBasDevpService.updateLocStsAndBarcodeByDevNo(wrkMast.getLocNo(),"F",wrkMast.getBarcode());
         }
 
     }
@@ -532,30 +537,27 @@
             throw new CoolException("褰撳墠浠诲姟涓嶅彲鍙栨秷");
         }
 
-        //AGV鏈哄櫒浜烘湭鍙栬揣鍓嶅彇娑�
-        if(wrkMast.getWrkSts() < 203){
-            //鍏ュ簱鍙栨秷
-            if(wrkMast.getIoType() == 1 || wrkMast.getIoType() == 10){
-                //婧愮珯鐐�
-                String devNo = wrkMast.getSourceLocNo();
-                //鐩爣搴撲綅
-                String locNo = wrkMast.getLocNo();
-                agvLocMastService.updateLocStsByLocNo(locNo,"O");
-                agvBasDevpService.updateLocStsAndBarcodeByDevNo(devNo,"F",wrkMast.getBarcode());
+        //鍏ュ簱鍙栨秷
+        if(wrkMast.getIoType() == 1 || wrkMast.getIoType() == 10){
+            //婧愮珯鐐�
+            String devNo = wrkMast.getSourceLocNo();
+            //鐩爣搴撲綅
+            String locNo = wrkMast.getLocNo();
+            agvLocMastService.updateLocStsByLocNo(locNo,"O","");
+            agvBasDevpService.updateLocStsAndBarcodeByDevNo(devNo,"F",wrkMast.getBarcode());
 
-                //鍑哄簱鍙栨秷
-            }else {
-                //婧愬簱浣�
-                String locNo = wrkMast.getSourceLocNo();
-                //鐩爣绔欑偣
-                String devNo = wrkMast.getLocNo();
-                agvLocMastService.updateLocStsByLocNo(locNo,"F");
-                if(devNo.contains("@")){
-                    agvBasDevpService.updateLocStsAndBarcodeByDevNo(devNo,"O","");
-                }
+            //鍑哄簱鍙栨秷
+        }else {
+            //婧愬簱浣�
+            String locNo = wrkMast.getSourceLocNo();
+            //鐩爣绔欑偣
+            String devNo = wrkMast.getLocNo();
+            agvLocMastService.updateLocStsByLocNo(locNo,"F",wrkMast.getBarcode());
+            if(devNo.contains("@")){
+                agvBasDevpService.updateLocStsAndBarcodeByDevNo(devNo,"O","");
             }
-
         }
+
 
         //璁㈠崟鍥炴粴
         //List<AgvWrkDetl> agvWrkDetlList = agvWrkDetlService.selectByWrkNo(wrkMast.getWrkNo());
@@ -563,9 +565,21 @@
         agvWrkDetlList1.forEach(agvWrkDetl -> {
 
             if(!Cools.isEmpty(agvWrkDetl.getOrderNo())){
-                OrderDetl orderDetl = orderDetlService.selectByOrderNoAndMatnr(agvWrkDetl.getOrderNo(),agvWrkDetl.getMatnr(),agvWrkDetl.getThreeCode(),agvWrkDetl.getDeadTime());
-                orderDetl.setQty(orderDetl.getQty() - agvWrkDetl.getAnfme());
-                orderDetlService.updateById(orderDetl);
+                String orderNo = agvWrkDetl.getOrderNo();
+                if(orderNo.contains("{")){
+                    JSONArray orderArray = JSON.parseArray(orderNo);
+                    for (Object o : orderArray){
+                        JSONObject jsonobject = (JSONObject) o;
+                        OrderDetl orderDetl = orderDetlService.selectByOrderNoAndMatnr(jsonobject.get("orderNo").toString(),agvWrkDetl.getMatnr(),agvWrkDetl.getThreeCode(),agvWrkDetl.getDeadTime());
+                        orderDetl.setQty(orderDetl.getQty() - agvWrkDetl.getAnfme());
+                        orderDetlService.updateById(orderDetl);
+                    }
+
+                }else {
+                    OrderDetl orderDetl = orderDetlService.selectByOrderNoAndMatnr(agvWrkDetl.getOrderNo(),agvWrkDetl.getMatnr(),agvWrkDetl.getThreeCode(),agvWrkDetl.getDeadTime());
+                    orderDetl.setQty(orderDetl.getQty() - agvWrkDetl.getAnfme());
+                    orderDetlService.updateById(orderDetl);
+                }
             }
         });
 

--
Gitblit v1.9.1