From 5264cf0915ee9901cb9520fdcc6b8cdd5ecd4837 Mon Sep 17 00:00:00 2001
From: skyouc
Date: 星期三, 20 八月 2025 10:50:03 +0800
Subject: [PATCH] 库存调整功能界面优化 库存调整接口功能开发

---
 rsf-server/src/main/java/com/vincent/rsf/server/api/service/impl/ReceiveMsgServiceImpl.java |   58 ++++++++++++++++++++++++++++++++++++++++++++++++++++++++++
 1 files changed, 58 insertions(+), 0 deletions(-)

diff --git a/rsf-server/src/main/java/com/vincent/rsf/server/api/service/impl/ReceiveMsgServiceImpl.java b/rsf-server/src/main/java/com/vincent/rsf/server/api/service/impl/ReceiveMsgServiceImpl.java
index cc26147..de0ec9c 100644
--- a/rsf-server/src/main/java/com/vincent/rsf/server/api/service/impl/ReceiveMsgServiceImpl.java
+++ b/rsf-server/src/main/java/com/vincent/rsf/server/api/service/impl/ReceiveMsgServiceImpl.java
@@ -79,6 +79,12 @@
     private TransferService transferService;
     @Autowired
     private TransferItemService transferItemService;
+    @Autowired
+    private LocReviseService locReviseService;
+    @Autowired
+    private ReviseLogService reviseLogService;
+    @Autowired
+    private ReviseLogItemService reviseLogItemService;
 
 
     /**
@@ -474,4 +480,56 @@
         return R.ok();
     }
 
+    /**
+     * @author Ryan
+     * @date 2025/8/20
+     * @description: 搴撳瓨璋冩暣鍗曞悓姝�
+     * @version 1.0
+     */
+    @Override
+    @Transactional(timeout = 60, rollbackFor = Exception.class)
+    public R syncLocRevise(SyncLocReviseParams reviseParams) {
+        LocRevise locRevise = new LocRevise();
+        if (Objects.isNull(reviseParams.getAreaName())) {
+            throw new CoolException("搴撳尯涓嶈兘涓虹┖锛侊紒");
+        }
+        WarehouseAreas warehouseAreas = warehouseAreasService
+                .getOne(new LambdaQueryWrapper<WarehouseAreas>()
+                        .eq(WarehouseAreas::getName, reviseParams.getAreaName()));
+        if (Objects.isNull(warehouseAreas)) {
+            throw new CoolException("搴撳尯涓嶅瓨鍦紒锛�");
+        }
+        locRevise.setAreaName(locRevise.getAreaName())
+                .setAreaId(warehouseAreas.getId());
+        locRevise.setCode(SerialRuleUtils.generateRuleCode(SerialRuleCode.SYS_LOC_REVISE_CODE, null));
+
+        if (!locReviseService.save(locRevise)) {
+            throw new CoolException("搴撳瓨璋冩暣鍗曚繚瀛樺け璐ワ紒锛�");
+        }
+
+        reviseParams.getItems().forEach(revise -> {
+            Loc loc = locService.getOne(new LambdaQueryWrapper<Loc>().eq(Loc::getCode, revise.getLocCode()));
+            ReviseLog reviseLog = new ReviseLog();
+            BeanUtils.copyProperties(loc, reviseLog);
+            reviseLog.setReviseId(locRevise.getId()).setReviseCode(locRevise.getCode());
+            if (!reviseLogService.save(reviseLog)) {
+                throw new CoolException("搴撳瓨璋冩暣鍗曚笉鑳戒负绌猴紒锛�");
+            }
+            revise.getItems().forEach(reviseItem -> {
+                ReviseLogItem logItem = new ReviseLogItem();
+                BeanUtils.copyProperties(reviseItem, logItem);
+                logItem.setLocId(loc.getId())
+                        .setLocCode(loc.getCode())
+                        .setId(null)
+                        .setReviseQty(reviseItem.getAnfme());
+
+                if (!reviseLogItemService.save(logItem)) {
+                    throw new CoolException("璋冩暣搴撳瓨鏄庣粏淇濆瓨澶辫触锛侊紒");
+                }
+            });
+        });
+
+        return R.ok();
+    }
+
 }

--
Gitblit v1.9.1