import { INodeProperties } from 'n8n-workflow';
export const accountOperations: INodeProperties[] = [
{
displayName: 'Operation',
name: 'operation',
type: 'options',
noDataExpression: true,
default: 'getBalances',
options: [
{
name: 'Get Balances',
value: 'getBalances',
description: 'Retrieve balances for all account currencies of this user',
action: 'Get balances',
},
{
name: 'Get Currencies',
value: 'getCurrencies',
description: 'Retrieve currencies in the borderless account of this user',
action: 'Get currencies',
},
{
name: 'Get Statement',
value: 'getStatement',
description: 'Retrieve the statement for the borderless account of this user',
action: 'Get a statement',
},
],
displayOptions: {
show: {
resource: ['account'],
},
},
},
];
export const accountFields: INodeProperties[] = [
// ----------------------------------
// account: getBalances
// ----------------------------------
{
displayName: 'Profile Name or ID',
name: 'profileId',
type: 'options',
required: true,
default: [],
typeOptions: {
loadOptionsMethod: 'getProfiles',
},
description:
'ID of the user profile to retrieve the balance of. Choose from the list, or specify an ID using an expression.',
displayOptions: {
show: {
resource: ['account'],
operation: ['getBalances'],
},
},
},
// ----------------------------------
// account: getStatement
// ----------------------------------
{
displayName: 'Profile Name or ID',
name: 'profileId',
type: 'options',
default: [],
typeOptions: {
loadOptionsMethod: 'getProfiles',
},
description:
'ID of the user profile whose account to retrieve the statement of. Choose from the list, or specify an ID using an expression.',
displayOptions: {
show: {
resource: ['account'],
operation: ['getStatement'],
},
},
},
{
displayName: 'Borderless Account Name or ID',
name: 'borderlessAccountId',
type: 'options',
default: [],
required: true,
typeOptions: {
loadOptionsMethod: 'getBorderlessAccounts',
loadOptionsDependsOn: ['profileId'],
},
description:
'ID of the borderless account to retrieve the statement of. Choose from the list, or specify an ID using an expression.',
displayOptions: {
show: {
resource: ['account'],
operation: ['getStatement'],
},
},
},
{
displayName: 'Currency',
name: 'currency',
type: 'string',
default: '',
// TODO: preload
description: 'Code of the currency of the borderless account to retrieve the statement of',
displayOptions: {
show: {
resource: ['account'],
operation: ['getStatement'],
},
},
},
{
displayName: 'Format',
name: 'format',
type: 'options',
default: 'json',
description: 'File format to retrieve the statement in',
displayOptions: {
show: {
resource: ['account'],
operation: ['getStatement'],
},
},
options: [
{
name: 'JSON',
value: 'json',
},
{
name: 'CSV',
value: 'csv',
},
{
name: 'PDF',
value: 'pdf',
},
],
},
{
displayName: 'Binary Property',
name: 'binaryProperty',
type: 'string',
required: true,
default: 'data',
description: 'Name of the binary property to which to write to',
displayOptions: {
show: {
resource: ['account'],
operation: ['getStatement'],
format: ['csv', 'pdf'],
},
},
},
{
displayName: 'File Name',
name: 'fileName',
type: 'string',
required: true,
default: '',
placeholder: 'data.pdf',
description: 'Name of the file that will be downloaded',
displayOptions: {
show: {
resource: ['account'],
operation: ['getStatement'],
format: ['csv', 'pdf'],
},
},
},
{
displayName: 'Additional Fields',
name: 'additionalFields',
type: 'collection',
placeholder: 'Add Field',
default: {},
displayOptions: {
show: {
resource: ['account'],
operation: ['getStatement'],
},
},
options: [
{
displayName: 'Line Style',
name: 'lineStyle',
type: 'options',
default: 'COMPACT',
description: 'Line style to retrieve the statement in',
options: [
{
name: 'Compact',
value: 'COMPACT',
description: 'Single line per transaction',
},
{
name: 'Flat',
value: 'FLAT',
description: 'Separate lines for transaction fees',
},
],
},
{
displayName: 'Range',
name: 'range',
type: 'fixedCollection',
placeholder: 'Add Range',
default: {},
options: [
{
displayName: 'Range Properties',
name: 'rangeProperties',
values: [
{
displayName: 'Range Start',
name: 'intervalStart',
type: 'dateTime',
default: '',
},
{
displayName: 'Range End',
name: 'intervalEnd',
type: 'dateTime',
default: '',
},
],
},
],
},
],
},
];