我正在尝试在 TransAccountForm 的每一行中添加供应商名称。
当 LedgerJournalTrans 中的 LedgerDimension 可用时,我编写了一小段代码来获取供应商名称:
static void GetVendorName(Args _args)
{
CustAccount custAccount;
VendTable vendTable;
LedgerJournalTrans ledgerJournalTrans;
while select ledgerJournalTrans
{
if (ledgerJournalTrans.AccountType == LedgerJournalACType::Vend)
{
custAccount = DimensionStorage::ledgerDimension2AccountNum(LedgerJournalTrans.LedgerDimension);
select firstOnly vendTable
where vendTable.AccountNum == custAccount;
info(strFmt("Vendor Name: %1, Voucher: %2", DirPartyTable::getName(vendTable.Party), ledgerJournalTrans.Voucher));
}
}
}
但是,我怎样才能运行此代码以将新列与供应商名称一起使用?
感谢 Jan B. Kjeldsen,我得到了这个解决方案:
LedgerTransAccount 中的数据源之一是 GeneralJournalEntry,我在其中添加了显示方法。在 SubLedgerVoucher 的帮助下,我可以从 LedgerJournalTrans 获得一行。
public display Name VendorName()
{
Name ret;
LedgerJournalTrans ledgerJournalTrans;
select firstFast firstOnly ledgerJournalTrans
where ledgerJournalTrans.Voucher == this.SubledgerVoucher &&
ledgerJournalTrans.TransDate == this.AccountingDate;
ret = ledgerJournalTrans.AccountType == LedgerJournalACType::Vend ?
vendTable::find(DimensionStorage::ledgerDimension2AccountNum
(ledgerJournalTrans.LedgerDimension)).name() : '';
return ret;
}
在此之后,我只需将此方法拖放到表单的网格上。