import { INodeProperties } from 'n8n-workflow'; export const databaseOperations: INodeProperties[] = [ { displayName: 'Operation', name: 'operation', type: 'options', noDataExpression: true, displayOptions: { show: { version: [2], resource: ['database'], }, }, options: [ { name: 'Get', value: 'get', description: 'Get a database', action: 'Get a database', }, { name: 'Get All', value: 'getAll', description: 'Get all databases', action: 'Get all databases', }, { name: 'Search', value: 'search', description: 'Search databases using text search', action: 'Search a database', }, ], default: 'get', }, { displayName: 'Operation', name: 'operation', type: 'options', noDataExpression: true, displayOptions: { show: { version: [1], resource: ['database'], }, }, options: [ { name: 'Get', value: 'get', description: 'Get a database', action: 'Get a database', }, { name: 'Get All', value: 'getAll', description: 'Get all databases', action: 'Get all databases', }, ], default: 'get', }, ]; export const databaseFields: INodeProperties[] = [ /* -------------------------------------------------------------------------- */ /* database:get */ /* -------------------------------------------------------------------------- */ { displayName: 'Database Link or ID', name: 'databaseId', type: 'string', default: '', required: true, displayOptions: { show: { resource: ['database'], operation: ['get'], }, }, description: "The Database URL from Notion's 'copy link' functionality (or just the ID contained within the URL)", }, /* -------------------------------------------------------------------------- */ /* database:getAll */ /* -------------------------------------------------------------------------- */ { displayName: 'Return All', name: 'returnAll', type: 'boolean', displayOptions: { show: { resource: ['database'], operation: ['getAll'], }, }, default: false, description: 'Whether to return all results or only up to a given limit', }, { displayName: 'Limit', name: 'limit', type: 'number', displayOptions: { show: { resource: ['database'], operation: ['getAll'], returnAll: [false], }, }, typeOptions: { minValue: 1, maxValue: 100, }, default: 50, description: 'Max number of results to return', }, { displayName: 'Simplify', name: 'simple', type: 'boolean', displayOptions: { show: { version: [2], resource: ['database'], operation: ['getAll', 'get'], }, }, default: true, description: 'Whether to return a simplified version of the response instead of the raw data', }, /* -------------------------------------------------------------------------- */ /* database:search */ /* -------------------------------------------------------------------------- */ { displayName: 'Search Text', name: 'text', type: 'string', default: '', displayOptions: { show: { resource: ['database'], operation: ['search'], }, }, description: 'The text to search for', }, { displayName: 'Return All', name: 'returnAll', type: 'boolean', displayOptions: { show: { resource: ['database'], operation: ['search'], }, }, default: false, description: 'Whether to return all results or only up to a given limit', }, { displayName: 'Limit', name: 'limit', type: 'number', displayOptions: { show: { resource: ['database'], operation: ['search'], returnAll: [false], }, }, typeOptions: { minValue: 1, maxValue: 100, }, default: 50, description: 'Max number of results to return', }, { displayName: 'Simplify', name: 'simple', type: 'boolean', displayOptions: { show: { resource: ['database'], operation: ['search'], }, }, default: true, description: 'Whether to return a simplified version of the response instead of the raw data', }, { displayName: 'Options', name: 'options', type: 'collection', displayOptions: { show: { resource: ['database'], operation: ['search'], }, }, default: {}, placeholder: 'Add Field', options: [ { displayName: 'Sort', name: 'sort', placeholder: 'Add Sort', type: 'fixedCollection', typeOptions: { multipleValues: false, }, default: {}, options: [ { displayName: 'Sort', name: 'sortValue', values: [ { displayName: 'Direction', name: 'direction', type: 'options', options: [ { name: 'Ascending', value: 'ascending', }, { name: 'Descending', value: 'descending', }, ], default: 'descending', description: 'The direction to sort', }, { displayName: 'Timestamp', name: 'timestamp', type: 'options', options: [ { name: 'Last Edited Time', value: 'last_edited_time', }, ], default: 'last_edited_time', description: 'The name of the timestamp to sort against', }, ], }, ], }, ], }, ];