647556386
10 小时以前 b5d01891fbbd69d8d50d2b4fb562fac3130fc2d6
ÏîÄ¿´úÂë/WMSÎÞ²Ö´¢°æ/WIDESEA_WMSServer/WIDESEA_OutboundService/OutboundPickingService.cs
@@ -2324,6 +2324,14 @@
            {
                return WebResponseContent.Instance.Error("未找到满足出库条件的出库单");
            }
            if (outboundOrder.DepartmentCode == "虚拟出入库锁定")
            {
                return WebResponseContent.Instance.Error("该单据另一台电脑正在进行虚拟出入库操作,请稍后再试");
            }
            else
            {
                outboundOrder.DepartmentCode = "虚拟出入库锁定";
            }
            if(outboundOrder.IsBatch == 0)
            {
                return WebResponseContent.Instance.Error("该单据不属于分批回传单据,不允许虚拟出入库");
@@ -2334,12 +2342,25 @@
                item.NoStockOutQty = 0;
                item.documentsNO = "";
            }
            _outboundOrderService.UpdateData(outboundOrder);
            _outboundOrderDetailService.UpdateData(outboundOrder.Details);
            return WebResponseContent.Instance.OK("成功");
        }
    public WebResponseContent BarcodeValidate(NoStockOutModel noStockOut)
        public WebResponseContent MovePickingOrders(string outOrder)
        {
            Dt_OutboundOrder outboundOrder = Db.Queryable<Dt_OutboundOrder>().Where(x => x.UpperOrderNo == outOrder).First();
            if (outboundOrder.DepartmentCode == "虚拟出入库锁定")
            {
                outboundOrder.DepartmentCode = "";
            }
            _outboundOrderService.UpdateData(outboundOrder);
            return WebResponseContent.Instance.OK("成功");
        }
        public WebResponseContent BarcodeValidate(NoStockOutModel noStockOut)
    {
        try
        {
@@ -2425,7 +2446,13 @@
                    {
                        return WebResponseContent.Instance.Error($"在出库单中未找到物料{item.MaterielCode}的可出库明细");
                    }
                    // x
                    foreach (var outboundOrderDetail in eligibleOutDetails)
                    {
                        outboundOrderDetail.NoStockOutQty = 0;
                        outboundOrderDetail.documentsNO = "";
                    }
                    _outboundOrderDetailService.UpdateData(eligibleOutDetails);
                    // éåŽ†ç¬¦åˆæ¡ä»¶çš„å‡ºåº“æ˜Žç»†ï¼Œé€è¡Œåˆ†é…æ•°é‡
                    foreach (var outDetail in eligibleOutDetails)
                    {
@@ -2709,12 +2736,58 @@
        {
            try
            {
                Dt_OutboundOrder outboundOrder = _inboundOrderRepository.Db.Queryable<Dt_OutboundOrder>().Where(x => x.UpperOrderNo == noStockOutSubmit.OutOderSubmit && x.OrderStatus != OutOrderStatusEnum.出库完成.ObjToInt()).Includes(x => x.Details).First();
                if (outboundOrder == null)
                {
                    return WebResponseContent.Instance.Error($"未找到出库单:{noStockOutSubmit.OutOderSubmit}");
                }
                // 1. ç­›é€‰å‡ºæœ¬æ¬¡æäº¤æ¡ç å…³è”的出库明细
                List<Dt_OutboundOrderDetail> outboundOrderDetail2 = outboundOrder.Details
                    .Where(x => !string.IsNullOrWhiteSpace(x.documentsNO)
                        && noStockOutSubmit.BarCodeSubmit.Any(barcode =>
                            x.documentsNO.IndexOf(barcode, StringComparison.OrdinalIgnoreCase) >= 0))
                    .ToList();
                HashSet<string> existBarcodes = new HashSet<string>();
                foreach (var detail in outboundOrderDetail2)
                {
                    try
                    {
                        // ååºåˆ—化明细里的条码列表
                        var barcodesInDoc = JsonConvert.DeserializeObject<List<Barcodes>>(detail.documentsNO);
                        if (barcodesInDoc == null) continue;
                        // æŠŠæ¡ç åŠ å…¥åŽ»é‡é›†åˆ
                        foreach (var b in barcodesInDoc)
                        {
                            if (!string.IsNullOrEmpty(b.Barcode))
                                existBarcodes.Add(b.Barcode.Trim());
                        }
                    }
                    catch { }
                }
                // 3. å‰ç«¯æäº¤çš„æ¡ç  â†’ åŽ»é‡
                HashSet<string> submitBarcodes = new HashSet<string>(
                    noStockOutSubmit.BarCodeSubmit
                        .Where(b => !string.IsNullOrEmpty(b))
                        .Select(b => b.Trim())
                );
                // 4. æ‰¾å‡ºã€æäº¤äº†ï¼Œä½†ç³»ç»Ÿé‡Œä¸å­˜åœ¨ã€‘的条码
                var missingBarcodes = submitBarcodes.Except(existBarcodes).ToList();
                // 5. å¦‚果有缺失 â†’ æ‹¦æˆªæŠ¥é”™
                if (missingBarcodes.Any())
                {
                    return WebResponseContent.Instance.Error(
                        $"数据异常,以下条码在出库单中未找到或已被清空:{string.Join(",", missingBarcodes)}"
                    );
                }
                List<Dt_OutboundOrderDetail> outboundOrderDetails = new List<Dt_OutboundOrderDetail>();
                Dictionary<int, List<string>> orderIdBarCodeDict = new Dictionary<int, List<string>>();