2023-01-27 03:22:44 -08:00
import type { INodeProperties } from 'n8n-workflow' ;
2021-09-29 17:10:39 -07:00
export const operationFields : INodeProperties [ ] = [
{
displayName : 'Operation' ,
name : 'operation' ,
type : 'options' ,
noDataExpression : true ,
options : [
{
name : 'Create Row' ,
value : 'create' ,
description : 'Create rows in a table' ,
2022-07-10 13:50:51 -07:00
action : 'Create rows in a table' ,
2021-09-29 17:10:39 -07:00
} ,
{
name : 'Delete Row' ,
value : 'delete' ,
description : 'Delete rows from a table' ,
2022-07-10 13:50:51 -07:00
action : 'Delete rows from a table' ,
2021-09-29 17:10:39 -07:00
} ,
{
2022-09-07 07:51:14 -07:00
// eslint-disable-next-line n8n-nodes-base/node-param-option-name-wrong-for-get-many
name : 'Get Many Rows' ,
2021-09-29 17:10:39 -07:00
value : 'getAll' ,
description : 'Read rows from a table' ,
2022-07-10 13:50:51 -07:00
action : 'Read rows from a table' ,
2021-09-29 17:10:39 -07:00
} ,
{
name : 'Update Row' ,
value : 'update' ,
description : 'Update rows in a table' ,
2022-07-10 13:50:51 -07:00
action : 'Update rows in a table' ,
2021-09-29 17:10:39 -07:00
} ,
] ,
default : 'getAll' ,
} ,
// ----------------------------------
// shared
// ----------------------------------
{
displayName : 'Document ID' ,
name : 'docId' ,
type : 'string' ,
default : '' ,
required : true ,
2022-08-17 08:50:24 -07:00
description :
'In your document, click your profile icon, then Document Settings, then copy the value under "This document\'s ID"' ,
2021-09-29 17:10:39 -07:00
} ,
{
displayName : 'Table ID' ,
name : 'tableId' ,
type : 'string' ,
default : '' ,
required : true ,
description : 'ID of table to operate on. If unsure, look at the Code View.' ,
} ,
// ----------------------------------
// delete
// ----------------------------------
{
displayName : 'Row ID' ,
name : 'rowId' ,
type : 'string' ,
displayOptions : {
show : {
2022-08-17 08:50:24 -07:00
operation : [ 'delete' ] ,
2021-09-29 17:10:39 -07:00
} ,
} ,
default : '' ,
description : 'ID of the row to delete, or comma-separated list of row IDs to delete' ,
required : true ,
} ,
// ----------------------------------
// getAll
// ----------------------------------
{
displayName : 'Return All' ,
name : 'returnAll' ,
type : 'boolean' ,
default : false ,
description : 'Whether to return all results or only up to a given limit' ,
displayOptions : {
show : {
2022-08-17 08:50:24 -07:00
operation : [ 'getAll' ] ,
2021-09-29 17:10:39 -07:00
} ,
} ,
} ,
{
displayName : 'Limit' ,
name : 'limit' ,
type : 'number' ,
typeOptions : {
minValue : 1 ,
} ,
default : 50 ,
description : 'Max number of results to return' ,
displayOptions : {
show : {
2022-08-17 08:50:24 -07:00
operation : [ 'getAll' ] ,
returnAll : [ false ] ,
2021-09-29 17:10:39 -07:00
} ,
} ,
} ,
{
displayName : 'Additional Options' ,
name : 'additionalOptions' ,
type : 'collection' ,
displayOptions : {
show : {
2022-08-17 08:50:24 -07:00
operation : [ 'getAll' ] ,
2021-09-29 17:10:39 -07:00
} ,
} ,
default : { } ,
2024-07-29 05:27:23 -07:00
placeholder : 'Add option' ,
2021-09-29 17:10:39 -07:00
options : [
{
displayName : 'Filter' ,
name : 'filter' ,
placeholder : 'Add Filter' ,
2022-08-17 08:50:24 -07:00
description :
'Only return rows matching all of the given filters. For complex filters, create a formula column and filter for the value "true".' ,
2021-09-29 17:10:39 -07:00
type : 'fixedCollection' ,
typeOptions : {
multipleValues : true ,
} ,
default : { } ,
options : [
{
displayName : 'Filter Properties' ,
name : 'filterProperties' ,
values : [
{
2022-06-03 10:23:49 -07:00
displayName : 'Column Name or ID' ,
2021-09-29 17:10:39 -07:00
name : 'field' ,
type : 'options' ,
typeOptions : {
2022-08-17 08:50:24 -07:00
loadOptionsDependsOn : [ 'docId' , 'tableId' ] ,
2021-09-29 17:10:39 -07:00
loadOptionsMethod : 'getTableColumns' ,
} ,
default : '' ,
2022-08-17 08:50:24 -07:00
description :
'Column to apply the filter in. Choose from the list, or specify an ID using an <a href="https://docs.n8n.io/code-examples/expressions/">expression</a>.' ,
2021-09-29 17:10:39 -07:00
required : true ,
} ,
{
displayName : 'Values' ,
name : 'values' ,
type : 'string' ,
default : '' ,
description : 'Comma-separated list of values to search for in the filtered column' ,
} ,
] ,
} ,
] ,
} ,
{
displayName : 'Sort Order' ,
name : 'sort' ,
placeholder : 'Add Field' ,
type : 'fixedCollection' ,
typeOptions : {
multipleValues : true ,
} ,
default : { } ,
options : [
{
displayName : 'Sort Properties' ,
name : 'sortProperties' ,
values : [
{
2022-06-03 10:23:49 -07:00
displayName : 'Column Name or ID' ,
2021-09-29 17:10:39 -07:00
name : 'field' ,
type : 'options' ,
typeOptions : {
2022-08-17 08:50:24 -07:00
loadOptionsDependsOn : [ 'docId' , 'tableId' ] ,
2021-09-29 17:10:39 -07:00
loadOptionsMethod : 'getTableColumns' ,
} ,
default : '' ,
required : true ,
2022-08-17 08:50:24 -07:00
description :
'Column to sort on. Choose from the list, or specify an ID using an <a href="https://docs.n8n.io/code-examples/expressions/">expression</a>.' ,
2021-09-29 17:10:39 -07:00
} ,
{
displayName : 'Direction' ,
name : 'direction' ,
type : 'options' ,
options : [
{
name : 'Ascending' ,
value : 'asc' ,
} ,
{
name : 'Descending' ,
value : 'desc' ,
} ,
] ,
default : 'asc' ,
description : 'Direction to sort in' ,
} ,
] ,
} ,
] ,
} ,
] ,
} ,
// ----------------------------------
// update
// ----------------------------------
{
displayName : 'Row ID' ,
name : 'rowId' ,
type : 'string' ,
displayOptions : {
show : {
2022-08-17 08:50:24 -07:00
operation : [ 'update' ] ,
2021-09-29 17:10:39 -07:00
} ,
} ,
default : '' ,
description : 'ID of the row to update' ,
required : true ,
} ,
// ----------------------------------
// create + update
// ----------------------------------
{
displayName : 'Data to Send' ,
name : 'dataToSend' ,
type : 'options' ,
options : [
{
name : 'Auto-Map Input Data to Columns' ,
value : 'autoMapInputs' ,
description : 'Use when node input properties match destination column names' ,
} ,
{
name : 'Define Below for Each Column' ,
value : 'defineInNode' ,
description : 'Set the value for each destination column' ,
} ,
] ,
displayOptions : {
show : {
2022-08-17 08:50:24 -07:00
operation : [ 'create' , 'update' ] ,
2021-09-29 17:10:39 -07:00
} ,
} ,
default : 'defineInNode' ,
description : 'Whether to insert the input data this node receives in the new row' ,
} ,
{
displayName : 'Inputs to Ignore' ,
name : 'inputsToIgnore' ,
type : 'string' ,
displayOptions : {
show : {
2022-08-17 08:50:24 -07:00
operation : [ 'create' , 'update' ] ,
dataToSend : [ 'autoMapInputs' ] ,
2021-09-29 17:10:39 -07:00
} ,
} ,
default : '' ,
2022-08-17 08:50:24 -07:00
description :
'List of input properties to avoid sending, separated by commas. Leave empty to send all properties.' ,
2021-09-29 17:10:39 -07:00
placeholder : 'Enter properties...' ,
} ,
{
displayName : 'Fields to Send' ,
name : 'fieldsToSend' ,
placeholder : 'Add Field' ,
type : 'fixedCollection' ,
typeOptions : {
multipleValueButtonText : 'Add Field to Send' ,
multipleValues : true ,
} ,
displayOptions : {
show : {
2022-08-17 08:50:24 -07:00
operation : [ 'create' , 'update' ] ,
dataToSend : [ 'defineInNode' ] ,
2021-09-29 17:10:39 -07:00
} ,
} ,
default : { } ,
options : [
{
displayName : 'Properties' ,
name : 'properties' ,
values : [
{
2022-06-03 10:23:49 -07:00
displayName : 'Column Name or ID' ,
2021-09-29 17:10:39 -07:00
name : 'fieldId' ,
2022-08-17 08:50:24 -07:00
description :
'Choose from the list, or specify an ID using an <a href="https://docs.n8n.io/code-examples/expressions/">expression</a>' ,
2021-09-29 17:10:39 -07:00
type : 'options' ,
typeOptions : {
2022-08-17 08:50:24 -07:00
loadOptionsDependsOn : [ 'tableId' ] ,
2021-09-29 17:10:39 -07:00
loadOptionsMethod : 'getTableColumns' ,
} ,
default : '' ,
} ,
{
displayName : 'Field Value' ,
name : 'fieldValue' ,
type : 'string' ,
default : '' ,
} ,
] ,
} ,
] ,
} ,
] ;