Error: Reference Nbr. cannot be found in the system.."}

Error: Reference Nbr. cannot be found in the system.."}

我自定义了 ARPaymentEntry,它在其中创建了带有创建的贷记凭证的日记帐凭单分录,它检索贷记凭证应用也应用于当前付款的未清发票。当我创建调用 Credit Memo 的实例并在 ARAdjust table 中添加 Invoice 时,尝试插入它时发生错误,在系统中找不到 Reference 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);
        }
    }

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

我发现在执行下面的代码后它不会立即更新视图。所以我所做的是在 ARPayment_RowSelected 事件中执行我的代码,如果文档已发布,则带有条件语句。

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