From c46d1d8c3b9875f051a6ec3c4a1d3fa7bd32e5db Mon Sep 17 00:00:00 2001
From: skyouc
Date: 星期四, 15 五月 2025 17:15:21 +0800
Subject: [PATCH] 新增库存管理 新增库存明细

---
 rsf-server/src/main/java/com/vincent/rsf/server/manager/controller/AsnOrderController.java |   53 ++++++++++++++++++++++++++++++++++++-----------------
 1 files changed, 36 insertions(+), 17 deletions(-)

diff --git a/rsf-server/src/main/java/com/vincent/rsf/server/manager/controller/AsnOrderController.java b/rsf-server/src/main/java/com/vincent/rsf/server/manager/controller/AsnOrderController.java
index 6724931..64afeec 100644
--- a/rsf-server/src/main/java/com/vincent/rsf/server/manager/controller/AsnOrderController.java
+++ b/rsf-server/src/main/java/com/vincent/rsf/server/manager/controller/AsnOrderController.java
@@ -8,8 +8,10 @@
 import com.vincent.rsf.framework.common.Cools;
 import com.vincent.rsf.framework.common.R;
 import com.vincent.rsf.framework.exception.CoolException;
-import com.vincent.rsf.server.api.entity.enums.OrderType;
-import com.vincent.rsf.server.api.entity.enums.OrderWorkType;
+import com.vincent.rsf.server.manager.entity.Purchase;
+import com.vincent.rsf.server.manager.entity.PurchaseItem;
+import com.vincent.rsf.server.manager.enums.OrderType;
+import com.vincent.rsf.server.manager.enums.OrderWorkType;
 import com.vincent.rsf.server.common.utils.ExcelUtil;
 import com.vincent.rsf.server.common.annotation.OperationLog;
 import com.vincent.rsf.server.common.domain.BaseParam;
@@ -19,11 +21,13 @@
 import com.vincent.rsf.server.manager.controller.params.BatchUpdateParam;
 import com.vincent.rsf.server.manager.entity.AsnOrder;
 import com.vincent.rsf.server.manager.entity.AsnOrderItem;
-import com.vincent.rsf.server.manager.entity.Matnr;
 import com.vincent.rsf.server.manager.entity.excel.AsnOrderTemplate;
 import com.vincent.rsf.server.manager.enums.AsnExceStatus;
+import com.vincent.rsf.server.manager.enums.POExceStatus;
 import com.vincent.rsf.server.manager.service.AsnOrderItemService;
 import com.vincent.rsf.server.manager.service.AsnOrderService;
+import com.vincent.rsf.server.manager.service.impl.PurchaseItemServiceImpl;
+import com.vincent.rsf.server.manager.service.impl.PurchaseServiceImpl;
 import com.vincent.rsf.server.system.constant.SerialRuleCode;
 import com.vincent.rsf.server.system.controller.BaseController;
 import com.vincent.rsf.server.system.utils.SerialRuleUtils;
@@ -31,10 +35,9 @@
 import io.swagger.annotations.ApiOperation;
 import org.springframework.beans.factory.annotation.Autowired;
 import org.springframework.security.access.prepost.PreAuthorize;
+import org.springframework.transaction.annotation.Transactional;
 import org.springframework.web.bind.annotation.*;
-import org.springframework.web.multipart.MultipartFile;
 
-import javax.mail.Multipart;
 import javax.servlet.http.HttpServletResponse;
 import java.util.*;
 import java.util.stream.Collectors;
@@ -47,6 +50,10 @@
     private AsnOrderService asnOrderService;
     @Autowired
     private AsnOrderItemService asnOrderItemService;
+    @Autowired
+    private PurchaseServiceImpl purchaseService;
+    @Autowired
+    private PurchaseItemServiceImpl purchaseItemService;
 
     @PreAuthorize("hasAuthority('manager:asnOrder:list')")
     @PostMapping("/asnOrder/page")
@@ -111,11 +118,12 @@
     @PreAuthorize("hasAuthority('manager:asnOrder:remove')")
     @OperationLog("Delete ASN鍗曟嵁")
     @PostMapping("/asnOrder/remove/{ids}")
+    @Transactional(rollbackFor = Exception.class)
     public R remove(@PathVariable Long[] ids) {
-        if (!asnOrderService.removeByIds(Arrays.asList(ids))) {
-            return R.error("Delete Fail");
+        if (Objects.isNull(ids) || ids.length == 0) {
+            return R.error("鍙傛暟涓嶈兘涓虹┖锛侊紒");
         }
-        return R.ok("Delete Success").add(ids);
+        return asnOrderService.removeOrders(Arrays.asList(ids));
     }
 
     @PreAuthorize("hasAuthority('manager:asnOrder:list')")
@@ -159,23 +167,15 @@
                 template.setCode(order.getCode())
                         .setType(OrderType.getValType(order.getType()))
                         .setWkType(OrderWorkType.getWorkDesc(order.getWkType()))
-                        .setExceStatus(AsnExceStatus.getExceStatus(order.getExceStatus()))
                         .setAnfme(item.getAnfme() + "")
                         .setMaktx(item.getMaktx())
                         .setMemo(item.getMemo())
                         .setMatnrCode(item.getMatnrCode())
                         .setPoCode(item.getPoCode())
                         .setSplrName(item.getSplrName())
-                        .setPoId(order.getPoId() + "")
-                        .setTrackCode(item.getTrackCode())
-                        .setBarcode(item.getBarcode())
-                        .setPackName(item.getPackName())
                         .setPlatItemId(item.getPlatItemId())
                         .setSplrBatch(item.getSplrBatch())
-                        .setSplrCode(item.getSplrCode())
-                        .setStockUnit(item.getStockUnit())
-                        .setPurQty(item.getPurQty() + "")
-                        .setPurUnit(item.getPurUnit());
+                        .setSplrCode(item.getSplrCode());
                 orderTemplates.add(template);
             }
         }
@@ -223,6 +223,25 @@
         return asnOrderService.saveOrderAndItems(params, getLoginUserId());
     }
 
+    @PostMapping("/asnOrder/purchases/save")
+    @ApiOperation("鏍规嵁PO鍗曟柊寤烘敹璐у崟")
+    @PreAuthorize("hasAuthority('manager:asnOrder:save')")
+    public R orderCreateByPo(@RequestBody Map<String, Object> params) {
+        if (Objects.isNull(params.get("purchaseId"))) {
+            return R.error("PO涓诲崟ID涓嶈兘涓虹┖锛侊紒");
+        }
+        if (Objects.isNull(params.get("items"))) {
+            return R.error("鏄庣粏鍗曟嵁涓嶈兘涓虹┖锛侊紒");
+        }
+//        List<Long> ids = JSONArray.parseArray(params.get("ids").toString(), Long.class);
+//        if (ids.isEmpty()) {
+//            return R.error("鍙傛暟涓嶈兘涓虹┖");
+//        }
+
+        return asnOrderService.createByPo(params);
+    }
+
+
     @ApiOperation("鍗曟嵁淇℃伅淇敼")
     @PostMapping("/asnOrder/items/update")
     @PreAuthorize("hasAuthority('manager:asnOrder:update')")

--
Gitblit v1.9.1