From b003a49794f49a329e2702918ecfc8d14b371d0d Mon Sep 17 00:00:00 2001
From: chen.lin <1442464845@qq.com>
Date: 星期三, 04 三月 2026 14:51:25 +0800
Subject: [PATCH] 云仓WMS接口流程

---
 rsf-server/src/main/java/com/vincent/rsf/server/manager/controller/WaitPakinController.java |  111 ++++++++++++++++++++++++++++++++++++++++++++++---------
 1 files changed, 93 insertions(+), 18 deletions(-)

diff --git a/rsf-server/src/main/java/com/vincent/rsf/server/manager/controller/WaitPakinController.java b/rsf-server/src/main/java/com/vincent/rsf/server/manager/controller/WaitPakinController.java
index 0c29bfe..f722a1b 100644
--- a/rsf-server/src/main/java/com/vincent/rsf/server/manager/controller/WaitPakinController.java
+++ b/rsf-server/src/main/java/com/vincent/rsf/server/manager/controller/WaitPakinController.java
@@ -10,22 +10,25 @@
 import com.vincent.rsf.server.common.domain.BaseParam;
 import com.vincent.rsf.server.common.domain.KeyValVo;
 import com.vincent.rsf.server.common.domain.PageParam;
+import com.vincent.rsf.server.manager.controller.params.GenerateTaskParams;
 import com.vincent.rsf.server.manager.controller.params.WaitPakinParam;
+import com.vincent.rsf.server.manager.entity.BasStation;
+import com.vincent.rsf.server.manager.entity.TaskItem;
 import com.vincent.rsf.server.manager.entity.WaitPakin;
 import com.vincent.rsf.server.manager.entity.WaitPakinItem;
-import com.vincent.rsf.server.manager.service.TaskService;
-import com.vincent.rsf.server.manager.service.WaitPakinItemService;
-import com.vincent.rsf.server.manager.service.WaitPakinService;
+import com.vincent.rsf.server.manager.service.*;
 import com.vincent.rsf.server.system.controller.BaseController;
 import io.swagger.annotations.Api;
 import io.swagger.annotations.ApiOperation;
 import org.apache.commons.lang3.StringUtils;
 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 javax.servlet.http.HttpServletResponse;
 import java.util.*;
+import java.util.stream.Collectors;
 
 @Api(tags = "缁勬嫋閫氱煡妗�")
 @RestController
@@ -38,32 +41,69 @@
     private WaitPakinItemService waitPakinItemService;
 
     @Autowired
+    private BasStationService basStationService;
+
+    @Autowired
     private TaskService taskService;
+    @Autowired
+    private TaskItemService taskItemService;
 
     @PreAuthorize("hasAuthority('manager:waitPakin:list')")
     @PostMapping("/waitPakin/page")
     public R page(@RequestBody Map<String, Object> map) {
         BaseParam baseParam = buildParam(map, BaseParam.class);
+        // 鍗曟嵁缁勬墭鎸夊崟鍙锋煡璇細鍗曞彿鍦ㄦ槑缁嗚〃 asn_code锛屼粠 map 鍙栧嚭骞剁Щ闄わ紝閬垮厤涓昏〃鏃犳瀛楁鎶ラ敊
+        String asnCode = null;
+        if (baseParam.getMap() != null && baseParam.getMap().containsKey("asnCode")) {
+            Object v = baseParam.getMap().get("asnCode");
+            if (v != null && StringUtils.isNotBlank(v.toString())) {
+                asnCode = v.toString().trim();
+            }
+            baseParam.getMap().remove("asnCode");
+        }
         PageParam<WaitPakin, BaseParam> pageParam = new PageParam<>(baseParam, WaitPakin.class);
-        return R.ok().add(waitPakinService.page(pageParam, pageParam.buildWrapper(true)));
+        com.baomidou.mybatisplus.core.conditions.query.QueryWrapper<WaitPakin> qw = pageParam.buildWrapper(true);
+        if (StringUtils.isNotBlank(asnCode)) {
+            List<Long> pakinIds = waitPakinItemService.list(
+                    new LambdaQueryWrapper<WaitPakinItem>()
+                            .select(WaitPakinItem::getPakinId)
+                            .like(WaitPakinItem::getAsnCode, asnCode))
+                    .stream().map(WaitPakinItem::getPakinId).distinct().collect(Collectors.toList());
+            if (pakinIds.isEmpty()) {
+                qw.and(w -> w.apply("1 = 0"));
+            } else {
+                qw.in("id", pakinIds);
+            }
+        }
+        Page<WaitPakin> page = waitPakinService.page(pageParam, qw);
+        fillAsnCodes(page.getRecords());
+        return R.ok().add(page);
     }
 
     @PreAuthorize("hasAuthority('manager:waitPakin:list')")
     @PostMapping("/waitPakin/list")
     public R list(@RequestBody Map<String, Object> map) {
-        return R.ok().add(waitPakinService.list());
+        List<WaitPakin> list = waitPakinService.list();
+        fillAsnCodes(list);
+        return R.ok().add(list);
     }
 
     @PreAuthorize("hasAuthority('manager:waitPakin:list')")
     @PostMapping({"/waitPakin/many/{ids}", "/waitPakins/many/{ids}"})
     public R many(@PathVariable Long[] ids) {
-        return R.ok().add(waitPakinService.listByIds(Arrays.asList(ids)));
+        List<WaitPakin> list = waitPakinService.listByIds(Arrays.asList(ids));
+        fillAsnCodes(list);
+        return R.ok().add(list);
     }
 
     @PreAuthorize("hasAuthority('manager:waitPakin:list')")
     @GetMapping("/waitPakin/{id}")
     public R get(@PathVariable("id") Long id) {
-        return R.ok().add(waitPakinService.getById(id));
+        WaitPakin one = waitPakinService.getById(id);
+        if (one != null) {
+            fillAsnCodes(Collections.singletonList(one));
+        }
+        return R.ok().add(one);
     }
 
     @PreAuthorize("hasAuthority('manager:waitPakin:save')")
@@ -100,16 +140,22 @@
     @PreAuthorize("hasAuthority('manager:waitPakin:remove')")
     @OperationLog("Delete 缁勬嫋妗�")
     @PostMapping("/waitPakin/remove/{ids}")
+    @Transactional(rollbackFor = Exception.class)
     public R remove(@PathVariable Long[] ids) {
-        List<WaitPakinItem> pakinItems = waitPakinItemService.list(new LambdaQueryWrapper<WaitPakinItem>()
-                .in(WaitPakinItem::getPakinId, ids));
-        if (!pakinItems.isEmpty()) {
-            return R.error("缁勬嫋妗f湁鏄庣粏浠诲姟");
+        if (Arrays.asList(ids).isEmpty()) {
+            return R.error("鍙傛暟涓嶈兘涓虹┖锛侊紒");
         }
-        if (!waitPakinService.removeByIds(Arrays.asList(ids))) {
-            return R.error("Delete Fail");
+        for (Long id : ids) {
+            WaitPakin waitPakin = waitPakinService.getById(id);
+            BasStation isBarcodeSta = basStationService.getOne(new LambdaQueryWrapper<BasStation>()
+                            .eq(BasStation::getBarcode, waitPakin.getBarcode())
+                    ,false
+            );
+            if (!Cools.isEmpty(isBarcodeSta)){
+                throw new CoolException("璇ユ潯鐮佸凡琚�"+isBarcodeSta.getStationName()+"绔欑粦瀹�");
+            }
         }
-        return R.ok("Delete Success").add(ids);
+        return waitPakinService.removePakin(Arrays.asList(ids));
     }
 
     @PreAuthorize("hasAuthority('manager:waitPakin:list')")
@@ -129,18 +175,47 @@
     @PreAuthorize("hasAuthority('manager:waitPakin:list')")
     @PostMapping("/waitPakin/export")
     public void export(@RequestBody Map<String, Object> map, HttpServletResponse response) throws Exception {
-        ExcelUtil.build(ExcelUtil.create(waitPakinService.list(), WaitPakin.class), response);
+        List<WaitPakin> list = waitPakinService.list();
+        fillAsnCodes(list);
+        ExcelUtil.build(ExcelUtil.create(list, WaitPakin.class), response);
     }
 
 
     @PreAuthorize("hasAuthority('manager:waitPakin:update')")
     @ApiOperation("鐢熸垚浠诲姟鍒楄〃")
     @PostMapping("/waitPakin/merge")
-    public R generateTask(@RequestBody List<WaitPakin> waitPakin) {
-        if (Objects.isNull(waitPakin) || waitPakin.isEmpty()) {
+    public R generateTask(@RequestBody GenerateTaskParams taskParams) {
+        if (Objects.isNull(taskParams)) {
             throw new CoolException("鍙傛暟涓嶈兘涓虹┖锛侊紒");
         }
-        return  taskService.generateTasks(waitPakin, getLoginUserId());
+        if (Objects.isNull(taskParams.getWaitPakins()) || taskParams.getWaitPakins().isEmpty()) {
+            throw new CoolException("缁勬嫋妗d笉鑳戒负绌猴紒锛�");
+        }
+        return  taskService.generateTasks(taskParams, getLoginUserId());
+    }
+
+    /**
+     * 鏍规嵁缁勬墭鏄庣粏濉厖涓绘。鐨勫叧鑱斿叆搴撻�氱煡鍗曞彿锛坅snCodes锛夛紝澶氫釜鍗曞彿閫楀彿鍒嗛殧
+     */
+    private void fillAsnCodes(List<WaitPakin> list) {
+        if (list == null || list.isEmpty()) {
+            return;
+        }
+        List<Long> pakinIds = list.stream().map(WaitPakin::getId).collect(Collectors.toList());
+        List<WaitPakinItem> items = waitPakinItemService.list(
+                new LambdaQueryWrapper<WaitPakinItem>()
+                        .in(WaitPakinItem::getPakinId, pakinIds)
+                        .select(WaitPakinItem::getPakinId, WaitPakinItem::getAsnCode));
+        Map<Long, String> asnCodesByPakinId = pakinIds.stream().collect(Collectors.toMap(
+                pid -> pid,
+                pid -> items.stream()
+                        .filter(i -> pid.equals(i.getPakinId()) && i.getAsnCode() != null && !i.getAsnCode().trim().isEmpty())
+                        .map(WaitPakinItem::getAsnCode)
+                        .distinct()
+                        .collect(Collectors.joining(","))));
+        for (WaitPakin p : list) {
+            p.setAsnCodes(asnCodesByPakinId.get(p.getId()));
+        }
     }
 
 }

--
Gitblit v1.9.1