From 80eea49cf0bf9db438eb85af7cd22aeb11fbfed2 Mon Sep 17 00:00:00 2001 From: CodeShakingSheep <19874562+CodeShakingSheep@users.noreply.github.com> Date: Mon, 16 Dec 2024 08:59:00 -0500 Subject: [PATCH] fix(Invoice Ninja Node): Fix actions for bank transactions (#11511) --- .../BankTransactionDescription.ts | 11 +++++ .../InvoiceNinja/BankTransactionInterface.ts | 7 +++- .../nodes/InvoiceNinja/InvoiceNinja.node.ts | 40 ++++++++++++++++--- 3 files changed, 51 insertions(+), 7 deletions(-) diff --git a/packages/nodes-base/nodes/InvoiceNinja/BankTransactionDescription.ts b/packages/nodes-base/nodes/InvoiceNinja/BankTransactionDescription.ts index abf39ab493..75c3f6dbf6 100644 --- a/packages/nodes-base/nodes/InvoiceNinja/BankTransactionDescription.ts +++ b/packages/nodes-base/nodes/InvoiceNinja/BankTransactionDescription.ts @@ -97,6 +97,17 @@ export const bankTransactionFields: INodeProperties[] = [ ], default: '', }, + { + displayName: 'Currency Name or ID', + name: 'currencyId', + type: 'options', + description: + 'Choose from the list, or specify an ID using an expression', + typeOptions: { + loadOptionsMethod: 'getCurrencies', + }, + default: '', + }, { displayName: 'Date', name: 'date', diff --git a/packages/nodes-base/nodes/InvoiceNinja/BankTransactionInterface.ts b/packages/nodes-base/nodes/InvoiceNinja/BankTransactionInterface.ts index 735f339ab8..385009aec6 100644 --- a/packages/nodes-base/nodes/InvoiceNinja/BankTransactionInterface.ts +++ b/packages/nodes-base/nodes/InvoiceNinja/BankTransactionInterface.ts @@ -2,8 +2,13 @@ export interface IBankTransaction { amount?: number; bank_integration_id?: number; base_type?: string; + currency_id?: number; date?: string; description?: string; id?: string; - paymentId?: string; + payment_id?: string; +} + +export interface IBankTransactions { + transactions: IBankTransaction[]; } diff --git a/packages/nodes-base/nodes/InvoiceNinja/InvoiceNinja.node.ts b/packages/nodes-base/nodes/InvoiceNinja/InvoiceNinja.node.ts index ef7494d306..f587701296 100644 --- a/packages/nodes-base/nodes/InvoiceNinja/InvoiceNinja.node.ts +++ b/packages/nodes-base/nodes/InvoiceNinja/InvoiceNinja.node.ts @@ -38,7 +38,7 @@ import { isoCountryCodes } from '@utils/ISOCountryCodes'; import { bankTransactionFields, bankTransactionOperations } from './BankTransactionDescription'; -import type { IBankTransaction } from './BankTransactionInterface'; +import type { IBankTransaction, IBankTransactions } from './BankTransactionInterface'; export class InvoiceNinja implements INodeType { description: INodeTypeDescription = { @@ -295,7 +295,7 @@ export class InvoiceNinja implements INodeType { } return returnData; }, - // Get all the available users to display them to user so that they can + // Get all the matchable payments to display them to user so that they can // select them easily async getPayments(this: ILoadOptionsFunctions): Promise { const returnData: INodePropertyOptions[] = []; @@ -322,6 +322,29 @@ export class InvoiceNinja implements INodeType { } return returnData; }, + // Get all the currencies to display them to user so that they can + // select them easily + async getCurrencies(this: ILoadOptionsFunctions): Promise { + const returnData: INodePropertyOptions[] = []; + + const statics = await invoiceNinjaApiRequestAllItems.call(this, 'data', 'GET', '/statics'); + + Object.entries(statics) + .filter(([key]) => key === 'currencies') + .forEach(([key, value]) => { + if (key === 'currencies' && Array.isArray(value)) { + for (const currency of value) { + const currencyName = [currency.number, currency.code].filter((e) => e).join(' - '); + const currencyId = currency.id as string; + returnData.push({ + name: currencyName, + value: currencyId, + }); + } + } + }); + return returnData; + }, }, }; @@ -986,6 +1009,9 @@ export class InvoiceNinja implements INodeType { if (additionalFields.client) { body.date = additionalFields.date as string; } + if (additionalFields.currencyId) { + body.currency_id = additionalFields.currencyId as number; + } if (additionalFields.email) { body.description = additionalFields.description as string; } @@ -1054,18 +1080,20 @@ export class InvoiceNinja implements INodeType { if (operation === 'matchPayment') { const bankTransactionId = this.getNodeParameter('bankTransactionId', i) as string; const paymentId = this.getNodeParameter('paymentId', i) as string; - const body: IBankTransaction = {}; + const body: IBankTransactions = { transactions: [] }; + const bankTransaction: IBankTransaction = {}; if (bankTransactionId) { - body.id = bankTransactionId; + bankTransaction.id = bankTransactionId as string; } if (paymentId) { - body.paymentId = paymentId; + bankTransaction.payment_id = paymentId as string; } + body.transactions.push(bankTransaction); responseData = await invoiceNinjaApiRequest.call( this, 'POST', `${resourceEndpoint}/match`, - body as IDataObject, + body as unknown as IDataObject, ); } }