cl
19 小时以前 2fa1c824c63048b49e45d867191ab3645aeaf3a4
补充收货
2个文件已修改
75 ■■■■■ 已修改文件
rsf-server/src/main/java/com/vincent/rsf/server/api/service/impl/MobileServiceImpl.java 13 ●●●● 补丁 | 查看 | 原始文档 | blame | 历史
rsf-server/src/main/java/com/vincent/rsf/server/api/service/impl/ReceiveMsgServiceImpl.java 62 ●●●●● 补丁 | 查看 | 原始文档 | blame | 历史
rsf-server/src/main/java/com/vincent/rsf/server/api/service/impl/MobileServiceImpl.java
@@ -558,6 +558,12 @@
        String code = params.get("code");
        String matnrCode = params.get("matnrCode");
        String asnCode = params.get("asnCode");
        if (asnCode != null) {
            asnCode = asnCode.trim();
            if (asnCode.isEmpty()) {
                asnCode = null;
            }
        }
        String crushNo = params.get("fieldsIndex");
        String batch = params.get("batch");
//        String barcode = params.get("barcode");
@@ -635,14 +641,15 @@
            return R.ok(resultList);
        }
        
        // 有ASN单号时:仅在单据存在时按单据限制组托
        // 有 WMS 单号时:必须能精确命中单据,否则直接返回空(避免落入无单号分支后 queryWrapper 无条件查全表收货区)
        WkOrder asnOrder = null;
        if (!Cools.isEmpty(asnCode)) {
            asnOrder = asnOrderMapper.getOne(new LambdaQueryWrapper<WkOrder>().eq(WkOrder::getCode, asnCode));
            if (asnOrder == null) {
                logger.info("未找到ASN单号: {},按无单据组托模式返回物料信息", asnCode);
                asnCode = null;
                logger.info("未找到WMS单号: {},返回空列表", asnCode);
                return R.ok(new ArrayList<>());
            }
            asnCode = asnOrder.getCode();
        }
        // 有ASN单号且单据存在时:DirectWaitPakin 启用则从收货区查可组托物料,未启用则从订单明细查
rsf-server/src/main/java/com/vincent/rsf/server/api/service/impl/ReceiveMsgServiceImpl.java
@@ -24,6 +24,7 @@
import com.vincent.rsf.server.manager.entity.*;
import com.vincent.rsf.server.manager.enums.*;
import com.vincent.rsf.server.manager.service.*;
import com.vincent.rsf.server.manager.schedules.ScheduleJobs;
import com.vincent.rsf.server.system.constant.DictTypeCode;
import com.vincent.rsf.server.system.constant.GlobalConfigCode;
import com.vincent.rsf.server.system.constant.SerialRuleCode;
@@ -123,6 +124,10 @@
    private TaskService taskService;
    @Autowired
    private CusBarcodeSyncMatnrService cusBarcodeSyncMatnrService;
    @Autowired
    private ScheduleJobs scheduleJobs;
    @Autowired
    private OutStockService outStockService;
    /**
     * 云仓改单/取消前:任务明细已关联该单据且主任务未逻辑删除则不允许
@@ -630,9 +635,66 @@
        if (!asnOrderService.updateById(wkOrder)) {
            throw new CoolException("计划收货数量修改失败!!");
        }
        directReceiptInboundAfterCloudSync(wkOrder, loginUserId);
        return "Success";
    }
    /**
     * DirectWaitPakin 开启时,云仓新增入库通知单成功后立即写入收货区,并将完成数量与计划数对齐(与 {@link ScheduleJobs#IgnoreReceipt} 一致,避免仅依赖定时任务延迟)。
     */
    private void directReceiptInboundAfterCloudSync(WkOrder wkOrder, Long loginUserId) {
        if (!isDirectWaitPakin() || wkOrder == null || wkOrder.getId() == null) {
            return;
        }
        if (!OrderType.ORDER_IN.type.equals(wkOrder.getType())) {
            return;
        }
        if (OrderWorkType.ORDER_WORK_TYPE_OTHER_TERANSFER.type.equals(wkOrder.getWkType())) {
            WkOrder one = outStockService.getOne(new LambdaQueryWrapper<WkOrder>()
                    .eq(WkOrder::getPoId, wkOrder.getPoId())
                    .eq(WkOrder::getWkType, OrderWorkType.ORDER_WORK_TYPE_STOCK_TERANSFER.type));
            if (one == null || !Objects.equals(AsnExceStatus.OUT_STOCK_STATUS_TASK_DONE.val, one.getExceStatus())) {
                return;
            }
        }
        WarehouseAreas receiptArea = warehouseAreasService.getOne(
                new LambdaQueryWrapper<WarehouseAreas>()
                        .eq(WarehouseAreas::getType, WarehouseAreasType.WAREHOUSE_AREAS_TYPE_RECEIPT.type), false);
        if (receiptArea == null) {
            log.warn("directReceiptInboundAfterCloudSync: 未配置收货区,跳过 orderId={}", wkOrder.getId());
            return;
        }
        List<WkOrderItem> orderItems = asnOrderItemService.list(
                new LambdaQueryWrapper<WkOrderItem>().eq(WkOrderItem::getOrderId, wkOrder.getId()));
        if (orderItems.isEmpty()) {
            return;
        }
        for (WkOrderItem item : orderItems) {
            Matnr matnr = matnrService.getOne(new LambdaQueryWrapper<Matnr>().eq(Matnr::getId, item.getMatnrId()));
            if (matnr == null) {
                throw new CoolException("物料不存在:" + item.getMatnrCode());
            }
            try {
                scheduleJobs.updateReceipt(receiptArea, item, wkOrder, matnr);
            } catch (Exception e) {
                throw new CoolException(e.getMessage());
            }
            if (!asnOrderItemService.update(new LambdaUpdateWrapper<WkOrderItem>()
                    .set(WkOrderItem::getQty, item.getAnfme())
                    .eq(WkOrderItem::getId, item.getId()))) {
                throw new CoolException("收货单明细完成数量修改失败!!");
            }
        }
        if (!asnOrderService.update(new LambdaUpdateWrapper<WkOrder>()
                .set(WkOrder::getQty, wkOrder.getAnfme())
                .set(WkOrder::getExceStatus, AsnExceStatus.ASN_EXCE_STATUS_RECEIPT_DONE.val)
                .set(WkOrder::getUpdateBy, loginUserId)
                .set(WkOrder::getUpdateTime, new Date())
                .eq(WkOrder::getId, wkOrder.getId()))) {
            throw new CoolException("收货单状态修改失败!!");
        }
    }
    /** 与 updateOrderNoPakin / mergeOrderWithPakin 写入规则一致;无有效变更时返回 null */
    private String computeWkOrderModifyChangeSummaryOrNull(WkOrder order, SyncOrderParams syncOrder,
            String resolvedOrderType, String typeCode, boolean mergeStyleAllowEmptyItems) {