From 6883e31331af4633d1b7d74ea7deb5f972afa05d Mon Sep 17 00:00:00 2001
From: skyouc
Date: 星期五, 23 五月 2025 20:02:19 +0800
Subject: [PATCH] 新增移库功能

---
 rsf-server/src/main/java/com/vincent/rsf/server/manager/service/impl/TaskServiceImpl.java    |   65 +++++++++++++++++++++++++++++++-
 rsf-server/src/main/java/com/vincent/rsf/server/manager/service/impl/LocItemServiceImpl.java |   21 ++++++++--
 rsf-admin/src/page/work/stockTransfer/stockTransferList.jsx                                  |   18 ++------
 rsf-admin/src/page/task/TaskList.jsx                                                         |    2 
 rsf-server/src/main/java/com/vincent/rsf/server/manager/schedules/TaskSchedules.java         |    6 +-
 rsf-server/src/main/java/com/vincent/rsf/server/manager/controller/LocItemController.java    |    6 ++
 6 files changed, 92 insertions(+), 26 deletions(-)

diff --git a/rsf-admin/src/page/task/TaskList.jsx b/rsf-admin/src/page/task/TaskList.jsx
index 6b73c19..3792b7a 100644
--- a/rsf-admin/src/page/task/TaskList.jsx
+++ b/rsf-admin/src/page/task/TaskList.jsx
@@ -245,7 +245,7 @@
         }
     }
     return (
-        ((record?.taskStatus < 98) || (record?.taskType > 101 && record?.taskStatus < 198)) ? (<ConfirmButton label={"toolbar.complete"} color="secondary" startIcon={<TaskAltIcon />} onConfirm={clickComplete} />) : (<></>)
+        ((record?.taskStatus < 98) || (record?.taskType >= 101 && record?.taskStatus < 199)) ? (<ConfirmButton label={"toolbar.complete"} color="secondary" startIcon={<TaskAltIcon />} onConfirm={clickComplete} />) : (<></>)
     )
 }
 
diff --git a/rsf-admin/src/page/work/stockTransfer/stockTransferList.jsx b/rsf-admin/src/page/work/stockTransfer/stockTransferList.jsx
index a0355b8..0007d69 100644
--- a/rsf-admin/src/page/work/stockTransfer/stockTransferList.jsx
+++ b/rsf-admin/src/page/work/stockTransfer/stockTransferList.jsx
@@ -186,7 +186,7 @@
     const redirect = useRedirect();
     const refresh = useRefresh();
     const { orgLoc, tarLoc } = props;
-    const check = () => {
+    const move = () => {
         console.log(orgLoc, tarLoc);
         if (orgLoc === "" || orgLoc === undefined || orgLoc === null) {
             notify("璇烽�夋嫨绔欑偣");
@@ -196,21 +196,13 @@
             notify("璇烽�夋嫨绔欑偣");
             return;
         }        
-        
+        http(orgLoc, tarLoc?.id)
     }
-    const http = async (sta, items) => {
-        console.log(items);
-
-        const filter = items.filter(item => (item.outQty + item.workQty) > item.anfme);
-        if (filter.length > 0) {
-            notify(translate('toolbar.request.error.out_stock_qty'))
-            return
-        }
-        const { data: { code, data, msg } } = await request.post(`/locItem/generate/task`, { siteNo: sta, items: items });
+    const http = async (orgLoc, tarLoc) => {
+        const { data: { code, data, msg } } = await request.post(`/locItem/move/task`, { orgLoc, tarLoc });
         if (code === 200) {
             notify(msg);
             refresh()
-            setTableData([])
             redirect("/task")
         } else {
             notify(msg);
@@ -220,7 +212,7 @@
         <ConfirmButton
             variant="contained"
             color="primary"
-            onConfirm={check}
+            onConfirm={move}
             label={"table.field.outBound.createTask"}
         >
         </ConfirmButton>
diff --git a/rsf-server/src/main/java/com/vincent/rsf/server/manager/controller/LocItemController.java b/rsf-server/src/main/java/com/vincent/rsf/server/manager/controller/LocItemController.java
index 5f8890f..5390de7 100644
--- a/rsf-server/src/main/java/com/vincent/rsf/server/manager/controller/LocItemController.java
+++ b/rsf-server/src/main/java/com/vincent/rsf/server/manager/controller/LocItemController.java
@@ -15,6 +15,7 @@
 import com.vincent.rsf.server.manager.service.LocItemService;
 import com.vincent.rsf.server.system.controller.BaseController;
 import com.vincent.rsf.server.manager.enums.LocStsType;
+import io.swagger.annotations.ApiOperation;
 import org.springframework.beans.factory.annotation.Autowired;
 import org.springframework.security.access.prepost.PreAuthorize;
 import org.springframework.web.bind.annotation.*;
@@ -82,6 +83,7 @@
      * @return
      */
     @PreAuthorize("hasAuthority('manager:locItem:list')")
+    @ApiOperation("鐢熸垚搴撳瓨鍑哄簱浠诲姟")
     @PostMapping("/locItem/generate/task")
     public R generateTask(@RequestBody Map<String, Object> map) {
         if (Objects.isNull(map)) {
@@ -96,7 +98,8 @@
      * @return
      */
     @PreAuthorize("hasAuthority('manager:locItem:list')")
-    @PostMapping("/locItem/generate/move/task")
+    @ApiOperation("鐢熸垚绉诲簱浠诲姟")
+    @PostMapping("/locItem/move/task")
     public R genMoveTask(@RequestBody Map<String, Object> map) {
         if (Objects.isNull(map)) {
             return R.error("鍙傛暟涓嶈兘涓虹┖锛侊紒");
@@ -110,6 +113,7 @@
      * @return
      */
     @PreAuthorize("hasAuthority('manager:locItem:list')")
+    @ApiOperation("鐢熸垚鐩樼偣鍑哄簱浠诲姟")
     @PostMapping("/locItem/check/task")
     public R genStatisticalTask(@RequestBody Map<String, Object> map) {
         if (Objects.isNull(map)) {
diff --git a/rsf-server/src/main/java/com/vincent/rsf/server/manager/schedules/TaskSchedules.java b/rsf-server/src/main/java/com/vincent/rsf/server/manager/schedules/TaskSchedules.java
index f35c3ab..75ddce8 100644
--- a/rsf-server/src/main/java/com/vincent/rsf/server/manager/schedules/TaskSchedules.java
+++ b/rsf-server/src/main/java/com/vincent/rsf/server/manager/schedules/TaskSchedules.java
@@ -97,12 +97,12 @@
         Config config = configService.getOne(new LambdaQueryWrapper<Config>().eq(Config::getFlag, GlobalConfigCode.ORDER_INOF_REPORT_PLAT));
         if (!Objects.isNull(config)) {
             if (Boolean.parseBoolean(config.getVal())) {
-                queryWrapper.eq(Task::getTaskStatus, TaskStsType.REPORT_IN.id);
+                queryWrapper.in(Task::getTaskStatus, TaskStsType.REPORT_IN.id);
             } else {
-                queryWrapper.eq(Task::getTaskStatus, TaskStsType.UPDATED_IN.id);
+                queryWrapper.in(Task::getTaskStatus, TaskStsType.UPDATED_IN.id, TaskStsType.UPDATED_OUT.id);
             }
         } else {
-            queryWrapper.eq(Task::getTaskStatus, TaskStsType.UPDATED_IN.id);
+            queryWrapper.in(Task::getTaskStatus, TaskStsType.UPDATED_IN.id, TaskStsType.UPDATED_OUT.id);
         }
         List<Task> tasks = taskService.list(queryWrapper);
         if (tasks.isEmpty()) {
diff --git a/rsf-server/src/main/java/com/vincent/rsf/server/manager/service/impl/LocItemServiceImpl.java b/rsf-server/src/main/java/com/vincent/rsf/server/manager/service/impl/LocItemServiceImpl.java
index b0584d9..7b7266f 100644
--- a/rsf-server/src/main/java/com/vincent/rsf/server/manager/service/impl/LocItemServiceImpl.java
+++ b/rsf-server/src/main/java/com/vincent/rsf/server/manager/service/impl/LocItemServiceImpl.java
@@ -165,10 +165,10 @@
     @Override
     @Transactional(rollbackFor = Exception.class)
     public R genMoveTask(Map<String, Object> map) {
-        if (Objects.isNull(map.get("targetLoc")) && StringUtils.isNotBlank(map.get("targetLoc").toString())) {
-            throw new CoolException("鐩爣搴撲綅涓嶈兘涓虹┖锛�1");
+        if (Objects.isNull(map.get("tarLoc")) || StringUtils.isBlank(map.get("tarLoc").toString())) {
+            throw new CoolException("鐩爣搴撲綅涓嶈兘涓虹┖锛�");
         }
-        if (Objects.isNull(map.get("orgLoc")) && StringUtils.isNotBlank(map.get("orgLoc").toString())) {
+        if (Objects.isNull(map.get("orgLoc")) || StringUtils.isBlank(map.get("orgLoc").toString())) {
             throw new CoolException("婧愬簱浣嶄笉鑳戒负绌猴紒");
         }
 
@@ -177,12 +177,19 @@
             throw new CoolException("婧愬簱浣嶄笉瀛樺湪锛侊紒");
         }
 
-        Loc targetLoc = locService.getOne(new LambdaQueryWrapper<Loc>().eq(Loc::getCode, map.get("targetLoc").toString()));
+        orgLoc.setUseStatus(LocStsType.LOC_STS_TYPE_R.type);
+
+        if (!locService.updateById(orgLoc)) {
+            throw new CoolException("鐩爣搴撲綅棰勭害澶辫触锛侊紒");
+        }
+
+
+        Loc targetLoc = locService.getOne(new LambdaQueryWrapper<Loc>().eq(Loc::getCode, map.get("tarLoc").toString()));
         if (Objects.isNull(targetLoc)) {
             throw new CoolException("鐩爣搴撲綅涓嶅瓨鍦紒锛�");
         }
 
-        targetLoc.setUseStatus(LocStsType.LOC_STS_TYPE_R.type);
+        targetLoc.setUseStatus(LocStsType.LOC_STS_TYPE_S.type);
 
         if (!locService.updateById(targetLoc)) {
             throw new CoolException("鐩爣搴撲綅棰勭害澶辫触锛侊紒");
@@ -197,6 +204,10 @@
                 .setTaskStatus(TaskStsType.GENERATE_IN.id)
                 .setBarcode(orgLoc.getBarcode());
 
+        if (!taskService.save(task)) {
+            throw new CoolException("鏂板缓绉诲簱浠诲姟澶辫触锛侊紒");
+        }
+
         List<LocItem> locItems = locItemService.list(new LambdaQueryWrapper<LocItem>().eq(LocItem::getLocId, orgLoc.getId()));
         if (locItems.isEmpty()) {
             throw new CoolException("搴撲綅鏄庣粏涓嶅瓨鍦紒锛�");
diff --git a/rsf-server/src/main/java/com/vincent/rsf/server/manager/service/impl/TaskServiceImpl.java b/rsf-server/src/main/java/com/vincent/rsf/server/manager/service/impl/TaskServiceImpl.java
index d6484af..30f92ac 100644
--- a/rsf-server/src/main/java/com/vincent/rsf/server/manager/service/impl/TaskServiceImpl.java
+++ b/rsf-server/src/main/java/com/vincent/rsf/server/manager/service/impl/TaskServiceImpl.java
@@ -390,14 +390,72 @@
             if (task.getTaskType().equals(TaskType.TASK_TYPE_IN.type)) {
                 //1.鍏ュ簱
                 complateInstock(task);
-            } else if (task.getTaskType().equals(TaskType.TASK_TYPE_PICK_IN.type)) {
+            } else if (task.getTaskType().equals(TaskType.TASK_TYPE_PICK_IN.type) || task.getTaskType().equals(TaskType.TASK_TYPE_CHECK_IN.type)) {
                 //53.鎷f枡鍐嶅叆搴�
-                pickComplateInStock(task);
-            } else if (task.getTaskType().equals(TaskType.TASK_TYPE_CHECK_IN.type)) {
                 //57.鐩樼偣鍐嶅叆搴�
                 pickComplateInStock(task);
+            } else if (task.getTaskType().equals(TaskType.TASK_TYPE_LOC_MOVE.type)) {
+                //绉诲簱
+                moveInStock(task);
             }
         }
+    }
+
+    @Transactional(rollbackFor = Exception.class)
+    public void moveInStock(Task task) {
+        if (Objects.isNull(task)) {
+            return;
+        }
+
+        Loc loc = locService.getOne(new LambdaQueryWrapper<Loc>().eq(Loc::getCode, task.getTargLoc()));
+        if (Objects.isNull(loc)) {
+            throw new CoolException("鐩爣搴撲綅涓嶅瓨鍦紒");
+        }
+
+        Loc orgLoc = locService.getOne(new LambdaQueryWrapper<Loc>().eq(Loc::getCode, task.getOrgLoc()));
+        if (Objects.isNull(orgLoc)) {
+            throw new CoolException("鐩爣搴撲綅涓嶅瓨鍦紒");
+        }
+
+        if (!loc.getUseStatus().equals(LocStsType.LOC_STS_TYPE_S.type)) {
+            throw new CoolException("褰撳墠搴撲綅鐘舵�佷笉澶勪簬S.鍏ュ簱棰勭害锛屼笉鍙墽琛屽叆搴撴搷浣滐紒");
+        }
+
+        if (!orgLoc.getUseStatus().equals(LocStsType.LOC_STS_TYPE_R.type)) {
+            throw new CoolException("褰撳墠搴撲綅鐘舵�佷笉澶勪簬R.鍑哄簱棰勭害锛屼笉鍙墽琛屽叆搴撴搷浣滐紒");
+        }
+
+        List<TaskItem> taskItems = taskItemService.list(new LambdaQueryWrapper<TaskItem>().eq(TaskItem::getTaskId, task.getId()));
+        if (taskItems.isEmpty()) {
+            throw new CoolException("浠诲姟鏄庣粏涓嶅瓨鍦紒锛�");
+        }
+        try {
+            //鏇存柊搴撲綅鏄庣粏
+            saveLocItem(taskItems, task.getId());
+        } catch (Exception e) {
+            throw new CoolException("搴撲綅鏄庣粏鏇存柊澶辫触锛侊紒");
+        }
+//        /**瀵逛换鍔℃槑缁嗘寜缁勬嫋鏄庣粏杩涜鍒嗙粍*/
+//        try {
+//            //淇濆瓨搴撳瓨鏄庣粏
+//            saveStockItems(taskItems, null, null, pakinItem.getWkType(), pakinItem.getType());
+//        } catch (Exception e) {
+//            log.error("<UNK>", e);
+//            throw new CoolException(e.getMessage());
+//        }
+        /**淇敼搴撲綅鐘舵�佷负F.鍦ㄥ簱*/
+        if (!locService.update(new LambdaUpdateWrapper<Loc>().set(Loc::getUseStatus, LocStsType.LOC_STS_TYPE_F.type).eq(Loc::getCode, task.getTargLoc()))) {
+            throw new CoolException("搴撲綅鐘舵�佷慨鏀瑰け璐ワ紒锛�");
+        }
+
+        if (!locService.update(new LambdaUpdateWrapper<Loc>().set(Loc::getUseStatus, LocStsType.LOC_STS_TYPE_O.type).eq(Loc::getCode, task.getOrgLoc()))) {
+            throw new CoolException("搴撲綅鐘舵�佷慨鏀瑰け璐ワ紒锛�");
+        }
+
+        if (!this.update(new LambdaUpdateWrapper<Task>().eq(Task::getId, task.getId()).set(Task::getTaskStatus, TaskStsType.UPDATED_IN.id))) {
+            throw new CoolException("浠诲姟鐘舵�佷慨鏀瑰け璐ワ紒锛�");
+        }
+
     }
 
 
@@ -906,6 +964,7 @@
         if (Objects.isNull(task)) {
             throw new CoolException("浠诲姟涓嶅瓨鍦�!!");
         }
+
         List<LocItem> locItems = new ArrayList<>();
         items.forEach(taskItem -> {
             Loc loc = locService.getOne(new LambdaQueryWrapper<Loc>().eq(Loc::getCode, task.getTargLoc()), false);

--
Gitblit v1.9.1