From 0b190d8a9aad67aa521ec163b437c59f6e63c400 Mon Sep 17 00:00:00 2001
From: skyouc
Date: 星期四, 17 七月 2025 14:04:27 +0800
Subject: [PATCH] 盘点单下发功能优化

---
 rsf-server/src/main/java/com/vincent/rsf/server/manager/controller/CheckOrderController.java |   82 ++++++++++++++++++++++++++++++++++++++++-
 1 files changed, 80 insertions(+), 2 deletions(-)

diff --git a/rsf-server/src/main/java/com/vincent/rsf/server/manager/controller/CheckOrderController.java b/rsf-server/src/main/java/com/vincent/rsf/server/manager/controller/CheckOrderController.java
index c159e4d..941cabb 100644
--- a/rsf-server/src/main/java/com/vincent/rsf/server/manager/controller/CheckOrderController.java
+++ b/rsf-server/src/main/java/com/vincent/rsf/server/manager/controller/CheckOrderController.java
@@ -1,5 +1,6 @@
 package com.vincent.rsf.server.manager.controller;
 
+import com.alibaba.fastjson.JSONArray;
 import com.baomidou.mybatisplus.core.conditions.query.LambdaQueryWrapper;
 import com.baomidou.mybatisplus.core.conditions.query.QueryWrapper;
 import com.baomidou.mybatisplus.extension.plugins.pagination.Page;
@@ -11,9 +12,13 @@
 import com.vincent.rsf.server.common.domain.PageParam;
 import com.vincent.rsf.server.common.utils.ExcelUtil;
 import com.vincent.rsf.server.manager.controller.params.AsnOrderAndItemsParams;
+import com.vincent.rsf.server.manager.controller.params.CheckOrderItemParams;
+import com.vincent.rsf.server.manager.controller.params.CheckOrderParams;
+import com.vincent.rsf.server.manager.controller.params.OrderOutTaskParam;
 import com.vincent.rsf.server.manager.entity.WkOrder;
 import com.vincent.rsf.server.manager.entity.WkOrderItem;
 import com.vincent.rsf.server.manager.entity.excel.CheckOrderTemplate;
+import com.vincent.rsf.server.manager.enums.CheckExceStatus;
 import com.vincent.rsf.server.manager.enums.OrderType;
 import com.vincent.rsf.server.manager.service.CheckOrderService;
 import com.vincent.rsf.server.system.constant.SerialRuleCode;
@@ -28,6 +33,7 @@
 
 import javax.servlet.http.HttpServletResponse;
 import java.util.*;
+import java.util.stream.Collectors;
 
 @Api("鐩樼偣")
 @RestController
@@ -95,7 +101,19 @@
     @OperationLog("Delete 瀛楀吀鏁版嵁闆�")
     @PostMapping("/check/remove/{ids}")
     public R remove(@PathVariable Long[] ids) {
-        if (!checkOrderService.removeByIds(Arrays.asList(ids))) {
+        if (Objects.isNull(ids)) {
+            throw new RuntimeException("鐩樼偣鍗旾D涓嶈兘涓虹┖锛侊紒");
+        }
+        List<WkOrder> wkOrders = checkOrderService.list(new LambdaQueryWrapper<WkOrder>().in(WkOrder::getId, Arrays.asList(ids)));
+        if (wkOrders.isEmpty()) {
+            return R.ok();
+        }
+        List<WkOrder> orders = wkOrders.stream().filter(order -> order.getExceStatus().equals(CheckExceStatus.CHECK_ORDER_STATUS_UN_EXCE.val)).collect(Collectors.toList());
+        if (orders.isEmpty()) {
+            return R.ok();
+        }
+        List<Long> orderIds = orders.stream().map(WkOrder::getId).collect(Collectors.toList());
+        if (!checkOrderService.removeByIds(orderIds)) {
             return R.error("Delete Fail");
         }
         return R.ok("Delete Success").add(ids);
@@ -138,7 +156,7 @@
     }
 
     @PostMapping("/check/items/save")
-    @ApiOperation("淇濆瓨涓诲崟鍙婃槑缁�")
+    @ApiOperation("淇濆瓨鐩樼偣鍗曞強鏄庣粏")
     @PreAuthorize("hasAuthority('manager:check:save')")
     public R saveOutStock(@RequestBody AsnOrderAndItemsParams params) throws Exception {
         if (Objects.isNull(params)) {
@@ -147,6 +165,66 @@
         return checkOrderService.saveCheckOrder(params, getLoginUserId());
     }
 
+    @ApiOperation("鐩樼偣鍗曚俊鎭慨鏀�")
+    @PostMapping("/check/items/update")
+    @PreAuthorize("hasAuthority('manager:check:update')")
+    public R orderAndrItemUpdate(@RequestBody AsnOrderAndItemsParams params) throws Exception {
+        if (Objects.isNull(params)) {
+            return R.error("鍙傛暟涓嶈兘涓虹┖锛侊紒");
+        }
+        return checkOrderService.updateOrderItem(params, getLoginUserId());
+    }
+
+    @PostMapping("/check/order/items")
+    @ApiOperation("鐩樼偣鍑哄簱棰勮")
+    @PreAuthorize("hasAuthority('manager:check:list')")
+    public R getOrderOutTaskItem(@RequestBody OrderOutTaskParam param) {
+        if (Cools.isEmpty(param)) {
+            return R.error("鍙傛暟涓嶈兘涓虹┖");
+        }
+        return checkOrderService.genCheckPreview(param);
+    }
+
+
+    /**
+     * 鐩樼偣鍗曠敓鎴愬嚭搴撲换鍔�
+     * @param params
+     * @return
+     */
+    @PostMapping("/check/generate/tasks")
+    @ApiOperation("鐢熸垚鐩樼偣鍑哄簱浠诲姟")
+    @PreAuthorize("hasAuthority('manager:outStock:list')")
+    public R genCheckOutTask( @RequestBody List<CheckOrderParams> params) {
+        if (Cools.isEmpty()) {
+            return R.error("鍙傛暟涓嶈兘涓虹┖锛侊紒");
+        }
+
+        return  checkOrderService.genCheckOutTask(params, getLoginUserId());
+    }
+
+    /**
+     * 鑾峰彇鍑哄簱绔欑偣
+     * @return
+     */
+    @GetMapping("/check/tasks/sites")
+    @ApiOperation("鑾峰彇鐩樼偣鍑哄簱鍙�")
+    @PreAuthorize("hasAuthority('manager:check:list')")
+    public R getSiteNos() {
+        return checkOrderService.getSiteNos();
+    }
+
+
+    @ApiOperation("鑾峰彇鍦ㄥ簱鐗╂枡鍒楄〃")
+    @PostMapping("/check/locs/{matnrs}")
+    @PreAuthorize("hasAuthority('manager:check:list')")
+    public R getAllLocByMatnr(@PathVariable String[] matnrs) {
+        if (Objects.isNull(matnrs)) {
+            return R.error("鍙傛暟涓嶈兘涓虹┖锛侊紒");
+        }
+        return checkOrderService.getAllLocByMatnr(Arrays.asList(matnrs));
+    }
+
+
     /**
      * @author Ryan
      * @description 涓嬭浇妯℃澘

--
Gitblit v1.9.1