From 3217d11481d7440f1526499d14a0c398369aa0e2 Mon Sep 17 00:00:00 2001
From: zjj <3272660260@qq.com>
Date: 星期三, 30 四月 2025 14:22:35 +0800
Subject: [PATCH] Merge remote-tracking branch 'origin/devlop' into devlop

---
 rsf-server/src/main/java/com/vincent/rsf/server/api/service/impl/MobileServiceImpl.java |   89 +++++++++++++++++++++++++++++++++++++++++---
 1 files changed, 82 insertions(+), 7 deletions(-)

diff --git a/rsf-server/src/main/java/com/vincent/rsf/server/api/service/impl/MobileServiceImpl.java b/rsf-server/src/main/java/com/vincent/rsf/server/api/service/impl/MobileServiceImpl.java
index 7006ac5..688e1a5 100644
--- a/rsf-server/src/main/java/com/vincent/rsf/server/api/service/impl/MobileServiceImpl.java
+++ b/rsf-server/src/main/java/com/vincent/rsf/server/api/service/impl/MobileServiceImpl.java
@@ -17,6 +17,7 @@
 import com.vincent.rsf.server.common.utils.CommonUtil;
 import com.vincent.rsf.server.common.utils.FieldsUtils;
 import com.vincent.rsf.server.common.utils.JwtUtil;
+import com.vincent.rsf.server.manager.controller.params.GenerateTaskParams;
 import com.vincent.rsf.server.manager.controller.params.IsptItemsParams;
 import com.vincent.rsf.server.manager.controller.params.WaitPakinParam;
 import com.vincent.rsf.server.manager.entity.*;
@@ -123,6 +124,8 @@
     private LocAreaRelaMapper locAreaRelaMapper;
     @Autowired
     private LocAreaMapper locAreaMapper;
+    @Autowired
+    private DeviceSiteMapper deviceSiteMapper;
 
     /**
      * @author Ryan
@@ -180,15 +183,16 @@
     }
 
     /**
+     * @param params
+     * @param loginUserId
+     * @return
      * @author Ryan
      * @description 鏀惰揣鑷虫敹璐у尯
-     * @param  params
-     * @return
      * @time 2025/3/10 15:41
      */
     @Override
     @Transactional(rollbackFor = Exception.class)
-    public R receiptToWarehouse(Map<String, Object> params) {
+    public R receiptToWarehouse(Map<String, Object> params, Long loginUserId) {
         if (Objects.isNull(params)) {
             throw new CoolException("鍙傛暟涓嶈兘涓虹┖锛侊紒");
         }
@@ -231,7 +235,7 @@
         }
         List<Map<String, Object>> receipts1 = (List<Map<String, Object>>) params.get("receipts");
         for (Map<String, Object> rcpt : receipts1) {
-            if (Objects.isNull(rcpt)) {continue;}
+            if (null == rcpt || Objects.isNull(rcpt)) {continue;}
             ReceiptDetlsDto dto = JSONObject.parseObject(JSONObject.toJSONString(rcpt), ReceiptDetlsDto.class);
             Matnr matnr = matnrMapper.selectById(dto.getMatnrId());
             if (Objects.isNull(matnr)) {
@@ -245,6 +249,7 @@
 //            }
             AsnOrderItem orderItem = asnOrderItemMapper.selectOne(new LambdaQueryWrapper<AsnOrderItem>()
                     .eq(AsnOrderItem::getAsnCode, asnCode)
+                            .eq(AsnOrderItem::getTrackCode, dto.getBarcode())
                     .eq(AsnOrderItem::getMatnrId, dto.getMatnrId()));
             if (Objects.isNull(orderItem)) {
                 throw new CoolException("閫氱煡鍗曟槑缁嗕笉瀛樺湪锛侊紒");
@@ -296,6 +301,8 @@
                     .setAnfme(dto.getReceiptQty())
                     .setSplrBatch(dto.getSplrBatch())
                     .setMatnrCode(matnr.getCode())
+                    .setUpdateBy(loginUserId)
+                    .setCreateBy(loginUserId)
                     .setMatnrId(matnr.getId())
                     .setMaktx(matnr.getName())
                     //搴撳瓨鍗曚綅涓烘渶灏忓崟浣�
@@ -618,7 +625,7 @@
                 .eq(AsnOrder::getId, OrderId)
                 .eq(AsnOrder::getType, OrderType.ORDER_PLAT_IN.type));
         if (Objects.isNull(order)) {
-            throw new CoolException("鍗曟嵁涓嶅瓨鍦紒锛�");
+            throw new CoolException("闈炲钩搴撳崟鎹笉鍙墽琛屼汉宸ヤ笂鏋讹紒锛�");
         }
         Stock stock = new Stock();
 //        if (!Objects.isNull(order.getPoCode()) && StringUtils.isNotBlank(order.getPoCode())) {
@@ -650,7 +657,9 @@
         itemList.forEach(asnOrderItem -> {
             LocItem item = new LocItem();
             BeanUtils.copyProperties(asnOrderItem, item);
-            item.setId(loc.getId())
+            item.setLocId(loc.getId())
+                    .setId(null)
+                    .setLocCode(loc.getCode())
                     .setOrderId(order.getId())
                     .setOrderItemId(asnOrderItem.getId())
                     .setWkType(Short.parseShort(order.getWkType()))
@@ -822,6 +831,71 @@
     }
 
     /**
+     * @author Ryan
+     * @description 鑾峰彇鍏ュ簱缁勬嫋淇℃伅
+     * @param barcode
+     * @return
+     */
+    @Override
+    public R getPakinInStock(String barcode) {
+        WaitPakin waitPakin = waitPakinService.getOne(new LambdaQueryWrapper<WaitPakin>().eq(WaitPakin::getBarcode, barcode));
+        if (Objects.isNull(waitPakin)) {
+            throw new CoolException("缁勬嫋鍗曟嵁涓嶅瓨鍦紒锛�");
+        }
+        List<WaitPakinItem> pakinItems = waitPakinItemService.list(new LambdaQueryWrapper<WaitPakinItem>().eq(WaitPakinItem::getPakinId, waitPakin.getId()));
+        if (pakinItems.isEmpty()) {
+            return R.ok(new ArrayList<>());
+        }
+        return R.ok(pakinItems);
+    }
+
+    /**
+     * @author Ryan
+     * @description 鑾峰彇搴撳彛绔欑偣淇℃伅
+     * @return
+     */
+    @Override
+    public R getDeviceSites() {
+        List<DeviceSite> sites = deviceSiteMapper.selectList(new LambdaQueryWrapper<DeviceSite>()
+                        .select(DeviceSite::getId, DeviceSite::getSite, DeviceSite::getName)
+                .eq(DeviceSite::getStatus, 1)
+                .groupBy(DeviceSite::getSite, DeviceSite::getId, DeviceSite::getName));
+        return R.ok(sites);
+    }
+
+    /**
+     * @author Ryan
+     * @description 鑾峰彇鎺ㄨ崘搴撲綅
+     * @return
+     */
+    @Override
+    public R getRecommondLocs() {
+        return R.ok(locService.list(new LambdaQueryWrapper<Loc>().last("limit 10")));
+    }
+
+    /**
+     * @param map
+     * @param loginUserId
+     * @return
+     * @author Ryan
+     * @description 鐢熸垚浠诲姟鍒楄〃
+     */
+    @Override
+    public R generateTask(Map<String, Object> map, Long loginUserId) {
+        String barcode = map.get("barcode").toString();
+        List<WaitPakin> waitPakins = waitPakinService.list(new LambdaQueryWrapper<WaitPakin>().eq(WaitPakin::getBarcode, barcode));
+        if (waitPakins.isEmpty()) {
+            throw new CoolException("鍗曟嵁涓嶅瓨鍦� 锛侊紒");
+        }
+        GenerateTaskParams taskParams = new GenerateTaskParams();
+        taskParams.setWaitPakins(waitPakins)
+                .setSiteId(Long.parseLong(map.get("site").toString()))
+                .setLocCode(map.get("locCode").toString());
+        return R.ok(taskService.generateTasks(taskParams, loginUserId));
+
+    }
+
+    /**
      * 鑾峰彇ReceiptDetlsDtos
      */
     private R getAsnOrderItem(List<AsnOrderItem> items) {
@@ -855,7 +929,8 @@
             }
             //鑾峰彇褰撳墠搴撳瓨淇℃伅
             LocItem stockItem = locItemService.getOne(new LambdaQueryWrapper<LocItem>()
-                    .eq(LocItem::getOrderItemId, asnOrderItem.getId())
+//                    .eq(LocItem::getOrderItemId, asnOrderItem.getId())
+                            .eq(LocItem::getFieldsIndex, asnOrderItem.getFieldsIndex())
                     .eq(LocItem::getBatch, asnOrderItem.getBatch())
                     .eq(LocItem::getMatnrId, asnOrderItem.getMatnrId()));
             //SET 褰撳墠搴撳瓨鏁伴噺

--
Gitblit v1.9.1