mirror of
https://github.com/n8n-io/n8n.git
synced 2025-01-12 21:37:32 -08:00
208 lines
4.4 KiB
TypeScript
208 lines
4.4 KiB
TypeScript
import type { INodeProperties } from 'n8n-workflow';
|
|
|
|
export const baseRLC: INodeProperties = {
|
|
displayName: 'Base',
|
|
name: 'base',
|
|
type: 'resourceLocator',
|
|
default: { mode: 'list', value: '' },
|
|
required: true,
|
|
// description: 'The Airtable Base in which to operate on',
|
|
modes: [
|
|
{
|
|
displayName: 'From List',
|
|
name: 'list',
|
|
type: 'list',
|
|
typeOptions: {
|
|
searchListMethod: 'baseSearch',
|
|
searchable: true,
|
|
},
|
|
},
|
|
{
|
|
displayName: 'By URL',
|
|
name: 'url',
|
|
type: 'string',
|
|
placeholder: 'e.g. https://airtable.com/app12DiScdfes/tbl9WvGeEPa6lZyVq/viwHdfasdfeieg5p',
|
|
validation: [
|
|
{
|
|
type: 'regex',
|
|
properties: {
|
|
regex: 'https://airtable.com/([a-zA-Z0-9]{2,})/.*',
|
|
errorMessage: 'Not a valid Airtable Base URL',
|
|
},
|
|
},
|
|
],
|
|
extractValue: {
|
|
type: 'regex',
|
|
regex: 'https://airtable.com/([a-zA-Z0-9]{2,})',
|
|
},
|
|
},
|
|
{
|
|
displayName: 'ID',
|
|
name: 'id',
|
|
type: 'string',
|
|
validation: [
|
|
{
|
|
type: 'regex',
|
|
properties: {
|
|
regex: '[a-zA-Z0-9]{2,}',
|
|
errorMessage: 'Not a valid Airtable Base ID',
|
|
},
|
|
},
|
|
],
|
|
placeholder: 'e.g. appD3dfaeidke',
|
|
url: '=https://airtable.com/{{$value}}',
|
|
},
|
|
],
|
|
};
|
|
|
|
export const tableRLC: INodeProperties = {
|
|
displayName: 'Table',
|
|
name: 'table',
|
|
type: 'resourceLocator',
|
|
default: { mode: 'list', value: '' },
|
|
required: true,
|
|
modes: [
|
|
{
|
|
displayName: 'From List',
|
|
name: 'list',
|
|
type: 'list',
|
|
typeOptions: {
|
|
searchListMethod: 'tableSearch',
|
|
searchable: true,
|
|
},
|
|
},
|
|
{
|
|
displayName: 'By URL',
|
|
name: 'url',
|
|
type: 'string',
|
|
placeholder: 'https://airtable.com/app12DiScdfes/tblAAAAAAAAAAAAA/viwHdfasdfeieg5p',
|
|
validation: [
|
|
{
|
|
type: 'regex',
|
|
properties: {
|
|
regex: 'https://airtable.com/[a-zA-Z0-9]{2,}/([a-zA-Z0-9]{2,})/.*',
|
|
errorMessage: 'Not a valid Airtable Table URL',
|
|
},
|
|
},
|
|
],
|
|
extractValue: {
|
|
type: 'regex',
|
|
regex: 'https://airtable.com/[a-zA-Z0-9]{2,}/([a-zA-Z0-9]{2,})',
|
|
},
|
|
},
|
|
{
|
|
displayName: 'ID',
|
|
name: 'id',
|
|
type: 'string',
|
|
validation: [
|
|
{
|
|
type: 'regex',
|
|
properties: {
|
|
regex: '[a-zA-Z0-9]{2,}',
|
|
errorMessage: 'Not a valid Airtable Table ID',
|
|
},
|
|
},
|
|
],
|
|
placeholder: 'tbl3dirwqeidke',
|
|
},
|
|
],
|
|
};
|
|
|
|
export const viewRLC: INodeProperties = {
|
|
displayName: 'View',
|
|
name: 'view',
|
|
type: 'resourceLocator',
|
|
default: { mode: 'list', value: '' },
|
|
modes: [
|
|
{
|
|
displayName: 'From List',
|
|
name: 'list',
|
|
type: 'list',
|
|
typeOptions: {
|
|
searchListMethod: 'viewSearch',
|
|
searchable: true,
|
|
},
|
|
},
|
|
{
|
|
displayName: 'By URL',
|
|
name: 'url',
|
|
type: 'string',
|
|
placeholder: 'https://airtable.com/app12DiScdfes/tblAAAAAAAAAAAAA/viwHdfasdfeieg5p',
|
|
validation: [
|
|
{
|
|
type: 'regex',
|
|
properties: {
|
|
regex: 'https://airtable.com/[a-zA-Z0-9]{2,}/[a-zA-Z0-9]{2,}/([a-zA-Z0-9]{2,})/.*',
|
|
errorMessage: 'Not a valid Airtable View URL',
|
|
},
|
|
},
|
|
],
|
|
extractValue: {
|
|
type: 'regex',
|
|
regex: 'https://airtable.com/[a-zA-Z0-9]{2,}/[a-zA-Z0-9]{2,}/([a-zA-Z0-9]{2,})',
|
|
},
|
|
},
|
|
{
|
|
displayName: 'ID',
|
|
name: 'id',
|
|
type: 'string',
|
|
validation: [
|
|
{
|
|
type: 'regex',
|
|
properties: {
|
|
regex: '[a-zA-Z0-9]{2,}',
|
|
errorMessage: 'Not a valid Airtable View ID',
|
|
},
|
|
},
|
|
],
|
|
placeholder: 'viw3dirwqeidke',
|
|
},
|
|
],
|
|
};
|
|
|
|
export const insertUpdateOptions: INodeProperties[] = [
|
|
{
|
|
displayName: 'Options',
|
|
name: 'options',
|
|
type: 'collection',
|
|
placeholder: 'Add Option',
|
|
default: {},
|
|
options: [
|
|
{
|
|
displayName: 'Typecast',
|
|
name: 'typecast',
|
|
type: 'boolean',
|
|
default: false,
|
|
description:
|
|
'Whether the Airtable API should attempt mapping of string values for linked records & select options',
|
|
},
|
|
{
|
|
displayName: 'Ignore Fields From Input',
|
|
name: 'ignoreFields',
|
|
type: 'string',
|
|
requiresDataPath: 'multiple',
|
|
displayOptions: {
|
|
show: {
|
|
'/columns.mappingMode': ['autoMapInputData'],
|
|
},
|
|
},
|
|
default: '',
|
|
description: 'Comma-separated list of fields in input to ignore when updating',
|
|
},
|
|
{
|
|
displayName: 'Update All Matches',
|
|
name: 'updateAllMatches',
|
|
type: 'boolean',
|
|
default: false,
|
|
description:
|
|
'Whether to update all records matching the value in the "Column to Match On". If not set, only the first matching record will be updated.',
|
|
displayOptions: {
|
|
show: {
|
|
'/operation': ['update', 'upsert'],
|
|
},
|
|
},
|
|
},
|
|
],
|
|
},
|
|
];
|