mirror of
https://github.com/Abdulazizzn/n8n-enterprise-unlocked.git
synced 2025-12-17 01:56:46 +00:00
* refactor: Clear unused ESLint directives from nodes-base (no-changelog) * removed unused disable directives --------- Co-authored-by: Marcus <marcus@n8n.io>
203 lines
4.4 KiB
TypeScript
203 lines
4.4 KiB
TypeScript
import type { INodeProperties } from 'n8n-workflow';
|
|
import * as append from './append.operation';
|
|
import * as appendOrUpdate from './appendOrUpdate.operation';
|
|
import * as clear from './clear.operation';
|
|
import * as create from './create.operation';
|
|
import * as del from './delete.operation';
|
|
import * as read from './read.operation';
|
|
import * as remove from './remove.operation';
|
|
import * as update from './update.operation';
|
|
import { GOOGLE_DRIVE_FILE_URL_REGEX } from '../../../../constants';
|
|
|
|
export { append, appendOrUpdate, clear, create, del as delete, read, remove, update };
|
|
|
|
export const descriptions: INodeProperties[] = [
|
|
{
|
|
displayName: 'Operation',
|
|
name: 'operation',
|
|
type: 'options',
|
|
noDataExpression: true,
|
|
displayOptions: {
|
|
show: {
|
|
resource: ['sheet'],
|
|
},
|
|
},
|
|
options: [
|
|
{
|
|
name: 'Append',
|
|
value: 'append',
|
|
description: 'Append data to a sheet',
|
|
action: 'Append data to a sheet',
|
|
},
|
|
{
|
|
name: 'Append or Update',
|
|
value: 'appendOrUpdate',
|
|
description: 'Append a new row or update the current one if it already exists (upsert)',
|
|
action: 'Append or update a sheet',
|
|
},
|
|
{
|
|
name: 'Clear',
|
|
value: 'clear',
|
|
description: 'Clear data from a sheet',
|
|
action: 'Clear a sheet',
|
|
},
|
|
{
|
|
name: 'Create',
|
|
value: 'create',
|
|
description: 'Create a new sheet',
|
|
action: 'Create a sheet',
|
|
},
|
|
{
|
|
name: 'Delete',
|
|
value: 'delete',
|
|
description: 'Delete columns and rows from a sheet',
|
|
action: 'Delete a sheet',
|
|
},
|
|
{
|
|
name: 'Read Rows',
|
|
value: 'read',
|
|
description: 'Read all rows in a sheet',
|
|
action: 'Read all rows',
|
|
},
|
|
{
|
|
name: 'Remove',
|
|
value: 'remove',
|
|
description: 'Remove a sheet',
|
|
action: 'Remove a sheet',
|
|
},
|
|
{
|
|
name: 'Update',
|
|
value: 'update',
|
|
description: 'Update rows in a sheet',
|
|
action: 'Update a sheet',
|
|
},
|
|
],
|
|
default: 'read',
|
|
},
|
|
{
|
|
displayName: 'Document',
|
|
name: 'documentId',
|
|
type: 'resourceLocator',
|
|
default: { mode: 'list', value: '' },
|
|
required: true,
|
|
modes: [
|
|
{
|
|
displayName: 'From List',
|
|
name: 'list',
|
|
type: 'list',
|
|
typeOptions: {
|
|
searchListMethod: 'spreadSheetsSearch',
|
|
searchable: true,
|
|
},
|
|
},
|
|
{
|
|
displayName: 'By URL',
|
|
name: 'url',
|
|
type: 'string',
|
|
extractValue: {
|
|
type: 'regex',
|
|
regex: GOOGLE_DRIVE_FILE_URL_REGEX,
|
|
},
|
|
validation: [
|
|
{
|
|
type: 'regex',
|
|
properties: {
|
|
regex: GOOGLE_DRIVE_FILE_URL_REGEX,
|
|
errorMessage: 'Not a valid Google Drive File URL',
|
|
},
|
|
},
|
|
],
|
|
},
|
|
{
|
|
displayName: 'By ID',
|
|
name: 'id',
|
|
type: 'string',
|
|
validation: [
|
|
{
|
|
type: 'regex',
|
|
properties: {
|
|
regex: '[a-zA-Z0-9\\-_]{2,}',
|
|
errorMessage: 'Not a valid Google Drive File ID',
|
|
},
|
|
},
|
|
],
|
|
url: '=https://docs.google.com/spreadsheets/d/{{$value}}/edit',
|
|
},
|
|
],
|
|
displayOptions: {
|
|
show: {
|
|
resource: ['sheet'],
|
|
},
|
|
},
|
|
},
|
|
{
|
|
displayName: 'Sheet',
|
|
name: 'sheetName',
|
|
type: 'resourceLocator',
|
|
default: { mode: 'list', value: '' },
|
|
// default: '', //empty string set to progresivly reveal fields
|
|
required: true,
|
|
typeOptions: {
|
|
loadOptionsDependsOn: ['documentId.value'],
|
|
},
|
|
modes: [
|
|
{
|
|
displayName: 'From List',
|
|
name: 'list',
|
|
type: 'list',
|
|
typeOptions: {
|
|
searchListMethod: 'sheetsSearch',
|
|
searchable: false,
|
|
},
|
|
},
|
|
{
|
|
displayName: 'By URL',
|
|
name: 'url',
|
|
type: 'string',
|
|
extractValue: {
|
|
type: 'regex',
|
|
regex:
|
|
'https:\\/\\/docs\\.google\\.com/spreadsheets\\/d\\/[0-9a-zA-Z\\-_]+\\/edit\\#gid=([0-9]+)',
|
|
},
|
|
validation: [
|
|
{
|
|
type: 'regex',
|
|
properties: {
|
|
regex:
|
|
'https:\\/\\/docs\\.google\\.com/spreadsheets\\/d\\/[0-9a-zA-Z\\-_]+\\/edit\\#gid=([0-9]+)',
|
|
errorMessage: 'Not a valid Sheet URL',
|
|
},
|
|
},
|
|
],
|
|
},
|
|
{
|
|
displayName: 'By ID',
|
|
name: 'id',
|
|
type: 'string',
|
|
validation: [
|
|
{
|
|
type: 'regex',
|
|
properties: {
|
|
regex: '((gid=)?[0-9]{1,})',
|
|
errorMessage: 'Not a valid Sheet ID',
|
|
},
|
|
},
|
|
],
|
|
},
|
|
],
|
|
displayOptions: {
|
|
show: {
|
|
resource: ['sheet'],
|
|
operation: ['append', 'appendOrUpdate', 'clear', 'delete', 'read', 'remove', 'update'],
|
|
},
|
|
},
|
|
},
|
|
...append.description,
|
|
...clear.description,
|
|
...create.description,
|
|
...del.description,
|
|
...read.description,
|
|
...update.description,
|
|
...appendOrUpdate.description,
|
|
];
|