mirror of
https://github.com/n8n-io/n8n.git
synced 2025-01-11 12:57:29 -08:00
⚡ Add card comment operation
This commit is contained in:
parent
f5c8fbe953
commit
4c075db26c
|
@ -367,7 +367,7 @@ export class Airtable implements INodeType {
|
||||||
const operation = this.getNodeParameter('operation', 0) as string;
|
const operation = this.getNodeParameter('operation', 0) as string;
|
||||||
|
|
||||||
const application = this.getNodeParameter('application', 0) as string;
|
const application = this.getNodeParameter('application', 0) as string;
|
||||||
const table = this.getNodeParameter('table', 0) as string;
|
const table = encodeURI(this.getNodeParameter('table', 0) as string);
|
||||||
|
|
||||||
let returnAll = false;
|
let returnAll = false;
|
||||||
let endpoint = '';
|
let endpoint = '';
|
||||||
|
|
|
@ -1,4 +1,6 @@
|
||||||
import { INodeProperties } from "n8n-workflow";
|
import {
|
||||||
|
INodeProperties,
|
||||||
|
} from "n8n-workflow";
|
||||||
|
|
||||||
export const attachmentOperations = [
|
export const attachmentOperations = [
|
||||||
// ----------------------------------
|
// ----------------------------------
|
||||||
|
|
|
@ -1,4 +1,6 @@
|
||||||
import { INodeProperties } from "n8n-workflow";
|
import {
|
||||||
|
INodeProperties,
|
||||||
|
} from "n8n-workflow";
|
||||||
|
|
||||||
export const boardOperations = [
|
export const boardOperations = [
|
||||||
// ----------------------------------
|
// ----------------------------------
|
||||||
|
|
177
packages/nodes-base/nodes/Trello/CardCommentDescription.ts
Normal file
177
packages/nodes-base/nodes/Trello/CardCommentDescription.ts
Normal file
|
@ -0,0 +1,177 @@
|
||||||
|
import {
|
||||||
|
INodeProperties,
|
||||||
|
} from "n8n-workflow";
|
||||||
|
|
||||||
|
export const cardCommentOperations = [
|
||||||
|
{
|
||||||
|
displayName: 'Operation',
|
||||||
|
name: 'operation',
|
||||||
|
type: 'options',
|
||||||
|
displayOptions: {
|
||||||
|
show: {
|
||||||
|
resource: [
|
||||||
|
'cardComment',
|
||||||
|
],
|
||||||
|
},
|
||||||
|
},
|
||||||
|
options: [
|
||||||
|
{
|
||||||
|
name: 'Add',
|
||||||
|
value: 'add',
|
||||||
|
description: 'Add a comment to a card',
|
||||||
|
},
|
||||||
|
{
|
||||||
|
name: 'Revove',
|
||||||
|
value: 'remove',
|
||||||
|
description: 'Remove a comment from a card',
|
||||||
|
},
|
||||||
|
{
|
||||||
|
name: 'Update',
|
||||||
|
value: 'update',
|
||||||
|
description: 'Update a comment in a card',
|
||||||
|
},
|
||||||
|
],
|
||||||
|
default: 'add',
|
||||||
|
description: 'The operation to perform.',
|
||||||
|
},
|
||||||
|
] as INodeProperties[];
|
||||||
|
|
||||||
|
export const cardCommentFields = [
|
||||||
|
// ----------------------------------
|
||||||
|
// cardComment:add
|
||||||
|
// ----------------------------------
|
||||||
|
{
|
||||||
|
displayName: 'Card ID',
|
||||||
|
name: 'cardId',
|
||||||
|
type: 'string',
|
||||||
|
default: '',
|
||||||
|
required: true,
|
||||||
|
displayOptions: {
|
||||||
|
show: {
|
||||||
|
operation: [
|
||||||
|
'add',
|
||||||
|
],
|
||||||
|
resource: [
|
||||||
|
'cardComment',
|
||||||
|
],
|
||||||
|
},
|
||||||
|
},
|
||||||
|
description: 'The id of the card',
|
||||||
|
},
|
||||||
|
{
|
||||||
|
displayName: 'Text',
|
||||||
|
name: 'text',
|
||||||
|
type: 'string',
|
||||||
|
default: '',
|
||||||
|
required: true,
|
||||||
|
displayOptions: {
|
||||||
|
show: {
|
||||||
|
operation: [
|
||||||
|
'add',
|
||||||
|
],
|
||||||
|
resource: [
|
||||||
|
'cardComment',
|
||||||
|
],
|
||||||
|
},
|
||||||
|
},
|
||||||
|
description: 'Text of the comment',
|
||||||
|
},
|
||||||
|
|
||||||
|
// ----------------------------------
|
||||||
|
// cardComment:remove
|
||||||
|
// ----------------------------------
|
||||||
|
{
|
||||||
|
displayName: 'Card ID',
|
||||||
|
name: 'cardId',
|
||||||
|
type: 'string',
|
||||||
|
default: '',
|
||||||
|
required: true,
|
||||||
|
displayOptions: {
|
||||||
|
show: {
|
||||||
|
operation: [
|
||||||
|
'remove',
|
||||||
|
],
|
||||||
|
resource: [
|
||||||
|
'cardComment',
|
||||||
|
],
|
||||||
|
},
|
||||||
|
},
|
||||||
|
description: 'The ID of the card.',
|
||||||
|
},
|
||||||
|
{
|
||||||
|
displayName: 'Comment ID',
|
||||||
|
name: 'commentId',
|
||||||
|
type: 'string',
|
||||||
|
default: '',
|
||||||
|
required: true,
|
||||||
|
displayOptions: {
|
||||||
|
show: {
|
||||||
|
operation: [
|
||||||
|
'remove',
|
||||||
|
],
|
||||||
|
resource: [
|
||||||
|
'cardComment',
|
||||||
|
],
|
||||||
|
},
|
||||||
|
},
|
||||||
|
description: 'The ID of the comment to delete.',
|
||||||
|
},
|
||||||
|
|
||||||
|
// ----------------------------------
|
||||||
|
// cardComment:update
|
||||||
|
// ----------------------------------
|
||||||
|
{
|
||||||
|
displayName: 'Card ID',
|
||||||
|
name: 'cardId',
|
||||||
|
type: 'string',
|
||||||
|
default: '',
|
||||||
|
required: true,
|
||||||
|
displayOptions: {
|
||||||
|
show: {
|
||||||
|
operation: [
|
||||||
|
'update',
|
||||||
|
],
|
||||||
|
resource: [
|
||||||
|
'cardComment',
|
||||||
|
],
|
||||||
|
},
|
||||||
|
},
|
||||||
|
description: 'The ID of the card to update.',
|
||||||
|
},
|
||||||
|
{
|
||||||
|
displayName: 'Comment ID',
|
||||||
|
name: 'commentId',
|
||||||
|
type: 'string',
|
||||||
|
default: '',
|
||||||
|
required: true,
|
||||||
|
displayOptions: {
|
||||||
|
show: {
|
||||||
|
operation: [
|
||||||
|
'update',
|
||||||
|
],
|
||||||
|
resource: [
|
||||||
|
'cardComment',
|
||||||
|
],
|
||||||
|
},
|
||||||
|
},
|
||||||
|
description: 'The ID of the comment to delete.',
|
||||||
|
},
|
||||||
|
{
|
||||||
|
displayName: 'Text',
|
||||||
|
name: 'text',
|
||||||
|
type: 'string',
|
||||||
|
default: '',
|
||||||
|
required: true,
|
||||||
|
displayOptions: {
|
||||||
|
show: {
|
||||||
|
operation: [
|
||||||
|
'update',
|
||||||
|
],
|
||||||
|
resource: [
|
||||||
|
'cardComment',
|
||||||
|
],
|
||||||
|
},
|
||||||
|
},
|
||||||
|
description: 'Text of the comment',
|
||||||
|
},
|
||||||
|
] as INodeProperties[];
|
|
@ -1,4 +1,6 @@
|
||||||
import { INodeProperties } from "n8n-workflow";
|
import {
|
||||||
|
INodeProperties,
|
||||||
|
} from "n8n-workflow";
|
||||||
|
|
||||||
export const cardOperations = [
|
export const cardOperations = [
|
||||||
// ----------------------------------
|
// ----------------------------------
|
||||||
|
|
|
@ -1,4 +1,6 @@
|
||||||
import { INodeProperties } from "n8n-workflow";
|
import {
|
||||||
|
INodeProperties,
|
||||||
|
} from 'n8n-workflow';
|
||||||
|
|
||||||
export const checklistOperations = [
|
export const checklistOperations = [
|
||||||
// ----------------------------------
|
// ----------------------------------
|
||||||
|
|
|
@ -4,9 +4,13 @@ import {
|
||||||
ILoadOptionsFunctions,
|
ILoadOptionsFunctions,
|
||||||
} from 'n8n-core';
|
} from 'n8n-core';
|
||||||
|
|
||||||
import { OptionsWithUri } from 'request';
|
import {
|
||||||
import { IDataObject } from 'n8n-workflow';
|
OptionsWithUri,
|
||||||
|
} from 'request';
|
||||||
|
|
||||||
|
import {
|
||||||
|
IDataObject,
|
||||||
|
} from 'n8n-workflow';
|
||||||
|
|
||||||
/**
|
/**
|
||||||
* Make an API request to Trello
|
* Make an API request to Trello
|
||||||
|
|
|
@ -1,4 +1,6 @@
|
||||||
import { INodeProperties } from "n8n-workflow";
|
import {
|
||||||
|
INodeProperties,
|
||||||
|
} from 'n8n-workflow';
|
||||||
|
|
||||||
export const labelOperations = [
|
export const labelOperations = [
|
||||||
// ----------------------------------
|
// ----------------------------------
|
||||||
|
|
|
@ -1,42 +1,46 @@
|
||||||
import { INodeProperties } from "n8n-workflow";
|
import {
|
||||||
|
INodeProperties,
|
||||||
|
} from 'n8n-workflow';
|
||||||
|
|
||||||
export const listOperations = [
|
export const listOperations = [
|
||||||
// ----------------------------------
|
// ----------------------------------
|
||||||
// list
|
// list
|
||||||
// ----------------------------------
|
// ----------------------------------
|
||||||
{
|
{
|
||||||
displayName: "Operation",
|
displayName: 'Operation',
|
||||||
name: "operation",
|
name: 'operation',
|
||||||
type: "options",
|
type: 'options',
|
||||||
displayOptions: {
|
displayOptions: {
|
||||||
show: {
|
show: {
|
||||||
resource: ["list"]
|
resource: [
|
||||||
}
|
'list',
|
||||||
|
],
|
||||||
|
},
|
||||||
},
|
},
|
||||||
options: [
|
options: [
|
||||||
{
|
{
|
||||||
name: "Archive",
|
name: 'Archive',
|
||||||
value: "archive",
|
value: 'archive',
|
||||||
description: "Archive/Unarchive a list"
|
description: 'Archive/Unarchive a list'
|
||||||
},
|
},
|
||||||
{
|
{
|
||||||
name: "Create",
|
name: 'Create',
|
||||||
value: "create",
|
value: 'create',
|
||||||
description: "Create a new list"
|
description: 'Create a new list'
|
||||||
},
|
},
|
||||||
{
|
{
|
||||||
name: "Get",
|
name: 'Get',
|
||||||
value: "get",
|
value: 'get',
|
||||||
description: "Get the data of a list"
|
description: 'Get the data of a list'
|
||||||
},
|
},
|
||||||
{
|
{
|
||||||
name: "Update",
|
name: 'Update',
|
||||||
value: "update",
|
value: 'update',
|
||||||
description: "Update a list"
|
description: 'Update a list'
|
||||||
}
|
}
|
||||||
],
|
],
|
||||||
default: "create",
|
default: 'create',
|
||||||
description: "The operation to perform."
|
description: 'The operation to perform.'
|
||||||
}
|
}
|
||||||
] as INodeProperties[];
|
] as INodeProperties[];
|
||||||
|
|
||||||
|
@ -45,92 +49,112 @@ export const listFields = [
|
||||||
// list:archive
|
// list:archive
|
||||||
// ----------------------------------
|
// ----------------------------------
|
||||||
{
|
{
|
||||||
displayName: "List ID",
|
displayName: 'List ID',
|
||||||
name: "id",
|
name: 'id',
|
||||||
type: "string",
|
type: 'string',
|
||||||
default: "",
|
default: '',
|
||||||
required: true,
|
required: true,
|
||||||
displayOptions: {
|
displayOptions: {
|
||||||
show: {
|
show: {
|
||||||
operation: ["archive"],
|
operation: [
|
||||||
resource: ["list"]
|
'archive',
|
||||||
}
|
],
|
||||||
|
resource: [
|
||||||
|
'list',
|
||||||
|
],
|
||||||
},
|
},
|
||||||
description: "The ID of the list to archive or unarchive."
|
},
|
||||||
|
description: 'The ID of the list to archive or unarchive.'
|
||||||
},
|
},
|
||||||
{
|
{
|
||||||
displayName: "Archive",
|
displayName: 'Archive',
|
||||||
name: "archive",
|
name: 'archive',
|
||||||
type: "boolean",
|
type: 'boolean',
|
||||||
default: false,
|
default: false,
|
||||||
displayOptions: {
|
displayOptions: {
|
||||||
show: {
|
show: {
|
||||||
operation: ["archive"],
|
operation: [
|
||||||
resource: ["list"]
|
'archive',
|
||||||
}
|
],
|
||||||
|
resource: [
|
||||||
|
'list',
|
||||||
|
],
|
||||||
},
|
},
|
||||||
description: "If the list should be archived or unarchived."
|
},
|
||||||
|
description: 'If the list should be archived or unarchived.'
|
||||||
},
|
},
|
||||||
|
|
||||||
// ----------------------------------
|
// ----------------------------------
|
||||||
// list:create
|
// list:create
|
||||||
// ----------------------------------
|
// ----------------------------------
|
||||||
{
|
{
|
||||||
displayName: "Board ID",
|
displayName: 'Board ID',
|
||||||
name: "idBoard",
|
name: 'idBoard',
|
||||||
type: "string",
|
type: 'string',
|
||||||
default: "",
|
default: '',
|
||||||
required: true,
|
required: true,
|
||||||
displayOptions: {
|
displayOptions: {
|
||||||
show: {
|
show: {
|
||||||
operation: ["create"],
|
operation: [
|
||||||
resource: ["list"]
|
'create',
|
||||||
}
|
],
|
||||||
|
resource: [
|
||||||
|
'list',
|
||||||
|
],
|
||||||
},
|
},
|
||||||
description: "The ID of the board the list should be created in"
|
},
|
||||||
|
description: 'The ID of the board the list should be created in'
|
||||||
},
|
},
|
||||||
{
|
{
|
||||||
displayName: "Name",
|
displayName: 'Name',
|
||||||
name: "name",
|
name: 'name',
|
||||||
type: "string",
|
type: 'string',
|
||||||
default: "",
|
default: '',
|
||||||
placeholder: "My list",
|
placeholder: 'My list',
|
||||||
required: true,
|
required: true,
|
||||||
displayOptions: {
|
displayOptions: {
|
||||||
show: {
|
show: {
|
||||||
operation: ["create"],
|
operation: [
|
||||||
resource: ["list"]
|
'create',
|
||||||
}
|
],
|
||||||
|
resource: [
|
||||||
|
'list',
|
||||||
|
],
|
||||||
},
|
},
|
||||||
description: "The name of the list"
|
},
|
||||||
|
description: 'The name of the list'
|
||||||
},
|
},
|
||||||
{
|
{
|
||||||
displayName: "Additional Fields",
|
displayName: 'Additional Fields',
|
||||||
name: "additionalFields",
|
name: 'additionalFields',
|
||||||
type: "collection",
|
type: 'collection',
|
||||||
placeholder: "Add Field",
|
placeholder: 'Add Field',
|
||||||
displayOptions: {
|
displayOptions: {
|
||||||
show: {
|
show: {
|
||||||
operation: ["create"],
|
operation: [
|
||||||
resource: ["list"]
|
'create',
|
||||||
}
|
],
|
||||||
|
resource: [
|
||||||
|
'list',
|
||||||
|
],
|
||||||
|
},
|
||||||
},
|
},
|
||||||
default: {},
|
default: {},
|
||||||
options: [
|
options: [
|
||||||
{
|
{
|
||||||
displayName: "List Source",
|
displayName: 'List Source',
|
||||||
name: "idListSource",
|
name: 'idListSource',
|
||||||
type: "string",
|
type: 'string',
|
||||||
default: "",
|
default: '',
|
||||||
description: "ID of the list to copy into the new list."
|
description: 'ID of the list to copy into the new list.'
|
||||||
},
|
},
|
||||||
{
|
{
|
||||||
displayName: "Position",
|
displayName: 'Position',
|
||||||
name: "pos",
|
name: 'pos',
|
||||||
type: "string",
|
type: 'string',
|
||||||
default: "bottom",
|
default: 'bottom',
|
||||||
description:
|
description:
|
||||||
"The position of the new list. top, bottom, or a positive float."
|
'The position of the new list. top, bottom, or a positive float.'
|
||||||
}
|
}
|
||||||
]
|
]
|
||||||
},
|
},
|
||||||
|
@ -139,39 +163,46 @@ export const listFields = [
|
||||||
// list:get
|
// list:get
|
||||||
// ----------------------------------
|
// ----------------------------------
|
||||||
{
|
{
|
||||||
displayName: "List ID",
|
displayName: 'List ID',
|
||||||
name: "id",
|
name: 'id',
|
||||||
type: "string",
|
type: 'string',
|
||||||
default: "",
|
default: '',
|
||||||
required: true,
|
required: true,
|
||||||
displayOptions: {
|
displayOptions: {
|
||||||
show: {
|
show: {
|
||||||
operation: ["get"],
|
operation: [
|
||||||
resource: ["list"]
|
'get',
|
||||||
}
|
],
|
||||||
|
resource: [
|
||||||
|
'list',
|
||||||
|
],
|
||||||
},
|
},
|
||||||
description: "The ID of the list to get."
|
},
|
||||||
|
description: 'The ID of the list to get.'
|
||||||
},
|
},
|
||||||
{
|
{
|
||||||
displayName: "Additional Fields",
|
displayName: 'Additional Fields',
|
||||||
name: "additionalFields",
|
name: 'additionalFields',
|
||||||
type: "collection",
|
type: 'collection',
|
||||||
placeholder: "Add Field",
|
placeholder: 'Add Field',
|
||||||
displayOptions: {
|
displayOptions: {
|
||||||
show: {
|
show: {
|
||||||
operation: ["get"],
|
operation: [
|
||||||
resource: ["list"]
|
'get',
|
||||||
}
|
],
|
||||||
|
resource: [
|
||||||
|
'list',
|
||||||
|
],
|
||||||
|
},
|
||||||
},
|
},
|
||||||
default: {},
|
default: {},
|
||||||
options: [
|
options: [
|
||||||
{
|
{
|
||||||
displayName: "Fields",
|
displayName: 'Fields',
|
||||||
name: "fields",
|
name: 'fields',
|
||||||
type: "string",
|
type: 'string',
|
||||||
default: "all",
|
default: 'all',
|
||||||
description:
|
description: 'Fields to return. Either "all" or a comma-separated list of fields.'
|
||||||
'Fields to return. Either "all" or a comma-separated list of fields.'
|
|
||||||
}
|
}
|
||||||
]
|
]
|
||||||
},
|
},
|
||||||
|
@ -180,67 +211,75 @@ export const listFields = [
|
||||||
// list:update
|
// list:update
|
||||||
// ----------------------------------
|
// ----------------------------------
|
||||||
{
|
{
|
||||||
displayName: "List ID",
|
displayName: 'List ID',
|
||||||
name: "id",
|
name: 'id',
|
||||||
type: "string",
|
type: 'string',
|
||||||
default: "",
|
default: '',
|
||||||
required: true,
|
required: true,
|
||||||
displayOptions: {
|
displayOptions: {
|
||||||
show: {
|
show: {
|
||||||
operation: ["update"],
|
operation: [
|
||||||
resource: ["list"]
|
'update',
|
||||||
}
|
],
|
||||||
|
resource: [
|
||||||
|
'list',
|
||||||
|
],
|
||||||
},
|
},
|
||||||
description: "The ID of the list to update."
|
},
|
||||||
|
description: 'The ID of the list to update.'
|
||||||
},
|
},
|
||||||
{
|
{
|
||||||
displayName: "Update Fields",
|
displayName: 'Update Fields',
|
||||||
name: "updateFields",
|
name: 'updateFields',
|
||||||
type: "collection",
|
type: 'collection',
|
||||||
placeholder: "Add Field",
|
placeholder: 'Add Field',
|
||||||
displayOptions: {
|
displayOptions: {
|
||||||
show: {
|
show: {
|
||||||
operation: ["update"],
|
operation: [
|
||||||
resource: ["list"]
|
'update',
|
||||||
}
|
],
|
||||||
|
resource: [
|
||||||
|
'list',
|
||||||
|
],
|
||||||
|
},
|
||||||
},
|
},
|
||||||
default: {},
|
default: {},
|
||||||
options: [
|
options: [
|
||||||
{
|
{
|
||||||
displayName: "Board ID",
|
displayName: 'Board ID',
|
||||||
name: "idBoard",
|
name: 'idBoard',
|
||||||
type: "string",
|
type: 'string',
|
||||||
default: "",
|
default: '',
|
||||||
description: "ID of a board the list should be moved to."
|
description: 'ID of a board the list should be moved to.'
|
||||||
},
|
},
|
||||||
{
|
{
|
||||||
displayName: "Closed",
|
displayName: 'Closed',
|
||||||
name: "closed",
|
name: 'closed',
|
||||||
type: "boolean",
|
type: 'boolean',
|
||||||
default: false,
|
default: false,
|
||||||
description: "Whether the list is closed."
|
description: 'Whether the list is closed.'
|
||||||
},
|
},
|
||||||
{
|
{
|
||||||
displayName: "Name",
|
displayName: 'Name',
|
||||||
name: "name",
|
name: 'name',
|
||||||
type: "string",
|
type: 'string',
|
||||||
default: "",
|
default: '',
|
||||||
description: "New name of the list"
|
description: 'New name of the list'
|
||||||
},
|
},
|
||||||
{
|
{
|
||||||
displayName: "Position",
|
displayName: 'Position',
|
||||||
name: "pos",
|
name: 'pos',
|
||||||
type: "string",
|
type: 'string',
|
||||||
default: "bottom",
|
default: 'bottom',
|
||||||
description:
|
description:
|
||||||
"The position of the list. top, bottom, or a positive float."
|
'The position of the list. top, bottom, or a positive float.'
|
||||||
},
|
},
|
||||||
{
|
{
|
||||||
displayName: "Subscribed",
|
displayName: 'Subscribed',
|
||||||
name: "subscribed",
|
name: 'subscribed',
|
||||||
type: "boolean",
|
type: 'boolean',
|
||||||
default: false,
|
default: false,
|
||||||
description: "Whether the acting user is subscribed to the list."
|
description: 'Whether the acting user is subscribed to the list.'
|
||||||
}
|
}
|
||||||
]
|
]
|
||||||
}
|
}
|
||||||
|
|
|
@ -1,4 +1,7 @@
|
||||||
import { IExecuteFunctions } from "n8n-core";
|
import {
|
||||||
|
IExecuteFunctions,
|
||||||
|
} from 'n8n-core';
|
||||||
|
|
||||||
import {
|
import {
|
||||||
IDataObject,
|
IDataObject,
|
||||||
INodeTypeDescription,
|
INodeTypeDescription,
|
||||||
|
@ -6,13 +9,44 @@ import {
|
||||||
INodeType,
|
INodeType,
|
||||||
} from 'n8n-workflow';
|
} from 'n8n-workflow';
|
||||||
|
|
||||||
import { apiRequest } from "./GenericFunctions";
|
import {
|
||||||
import { attachmentOperations, attachmentFields } from './AttachmentDescription';
|
apiRequest,
|
||||||
import { boardOperations, boardFields } from './BoardDescription';
|
} from './GenericFunctions';
|
||||||
import { cardOperations, cardFields } from './CardDescription';
|
|
||||||
import { checklistOperations, checklistFields } from './ChecklistDescription';
|
import {
|
||||||
import { labelOperations, labelFields } from './LabelDescription';
|
attachmentOperations,
|
||||||
import { listOperations, listFields } from './ListDescription';
|
attachmentFields,
|
||||||
|
} from './AttachmentDescription';
|
||||||
|
|
||||||
|
import {
|
||||||
|
boardOperations,
|
||||||
|
boardFields,
|
||||||
|
} from './BoardDescription';
|
||||||
|
|
||||||
|
import {
|
||||||
|
cardOperations,
|
||||||
|
cardFields,
|
||||||
|
} from './CardDescription';
|
||||||
|
|
||||||
|
import {
|
||||||
|
cardCommentOperations,
|
||||||
|
cardCommentFields,
|
||||||
|
} from './CardCommentDescription';
|
||||||
|
|
||||||
|
import {
|
||||||
|
checklistOperations,
|
||||||
|
checklistFields,
|
||||||
|
} from './ChecklistDescription';
|
||||||
|
|
||||||
|
import {
|
||||||
|
labelOperations,
|
||||||
|
labelFields,
|
||||||
|
} from './LabelDescription';
|
||||||
|
|
||||||
|
import {
|
||||||
|
listOperations,
|
||||||
|
listFields,
|
||||||
|
} from './ListDescription';
|
||||||
|
|
||||||
export class Trello implements INodeType {
|
export class Trello implements INodeType {
|
||||||
description: INodeTypeDescription = {
|
description: INodeTypeDescription = {
|
||||||
|
@ -33,7 +67,7 @@ export class Trello implements INodeType {
|
||||||
{
|
{
|
||||||
name: 'trelloApi',
|
name: 'trelloApi',
|
||||||
required: true,
|
required: true,
|
||||||
}
|
},
|
||||||
],
|
],
|
||||||
properties: [
|
properties: [
|
||||||
{
|
{
|
||||||
|
@ -53,6 +87,10 @@ export class Trello implements INodeType {
|
||||||
name: 'Card',
|
name: 'Card',
|
||||||
value: 'card',
|
value: 'card',
|
||||||
},
|
},
|
||||||
|
{
|
||||||
|
name: 'Card Comment',
|
||||||
|
value: 'cardComment',
|
||||||
|
},
|
||||||
{
|
{
|
||||||
name: 'Checklist',
|
name: 'Checklist',
|
||||||
value: 'checklist',
|
value: 'checklist',
|
||||||
|
@ -76,6 +114,7 @@ export class Trello implements INodeType {
|
||||||
...attachmentOperations,
|
...attachmentOperations,
|
||||||
...boardOperations,
|
...boardOperations,
|
||||||
...cardOperations,
|
...cardOperations,
|
||||||
|
...cardCommentOperations,
|
||||||
...checklistOperations,
|
...checklistOperations,
|
||||||
...labelOperations,
|
...labelOperations,
|
||||||
...listOperations,
|
...listOperations,
|
||||||
|
@ -86,15 +125,14 @@ export class Trello implements INodeType {
|
||||||
...attachmentFields,
|
...attachmentFields,
|
||||||
...boardFields,
|
...boardFields,
|
||||||
...cardFields,
|
...cardFields,
|
||||||
|
...cardCommentFields,
|
||||||
...checklistFields,
|
...checklistFields,
|
||||||
...labelFields,
|
...labelFields,
|
||||||
...listFields
|
...listFields
|
||||||
|
|
||||||
],
|
],
|
||||||
|
|
||||||
};
|
};
|
||||||
|
|
||||||
|
|
||||||
async execute(this: IExecuteFunctions): Promise<INodeExecutionData[][]> {
|
async execute(this: IExecuteFunctions): Promise<INodeExecutionData[][]> {
|
||||||
const items = this.getInputData();
|
const items = this.getInputData();
|
||||||
const returnData: IDataObject[] = [];
|
const returnData: IDataObject[] = [];
|
||||||
|
@ -236,6 +274,54 @@ export class Trello implements INodeType {
|
||||||
throw new Error(`The operation "${operation}" is not known!`);
|
throw new Error(`The operation "${operation}" is not known!`);
|
||||||
}
|
}
|
||||||
|
|
||||||
|
} else if (resource === 'cardComment') {
|
||||||
|
|
||||||
|
if (operation === 'add') {
|
||||||
|
// ----------------------------------
|
||||||
|
// add
|
||||||
|
// ----------------------------------
|
||||||
|
|
||||||
|
const cardId = this.getNodeParameter('cardId', i) as string;
|
||||||
|
|
||||||
|
qs.text = this.getNodeParameter('text', i) as string;
|
||||||
|
|
||||||
|
requestMethod = 'POST';
|
||||||
|
|
||||||
|
endpoint = `cards/${cardId}/actions/comments`;
|
||||||
|
|
||||||
|
|
||||||
|
} else if (operation === 'remove') {
|
||||||
|
// ----------------------------------
|
||||||
|
// delete
|
||||||
|
// ----------------------------------
|
||||||
|
|
||||||
|
requestMethod = 'DELETE';
|
||||||
|
|
||||||
|
const cardId = this.getNodeParameter('cardId', i) as string;
|
||||||
|
|
||||||
|
const commentId = this.getNodeParameter('commentId', i) as string;
|
||||||
|
|
||||||
|
endpoint = `/cards/${cardId}/actions/${commentId}/comments`;
|
||||||
|
|
||||||
|
} else if (operation === 'update') {
|
||||||
|
// ----------------------------------
|
||||||
|
// update
|
||||||
|
// ----------------------------------
|
||||||
|
|
||||||
|
requestMethod = 'PUT';
|
||||||
|
|
||||||
|
const cardId = this.getNodeParameter('cardId', i) as string;
|
||||||
|
|
||||||
|
const commentId = this.getNodeParameter('commentId', i) as string;
|
||||||
|
|
||||||
|
qs.text = this.getNodeParameter('text', i) as string;
|
||||||
|
|
||||||
|
endpoint = `cards/${cardId}/actions/${commentId}/comments`;
|
||||||
|
|
||||||
|
} else {
|
||||||
|
throw new Error(`The operation "${operation}" is not known!`);
|
||||||
|
}
|
||||||
|
|
||||||
} else if (resource === 'list') {
|
} else if (resource === 'list') {
|
||||||
|
|
||||||
if (operation === 'archive') {
|
if (operation === 'archive') {
|
||||||
|
|
Loading…
Reference in a new issue