Add card comment operation

This commit is contained in:
ricardo 2020-08-24 20:55:57 -04:00
parent f5c8fbe953
commit 4c075db26c
10 changed files with 463 additions and 147 deletions

View file

@ -367,7 +367,7 @@ export class Airtable implements INodeType {
const operation = this.getNodeParameter('operation', 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 endpoint = '';

View file

@ -1,4 +1,6 @@
import { INodeProperties } from "n8n-workflow";
import {
INodeProperties,
} from "n8n-workflow";
export const attachmentOperations = [
// ----------------------------------

View file

@ -1,4 +1,6 @@
import { INodeProperties } from "n8n-workflow";
import {
INodeProperties,
} from "n8n-workflow";
export const boardOperations = [
// ----------------------------------

View 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[];

View file

@ -1,4 +1,6 @@
import { INodeProperties } from "n8n-workflow";
import {
INodeProperties,
} from "n8n-workflow";
export const cardOperations = [
// ----------------------------------

View file

@ -1,4 +1,6 @@
import { INodeProperties } from "n8n-workflow";
import {
INodeProperties,
} from 'n8n-workflow';
export const checklistOperations = [
// ----------------------------------

View file

@ -4,9 +4,13 @@ import {
ILoadOptionsFunctions,
} from 'n8n-core';
import { OptionsWithUri } from 'request';
import { IDataObject } from 'n8n-workflow';
import {
OptionsWithUri,
} from 'request';
import {
IDataObject,
} from 'n8n-workflow';
/**
* Make an API request to Trello

View file

@ -1,4 +1,6 @@
import { INodeProperties } from "n8n-workflow";
import {
INodeProperties,
} from 'n8n-workflow';
export const labelOperations = [
// ----------------------------------

View file

@ -1,42 +1,46 @@
import { INodeProperties } from "n8n-workflow";
import {
INodeProperties,
} from 'n8n-workflow';
export const listOperations = [
// ----------------------------------
// list
// ----------------------------------
{
displayName: "Operation",
name: "operation",
type: "options",
displayName: 'Operation',
name: 'operation',
type: 'options',
displayOptions: {
show: {
resource: ["list"]
}
resource: [
'list',
],
},
},
options: [
{
name: "Archive",
value: "archive",
description: "Archive/Unarchive a list"
name: 'Archive',
value: 'archive',
description: 'Archive/Unarchive a list'
},
{
name: "Create",
value: "create",
description: "Create a new list"
name: 'Create',
value: 'create',
description: 'Create a new list'
},
{
name: "Get",
value: "get",
description: "Get the data of a list"
name: 'Get',
value: 'get',
description: 'Get the data of a list'
},
{
name: "Update",
value: "update",
description: "Update a list"
name: 'Update',
value: 'update',
description: 'Update a list'
}
],
default: "create",
description: "The operation to perform."
default: 'create',
description: 'The operation to perform.'
}
] as INodeProperties[];
@ -45,92 +49,112 @@ export const listFields = [
// list:archive
// ----------------------------------
{
displayName: "List ID",
name: "id",
type: "string",
default: "",
displayName: 'List ID',
name: 'id',
type: 'string',
default: '',
required: true,
displayOptions: {
show: {
operation: ["archive"],
resource: ["list"]
}
operation: [
'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",
name: "archive",
type: "boolean",
displayName: 'Archive',
name: 'archive',
type: 'boolean',
default: false,
displayOptions: {
show: {
operation: ["archive"],
resource: ["list"]
}
operation: [
'archive',
],
resource: [
'list',
],
},
},
description: "If the list should be archived or unarchived."
description: 'If the list should be archived or unarchived.'
},
// ----------------------------------
// list:create
// ----------------------------------
{
displayName: "Board ID",
name: "idBoard",
type: "string",
default: "",
displayName: 'Board ID',
name: 'idBoard',
type: 'string',
default: '',
required: true,
displayOptions: {
show: {
operation: ["create"],
resource: ["list"]
}
operation: [
'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",
name: "name",
type: "string",
default: "",
placeholder: "My list",
displayName: 'Name',
name: 'name',
type: 'string',
default: '',
placeholder: 'My list',
required: true,
displayOptions: {
show: {
operation: ["create"],
resource: ["list"]
}
operation: [
'create',
],
resource: [
'list',
],
},
},
description: "The name of the list"
description: 'The name of the list'
},
{
displayName: "Additional Fields",
name: "additionalFields",
type: "collection",
placeholder: "Add Field",
displayName: 'Additional Fields',
name: 'additionalFields',
type: 'collection',
placeholder: 'Add Field',
displayOptions: {
show: {
operation: ["create"],
resource: ["list"]
}
operation: [
'create',
],
resource: [
'list',
],
},
},
default: {},
options: [
{
displayName: "List Source",
name: "idListSource",
type: "string",
default: "",
description: "ID of the list to copy into the new list."
displayName: 'List Source',
name: 'idListSource',
type: 'string',
default: '',
description: 'ID of the list to copy into the new list.'
},
{
displayName: "Position",
name: "pos",
type: "string",
default: "bottom",
displayName: 'Position',
name: 'pos',
type: 'string',
default: 'bottom',
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
// ----------------------------------
{
displayName: "List ID",
name: "id",
type: "string",
default: "",
displayName: 'List ID',
name: 'id',
type: 'string',
default: '',
required: true,
displayOptions: {
show: {
operation: ["get"],
resource: ["list"]
}
operation: [
'get',
],
resource: [
'list',
],
},
},
description: "The ID of the list to get."
description: 'The ID of the list to get.'
},
{
displayName: "Additional Fields",
name: "additionalFields",
type: "collection",
placeholder: "Add Field",
displayName: 'Additional Fields',
name: 'additionalFields',
type: 'collection',
placeholder: 'Add Field',
displayOptions: {
show: {
operation: ["get"],
resource: ["list"]
}
operation: [
'get',
],
resource: [
'list',
],
},
},
default: {},
options: [
{
displayName: "Fields",
name: "fields",
type: "string",
default: "all",
description:
'Fields to return. Either "all" or a comma-separated list of fields.'
displayName: 'Fields',
name: 'fields',
type: 'string',
default: 'all',
description: 'Fields to return. Either "all" or a comma-separated list of fields.'
}
]
},
@ -180,67 +211,75 @@ export const listFields = [
// list:update
// ----------------------------------
{
displayName: "List ID",
name: "id",
type: "string",
default: "",
displayName: 'List ID',
name: 'id',
type: 'string',
default: '',
required: true,
displayOptions: {
show: {
operation: ["update"],
resource: ["list"]
}
operation: [
'update',
],
resource: [
'list',
],
},
},
description: "The ID of the list to update."
description: 'The ID of the list to update.'
},
{
displayName: "Update Fields",
name: "updateFields",
type: "collection",
placeholder: "Add Field",
displayName: 'Update Fields',
name: 'updateFields',
type: 'collection',
placeholder: 'Add Field',
displayOptions: {
show: {
operation: ["update"],
resource: ["list"]
}
operation: [
'update',
],
resource: [
'list',
],
},
},
default: {},
options: [
{
displayName: "Board ID",
name: "idBoard",
type: "string",
default: "",
description: "ID of a board the list should be moved to."
displayName: 'Board ID',
name: 'idBoard',
type: 'string',
default: '',
description: 'ID of a board the list should be moved to.'
},
{
displayName: "Closed",
name: "closed",
type: "boolean",
displayName: 'Closed',
name: 'closed',
type: 'boolean',
default: false,
description: "Whether the list is closed."
description: 'Whether the list is closed.'
},
{
displayName: "Name",
name: "name",
type: "string",
default: "",
description: "New name of the list"
displayName: 'Name',
name: 'name',
type: 'string',
default: '',
description: 'New name of the list'
},
{
displayName: "Position",
name: "pos",
type: "string",
default: "bottom",
displayName: 'Position',
name: 'pos',
type: 'string',
default: 'bottom',
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",
name: "subscribed",
type: "boolean",
displayName: 'Subscribed',
name: 'subscribed',
type: 'boolean',
default: false,
description: "Whether the acting user is subscribed to the list."
description: 'Whether the acting user is subscribed to the list.'
}
]
}

View file

@ -1,4 +1,7 @@
import { IExecuteFunctions } from "n8n-core";
import {
IExecuteFunctions,
} from 'n8n-core';
import {
IDataObject,
INodeTypeDescription,
@ -6,13 +9,44 @@ import {
INodeType,
} from 'n8n-workflow';
import { apiRequest } from "./GenericFunctions";
import { attachmentOperations, attachmentFields } from './AttachmentDescription';
import { boardOperations, boardFields } from './BoardDescription';
import { cardOperations, cardFields } from './CardDescription';
import { checklistOperations, checklistFields } from './ChecklistDescription';
import { labelOperations, labelFields } from './LabelDescription';
import { listOperations, listFields } from './ListDescription';
import {
apiRequest,
} from './GenericFunctions';
import {
attachmentOperations,
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 {
description: INodeTypeDescription = {
@ -33,7 +67,7 @@ export class Trello implements INodeType {
{
name: 'trelloApi',
required: true,
}
},
],
properties: [
{
@ -53,6 +87,10 @@ export class Trello implements INodeType {
name: 'Card',
value: 'card',
},
{
name: 'Card Comment',
value: 'cardComment',
},
{
name: 'Checklist',
value: 'checklist',
@ -76,6 +114,7 @@ export class Trello implements INodeType {
...attachmentOperations,
...boardOperations,
...cardOperations,
...cardCommentOperations,
...checklistOperations,
...labelOperations,
...listOperations,
@ -86,15 +125,14 @@ export class Trello implements INodeType {
...attachmentFields,
...boardFields,
...cardFields,
...cardCommentFields,
...checklistFields,
...labelFields,
...listFields
],
};
async execute(this: IExecuteFunctions): Promise<INodeExecutionData[][]> {
const items = this.getInputData();
const returnData: IDataObject[] = [];
@ -236,6 +274,54 @@ export class Trello implements INodeType {
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') {
if (operation === 'archive') {