From 6c3cc6842009f3897c3fb18bef8a6634fe653818 Mon Sep 17 00:00:00 2001
From: 1 <1@123>
Date: 星期三, 04 三月 2026 19:59:11 +0800
Subject: [PATCH] lsh#

---
 rsf-server/src/main/java/com/vincent/rsf/server/api/service/impl/InBoundServiceImpl.java |   93 +++++++++++++++++++++++++++++++++++++++++++---
 1 files changed, 87 insertions(+), 6 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 9a4f334..c1b6af1 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
@@ -25,6 +25,7 @@
 import org.springframework.transaction.annotation.Transactional;
 
 import java.util.ArrayList;
+import java.util.Date;
 import java.util.List;
 import java.util.Objects;
 import java.util.stream.Collectors;
@@ -48,7 +49,11 @@
     @Autowired
     private LocService locService;
     @Autowired
+    private LocItemService locItemService;
+    @Autowired
     private TaskService taskService;
+    @Autowired
+    private TaskItemService taskItemService;
 
 
     private BasStation checkStaStatus(String barcode, String sta) {
@@ -75,7 +80,7 @@
             throw new CoolException("绔欑偣鐘舵�佷笉涓虹┖闂�");
         }
         if (!Cools.isEmpty(basStation.getContainerType())) {
-            List<Long> longs1 = JSONObject.parseArray(basStation.getContainerType(), Long.class);
+            List<Integer> longs1 = basStation.getContainerType();
             List<BasContainer> containers = basContainerService.list(
                     new LambdaQueryWrapper<BasContainer>()
                             .in(BasContainer::getContainerType, longs1)
@@ -126,12 +131,12 @@
             throw new CoolException("绔欑偣鐘舵�佷笉涓虹┖闂�");
         }
 
-        List<String> areaList = JSONObject.parseArray(basStation.getCrossZoneArea(), String.class);
-        if (!areaList.contains(area)) {
+        List<Integer> areaList = basStation.getCrossZoneArea();
+        if (!areaList.contains(Integer.parseInt(area))) {
             throw new CoolException("褰撳墠绔欑偣涓嶆敮鎸佺洰鏍囧簱鍖�");
         }
         if (!Cools.isEmpty(basStation.getContainerType())) {
-            List<Long> longs1 = JSONObject.parseArray(basStation.getContainerType(), Long.class);
+            List<Integer> longs1 = basStation.getContainerType();
             List<BasContainer> containers = basContainerService.list(
                     new LambdaQueryWrapper<BasContainer>()
                             .in(BasContainer::getContainerType, longs1)
@@ -182,6 +187,9 @@
         }
         StringBuilder errorBuilder = new StringBuilder();
         List<Long> areaTypeList = LocUtils.getAreaTypeList(station.getStationName());
+        if (areaTypeList.isEmpty()) {
+            throw new CoolException("鏈煡璇㈠埌璧风偣鍙叆搴撳尯锛堝簱浣嶈鍒欐湭閰嶇疆锛夛紒锛侊紒");
+        }
         for (Long areaType : areaTypeList) {
             if (errorBuilder.length() > 0) {
                 errorBuilder.append(",");
@@ -226,7 +234,8 @@
 //                throw new CoolException("璇ョ珯鐐瑰搴斿簱鍖烘湭鎵惧埌搴撲綅");
             }
 
-            String ruleCode = SerialRuleUtils.generateRuleCode(SerialRuleCode.SYS_TASK_CODE, null);
+            String ruleCode = StringUtils.isBlank(param.getTaskNo()) ?
+                    SerialRuleUtils.generateRuleCode(SerialRuleCode.SYS_TASK_CODE, null) : param.getTaskNo();
             if (StringUtils.isBlank(ruleCode)) {
                 throw new CoolException("缂栫爜閿欒锛氳纭缂栫爜銆孲YS_TASK_CODE銆嶆槸鍚﹀凡鐢熸垚!!");
             }
@@ -242,13 +251,14 @@
             }
             Task task = new Task();
             task.setTaskCode(ruleCode)
-                    .setTaskStatus(TaskStsType.GENERATE_IN.id)
+                    .setTaskStatus(TaskStsType.MISSION_INITIAL.id)
                     .setTaskType(TaskType.TASK_TYPE_EMPTY_IN.type)
                     .setWarehType(WarehType.WAREHOUSE_TYPE_AGV.val)//lsh寰呬慨鏀�
                     .setTargLoc(targetLoc)
                     .setOrgSite(station.getStationName())
                     .setBarcode(param.getContainerNo())
                     .setTargSite(stationName)
+                    .setTaskOrigin(StringUtils.isBlank(param.getTaskOrigin()) ? null : param.getTaskOrigin())
                     .setCreateBy(loginUserId)
                     .setUpdateBy(loginUserId);
             if (!taskService.save(task)) {
@@ -280,4 +290,75 @@
         return R.ok(basStation);
     }
 
+    @Override
+    public R checkNonOrder(PdaGeneralParam param, Long loginUserId) {
+
+        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("鐩爣绔欑偣涓嶅瓨鍦ㄦ垨绔欑偣涓嶅浜庣┖搴撶姸鎬侊紒锛�");
+        }
+
+        Loc loc = locService.getOne(new LambdaQueryWrapper<Loc>().eq(Loc::getCode, param.getLocNo()));
+        if (Objects.isNull(loc) || !loc.getUseStatus().equals(LocStsType.LOC_STS_TYPE_F.type) ) {
+            throw new CoolException("璧风偣搴撲綅涓嶅瓨鍦ㄦ垨涓嶅浜庡湪搴撶姸鎬侊紒锛�");
+        }
+        List<LocItem> itemParams = locItemService.list(new LambdaQueryWrapper<LocItem>().eq(LocItem::getLocId, loc.getId()));
+
+        if (itemParams.isEmpty()) {
+            throw new CoolException("璧风偣搴撲綅搴撳瓨鏄庣粏涓虹┖锛屽紓甯革紒锛�");
+        }
+        Task task = new Task();
+        String ruleCode = SerialRuleUtils.generateRuleCode(SerialRuleCode.SYS_TASK_CODE, null);
+        if (StringUtils.isBlank(ruleCode)) {
+            throw new CoolException("浠诲姟鍙蜂笉鑳戒负绌猴紒锛�");
+        }
+        task.setOrgLoc(loc.getCode())
+                .setTaskCode(ruleCode)
+                .setOrgLoc(loc.getCode())
+                .setTargSite(station.getStationName())
+                .setResource(TaskResouceType.TASK_RESOUCE_CHECK_TYPE.val)
+                .setTaskType(TaskType.TASK_TYPE_CHECK_OUT.type)
+                .setTaskStatus(TaskStsType.MISSION_INITIAL.id)
+                .setWarehType(WarehType.WAREHOUSE_TYPE_AGV.val)
+                .setBarcode(param.getContainerNo())
+                .setCreateTime(new Date())
+                .setUpdateBy(loginUserId)
+                .setUpdateTime(new Date())
+                .setCreateBy(loginUserId)
+                .setBarcode(loc.getBarcode());
+
+        if (!taskService.save(task)) {
+            throw new CoolException("鐩樼偣浠诲姟鐢熸垚澶辫触锛侊紒");
+        }
+        List<TaskItem> taskItems = new ArrayList<>();
+        for (LocItem item : itemParams) {
+            TaskItem taskItem = new TaskItem();
+            BeanUtils.copyProperties(item, taskItem);
+            taskItem.setTaskId(task.getId())
+                    .setAnfme(item.getAnfme())
+                    .setBatch(item.getBatch())
+                    .setUpdateBy(loginUserId)
+                    .setSourceId(item.getLocId())
+                    .setSourceCode(item.getLocCode())
+                    .setSource(item.getId())
+                    .setUpdateTime(new Date())
+                    .setSplrBatch(item.getBatch())
+                    .setPlatWorkCode(item.getPlatWorkCode())
+                    .setPlatItemId(item.getPlatItemId())
+                    .setOrderType(OrderType.ORDER_IN.type)
+                    .setWkType(Short.parseShort(OrderWorkType.ORDER_WORK_TYPE_OTHER_IN.type));
+            taskItems.add(taskItem);
+        }
+        if (!taskItemService.saveBatch(taskItems)) {
+            throw new CoolException("浠诲姟鏄庣粏淇濆瓨澶辫触锛侊紒");
+        }
+
+        loc.setUseStatus(LocStsType.LOC_STS_TYPE_R.type);
+        if (!locService.updateById(loc)) {
+            throw new CoolException("搴撲綅棰勭害鍑哄簱澶辫触锛侊紒");
+        }
+        return R.ok();
+    }
+
 }
\ No newline at end of file

--
Gitblit v1.9.1