From 343df1a8fbdbf46497f8cf5e219ace4e0b400268 Mon Sep 17 00:00:00 2001
From: 1 <1@123>
Date: 星期一, 19 一月 2026 13:15:57 +0800
Subject: [PATCH] lsh#

---
 rsf-server/src/main/java/com/vincent/rsf/server/api/service/impl/InBoundServiceImpl.java |   31 ++++++++++++++++++-------------
 1 files changed, 18 insertions(+), 13 deletions(-)

diff --git a/rsf-server/src/main/java/com/vincent/rsf/server/api/service/impl/InBoundServiceImpl.java b/rsf-server/src/main/java/com/vincent/rsf/server/api/service/impl/InBoundServiceImpl.java
index 4f19282..dab9f20 100644
--- a/rsf-server/src/main/java/com/vincent/rsf/server/api/service/impl/InBoundServiceImpl.java
+++ b/rsf-server/src/main/java/com/vincent/rsf/server/api/service/impl/InBoundServiceImpl.java
@@ -125,6 +125,11 @@
         if (!basStation.getUseStatus().equals("O")) {
             throw new CoolException("绔欑偣鐘舵�佷笉涓虹┖闂�");
         }
+
+        List<String> areaList = JSONObject.parseArray(basStation.getCrossZoneArea(), String.class);
+        if (!areaList.contains(area)) {
+            throw new CoolException("褰撳墠绔欑偣涓嶆敮鎸佺洰鏍囧簱鍖�");
+        }
         if (!Cools.isEmpty(basStation.getContainerType())) {
             List<Long> longs1 = JSONObject.parseArray(basStation.getContainerType(), Long.class);
             List<BasContainer> containers = basContainerService.list(
@@ -136,8 +141,8 @@
             for (BasContainer container : containers) {
                 String codeType = container.getCodeType();  // 鑾峰彇姝e垯琛ㄨ揪寮�
                 if (barcode.matches(codeType)) {  // 鍒ゆ柇鏉$爜鏄惁绗﹀悎杩欎釜姝e垯
-                    List<String> areaList2 = JSONObject.parseArray(container.getAreas(), String.class);
-                    if (!areaList2.contains(area)) {
+                    List<Integer> areaList2 = container.getAreas();
+                    if (!areaList2.contains(Integer.parseInt(area))) {
                         matches2 = false;
                         continue;
                     }
@@ -165,11 +170,16 @@
     @Transactional(rollbackFor = Exception.class)
     public synchronized R generateTasks(PdaGeneralParam param, Long loginUserId) {
 
-        DeviceSite deviceSite = deviceSiteService.getOne(new LambdaQueryWrapper<DeviceSite>().eq(DeviceSite::getSite,param.getTransferStationNo()).orderByDesc(DeviceSite::getId),false);
-        if (Objects.isNull(deviceSite)) {
-            throw new CoolException("绔欑偣涓嶅瓨鍦紒锛�");
+//        DeviceSite deviceSite = deviceSiteService.getOne(new LambdaQueryWrapper<DeviceSite>().eq(DeviceSite::getSite,param.getTransferStationNo()).orderByDesc(DeviceSite::getId),false);
+//        if (Objects.isNull(deviceSite)) {
+//            throw new CoolException("绔欑偣涓嶅瓨鍦紒锛�");
+//        }
+        BasStation station = basStationService.getOne(new LambdaQueryWrapper<BasStation>()
+                .eq(BasStation::getStationName, param.getTransferStationNo()));
+        if (Objects.isNull(station) || !station.getUseStatus().equals(LocStsType.LOC_STS_TYPE_O.type)) {
+            throw new CoolException("绔欑偣涓嶅瓨鍦ㄦ垨绔欑偣涓嶅浜庣┖搴撶姸鎬侊紒锛�");
         }
-        DeviceBind deviceBind = deviceBindService.getById(LocUtils.getAreaType(deviceSite.getSite()));
+        DeviceBind deviceBind = deviceBindService.getById(LocUtils.getAreaType(station.getStationName()));
         if (Cools.isEmpty(deviceBind)) {
             throw new CoolException("搴撲綅瑙勫垯鏈煡");
         }
@@ -201,18 +211,13 @@
                 .setTaskType(TaskType.TASK_TYPE_EMPITY_IN.type)
                 .setWarehType(WarehType.WAREHOUSE_TYPE_AGV.val)//lsh寰呬慨鏀�
                 .setTargLoc(targetLoc)
-                .setOrgSite(deviceSite.getSite())
+                .setOrgSite(station.getStationName())
                 .setBarcode(param.getContainerNo())
-                .setTargSite(deviceSite.getDeviceSite())
+                .setTargSite(station.getStationName())
                 .setCreateBy(loginUserId)
                 .setUpdateBy(loginUserId);
         if (!taskService.save(task)) {
             throw new CoolException("浠诲姟淇濆瓨澶辫触锛侊紒");
-        }
-        BasStation station = basStationService.getOne(new LambdaQueryWrapper<BasStation>()
-                .eq(BasStation::getStationName, deviceSite.getSite()));
-        if (Objects.isNull(station) || !station.getUseStatus().equals(LocStsType.LOC_STS_TYPE_O.type)) {
-            throw new CoolException("绔欑偣涓嶅瓨鍦ㄦ垨绔欑偣涓嶅浜庣┖搴撶姸鎬侊紒锛�");
         }
         station.setUseStatus(LocStsType.LOC_STS_TYPE_R.type);
 

--
Gitblit v1.9.1