From e046dba174365eb8934ee1e4206f09821145e876 Mon Sep 17 00:00:00 2001
From: skyouc
Date: 星期四, 21 八月 2025 13:23:22 +0800
Subject: [PATCH] no message

---
 zy-asrs-wms/src/main/java/com/zy/asrs/wms/asrs/service/impl/MobileServiceImpl.java |   79 +++++++++++++++++++++++----------------
 1 files changed, 47 insertions(+), 32 deletions(-)

diff --git a/zy-asrs-wms/src/main/java/com/zy/asrs/wms/asrs/service/impl/MobileServiceImpl.java b/zy-asrs-wms/src/main/java/com/zy/asrs/wms/asrs/service/impl/MobileServiceImpl.java
index effb1d3..5b25040 100644
--- a/zy-asrs-wms/src/main/java/com/zy/asrs/wms/asrs/service/impl/MobileServiceImpl.java
+++ b/zy-asrs-wms/src/main/java/com/zy/asrs/wms/asrs/service/impl/MobileServiceImpl.java
@@ -2,6 +2,7 @@
 
 import com.alibaba.fastjson.JSONObject;
 import com.baomidou.mybatisplus.core.conditions.query.LambdaQueryWrapper;
+import com.baomidou.mybatisplus.core.conditions.query.QueryWrapper;
 import com.baomidou.mybatisplus.core.conditions.update.LambdaUpdateWrapper;
 import com.baomidou.mybatisplus.extension.service.IService;
 import com.zy.asrs.framework.common.R;
@@ -126,7 +127,7 @@
 
         //缁勬嫋閫氱煡妗�
         waitPakins.forEach(pakin -> {
-            waitPakinService.comb(pakin);
+            waitPakinService.comb(pakin, ordersParam.getInType());
         });
 
 
@@ -238,10 +239,10 @@
         orders.forEach(order -> {
             List<OrderDetl> detls = orderDetlService.list(new LambdaQueryWrapper<OrderDetl>().eq(OrderDetl::getOrderId, order.getId()));
             Double sum = detls.stream().mapToDouble(OrderDetl::getQty).sum();
-            Double summed = detls.stream().mapToDouble(OrderDetl::getWorkQty).sum();
-            Double v = Math.round((sum + summed) * 1000) / 1000.0;
+//            Double summed = detls.stream().mapToDouble(OrderDetl::getWorkQty).sum();
+//            Double v = Math.round((sum ) * 1000) / 1000.0;
             Double anfme = detls.stream().mapToDouble(OrderDetl::getAnfme).sum();
-            if (v.compareTo(anfme) == 0.0) {
+            if (sum.compareTo(anfme) == 0.0) {
                 order.setOrderSettle(OrderSettleType.COMPLETE.val());
                 if (!orderService.updateById(order)) {
                     throw new CoolException("鍗曟嵁鐘舵�佷慨鏀瑰け璐ワ紒锛�");
@@ -373,27 +374,30 @@
                 }
             }
         });
+        
+        //鍒ゆ柇鏄惁涓烘尝娆″崟鎹�
+        if (pickSheet.getType().equals(1)) {
+            //鍒犻櫎娉㈡鍙婂搴旀槑缁嗕俊鎭�
+            if (!waveService.remove(new LambdaQueryWrapper<Wave>().eq(Wave::getId, pickSheet.getWaveId()))) {
+                throw new CoolException("娉㈡鍒楄〃鍗曟嵁鍒犻櫎澶辫触锛侊紒");
+            }
 
-        //鍒犻櫎娉㈡鍙婂搴旀槑缁嗕俊鎭�
-        if (!waveService.remove(new LambdaQueryWrapper<Wave>().eq(Wave::getId, pickSheet.getWaveId()))) {
-            throw new CoolException("娉㈡鍒楄〃鍗曟嵁鍒犻櫎澶辫触锛侊紒");
-        }
+            if (!waveDetlService.remove(new LambdaQueryWrapper<WaveDetl>().eq(WaveDetl::getWaveId, pickSheet.getWaveId()))) {
+                throw new CoolException("娉㈡鏄庣粏鍒楄〃鍒犻櫎澶辫触锛侊紒");
+            }
 
-        if (!waveDetlService.remove(new LambdaQueryWrapper<WaveDetl>().eq(WaveDetl::getWaveId, pickSheet.getWaveId()))) {
-            throw new CoolException("娉㈡鏄庣粏鍒楄〃鍒犻櫎澶辫触锛侊紒");
-        }
-
-        List<Order> orders = orderService.list(new LambdaQueryWrapper<Order>().eq(Order::getWaveId, pickSheet.getWaveId()));
-        if (orders.isEmpty()) {
-            throw new CoolException("娉㈡璁㈠崟涓嶅瓨鍦紒锛�");
-        }
-        List<Long> list = orders.stream().map(Order::getId).collect(Collectors.toList());
-        boolean remove = orderDetlService.remove(new LambdaQueryWrapper<OrderDetl>().in(OrderDetl::getOrderId, list));
-        if (!remove) {
-            throw new CoolException("鍘熷璁㈠崟鏄庣粏鍒犻櫎澶辫触锛侊紒");
-        }
-        if (!orderService.remove(new LambdaQueryWrapper<Order>().in(Order::getId, list))) {
-            throw new CoolException("鍘熷璁㈠崟鍒犻櫎澶辫触锛侊紒");
+            List<Order> orders = orderService.list(new LambdaQueryWrapper<Order>().eq(Order::getWaveId, pickSheet.getWaveId()));
+            if (orders.isEmpty()) {
+                throw new CoolException("娉㈡璁㈠崟涓嶅瓨鍦紒锛�");
+            }
+            List<Long> list = orders.stream().map(Order::getId).collect(Collectors.toList());
+            boolean remove = orderDetlService.remove(new LambdaQueryWrapper<OrderDetl>().in(OrderDetl::getOrderId, list));
+            if (!remove) {
+                throw new CoolException("鍘熷璁㈠崟鏄庣粏鍒犻櫎澶辫触锛侊紒");
+            }
+            if (!orderService.remove(new LambdaQueryWrapper<Order>().in(Order::getId, list))) {
+                throw new CoolException("鍘熷璁㈠崟鍒犻櫎澶辫触锛侊紒");
+            }
         }
 
         return true;
@@ -418,7 +422,8 @@
     @Override
     @Transactional(rollbackFor = Exception.class)
     public boolean bindOrderBySite(Map<String, Object> param) {
-        CacheSite siteNo = cacheSiteMapper.selectOne(new LambdaQueryWrapper<CacheSite>().eq(CacheSite::getSiteNo, param.get("siteNo")), false);
+        CacheSite siteNo = cacheSiteMapper.selectOne(new LambdaQueryWrapper<CacheSite>()
+                .eq(CacheSite::getSiteNo, param.get("siteNo")), false);
         if (Objects.isNull(siteNo)) {
             throw new CoolException("绔欑偣寮傚父锛侊紒");
         }
@@ -426,7 +431,8 @@
             if (!StringUtil.isNullOrEmpty(siteNo.getOrderNo())) {
                 throw new CoolException("褰撳墠鎾绔欑偣宸茬粦瀹氳鍗曪紒锛�");
             }
-            Order order = orderService.getOne(new LambdaQueryWrapper<Order>().eq(Order::getOrderNo, param.get("orderNo").toString()));
+            Order order = orderService.getOne(new LambdaQueryWrapper<Order>()
+                    .eq(Order::getOrderNo, param.get("orderNo").toString()));
             if (Objects.isNull(order)) {
                 throw new CoolException("缁戝畾璁㈠崟涓嶅瓨鍦紒锛�");
             }
@@ -438,12 +444,12 @@
                 throw new CoolException("璁㈠崟鎾浣嶇粦瀹氬け璐ワ紒锛�");
             }
 
-            if (!waveSeedMapper.update(new LambdaUpdateWrapper<WaveSeed>()
-                    .eq(WaveSeed::getOrderNo, order.getOrderNo())
-                    .set(WaveSeed::getSiteId, siteNo.getId())
-                    .set(WaveSeed::getSiteNo, siteNo.getSiteNo()))) {
-                throw new CoolException("鎾绔欑偣鏇存柊澶辫触锛侊紒");
-            }
+//            if (!waveSeedMapper.update(new LambdaUpdateWrapper<WaveSeed>()
+//                    .eq(WaveSeed::getOrderNo, order.getOrderNo())
+//                    .set(WaveSeed::getSiteId, siteNo.getId())
+//                    .set(WaveSeed::getSiteNo, siteNo.getSiteNo()))) {
+//                throw new CoolException("鎾绔欑偣鏇存柊澶辫触锛侊紒");
+//            }
             //缁戝畾鎴愬姛锛屾挱绉嶅浜伅
             sowLightMange(siteNo.getSiteNo(), order, "LIGHT");
         } else {
@@ -657,7 +663,16 @@
      */
     @Override
     public R getMatsByCode(String matnr) {
-        return R.ok().add(matService.list(new LambdaQueryWrapper<Mat>().eq(Mat::getMatnr, matnr)));
+        QueryWrapper<LocDetl> wrapper = new QueryWrapper<>();
+        wrapper.eq("matnr", matnr).select("matnr, SUM(anfme) anfme");
+        LocDetl detl = locDetlService.getOne(wrapper);
+
+        Mat one = matService.getOne(new LambdaQueryWrapper<Mat>().eq(Mat::getMatnr, detl.getMatnr()), false);
+        if (Objects.isNull(one)) {
+            throw new CoolException("鐗╂枡涓嶅瓨鍦紒锛�");
+        }
+        one.setAnfme(detl.getAnfme());
+        return R.ok().add(Arrays.asList(one));
     }
 
     /**

--
Gitblit v1.9.1