From f9b3bc593ec9625674cd72cc06f0d6474405e7dd Mon Sep 17 00:00:00 2001
From: zhou zhou <3272660260@qq.com>
Date: 星期一, 12 一月 2026 13:10:06 +0800
Subject: [PATCH] #pda获取收货区增加权限

---
 rsf-server/src/main/java/com/vincent/rsf/server/manager/utils/LocManageUtil.java |   66 +++++++++++++++++++++-----------
 1 files changed, 43 insertions(+), 23 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 cc667d6..974c0b7 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
@@ -8,15 +8,12 @@
 import com.vincent.rsf.server.manager.controller.dto.OrderOutItemDto;
 import com.vincent.rsf.server.manager.controller.params.WaveToLocParams;
 import com.vincent.rsf.server.manager.entity.*;
-import com.vincent.rsf.server.manager.enums.ContainerType;
 import com.vincent.rsf.server.manager.enums.TaskType;
 import com.vincent.rsf.server.manager.enums.WaveRuleType;
 import com.vincent.rsf.server.manager.service.*;
 import com.vincent.rsf.server.manager.enums.LocStsType;
-import io.swagger.models.auth.In;
 import org.apache.commons.lang3.StringUtils;
 
-import javax.swing.*;
 import java.math.BigDecimal;
 import java.util.*;
 import java.util.stream.Collectors;
@@ -36,26 +33,45 @@
         return getTargetLoc(areaId, null);
     }
 
+    public static String getTargetLoc(Long areaId, Long containerType,List<Integer> rowList) {
+
+        Long locType = containerType;
+        //TODO 搴撲綅绛栫暐鍚庣画鎺掓湡
+        LocService locService = SpringUtils.getBean(LocService.class);
+        Loc loc = locService.getOne(new LambdaQueryWrapper<Loc>()
+                .eq(!Objects.isNull(locType), Loc::getType, locType)
+                .eq(Loc::getAreaId, areaId)
+                .eq(Loc::getUseStatus, LocStsType.LOC_STS_TYPE_O.type)
+                .in(Objects.nonNull(rowList) && !rowList.isEmpty(), Loc::getRow, rowList)
+                .orderByAsc(Loc::getLev)
+                .orderByAsc(Loc::getCol)
+                .orderByAsc(Loc::getRow)
+                .last("LIMIT 1")
+        );
+
+        return !Objects.isNull(loc) ? loc.getCode() : null;
+    }
+
     public static String getTargetLoc(Long areaId, Long containerType) {
         Long locType = null;
-        if (!Objects.isNull(containerType)) {
-            LocTypeService locService = SpringUtils.getBean(LocTypeService.class);
-            if (containerType.equals(ContainerType.CONTAINER_TYPE_NORMAL.val)) {
-                LocType low = locService.getOne(new LambdaQueryWrapper<LocType>()
-                        .eq(LocType::getCode, "L"));
-                if (Objects.isNull(low)) {
-                    throw new CoolException("搴綅椤炲瀷涓嶅瓨鍦紒锛�");
-                }
-                locType = low.getId();
-            } else {
-                LocType low = locService.getOne(new LambdaQueryWrapper<LocType>()
-                        .eq(LocType::getCode, "H"));
-                if (Objects.isNull(low)) {
-                    throw new CoolException("搴綅椤炲瀷涓嶅瓨鍦紒锛�");
-                }
-                locType = low.getId();
-            }
-        }
+//        if (!Objects.isNull(containerType)) {
+//            LocTypeService locService = SpringUtils.getBean(LocTypeService.class);
+//            if (containerType.equals(ContainerType.CONTAINER_TYPE_NORMAL.val)) {
+//                LocType low = locService.getOne(new LambdaQueryWrapper<LocType>()
+//                        .eq(LocType::getCode, "L"));
+//                if (Objects.isNull(low)) {
+//                    throw new CoolException("搴綅椤炲瀷涓嶅瓨鍦紒锛�");
+//                }
+//                locType = low.getId();
+//            } else {
+//                LocType low = locService.getOne(new LambdaQueryWrapper<LocType>()
+//                        .eq(LocType::getCode, "H"));
+//                if (Objects.isNull(low)) {
+//                    throw new CoolException("搴綅椤炲瀷涓嶅瓨鍦紒锛�");
+//                }
+//                locType = low.getId();
+//            }
+//        }
         //TODO 搴撲綅绛栫暐鍚庣画鎺掓湡
         LocService locService = SpringUtils.getBean(LocService.class);
         Loc loc = locService.getOne(new LambdaQueryWrapper<Loc>()
@@ -129,7 +145,12 @@
         LambdaQueryWrapper<LocItem> locItemQueryWrapper = new LambdaQueryWrapper<>();
         locItemQueryWrapper.eq(LocItem::getMatnrCode, matnrCode);
         locItemQueryWrapper.eq(StringUtils.isNotEmpty(splrBatch), LocItem::getBatch, splrBatch);
-        locItemQueryWrapper.orderByAsc(LocItem::getCreateTime);
+        //濡傛灉鎵规涓嶄负绌猴紝鎸夋壒娆″厛鍚庡嚭搴�
+        if (StringUtils.isNotBlank(splrBatch)) {
+            locItemQueryWrapper.orderByAsc(LocItem::getBatch);
+        } else {
+            locItemQueryWrapper.orderByAsc(LocItem::getCreateTime);
+        }
         String applySql = String.format(
                 "EXISTS (SELECT 1 FROM man_loc ml " +
                         "WHERE ml.use_status = '%s'" +
@@ -224,7 +245,6 @@
 
                         orderOutItemDto.setSource(item.getItemId())
                                 .setSourceId(item.getWaveId());
-
                         list.add(orderOutItemDto);
 
                         issued = issued.subtract(new BigDecimal(locItem.getAnfme().toString()));

--
Gitblit v1.9.1