From a5d29f27bcaf5c44a10388473dc416918276dad7 Mon Sep 17 00:00:00 2001
From: skyouc
Date: 星期一, 10 十一月 2025 15:07:50 +0800
Subject: [PATCH] 出库在同一个站点问题修复

---
 rsf-server/src/main/java/com/vincent/rsf/server/manager/utils/LocManageUtil.java |   17 ++++++++++++-----
 1 files changed, 12 insertions(+), 5 deletions(-)

diff --git a/rsf-server/src/main/java/com/vincent/rsf/server/manager/utils/LocManageUtil.java b/rsf-server/src/main/java/com/vincent/rsf/server/manager/utils/LocManageUtil.java
index aa46ba7..cc667d6 100644
--- a/rsf-server/src/main/java/com/vincent/rsf/server/manager/utils/LocManageUtil.java
+++ b/rsf-server/src/main/java/com/vincent/rsf/server/manager/utils/LocManageUtil.java
@@ -156,6 +156,8 @@
         DeviceSiteService deviceSiteService = SpringUtils.getBean(DeviceSiteService.class);
 
         List<OrderOutItemDto> list = new ArrayList<>();
+        //涓嶈绔欑偣閲嶅浣跨敤闂
+        List<BasStation> stations = new ArrayList<>();
         Set<ExistDto> existDtos = new HashSet<>();
         for (WaveToLocParams item : params) {
             BigDecimal issued = new BigDecimal(item.getAnfme().toString())
@@ -175,7 +177,6 @@
                     locItems = LocManageUtil.getFirstInFirstOutItemList(item.getMatnrCode(), item.getBatch(), item.getAnfme());
                 }
             }
-
             for (LocItem locItem : locItems) {
                 Loc loc = locService.getById(locItem.getLocId());
                 List<LocItem> itemList = locItemService.list(new LambdaQueryWrapper<LocItem>().eq(LocItem::getLocCode, locItem.getLocCode()));
@@ -184,8 +185,8 @@
                     if (existDtos.add(existDto)) {
                         locItem.setOutQty(issued.doubleValue() >= locItem.getAnfme() ? locItem.getAnfme() : issued.doubleValue());
                         locItem.setBarcode(loc.getBarcode())
-                                .setSourceId(item.getWaveId())
-                                .setSource(item.getItemId());
+                                .setSourceId(item.getWaveId())//娉㈡ID
+                                .setSource(item.getItemId());//娉㈡鏄庣粏ID
                         OrderOutItemDto orderOutItemDto = new OrderOutItemDto();
                         orderOutItemDto.setLocItem(locItem);
 
@@ -203,12 +204,18 @@
                                 maps.add(staListDto);
                             }
                             orderOutItemDto.setStaNos(maps);
-                            //榛樿鑾峰彇绗竴绔欑偣
-                            DeviceSite deviceSite = deviceSites.stream().findFirst().get();
+                            //鑾峰彇婊¤冻鏉′欢绔欑偣
+                            Set<String> stationSet = deviceSites.stream().map(DeviceSite::getSite).collect(Collectors.toSet());
+                            //宸蹭娇鐢ㄧ珯鐐�
+                            Set<String> stas = stations.stream().map(BasStation::getStationName).collect(Collectors.toSet());
                             BasStationService basStationService = SpringUtils.getBean(BasStationService.class);
                             BasStation basStation = basStationService.getOne(new LambdaQueryWrapper<BasStation>()
                                     .eq(BasStation::getUseStatus, LocStsType.LOC_STS_TYPE_O.type)
+                                    .in(BasStation::getStationName, stationSet)
+                                    .notIn(!stas.isEmpty(), BasStation::getStationName, stas)
                                     .last("LIMIT 1"));
+                            stations.add(basStation);
+
                             if (Objects.isNull(basStation)) {
                                 throw new CoolException("绔欓粸涓嶅瓨鍦紒锛�");
                             }

--
Gitblit v1.9.1