This extension contains modifications to the standard solution to enable enhancements on Bank Accounts and Vendor Bank Accounts in Business Central.

Enhancements included:

  1. Customer Preferred Bank Accounts
  2. Vendor Bank Account Enhancements
  3. Bank Account Card Enhancements
  4. Restrictions on Payment Journals
  5. Bank Account Reconciliation Enhancements

1. Customer Preferred Bank Accounts

Summary:

This feature allows users to specify and manage preferred bank accounts for customers based on currency. It integrates with reports to display the preferred bank account information and provides actions in the Customer List page to manage these accounts.

Components:

  • Table: CustPrefBankAccount_BANK_LINC
  • Page: CustPrefBankAccounts_BANK_LINC
  • Page Extension: CustomerList_BANK_LINC
  • Procedure: GetPreferredBankAccount_BANK_LINC
  • Report Extension: StdSalesInv_BANK_LINC
  • Report Extension: StdSalesProFormaInv_BANK_LINC
  • Report Extension: StdStatement_BANK_LINC
  • Report Extension: SalesOrderConf_BANK_LINC
  • Report Extension: SalesCreditMemo_BANK_LINC
  • Report Extension: StdSalesDraftInv_BANK_LINC
  • Report Extension: StdSalesQuote_BANK_LINC

Explanation:

  • Table: Stores preferred bank account information for customers.
  • Page: Allows users to view and manage preferred bank accounts.
  • Page Extension: Adds a “Preferred Bank Accounts” action to the Customer List page.
  • Procedure: Retrieves preferred bank account details for a given customer and currency code.
  • Report Extensions: Add preferred bank account details to report datasets for Standard Sales Invoice, Sales Credit Memo, Sales Order Confirmation, Customer Statement, Pro-Forma Invoice, Sales Draft Invoice, Sales Quote.

2. Vendor Bank Account Enhancements

Summary:

Enhances various pages by displaying vendor bank account information in a factbox and adding a field for bank branch names in the Vendor Bank Account List page.

Components:

  • Page Extension: PostedPurchInvoices_BANK_LINC
  • Page Extension: PurchaseInvoices_BANK_LINC
  • Page Extension: PurchInvoice_BANK_LINC
  • Page Extension: VendorLedgerEntries_BANK_LINC
  • Page Extension: VendorBankAccList_BANK_LINC

Explanation:

  • Page Extensions: Add a factbox to display vendor bank account information on various pages, including Posted Purchase Invoices, Purchase Invoices, Purchase Invoice, and Vendor Ledger Entries.
  • Page Extension: Adds a field for “Bank Branch Name” to the Vendor Bank Account List page.

3. Bank Account Card Enhancements

Summary:

Enhances the Bank Account Card page by adding fields for direct transfer batch limits and Netcash service keys. It also enhances the General Ledger Setup and Bank Export/Import Setup pages by adding fields related to bank branch codes and file types. Supports various bank export formats through dedicated codeunits. The following South African banking institutions are supported: FNB, ABSA, Standard Bank, Nedbank, Capitec, Netcash.

Components:

  • Page Extension: BankAccountCard_BANK_LINC
  • Page Extension: GeneralLedgerSetup_BANK_LINC
  • Page Extension: BankExpImpSetup_BANK_LINC
  • Codeunit: BankExportFormat_BANK_LINC
  • Codeunit: EFTExportFNB_BANK_LINC
  • Codeunit: EFTExportABSA_BANK_LINC
  • Codeunit: EFTExportSTD_BANK_LINC
  • Codeunit: EFTExportNED_BANK_LINC
  • Codeunit: EFTExportCapitec_BANK_LINC
  • Codeunit: EFTExportNetcash_BANK_LINC

Explanation:

  • Page Extension: Adds fields for “Direct Tfr. Batch Limit” and “Netcash Service Key” to the Bank Account Card page.
  • Page Extension: Adds a field to enable the use of the Bank Branch List for selecting/capturing branch codes in the General Ledger Setup page.
  • Page Extension: Adds a field for specifying the bank export/import file type in the Bank Export/Import Setup page.
  • Codeunit: Supports various bank export formats, including:
    • Codeunit: BankExportFormat1_BANK_LINC
    • Codeunit: BankExportFormat2_BANK_LINC
    • Codeunit: BankExportFormat3_BANK_LINC

4. Restrictions on Payment Journals

Summary:

Enforces restrictions on payment journals based on the app subscription status and ensures compliance with direct transfer limits.

Components:

  • Codeunit: Subscriptions_BANK_LINC

Explanation:

  • Event Subscribers: Prevent certain actions related to payment journals if the app subscription is not active.
  • Procedure: CheckBankEFTLimit: Ensures that the total amount of a payment journal batch does not exceed the predefined direct transfer limit.

5. Bank Account Reconciliation Enhancements

Summary:

Enhances the bank account reconciliation process by ensuring that the general and VAT product posting groups are correctly updated and validated.

Components:

  • Event Subscriber: BankAccReconciliationLine_OnAfterValidateEvent_AccountNo
  • Event Subscriber: BankAccReconciliationPost_OnPostPaymentApplicationsOnBeforeValidateApplyRequirements

Explanation:

  • Event Subscriber: Updates the Gen. Prod. Posting Group and VAT Prod. Posting Group fields in the Bank Acc. Reconciliation Line table when the Account No. field is validated.
  • Event Subscriber: Ensures that the Gen. Prod. Posting Group and VAT Prod. Posting Group fields in the Gen. Journal Line table match those in the Bank Acc. Reconciliation Line table during the posting of payment applications.

All public facing object definitions can be found here: Public Objects