From 24c2fd8ab62fa12ae96658664e7ffd478bef6e62 Mon Sep 17 00:00:00 2001
From: whycq <913841844@qq.com>
Date: 星期一, 13 五月 2024 19:16:15 +0800
Subject: [PATCH] #

---
 src/main/java/com/zy/asrs/service/impl/AgvMobileServiceImpl.java |   41 +++++++++++++++++++++++++----------------
 1 files changed, 25 insertions(+), 16 deletions(-)

diff --git a/src/main/java/com/zy/asrs/service/impl/AgvMobileServiceImpl.java b/src/main/java/com/zy/asrs/service/impl/AgvMobileServiceImpl.java
index 66c5915..971beea 100644
--- a/src/main/java/com/zy/asrs/service/impl/AgvMobileServiceImpl.java
+++ b/src/main/java/com/zy/asrs/service/impl/AgvMobileServiceImpl.java
@@ -103,23 +103,32 @@
 
         for (PickParam.Pick pick : pickParams.getPicks()) {
             if (pick.getCount().equals(0D)) continue;
-            AgvWrkDetl wrkDetl = new AgvWrkDetl();
-            Mat mat = matService.selectByMatnr(pick.getMatnr());
-            if (Cools.isEmpty(mat)) {
-                throw new CoolException(pick.getMatnr() + "鍟嗗搧涓嶅瓨鍦�");
+            AgvWrkDetl agvWrkDetl = agvWrkDetlService.selectOne(new EntityWrapper<AgvWrkDetl>().eq("matnr", pick.getMatnr()).eq("three_code", pick.getThreeCode()));
+            if (Cools.isEmpty(agvWrkDetl)) {
+                AgvWrkDetl wrkDetl = new AgvWrkDetl();
+                Mat mat = matService.selectByMatnr(pick.getMatnr());
+                if (Cools.isEmpty(mat)) {
+                    throw new CoolException(pick.getMatnr() + "鍟嗗搧涓嶅瓨鍦�");
+                }
+                wrkDetl.sync(mat);
+                wrkDetl.setWrkNo(pickParams.getWrkNo());
+                wrkDetl.setOrderNo(pick.getOrderNo());
+                wrkDetl.setIoTime(now);
+                wrkDetl.setAnfme(pick.getCount()); // 鏁伴噺
+                wrkDetl.setSuppCode(pick.getSuppCode()); // 鎵樼洏鏉$爜
+                wrkDetl.setAppeUser(userId);
+                wrkDetl.setAppeTime(now);
+                wrkDetl.setModiUser(userId);
+                wrkDetl.setModiTime(now);
+                wrkDetl.setThreeCode(pick.getThreeCode());
+                agvWrkDetlService.insert(wrkDetl);
+            } else {
+                Double anfme = agvWrkDetl.getAnfme() + pick.getCount();
+                agvWrkDetl.setAnfme(anfme);
+                agvWrkDetlService.update(agvWrkDetl,new EntityWrapper<AgvWrkDetl>().eq("matnr",agvWrkDetl.getMatnr()).eq("three_code",agvWrkDetl.getThreeCode()));
+
             }
-            wrkDetl.sync(mat);
-            wrkDetl.setWrkNo(pickParams.getWrkNo());
-            wrkDetl.setOrderNo(pick.getOrderNo());
-            wrkDetl.setIoTime(now);
-            wrkDetl.setAnfme(pick.getCount()); // 鏁伴噺
-            wrkDetl.setSuppCode(pick.getSuppCode()); // 鎵樼洏鏉$爜
-            wrkDetl.setAppeUser(userId);
-            wrkDetl.setAppeTime(now);
-            wrkDetl.setModiUser(userId);
-            wrkDetl.setModiTime(now);
-            wrkDetl.setThreeCode(pick.getThreeCode());
-            agvWrkDetlService.insert(wrkDetl);
+
 
             // 鏇存柊璁㈠崟
             OrderDetl orderDetl = orderDetlService.selectOne(new EntityWrapper<OrderDetl>().eq("order_no", pick.getOrderNo()).eq("matnr", pick.getMatnr()).eq("three_code",pick.getThreeCode()));

--
Gitblit v1.9.1