错误:在系统中找不到参考 Nbr..."}



我自定义了ARPaymentEntry,其中它使用创建的贷项通知单创建日记帐凭证条目,它检索贷项通知单应用也应用于当前付款的未结发票。 当我创建实例以调用贷项通知单并在 ARAdjust 表中添加发票时,尝试插入它时出错, 在系统中找不到提供参考 Nbr,尽管当我尝试手动应用它时,我可以看到未结发票。

    public void ReleaseCreditMemo(string refNbr)
    {
        try
        {
            ARPaymentEntry docGraph = PXGraph.CreateInstance<ARPaymentEntry>();
            List<ARRegister> list = new List<ARRegister>();
            ARPayment payment;
            ARRegister invoice = PXSelect<ARRegister, Where<ARRegister.docType, Equal<Required<ARRegister.docType>>, And<ARRegister.refNbr, Equal<Required<ARRegister.refNbr>>>>>.Select(docGraph, ARInvoiceType.CreditMemo, refNbr);
            docGraph.Document.Current = PXSelect<ARPayment, Where<ARPayment.docType, Equal<Required<ARPayment.docType>>, And<ARPayment.refNbr, Equal<Required<ARPayment.refNbr>>>>>.Select(docGraph, ARInvoiceType.CreditMemo, refNbr);
            payment = docGraph.Document.Current;
            list.Add(payment);
            foreach (ISARWhTax item in ARWhLine.Select())
            {
                decimal? _CuryAdjgAmt = payment.CuryOrigDocAmt > invoice.CuryDocBal ? invoice.CuryDocBal : payment.CuryOrigDocAmt;
                decimal? _CuryAdjgDiscAmt = payment.CuryOrigDocAmt > invoice.CuryDocBal ? 0m : invoice.CuryDiscBal;
                ARAdjust adj = new ARAdjust();
                adj.AdjdBranchID = item.AdjdBranchID;
                adj.AdjdDocType = ARInvoiceType.Invoice;
                adj.AdjdRefNbr = item.AdjdRefNbr;
                adj.AdjdCustomerID = item.CustomerID;
                adj.AdjdDocDate = invoice.DocDate;
                adj.CuryAdjgAmt = _CuryAdjgAmt;
                adj.CuryAdjdDiscAmt = _CuryAdjgDiscAmt;
                if (docGraph.Document.Current.CuryUnappliedBal == 0m && docGraph.Document.Current.CuryOrigDocAmt > 0m)
                {
                    throw new PXLoadInvoiceException();
                }
                //This line code below OCCURS THE ERROR
                docGraph.Adjustments.Insert(adj);
            }
            docGraph.Save.Press();
            PXLongOperation.StartOperation(docGraph, delegate() { ARDocumentRelease.ReleaseDoc(list, false); });
        }
        catch (Exception ex)
        {
            throw new PXException(ex.Message);
        }
    }

我会查看导致错误的字段的选择器("引用 Nbr."),因为在字段上有一个选择器将验证输入到选择器的 select 语句的值(除非选择器的 validatevalue=false)。也许选择器会给你一些关于缺少什么或导致验证失败的指示。

我想通了,在

下面的代码执行后,它不会立即更新视图。所以我所做的是在发布文档时ARPayment_RowSelected事件中使用条件语句执行我的代码。

 PXLongOperation.StartOperation(this.Base, delegate() { ARDocumentRelease.ReleaseDoc(list, false); });

最新更新