From 15ed897e0bd9ec3ac56f260e326b21ffd4bafae9 Mon Sep 17 00:00:00 2001
From: skyouc
Date: 星期五, 13 六月 2025 08:04:25 +0800
Subject: [PATCH] 新增自定义编辑列 新增自定义出库路由

---
 rsf-server/src/main/java/com/vincent/rsf/server/manager/service/impl/OutStockServiceImpl.java |   40 ++++++++++++++++++++++++++++++++++------
 1 files changed, 34 insertions(+), 6 deletions(-)

diff --git a/rsf-server/src/main/java/com/vincent/rsf/server/manager/service/impl/OutStockServiceImpl.java b/rsf-server/src/main/java/com/vincent/rsf/server/manager/service/impl/OutStockServiceImpl.java
index 5e2785c..01a31d2 100644
--- a/rsf-server/src/main/java/com/vincent/rsf/server/manager/service/impl/OutStockServiceImpl.java
+++ b/rsf-server/src/main/java/com/vincent/rsf/server/manager/service/impl/OutStockServiceImpl.java
@@ -413,7 +413,7 @@
             throw new CoolException("绛栫暐鍙傛暟涓虹┖");
         }
         if (Cools.isEmpty(param.getOrderId())) {
-            throw new CoolException("鍗曟嵁id涓虹┖");
+            throw new CoolException("鍗曟嵁ID涓虹┖");
         }
         WaveRule waveRule = waveRuleService.getOne(new LambdaQueryWrapper<WaveRule>().eq(WaveRule::getId, param.getWaveId()));
         if (Cools.isEmpty(waveRule)) {
@@ -446,7 +446,7 @@
             if (Objects.isNull(param)) {
                 continue;
             }
-            Loc loc = locService.getOne(new LambdaQueryWrapper<Loc>().eq(Loc::getBarcode, param.getBarcode()));
+            Loc loc = locService.getOne(new LambdaQueryWrapper<Loc>().eq(Loc::getCode, param.getLocCode()).eq(Loc::getBarcode, param.getBarcode()));
             if (!Objects.isNull(loc)) {
                 List<LocItem> locItems = new ArrayList<>();
                 LocItem locItem = locItemService.getById(param.getId());
@@ -476,7 +476,7 @@
                         .setSiteNo(param.getSiteNo());
                 try {
                     //鐢熸垚鍑哄簱浠诲姟
-                    locItemService.generateTask(taskParams, loginUserId);
+                    locItemService.generateTask(TaskResouceType.TASK_RESOUCE_ORDER_TYPE.val, taskParams, loginUserId);
                 } catch (Exception e) {
                     logger.error("UNK", e);
                     throw new CoolException(e.getMessage());
@@ -508,6 +508,20 @@
         }
 
         return R.ok();
+    }
+
+    /**
+     * 鑾峰彇鍑哄簱绔欑偣
+     * @return
+     */
+    @Override
+    public R getSiteNos() {
+        List<Integer> list = Arrays.asList(TaskType.TASK_TYPE_MERGE_OUT.type,
+                TaskType.TASK_TYPE_OUT.type,
+                TaskType.TASK_TYPE_MERGE_OUT.type,
+                TaskType.TASK_TYPE_PICK_AGAIN_OUT.type);
+        List<DeviceSite> sites = deviceSiteService.list(new LambdaQueryWrapper<DeviceSite>().in(DeviceSite::getType, list).groupBy(DeviceSite::getSite));
+        return R.ok(sites);
     }
 
 
@@ -549,8 +563,7 @@
 
     private List<OrderOutItemDto> getOutOrderList(Long orderId, WaveRule waveRule) {
         List<AsnOrderItem> asnOrderItems = asnOrderItemService.list(new LambdaQueryWrapper<AsnOrderItem>()
-                .eq(AsnOrderItem::getAsnId, orderId)
-        );
+                .eq(AsnOrderItem::getAsnId, orderId));
         List<OrderOutItemDto> list = new ArrayList<>();
         Set<ExistDto> existDtos = new HashSet<>();
 
@@ -603,8 +616,23 @@
 
                         issued = issued.subtract(new BigDecimal(locItem.getAnfme().toString()));
                     }
-                }
+                } else {
 
+                }
+            }
+            if (issued.doubleValue() > 0) {
+                LocItem locItem = new LocItem()
+                        .setId(new Random().nextLong())
+                        .setMatnrCode(asnOrderItem.getMatnrCode())
+                        .setMaktx(asnOrderItem.getMaktx())
+                        .setAnfme(0.00)
+                        .setWorkQty(issued.doubleValue())
+                        .setOutQty(issued.doubleValue())
+                        .setUnit(asnOrderItem.getStockUnit())
+                        .setBatch(asnOrderItem.getSplrBatch());
+                OrderOutItemDto orderOutItemDto = new OrderOutItemDto();
+                orderOutItemDto.setLocItem(locItem);
+                list.add(orderOutItemDto);
             }
         }
 

--
Gitblit v1.9.1