From dc434264996b83c7900be642dd6af604bd98b13d Mon Sep 17 00:00:00 2001
From: 1 <1@123>
Date: 星期五, 16 一月 2026 16:47:41 +0800
Subject: [PATCH] Merge remote-tracking branch 'origin/devlop-phyz' into devlop-phyz

---
 rsf-server/src/main/java/com/vincent/rsf/server/api/controller/pda/PdaOutStockController.java |  105 ++++++++++++++++++++++++++++++++++++++++++++++++++--
 1 files changed, 101 insertions(+), 4 deletions(-)

diff --git a/rsf-server/src/main/java/com/vincent/rsf/server/api/controller/pda/PdaOutStockController.java b/rsf-server/src/main/java/com/vincent/rsf/server/api/controller/pda/PdaOutStockController.java
index f4045d5..9710717 100644
--- a/rsf-server/src/main/java/com/vincent/rsf/server/api/controller/pda/PdaOutStockController.java
+++ b/rsf-server/src/main/java/com/vincent/rsf/server/api/controller/pda/PdaOutStockController.java
@@ -1,24 +1,46 @@
 package com.vincent.rsf.server.api.controller.pda;
 
+import com.alibaba.fastjson.JSONObject;
+import com.baomidou.mybatisplus.core.conditions.query.LambdaQueryWrapper;
+import com.baomidou.mybatisplus.extension.plugins.pagination.Page;
+import com.vincent.rsf.framework.common.Cools;
 import com.vincent.rsf.framework.common.R;
-import com.vincent.rsf.server.api.entity.dto.ContainerWaveDto;
+import com.vincent.rsf.server.api.entity.params.CallForEmptyContainersParam;
+import com.vincent.rsf.server.api.entity.params.ContainerWaveParam;
+import com.vincent.rsf.server.api.entity.params.OrderOutGeneralParam;
 import com.vincent.rsf.server.api.service.PdaOutStockService;
+import com.vincent.rsf.server.manager.entity.WkOrder;
+import com.vincent.rsf.server.manager.entity.WkOrderItem;
+import com.vincent.rsf.server.manager.enums.OrderType;
+import com.vincent.rsf.server.manager.service.OutStockItemService;
+import com.vincent.rsf.server.manager.service.OutStockService;
+import com.vincent.rsf.server.system.constant.DictTypeCode;
+import com.vincent.rsf.server.system.controller.BaseController;
+import com.vincent.rsf.server.system.entity.DictData;
+import com.vincent.rsf.server.system.service.DictDataService;
 import io.swagger.annotations.Api;
 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.*;
 
+import javax.annotation.Resource;
 import java.util.List;
 import java.util.Map;
 
 @Api(tags = "PDA鍑哄簱鎿嶄綔鎺ュ彛")
 @RequestMapping("/pda")
 @RestController
-public class PdaOutStockController {
+public class PdaOutStockController extends BaseController {
 
     @Autowired
     private PdaOutStockService pdaOutStockService;
+    @Resource
+    private OutStockService outStockService;
+    @Resource
+    private OutStockItemService outStockItemService;
+    @Autowired
+    private DictDataService dictDataService;
 
     @PreAuthorize("hasAuthority('manager:task:list')")
     @GetMapping("/outStockTaskItem/{barcode}")
@@ -26,6 +48,14 @@
     public R getOutStockTaskItem(@PathVariable String barcode) {
 
         return pdaOutStockService.getOutStockTaskItem(barcode);
+    }
+
+    @PreAuthorize("hasAuthority('manager:task:list')")
+    @GetMapping("/saveOutTaskSts/{barcode}")
+    @ApiOperation("蹇�熸嫞璐�")
+    public R saveOutTaskSts(@PathVariable String barcode) {
+
+        return pdaOutStockService.saveOutTaskSts(barcode);
     }
 
     @PreAuthorize("hasAuthority('manager:task:list')")
@@ -47,8 +77,75 @@
     @PreAuthorize("hasAuthority('manager:task:list')")
     @PostMapping("/saveWavePick")
     @ApiOperation("鏍规嵁瀹瑰櫒鐮佹煡璇㈡尝娆″強鍑哄簱鍗�")
-    public R saveWavePick(@RequestBody List<ContainerWaveDto> containerWaveDtos) {
+    public R saveWavePick(@RequestBody ContainerWaveParam containerWaveParam) {
 
-        return pdaOutStockService.saveWavePick(containerWaveDtos);
+        return pdaOutStockService.saveWavePick(containerWaveParam,getLoginUserId());
     }
+
+    @PreAuthorize("hasAuthority('manager:task:list')")
+    @PostMapping("/callForEmptyContainers")
+    @ApiOperation("鍛煎彨绌哄鍣�")
+    public R callForEmptyContainers(@RequestBody CallForEmptyContainersParam containerWaveParam) {
+
+        return pdaOutStockService.callForEmptyContainers(containerWaveParam,getLoginUserId());
+    }
+
+//    @PreAuthorize("hasAuthority('manager:outStock:list')")
+    @PostMapping("/outStockItem/page")
+    public R page(@RequestBody JSONObject param) {
+
+        return R.ok().add(outStockItemService.list(new LambdaQueryWrapper<>(WkOrderItem.class).eq(WkOrderItem::getDeleted, 0)
+                .eq(WkOrderItem::getOrderCode, param.getString("orderId"))));
+    }
+
+    @PostMapping("/orderOut/getType")
+    public R orderOutGetType(@RequestBody OrderOutGeneralParam param) {
+        if (Cools.isEmpty(param)){
+            return R.ok();
+        }
+
+        List<DictData> dictData = dictDataService.list(new LambdaQueryWrapper<DictData>()
+                .eq(DictData::getDictTypeCode, DictTypeCode.DICT_SYS_BUSINESS_TYPE)
+                .in(DictData::getValue, param.getType())
+        );
+        return R.ok(dictData);
+    }
+
+    @RequestMapping(value = "/orderOut/list")
+    public R pdaPageList(@RequestParam(required = true)String orderNo,
+                         @RequestParam(defaultValue = "1")Integer curr,
+                         @RequestParam(defaultValue = "5")Integer limit){
+
+        Page<WkOrder> page = new Page<>(curr, limit);
+        LambdaQueryWrapper<WkOrder> wkOrderLambdaQueryWrapper = new LambdaQueryWrapper<>();
+        wkOrderLambdaQueryWrapper.eq(WkOrder::getType, OrderType.ORDER_OUT.type);
+        wkOrderLambdaQueryWrapper.eq(!Cools.isEmpty(orderNo),WkOrder::getCode, orderNo);
+        Page<WkOrder> wkOrderPage = outStockService.page(page, wkOrderLambdaQueryWrapper);
+        return R.ok(wkOrderPage);
+    }
+
+    @RequestMapping(value = "/orderOut/detlList")
+    public R orderOutDetlList(@RequestParam(required = true)String orderNo){
+
+        if (Cools.isEmpty(orderNo)){
+            return R.error("璁㈠崟鍙蜂负绌�");
+        }
+
+        LambdaQueryWrapper<WkOrderItem> wkOrderLambdaQueryWrapper = new LambdaQueryWrapper<>();
+//        wkOrderLambdaQueryWrapper.eq(WkOrderItem::getType, OrderType.ORDER_OUT.type);
+        wkOrderLambdaQueryWrapper.eq(!Cools.isEmpty(orderNo),WkOrderItem::getOrderCode, orderNo);
+        List<WkOrderItem> list = outStockItemService.list(wkOrderLambdaQueryWrapper);
+        return R.ok(list);
+
+    }
+
+    @PostMapping("/orderOut/getOutLocView")
+    public R orderOutGetOutLocView(@RequestBody OrderOutGeneralParam param) {
+        //鍙傛暟 param.getOrderItemId()
+
+        return R.ok();
+    }
+
+
+
 }

--
Gitblit v1.9.1