diff --git a/src/app-gocardless/banks/ANDELSKASSEN_FALLESKASSEN_FAELDKK1.js b/src/app-gocardless/banks/ANDELSKASSEN_FALLESKASSEN_FAELDKK1.js index 79d263f39..2215f0ccc 100644 --- a/src/app-gocardless/banks/ANDELSKASSEN_FALLESKASSEN_FAELDKK1.js +++ b/src/app-gocardless/banks/ANDELSKASSEN_FALLESKASSEN_FAELDKK1.js @@ -1,60 +1,60 @@ import { - printIban, - amountToInteger, - sortByBookingDateOrValueDate, - } from '../utils.js'; - - /** @type {import('./bank.interface.js').IBank} */ - export default { - institutionIds: ['ANDELSKASSEN_FALLESKASSEN_FAELDKK1'], - - normalizeAccount(account) { - return { - account_id: account.resourceId, - institution: account.institution, - mask: account.iban.slice(-4), - iban: account.iban, - name: [account.name, printIban(account)].join(' '), - official_name: account.product, - type: 'checking', - }; - }, - - /** - * Following the GoCardless documentation[0] we should prefer `bookingDate` - * here, though some of their bank integrations uses the date field - * differently from what's describen in their documentation and so it's - * sometimes necessary to use `valueDate` instead. - * - * [0]: https://nordigen.zendesk.com/hc/en-gb/articles/7899367372829-valueDate-and-bookingDate-for-transactions - */ - normalizeTransaction(transaction, _booked) { - return { - ...transaction, - date: transaction.bookingDate, - remittanceInformationUnstructured: transaction.additionalInformation, - }; - }, - - sortTransactions(transactions = []) { - return sortByBookingDateOrValueDate(transactions); - }, - - /** - * For SANDBOXFINANCE_SFIN0000 we don't know what balance was - * after each transaction so we have to calculate it by getting - * current balance from the account and subtract all the transactions - * - * As a current balance we use `interimBooked` balance type because - * it includes transaction placed during current day - */ - calculateStartingBalance(sortedTransactions = [], balances = []) { - const currentBalance = balances.find( - (balance) => 'closingBooked' === balance.balanceType, - ); - - return sortedTransactions.reduce((total, trans) => { - return total - amountToInteger(trans.transactionAmount.amount); - }, amountToInteger(currentBalance.balanceAmount.amount)); - }, - }; \ No newline at end of file + printIban, + amountToInteger, + sortByBookingDateOrValueDate +} from '../utils.js' + +/** @type {import('./bank.interface.js').IBank} */ +export default { + institutionIds: ['ANDELSKASSEN_FALLESKASSEN_FAELDKK1'], + + normalizeAccount (account) { + return { + account_id: account.resourceId, + institution: account.institution, + mask: account.iban.slice(-4), + iban: account.iban, + name: [account.name, printIban(account)].join(' '), + official_name: account.product, + type: 'checking' + } + }, + + /** + * Following the GoCardless documentation[0] we should prefer `bookingDate` + * here, though some of their bank integrations uses the date field + * differently from what's describen in their documentation and so it's + * sometimes necessary to use `valueDate` instead. + * + * [0]: https://nordigen.zendesk.com/hc/en-gb/articles/7899367372829-valueDate-and-bookingDate-for-transactions + */ + normalizeTransaction (transaction, _booked) { + return { + ...transaction, + date: transaction.bookingDate, + remittanceInformationUnstructured: transaction.additionalInformation + } + }, + + sortTransactions (transactions = []) { + return sortByBookingDateOrValueDate(transactions) + }, + + /** + * For SANDBOXFINANCE_SFIN0000 we don't know what balance was + * after each transaction so we have to calculate it by getting + * current balance from the account and subtract all the transactions + * + * As a current balance we use `interimBooked` balance type because + * it includes transaction placed during current day + */ + calculateStartingBalance (sortedTransactions = [], balances = []) { + const currentBalance = balances.find( + balance => 'closingBooked' === balance.balanceType + ) + + return sortedTransactions.reduce((total, trans) => { + return total - amountToInteger(trans.transactionAmount.amount) + }, amountToInteger(currentBalance.balanceAmount.amount)) + } +}