From d346400e27af0205539dd61f72dd2cdf40d44ab9 Mon Sep 17 00:00:00 2001
From: skyouc
Date: 星期二, 01 四月 2025 16:35:55 +0800
Subject: [PATCH] 新增任务档

---
 rsf-server/src/main/java/com/vincent/rsf/server/api/service/impl/MobileServiceImpl.java |   87 ++++++++++++++++++++++++++++++++++++++++---
 1 files changed, 81 insertions(+), 6 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 923f464..f970056 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
@@ -6,6 +6,8 @@
 import com.vincent.rsf.framework.exception.CoolException;
 import com.vincent.rsf.server.api.controller.params.OtherReceiptParams;
 import com.vincent.rsf.server.api.controller.params.ReceiptParams;
+import com.vincent.rsf.server.api.entity.dto.InspectDetlDto;
+import com.vincent.rsf.server.api.entity.dto.InspectItemDto;
 import com.vincent.rsf.server.api.entity.dto.ReceiptDetlsDto;
 import com.vincent.rsf.server.api.entity.enums.OrderWorkType;
 import com.vincent.rsf.server.api.service.MobileService;
@@ -14,12 +16,10 @@
 import com.vincent.rsf.server.common.security.JwtSubject;
 import com.vincent.rsf.server.common.utils.CommonUtil;
 import com.vincent.rsf.server.common.utils.JwtUtil;
+import com.vincent.rsf.server.manager.controller.params.WaitPakinParam;
 import com.vincent.rsf.server.manager.entity.*;
 import com.vincent.rsf.server.manager.mapper.*;
-import com.vincent.rsf.server.manager.service.AsnOrderItemLogService;
-import com.vincent.rsf.server.manager.service.AsnOrderLogService;
-import com.vincent.rsf.server.manager.service.WarehouseAreasItemService;
-import com.vincent.rsf.server.manager.service.WarehouseAreasService;
+import com.vincent.rsf.server.manager.service.*;
 import com.vincent.rsf.server.system.constant.CodeRes;
 import com.vincent.rsf.server.system.constant.SerialRuleCode;
 import com.vincent.rsf.server.system.controller.param.LoginParam;
@@ -84,9 +84,17 @@
     private PurchaseItemMapper purchaseItemMapper;
     @Resource
     private FieldsMapper fieldsMapper;
+    @Autowired
+    private IsptHistoriesMapper isptHistoriesMapper;
 
     @Autowired
     private AsnOrderLogService asnOrderLogService;
+
+    @Autowired
+    private WaitPakinService waitPakinService;
+
+    @Autowired
+    private WaitPakinItemService waitPakinItemService;
 
     @Autowired
     private AsnOrderItemLogService asnOrderItemLogService;
@@ -212,6 +220,9 @@
                     .eq(AsnOrderItem::getMatnrId, dto.getMatnrId()));
             if (Objects.isNull(orderItem)) {
                 throw new CoolException("閫氱煡鍗曟槑缁嗕笉瀛樺湪锛侊紒");
+            }
+            if (Objects.isNull(dto.getReceiptQty()) || Double.compare(dto.getReceiptQty(), 0.0) == 0) {
+                throw new CoolException("鏀惰揣鏁伴噺涓嶈兘涓洪浂锛侊紒");
             }
             orderItem.setQty(dto.getReceiptQty())
                     .setProdTime(dto.getProdTime());
@@ -391,6 +402,69 @@
         return fieldsMapper.selectList(new LambdaQueryWrapper<Fields>().eq(Fields::getFlagEnable, 1).eq(Fields::getStatus, 1));
     }
 
+    @Override
+    public R getDeltByCode(String code) {
+        return R.ok(asnOrderItemMapper.selectOne(new LambdaQueryWrapper<AsnOrderItem>().eq(AsnOrderItem::getTrackCode, code)));
+    }
+
+    /**
+     * @author Ryan
+     * @description PDA缁勬嫋
+     * @param
+     * @return
+     * @time 2025/3/29 14:26
+     */
+    @Override
+    public WaitPakin mergeItems(WaitPakinParam waitPakin) {
+        return waitPakinService.mergeItems(waitPakin);
+    }
+
+    @Override
+    public WaitPakin unBind(WaitPakinParam param) {
+        return waitPakinService.unBind(param);
+    }
+
+    /**
+     * 鎶ユ鍔熻兘
+     * @param code
+     * @param loginUserId
+     * @return
+     */
+    @Override
+    public R inspect(String code, Long loginUserId) {
+        AsnOrder asnOrders = asnOrderMapper.selectOne(new LambdaQueryWrapper<AsnOrder>().eq(AsnOrder::getCode, code));
+        if (Objects.isNull(asnOrders)) {
+            throw new CoolException("鍗曟嵁涓嶅瓨鍦紒锛�");
+        }
+        InspectDetlDto detlDto = new InspectDetlDto();
+        detlDto.setCode(asnOrders.getCode()).setPoCode(asnOrders.getPoCode());
+        List<AsnOrderItem> orderItems = asnOrderItemMapper.selectList(new LambdaQueryWrapper<AsnOrderItem>().eq(AsnOrderItem::getAsnCode, code));
+        if (orderItems.isEmpty()) {
+            detlDto.setItems(new ArrayList<>());
+        } else {
+            List<InspectItemDto> itemDtos = new ArrayList<>();
+            orderItems.forEach(dto -> {
+                InspectItemDto itemDto = new InspectItemDto();
+                if (!Objects.isNull(dto.getMatnrCode())) {
+                    Matnr matnr = matnrMapper.selectOne(new LambdaQueryWrapper<Matnr>().eq(Matnr::getCode, dto.getMatnrCode()));
+                    itemDto.setGroup(matnr.getGroupCode());
+                }
+                itemDto.setMaktx(dto.getMaktx())
+                        .setMatnrCode(dto.getMatnrCode())
+                        .setPurUnit(dto.getPurUnit())
+                        .setSuplierCode(dto.getSplrCode())
+                        .setSuplierName(dto.getSplrName())
+                        .setPurQty(dto.getPurQty());
+                itemDtos.add(itemDto);
+            });
+            detlDto.setItems(itemDtos);
+        }
+
+        List<IsptHistories> histories = isptHistoriesMapper.selectList(new LambdaQueryWrapper<IsptHistories>().eq(IsptHistories::getAsnId, asnOrders.getId()));
+        detlDto.setHistories(histories);
+        return R.ok(detlDto);
+    }
+
     /**
      * 鑾峰彇ReceiptDetlsDtos
      */
@@ -401,7 +475,8 @@
 
             detlsDto.setAsnCode(asnOrderItem.getAsnCode())
                     .setMaktx(asnOrderItem.getMaktx())
-                    .setBarcode(asnOrderItem.getBarcode())
+                    .setBarcode(asnOrderItem.getTrackCode())
+                    .setQty(asnOrderItem.getQty())
                     .setPoCode(asnOrderItem.getPoCode())
                     .setAnfme(asnOrderItem.getAnfme())
                     .setPurQty(asnOrderItem.getPurQty())
@@ -416,7 +491,7 @@
                     .setMatnrId(matnr.getId())
                     .setStockUnit(matnr.getStockUnit());
             QlyInspect inspect = qlyInspectMapper.selectOne(new LambdaQueryWrapper<QlyInspect>()
-                    .eq(QlyInspect::getAsnItemId, asnOrderItem.getId()));
+                    .eq(QlyInspect::getAsnId, asnOrderItem.getAsnId()));
             if (!Objects.isNull(inspect)) {
                 //set 璐ㄦ缁撴灉
                 detlsDto.setInspect(inspect.getStatus$());

--
Gitblit v1.9.1