From 63a459ac92c4aefcc211617f03c5d0de9b262863 Mon Sep 17 00:00:00 2001 From: Ricardo Espinoza Date: Wed, 13 Jan 2021 04:45:41 -0500 Subject: [PATCH] :zap: Add filters to all getAll operations to Salesforce Node (#1292) MIME-Version: 1.0 Content-Type: text/plain; charset=UTF-8 Content-Transfer-Encoding: 8bit * :zap: Add filters to all get:All operations * :zap: Small fix * ⚡Add description to condition fields * :zap: Minor improvements to Salesforce-Node Co-authored-by: Harshil Co-authored-by: Jan Oberhauser --- .../nodes/Salesforce/AccountDescription.ts | 123 ++++++-- .../nodes/Salesforce/AccountInterface.ts | 2 +- .../nodes/Salesforce/AttachmentDescription.ts | 104 +++++-- .../nodes/Salesforce/AttachmentInterface.ts | 1 - .../nodes/Salesforce/CaseDescription.ts | 142 ++++++--- .../nodes/Salesforce/ContactDescription.ts | 139 ++++++--- .../nodes/Salesforce/ContactInterface.ts | 3 +- .../Salesforce/CustomObjectDescription.ts | 112 +++++-- .../nodes/Salesforce/FlowDescription.ts | 15 +- .../nodes/Salesforce/GenericFunctions.ts | 52 ++++ .../nodes/Salesforce/LeadDescription.ts | 130 +++++++-- .../nodes/Salesforce/LeadInterface.ts | 1 - .../nodes/Salesforce/NoteInterface.ts | 1 - .../Salesforce/OpportunityDescription.ts | 126 ++++++-- .../nodes/Salesforce/OpportunityInterface.ts | 3 +- .../nodes/Salesforce/Salesforce.node.ts | 274 ++++++++++++------ .../nodes/Salesforce/SearchDescription.ts | 52 ++++ .../nodes/Salesforce/TaskDescription.ts | 104 +++++-- .../nodes/Salesforce/TaskInterface.ts | 3 +- .../nodes/Salesforce/UserDescription.ts | 69 ++++- 20 files changed, 1132 insertions(+), 324 deletions(-) create mode 100644 packages/nodes-base/nodes/Salesforce/SearchDescription.ts diff --git a/packages/nodes-base/nodes/Salesforce/AccountDescription.ts b/packages/nodes-base/nodes/Salesforce/AccountDescription.ts index 1a181c2b23..35af86a2ff 100644 --- a/packages/nodes-base/nodes/Salesforce/AccountDescription.ts +++ b/packages/nodes-base/nodes/Salesforce/AccountDescription.ts @@ -58,9 +58,9 @@ export const accountOperations = [ export const accountFields = [ -/* -------------------------------------------------------------------------- */ -/* account:create */ -/* -------------------------------------------------------------------------- */ + /* -------------------------------------------------------------------------- */ + /* account:create */ + /* -------------------------------------------------------------------------- */ { displayName: 'Name', name: 'name', @@ -104,7 +104,7 @@ export const accountFields = [ loadOptionsMethod: 'getAccountSources', }, default: '', - description: 'The source of the account record', + description: 'The source of the account record.', }, { displayName: 'Annual Revenue', @@ -209,7 +209,7 @@ export const accountFields = [ name: 'jigsaw', type: 'string', default: '', - description: 'references the ID of a company in Data.com', + description: 'References the ID of a company in Data.com', }, { displayName: 'Industry', @@ -262,7 +262,7 @@ export const accountFields = [ description: 'Type of account', }, { - displayName: 'Parent Id', + displayName: 'Parent ID', name: 'parentId', type: 'string', default: '', @@ -312,9 +312,10 @@ export const accountFields = [ }, ], }, -/* -------------------------------------------------------------------------- */ -/* account:update */ -/* -------------------------------------------------------------------------- */ + + /* -------------------------------------------------------------------------- */ + /* account:update */ + /* -------------------------------------------------------------------------- */ { displayName: 'Account ID', name: 'accountId', @@ -331,7 +332,7 @@ export const accountFields = [ ], }, }, - description: 'Id of account that needs to be fetched', + description: 'ID of account that needs to be fetched.', }, { displayName: 'Update Fields', @@ -358,7 +359,7 @@ export const accountFields = [ loadOptionsMethod: 'getAccountSources', }, default: '', - description: 'The source of the account record', + description: 'The source of the account record.', }, { displayName: 'Annual Revenue', @@ -470,7 +471,7 @@ export const accountFields = [ name: 'jigsaw', type: 'string', default: '', - description: 'references the ID of a company in Data.com', + description: 'References the ID of a company in Data.com', }, { displayName: 'Owner', @@ -514,7 +515,7 @@ export const accountFields = [ description: 'Number of employees', }, { - displayName: 'Parent Id', + displayName: 'Parent ID', name: 'parentId', type: 'string', default: '', @@ -574,9 +575,9 @@ export const accountFields = [ ], }, -/* -------------------------------------------------------------------------- */ -/* account:get */ -/* -------------------------------------------------------------------------- */ + /* -------------------------------------------------------------------------- */ + /* account:get */ + /* -------------------------------------------------------------------------- */ { displayName: 'Account ID', name: 'accountId', @@ -593,11 +594,12 @@ export const accountFields = [ ], }, }, - description: 'Id of account that needs to be fetched', + description: 'ID of account that needs to be fetched.', }, -/* -------------------------------------------------------------------------- */ -/* account:delete */ -/* -------------------------------------------------------------------------- */ + + /* -------------------------------------------------------------------------- */ + /* account:delete */ + /* -------------------------------------------------------------------------- */ { displayName: 'Account ID', name: 'accountId', @@ -614,11 +616,12 @@ export const accountFields = [ ], }, }, - description: 'Id of account that needs to be fetched', + description: 'ID of account that needs to be fetched.', }, -/* -------------------------------------------------------------------------- */ -/* account:getAll */ -/* -------------------------------------------------------------------------- */ + + /* -------------------------------------------------------------------------- */ + /* account:getAll */ + /* -------------------------------------------------------------------------- */ { displayName: 'Return All', name: 'returnAll', @@ -684,11 +687,75 @@ export const accountFields = [ default: '', description: 'Fields to include separated by ,', }, + { + displayName: 'Conditions', + name: 'conditionsUi', + placeholder: 'Add Condition', + type: 'fixedCollection', + typeOptions: { + multipleValues: true, + }, + description: 'The condition to set.', + default: {}, + options: [ + { + name: 'conditionValues', + displayName: 'Condition', + values: [ + { + displayName: 'Field', + name: 'field', + type: 'options', + typeOptions: { + loadOptionsMethod: 'getAccountFields', + }, + default: '', + description: 'For date, number, or boolean, please use expressions', + }, + { + displayName: 'Operation', + name: 'operation', + type: 'options', + options: [ + { + name: '=', + value: 'equal', + }, + { + name: '>', + value: '>', + }, + { + name: '<', + value: '<', + }, + { + name: '>=', + value: '>=', + }, + { + name: '<=', + value: '<=', + }, + ], + default: 'equal', + }, + { + displayName: 'Value', + name: 'value', + type: 'string', + default: '', + }, + ], + }, + ], + }, ], }, -/* -------------------------------------------------------------------------- */ -/* account:addNote */ -/* -------------------------------------------------------------------------- */ + + /* -------------------------------------------------------------------------- */ + /* account:addNote */ + /* -------------------------------------------------------------------------- */ { displayName: 'Account ID', name: 'accountId', @@ -705,7 +772,7 @@ export const accountFields = [ ], }, }, - description: 'Id of account that needs to be fetched', + description: 'ID of account that needs to be fetched.', }, { displayName: 'Title', diff --git a/packages/nodes-base/nodes/Salesforce/AccountInterface.ts b/packages/nodes-base/nodes/Salesforce/AccountInterface.ts index c42b485105..af0468d93d 100644 --- a/packages/nodes-base/nodes/Salesforce/AccountInterface.ts +++ b/packages/nodes-base/nodes/Salesforce/AccountInterface.ts @@ -13,7 +13,7 @@ export interface IAccount { Description?: string; BillingState?: string; ShippingStreet?: string; - ShippingCity?:string; + ShippingCity?: string; AccountSource?: string; AnnualRevenue?: number; BillingStreet?: string; diff --git a/packages/nodes-base/nodes/Salesforce/AttachmentDescription.ts b/packages/nodes-base/nodes/Salesforce/AttachmentDescription.ts index 741d8dd911..9ea5454ef1 100644 --- a/packages/nodes-base/nodes/Salesforce/AttachmentDescription.ts +++ b/packages/nodes-base/nodes/Salesforce/AttachmentDescription.ts @@ -51,9 +51,9 @@ export const attachmentOperations = [ export const attachmentFields = [ -/* -------------------------------------------------------------------------- */ -/* attachment:create */ -/* -------------------------------------------------------------------------- */ + /* -------------------------------------------------------------------------- */ + /* attachment:create */ + /* -------------------------------------------------------------------------- */ { displayName: 'Parent ID', name: 'parentId', @@ -152,9 +152,10 @@ export const attachmentFields = [ }, ], }, -/* -------------------------------------------------------------------------- */ -/* attachment:update */ -/* -------------------------------------------------------------------------- */ + + /* -------------------------------------------------------------------------- */ + /* attachment:update */ + /* -------------------------------------------------------------------------- */ { displayName: 'Attachment ID', name: 'attachmentId', @@ -171,7 +172,7 @@ export const attachmentFields = [ ], }, }, - description: 'Id of attachment that needs to be fetched', + description: 'ID of attachment that needs to be fetched.', }, { displayName: 'Update Fields', @@ -224,7 +225,7 @@ export const attachmentFields = [ name: 'owner', type: 'options', typeOptions: { - loadOptionsMethod: 'getUsers', + loadOptionsMethod: 'getUsers', }, default: '', description: 'ID of the User who owns the attachment.', @@ -232,9 +233,9 @@ export const attachmentFields = [ ], }, -/* -------------------------------------------------------------------------- */ -/* attachment:get */ -/* -------------------------------------------------------------------------- */ + /* -------------------------------------------------------------------------- */ + /* attachment:get */ + /* -------------------------------------------------------------------------- */ { displayName: 'Attachment ID', name: 'attachmentId', @@ -251,11 +252,12 @@ export const attachmentFields = [ ], }, }, - description: 'Id of attachment that needs to be fetched', + description: 'ID of attachment that needs to be fetched.', }, -/* -------------------------------------------------------------------------- */ -/* attachment:delete */ -/* -------------------------------------------------------------------------- */ + + /* -------------------------------------------------------------------------- */ + /* attachment:delete */ + /* -------------------------------------------------------------------------- */ { displayName: 'Attachment ID', name: 'attachmentId', @@ -272,11 +274,12 @@ export const attachmentFields = [ ], }, }, - description: 'Id of attachment that needs to be fetched', + description: 'ID of attachment that needs to be fetched.', }, -/* -------------------------------------------------------------------------- */ -/* attachment:getAll */ -/* -------------------------------------------------------------------------- */ + + /* -------------------------------------------------------------------------- */ + /* attachment:getAll */ + /* -------------------------------------------------------------------------- */ { displayName: 'Return All', name: 'returnAll', @@ -335,6 +338,69 @@ export const attachmentFields = [ }, }, options: [ + { + displayName: 'Conditions', + name: 'conditionsUi', + placeholder: 'Add Condition', + type: 'fixedCollection', + typeOptions: { + multipleValues: true, + }, + description: 'The condition to set.', + default: {}, + options: [ + { + name: 'conditionValues', + displayName: 'Condition', + values: [ + { + displayName: 'Field', + name: 'field', + type: 'options', + typeOptions: { + loadOptionsMethod: 'getAtachmentFields', + }, + default: '', + description: 'For date, number, or boolean, please use expressions.', + }, + { + displayName: 'Operation', + name: 'operation', + type: 'options', + options: [ + { + name: '=', + value: 'equal', + }, + { + name: '>', + value: '>', + }, + { + name: '<', + value: '<', + }, + { + name: '>=', + value: '>=', + }, + { + name: '<=', + value: '<=', + }, + ], + default: 'equal', + }, + { + displayName: 'Value', + name: 'value', + type: 'string', + default: '', + }, + ], + }, + ], + }, { displayName: 'Fields', name: 'fields', diff --git a/packages/nodes-base/nodes/Salesforce/AttachmentInterface.ts b/packages/nodes-base/nodes/Salesforce/AttachmentInterface.ts index e63558a496..e26b2a9c87 100644 --- a/packages/nodes-base/nodes/Salesforce/AttachmentInterface.ts +++ b/packages/nodes-base/nodes/Salesforce/AttachmentInterface.ts @@ -1,4 +1,3 @@ - export interface IAttachment { ParentId?: string; Name?: string; diff --git a/packages/nodes-base/nodes/Salesforce/CaseDescription.ts b/packages/nodes-base/nodes/Salesforce/CaseDescription.ts index f703414a1b..381d5085fb 100644 --- a/packages/nodes-base/nodes/Salesforce/CaseDescription.ts +++ b/packages/nodes-base/nodes/Salesforce/CaseDescription.ts @@ -36,7 +36,7 @@ export const caseOperations = [ { name: 'Get Summary', value: 'getSummary', - description: `Returns an overview of case's metadata.`, + description: `Returns an overview of case's metadata`, }, { name: 'Delete', @@ -56,16 +56,16 @@ export const caseOperations = [ export const caseFields = [ -/* -------------------------------------------------------------------------- */ -/* case:create */ -/* -------------------------------------------------------------------------- */ + /* -------------------------------------------------------------------------- */ + /* case:create */ + /* -------------------------------------------------------------------------- */ { displayName: 'Type', name: 'type', type: 'options', required: true, typeOptions: { - loadOptionsMethod: 'getCaseTypes', + loadOptionsMethod: 'getCaseTypes', }, displayOptions: { show: { @@ -98,18 +98,18 @@ export const caseFields = [ }, options: [ { - displayName: 'Account Id', + displayName: 'Account ID', name: 'accountId', type: 'string', default: '', description: 'ID of the account associated with this case.', }, { - displayName: 'Contact Id', + displayName: 'Contact ID', name: 'contactId', type: 'string', default: '', - description: 'IID of the associated Contact.', + description: 'ID of the associated Contact.', }, { displayName: 'Description', @@ -130,7 +130,7 @@ export const caseFields = [ name: 'origin', type: 'options', typeOptions: { - loadOptionsMethod: 'getCaseOrigins', + loadOptionsMethod: 'getCaseOrigins', }, default: '', description: 'The source of the case, such as Email, Phone, or Web. Label is Case Origin.', @@ -146,7 +146,7 @@ export const caseFields = [ description: 'The owner of the case.', }, { - displayName: 'Parent Id', + displayName: 'Parent ID', name: 'ParentId', type: 'string', default: '', @@ -167,7 +167,7 @@ export const caseFields = [ name: 'reason', type: 'options', typeOptions: { - loadOptionsMethod: 'getCaseReasons', + loadOptionsMethod: 'getCaseReasons', }, default: '', description: 'The reason why the case was created, such as Instructions not clear, or User didn’t attend training.', @@ -177,7 +177,7 @@ export const caseFields = [ name: 'status', type: 'options', typeOptions: { - loadOptionsMethod: 'getCaseStatuses', + loadOptionsMethod: 'getCaseStatuses', }, default: '', description: 'The status of the case, such as “New,” “Closed,” or “Escalated.” This field directly controls the IsClosed flag', @@ -219,9 +219,10 @@ export const caseFields = [ }, ], }, -/* -------------------------------------------------------------------------- */ -/* case:update */ -/* -------------------------------------------------------------------------- */ + + /* -------------------------------------------------------------------------- */ + /* case:update */ + /* -------------------------------------------------------------------------- */ { displayName: 'Case ID', name: 'caseId', @@ -262,7 +263,7 @@ export const caseFields = [ name: 'type', type: 'options', typeOptions: { - loadOptionsMethod: 'getCaseTypes', + loadOptionsMethod: 'getCaseTypes', }, default: '', description: 'The type of case', @@ -272,7 +273,7 @@ export const caseFields = [ name: 'origin', type: 'options', typeOptions: { - loadOptionsMethod: 'getCaseOrigins', + loadOptionsMethod: 'getCaseOrigins', }, default: '', description: 'The source of the case, such as Email, Phone, or Web. Label is Case Origin.', @@ -282,7 +283,7 @@ export const caseFields = [ name: 'reason', type: 'options', typeOptions: { - loadOptionsMethod: 'getCaseReasons', + loadOptionsMethod: 'getCaseReasons', }, default: '', description: 'The reason why the case was created, such as Instructions not clear, or User didn’t attend training.', @@ -292,7 +293,7 @@ export const caseFields = [ name: 'status', type: 'options', typeOptions: { - loadOptionsMethod: 'getCaseStatuses', + loadOptionsMethod: 'getCaseStatuses', }, default: '', description: 'The status of the case, such as “New,” “Closed,” or “Escalated.” This field directly controls the IsClosed flag', @@ -315,7 +316,7 @@ export const caseFields = [ description: 'The subject of the case. Limit: 255 characters.', }, { - displayName: 'Parent Id', + displayName: 'Parent ID', name: 'ParentId', type: 'string', default: '', @@ -332,18 +333,18 @@ export const caseFields = [ description: 'The importance or urgency of the case, such as High, Medium, or Low.', }, { - displayName: 'Account Id', + displayName: 'Account ID', name: 'accountId', type: 'string', default: '', description: 'ID of the account associated with this case.', }, { - displayName: 'Contact Id', + displayName: 'Contact ID', name: 'contactId', type: 'string', default: '', - description: 'IID of the associated Contact.', + description: 'ID of the associated Contact.', }, { displayName: 'Description', @@ -390,9 +391,9 @@ export const caseFields = [ ], }, -/* -------------------------------------------------------------------------- */ -/* case:get */ -/* -------------------------------------------------------------------------- */ + /* -------------------------------------------------------------------------- */ + /* case:get */ + /* -------------------------------------------------------------------------- */ { displayName: 'Case ID', name: 'caseId', @@ -409,11 +410,12 @@ export const caseFields = [ ], }, }, - description: 'Id of case that needs to be fetched', + description: 'ID of case that needs to be fetched.', }, -/* -------------------------------------------------------------------------- */ -/* case:delete */ -/* -------------------------------------------------------------------------- */ + + /* -------------------------------------------------------------------------- */ + /* case:delete */ + /* -------------------------------------------------------------------------- */ { displayName: 'Case ID', name: 'caseId', @@ -430,11 +432,12 @@ export const caseFields = [ ], }, }, - description: 'Id of case that needs to be fetched', + description: 'ID of case that needs to be fetched.', }, -/* -------------------------------------------------------------------------- */ -/* case:getAll */ -/* -------------------------------------------------------------------------- */ + + /* -------------------------------------------------------------------------- */ + /* case:getAll */ + /* -------------------------------------------------------------------------- */ { displayName: 'Return All', name: 'returnAll', @@ -493,6 +496,69 @@ export const caseFields = [ }, }, options: [ + { + displayName: 'Conditions', + name: 'conditionsUi', + placeholder: 'Add Condition', + type: 'fixedCollection', + typeOptions: { + multipleValues: true, + }, + description: 'The condition to set.', + default: {}, + options: [ + { + name: 'conditionValues', + displayName: 'Condition', + values: [ + { + displayName: 'Field', + name: 'field', + type: 'options', + typeOptions: { + loadOptionsMethod: 'getCaseFields', + }, + default: '', + description: 'For date, number, or boolean, please use expressions.', + }, + { + displayName: 'Operation', + name: 'operation', + type: 'options', + options: [ + { + name: '=', + value: 'equal', + }, + { + name: '>', + value: '>', + }, + { + name: '<', + value: '<', + }, + { + name: '>=', + value: '>=', + }, + { + name: '<=', + value: '<=', + }, + ], + default: 'equal', + }, + { + displayName: 'Value', + name: 'value', + type: 'string', + default: '', + }, + ], + }, + ], + }, { displayName: 'Fields', name: 'fields', @@ -503,9 +569,9 @@ export const caseFields = [ ], }, -/* -------------------------------------------------------------------------- */ -/* case:addComment */ -/* -------------------------------------------------------------------------- */ + /* -------------------------------------------------------------------------- */ + /* case:addComment */ + /* -------------------------------------------------------------------------- */ { displayName: 'Case ID', name: 'caseId', @@ -522,7 +588,7 @@ export const caseFields = [ ], }, }, - description: 'Id of case that needs to be fetched', + description: 'ID of case that needs to be fetched.', }, { displayName: 'Options', diff --git a/packages/nodes-base/nodes/Salesforce/ContactDescription.ts b/packages/nodes-base/nodes/Salesforce/ContactDescription.ts index 39d437209d..aac14a6a75 100644 --- a/packages/nodes-base/nodes/Salesforce/ContactDescription.ts +++ b/packages/nodes-base/nodes/Salesforce/ContactDescription.ts @@ -43,7 +43,7 @@ export const contactOperations = [ { name: 'Get Summary', value: 'getSummary', - description: `Returns an overview of contact's metadata.`, + description: `Returns an overview of contact's metadata`, }, { name: 'Get All', @@ -63,9 +63,9 @@ export const contactOperations = [ export const contactFields = [ -/* -------------------------------------------------------------------------- */ -/* contact:create */ -/* -------------------------------------------------------------------------- */ + /* -------------------------------------------------------------------------- */ + /* contact:create */ + /* -------------------------------------------------------------------------- */ { displayName: 'Last Name', name: 'lastname', @@ -335,13 +335,6 @@ export const contactFields = [ default: '', description: 'Phone number for the contact.', }, - { - displayName: 'Title', - name: 'title', - type: 'string', - default: '', - description: 'Title of the contact such as CEO or Vice President.', - }, { displayName: 'Salutation', name: 'salutation', @@ -349,11 +342,19 @@ export const contactFields = [ default: '', description: 'Honorific abbreviation, word, or phrase to be used in front of name in greetings, such as Dr. or Mrs.', }, + { + displayName: 'Title', + name: 'title', + type: 'string', + default: '', + description: 'Title of the contact such as CEO or Vice President.', + }, ], }, -/* -------------------------------------------------------------------------- */ -/* contact:update */ -/* -------------------------------------------------------------------------- */ + + /* -------------------------------------------------------------------------- */ + /* contact:update */ + /* -------------------------------------------------------------------------- */ { displayName: 'Contact ID', name: 'contactId', @@ -370,7 +371,7 @@ export const contactFields = [ ], }, }, - description: 'Id of contact that needs to be fetched', + description: 'ID of contact that needs to be fetched.', }, { displayName: 'Update Fields', @@ -640,9 +641,9 @@ export const contactFields = [ ], }, -/* -------------------------------------------------------------------------- */ -/* contact:get */ -/* -------------------------------------------------------------------------- */ + /* -------------------------------------------------------------------------- */ + /* contact:get */ + /* -------------------------------------------------------------------------- */ { displayName: 'Contact ID', name: 'contactId', @@ -659,11 +660,12 @@ export const contactFields = [ ], }, }, - description: 'Id of contact that needs to be fetched', + description: 'ID of contact that needs to be fetched.', }, -/* -------------------------------------------------------------------------- */ -/* contact:delete */ -/* -------------------------------------------------------------------------- */ + + /* -------------------------------------------------------------------------- */ + /* contact:delete */ + /* -------------------------------------------------------------------------- */ { displayName: 'Contact ID', name: 'contactId', @@ -680,11 +682,12 @@ export const contactFields = [ ], }, }, - description: 'Id of contact that needs to be fetched', + description: 'ID of contact that needs to be fetched', }, -/* -------------------------------------------------------------------------- */ -/* contact:getAll */ -/* -------------------------------------------------------------------------- */ + + /* -------------------------------------------------------------------------- */ + /* contact:getAll */ + /* -------------------------------------------------------------------------- */ { displayName: 'Return All', name: 'returnAll', @@ -743,6 +746,69 @@ export const contactFields = [ }, }, options: [ + { + displayName: 'Conditions', + name: 'conditionsUi', + placeholder: 'Add Condition', + type: 'fixedCollection', + typeOptions: { + multipleValues: true, + }, + description: 'The condition to set.', + default: {}, + options: [ + { + name: 'conditionValues', + displayName: 'Condition', + values: [ + { + displayName: 'Field', + name: 'field', + type: 'options', + typeOptions: { + loadOptionsMethod: 'getContactFields', + }, + default: '', + description: 'For date, number, or boolean, please use expressions.', + }, + { + displayName: 'Operation', + name: 'operation', + type: 'options', + options: [ + { + name: '=', + value: 'equal', + }, + { + name: '>', + value: '>', + }, + { + name: '<', + value: '<', + }, + { + name: '>=', + value: '>=', + }, + { + name: '<=', + value: '<=', + }, + ], + default: 'equal', + }, + { + displayName: 'Value', + name: 'value', + type: 'string', + default: '', + }, + ], + }, + ], + }, { displayName: 'Fields', name: 'fields', @@ -753,9 +819,9 @@ export const contactFields = [ ], }, -/* -------------------------------------------------------------------------- */ -/* contact:addToCampaign */ -/* -------------------------------------------------------------------------- */ + /* -------------------------------------------------------------------------- */ + /* contact:addToCampaign */ + /* -------------------------------------------------------------------------- */ { displayName: 'Contact ID', name: 'contactId', @@ -772,7 +838,7 @@ export const contactFields = [ ], }, }, - description: 'Id of contact that needs to be fetched', + description: 'ID of contact that needs to be fetched.', }, { displayName: 'Campaign', @@ -793,7 +859,7 @@ export const contactFields = [ ], }, }, - description: 'Id of the campaign that needs to be fetched', + description: 'ID of the campaign that needs to be fetched.', }, { displayName: 'Options', @@ -817,13 +883,14 @@ export const contactFields = [ name: 'status', type: 'string', default: '', - description: 'Controls the HasResponded flag on this object', + description: 'Controls the HasResponded flag on this object.', }, ], }, -/* -------------------------------------------------------------------------- */ -/* contact:addNote */ -/* -------------------------------------------------------------------------- */ + + /* -------------------------------------------------------------------------- */ + /* contact:addNote */ + /* -------------------------------------------------------------------------- */ { displayName: 'Contact ID', name: 'contactId', @@ -840,7 +907,7 @@ export const contactFields = [ ], }, }, - description: 'Id of contact that needs to be fetched', + description: 'ID of contact that needs to be fetched.', }, { displayName: 'Title', diff --git a/packages/nodes-base/nodes/Salesforce/ContactInterface.ts b/packages/nodes-base/nodes/Salesforce/ContactInterface.ts index e51090b88f..2a3a9784bc 100644 --- a/packages/nodes-base/nodes/Salesforce/ContactInterface.ts +++ b/packages/nodes-base/nodes/Salesforce/ContactInterface.ts @@ -1,4 +1,3 @@ - export interface IContact { LastName?: string; Fax?: string; @@ -8,7 +7,7 @@ export interface IContact { Jigsaw?: string; OwnerId?: string; AccountId?: string; - Birthdate?:string; + Birthdate?: string; FirstName?: string; HomePhone?: string; OtherCity?: string; diff --git a/packages/nodes-base/nodes/Salesforce/CustomObjectDescription.ts b/packages/nodes-base/nodes/Salesforce/CustomObjectDescription.ts index 921b6c5aac..1e55cf54a3 100644 --- a/packages/nodes-base/nodes/Salesforce/CustomObjectDescription.ts +++ b/packages/nodes-base/nodes/Salesforce/CustomObjectDescription.ts @@ -48,9 +48,9 @@ export const customObjectOperations = [ export const customObjectFields = [ -/* -------------------------------------------------------------------------- */ -/* customObject:create */ -/* -------------------------------------------------------------------------- */ + /* -------------------------------------------------------------------------- */ + /* customObject:create */ + /* -------------------------------------------------------------------------- */ { displayName: 'Custom Object', name: 'customObject', @@ -70,7 +70,7 @@ export const customObjectFields = [ ], }, }, - description: 'Name of the custom object', + description: 'Name of the custom object.', }, { displayName: 'Fields', @@ -90,7 +90,7 @@ export const customObjectFields = [ ], }, }, - description: 'Filter by custom fields ', + description: 'Filter by custom fields.', default: {}, options: [ { @@ -121,9 +121,10 @@ export const customObjectFields = [ }, ], }, -/* -------------------------------------------------------------------------- */ -/* customObject:update */ -/* -------------------------------------------------------------------------- */ + + /* -------------------------------------------------------------------------- */ + /* customObject:update */ + /* -------------------------------------------------------------------------- */ { displayName: 'Custom Object', name: 'customObject', @@ -161,7 +162,7 @@ export const customObjectFields = [ ], }, }, - description: 'Record id to be updated', + description: 'Record ID to be updated.', }, { displayName: 'Fields', @@ -212,9 +213,10 @@ export const customObjectFields = [ }, ], }, -/* -------------------------------------------------------------------------- */ -/* customObject:get */ -/* -------------------------------------------------------------------------- */ + + /* -------------------------------------------------------------------------- */ + /* customObject:get */ + /* -------------------------------------------------------------------------- */ { displayName: 'Custom Object', name: 'customObject', @@ -252,11 +254,12 @@ export const customObjectFields = [ ], }, }, - description: 'Record id to be retrieved', + description: 'Record ID to be retrieved.', }, -/* -------------------------------------------------------------------------- */ -/* customObject:delete */ -/* -------------------------------------------------------------------------- */ + + /* -------------------------------------------------------------------------- */ + /* customObject:delete */ + /* -------------------------------------------------------------------------- */ { displayName: 'Custom Object', name: 'customObject', @@ -276,7 +279,7 @@ export const customObjectFields = [ ], }, }, - description: 'Name of the custom object', + description: 'Name of the custom object.', }, { displayName: 'Record ID', @@ -294,11 +297,12 @@ export const customObjectFields = [ ], }, }, - description: 'Record id to be deleted', + description: 'Record ID to be deleted.', }, -/* -------------------------------------------------------------------------- */ -/* customObject:getAll */ -/* -------------------------------------------------------------------------- */ + + /* -------------------------------------------------------------------------- */ + /* customObject:getAll */ + /* -------------------------------------------------------------------------- */ { displayName: 'Custom Object', name: 'customObject', @@ -378,6 +382,72 @@ export const customObjectFields = [ }, }, options: [ + { + displayName: 'Conditions', + name: 'conditionsUi', + placeholder: 'Add Condition', + type: 'fixedCollection', + typeOptions: { + multipleValues: true, + }, + description: 'The condition to set.', + default: {}, + options: [ + { + name: 'conditionValues', + displayName: 'Condition', + values: [ + { + displayName: 'Field', + name: 'field', + type: 'options', + typeOptions: { + loadOptionsMethod: 'getCustomObjectFields', + loadOptionsDependsOn: [ + 'customObject', + ], + }, + default: '', + description: 'For date, number, or boolean, please use expressions.', + }, + { + displayName: 'Operation', + name: 'operation', + type: 'options', + options: [ + { + name: '=', + value: 'equal', + }, + { + name: '>', + value: '>', + }, + { + name: '<', + value: '<', + }, + { + name: '>=', + value: '>=', + }, + { + name: '<=', + value: '<=', + }, + ], + default: 'equal', + }, + { + displayName: 'Value', + name: 'value', + type: 'string', + default: '', + }, + ], + }, + ], + }, { displayName: 'Fields', name: 'fields', diff --git a/packages/nodes-base/nodes/Salesforce/FlowDescription.ts b/packages/nodes-base/nodes/Salesforce/FlowDescription.ts index ae81f900ff..49a6af771f 100644 --- a/packages/nodes-base/nodes/Salesforce/FlowDescription.ts +++ b/packages/nodes-base/nodes/Salesforce/FlowDescription.ts @@ -33,9 +33,9 @@ export const flowOperations = [ export const flowFields = [ -/* -------------------------------------------------------------------------- */ -/* flow:getAll */ -/* -------------------------------------------------------------------------- */ + /* -------------------------------------------------------------------------- */ + /* flow:getAll */ + /* -------------------------------------------------------------------------- */ { displayName: 'Return All', name: 'returnAll', @@ -77,9 +77,10 @@ export const flowFields = [ default: 100, description: 'How many results to return.', }, -/* -------------------------------------------------------------------------- */ -/* flow:invoke */ -/* -------------------------------------------------------------------------- */ + + /* -------------------------------------------------------------------------- */ + /* flow:invoke */ + /* -------------------------------------------------------------------------- */ { displayName: 'API Name', name: 'apiName', @@ -133,7 +134,7 @@ export const flowFields = [ }, }, default: '', - description: 'Input variables as JSON object', + description: 'Input variables as JSON object.', }, { displayName: 'Variables', diff --git a/packages/nodes-base/nodes/Salesforce/GenericFunctions.ts b/packages/nodes-base/nodes/Salesforce/GenericFunctions.ts index 8dd761acb9..a90a2d22e7 100644 --- a/packages/nodes-base/nodes/Salesforce/GenericFunctions.ts +++ b/packages/nodes-base/nodes/Salesforce/GenericFunctions.ts @@ -134,3 +134,55 @@ function getAccessToken(this: IExecuteFunctions | IExecuteSingleFunctions | ILoa //@ts-ignore return this.helpers.request(options); } + +export function getConditions(options: IDataObject) { + const conditions = (options.conditionsUi as IDataObject || {}).conditionValues as IDataObject[]; + let data = undefined; + if (Array.isArray(conditions) && conditions.length !== 0) { + data = conditions.map((condition: IDataObject) => `${condition.field}${(condition.operation) === 'equal' ? '=' : condition.operation}${getValue(condition.value)}`); + console.log(data); + data = `WHERE ${data.join(' AND ')}`; + } + return data; +} + +export function getDefaultFields(sobject: string) { + return ( + { + 'Account': 'id,name,type', + 'Lead': 'id,company,firstname,lastname,street,postalCode,city,email,status', + 'Contact': 'id,firstname,lastname,email', + 'Opportunity': 'id,accountId,amount,probability,type', + 'Case': 'id,accountId,contactId,priority,status,subject,type', + 'Task': 'id,subject,status,priority', + 'Attachment': 'id,name', + 'User': 'id,name,email', + } as IDataObject + )[sobject]; +} + +export function getQuery(options: IDataObject, sobject: string, returnAll: boolean, limit = 0) { + const fields: string[] = []; + if (options.fields) { + fields.push.apply(fields, (options.fields as string).split(',')); + } else { + fields.push.apply(fields, (getDefaultFields(sobject) as string || 'id').split(',')); + } + const conditions = getConditions(options); + + let query = `SELECT ${fields.join(',')} FROM ${sobject} ${(conditions ? conditions : '')}`; + + if (returnAll === false) { + query = `SELECT ${fields.join(',')} FROM ${sobject} ${(conditions ? conditions : '')} LIMIT ${limit}`; + } + + return query; +} + +export function getValue(value: any) { + if (typeof value === 'string') { + return `'${value}'`; + } else { + return value; + } +} diff --git a/packages/nodes-base/nodes/Salesforce/LeadDescription.ts b/packages/nodes-base/nodes/Salesforce/LeadDescription.ts index c40b25752f..802b20c3bd 100644 --- a/packages/nodes-base/nodes/Salesforce/LeadDescription.ts +++ b/packages/nodes-base/nodes/Salesforce/LeadDescription.ts @@ -48,7 +48,7 @@ export const leadOperations = [ { name: 'Get Summary', value: 'getSummary', - description: `Returns an overview of Lead's metadata.`, + description: `Returns an overview of Lead's metadata`, }, { name: 'Update', @@ -63,9 +63,9 @@ export const leadOperations = [ export const leadFields = [ -/* -------------------------------------------------------------------------- */ -/* lead:create */ -/* -------------------------------------------------------------------------- */ + /* -------------------------------------------------------------------------- */ + /* lead:create */ + /* -------------------------------------------------------------------------- */ { displayName: 'Company', name: 'company', @@ -299,7 +299,7 @@ export const leadFields = [ name: 'street', type: 'string', default: '', - description: 'Street number and name for the address of the lead', + description: 'Street number and name for the address of the lead.', }, { displayName: 'Title', @@ -317,9 +317,10 @@ export const leadFields = [ }, ], }, -/* -------------------------------------------------------------------------- */ -/* lead:update */ -/* -------------------------------------------------------------------------- */ + + /* -------------------------------------------------------------------------- */ + /* lead:update */ + /* -------------------------------------------------------------------------- */ { displayName: 'Lead ID', name: 'leadId', @@ -336,7 +337,7 @@ export const leadFields = [ ], }, }, - description: 'Id of Lead that needs to be fetched', + description: 'ID of Lead that needs to be fetched.', }, { displayName: 'Update Fields', @@ -549,7 +550,7 @@ export const leadFields = [ name: 'street', type: 'string', default: '', - description: 'Street number and name for the address of the lead', + description: 'Street number and name for the address of the lead.', }, { displayName: 'Title', @@ -568,9 +569,9 @@ export const leadFields = [ ], }, -/* -------------------------------------------------------------------------- */ -/* lead:get */ -/* -------------------------------------------------------------------------- */ + /* -------------------------------------------------------------------------- */ + /* lead:get */ + /* -------------------------------------------------------------------------- */ { displayName: 'Lead ID', name: 'leadId', @@ -587,11 +588,12 @@ export const leadFields = [ ], }, }, - description: 'Id of Lead that needs to be fetched', + description: 'ID of Lead that needs to be fetched.', }, -/* -------------------------------------------------------------------------- */ -/* lead:delete */ -/* -------------------------------------------------------------------------- */ + + /* -------------------------------------------------------------------------- */ + /* lead:delete */ + /* -------------------------------------------------------------------------- */ { displayName: 'Lead ID', name: 'leadId', @@ -608,11 +610,12 @@ export const leadFields = [ ], }, }, - description: 'Id of Lead that needs to be fetched', + description: 'ID of Lead that needs to be fetched.', }, -/* -------------------------------------------------------------------------- */ -/* lead:getAll */ -/* -------------------------------------------------------------------------- */ + + /* -------------------------------------------------------------------------- */ + /* lead:getAll */ + /* -------------------------------------------------------------------------- */ { displayName: 'Return All', name: 'returnAll', @@ -671,6 +674,69 @@ export const leadFields = [ }, }, options: [ + { + displayName: 'Conditions', + name: 'conditionsUi', + placeholder: 'Add Condition', + type: 'fixedCollection', + typeOptions: { + multipleValues: true, + }, + description: 'The condition to set.', + default: {}, + options: [ + { + name: 'conditionValues', + displayName: 'Condition', + values: [ + { + displayName: 'Field', + name: 'field', + type: 'options', + typeOptions: { + loadOptionsMethod: 'getLeadFields', + }, + default: '', + description: 'For date, number, or boolean, please use expressions.', + }, + { + displayName: 'Operation', + name: 'operation', + type: 'options', + options: [ + { + name: '=', + value: 'equal', + }, + { + name: '>', + value: '>', + }, + { + name: '<', + value: '<', + }, + { + name: '>=', + value: '>=', + }, + { + name: '<=', + value: '<=', + }, + ], + default: 'equal', + }, + { + displayName: 'Value', + name: 'value', + type: 'string', + default: '', + }, + ], + }, + ], + }, { displayName: 'Fields', name: 'fields', @@ -680,9 +746,10 @@ export const leadFields = [ }, ], }, -/* -------------------------------------------------------------------------- */ -/* contact:addToCampaign */ -/* -------------------------------------------------------------------------- */ + + /* -------------------------------------------------------------------------- */ + /* contact:addToCampaign */ + /* -------------------------------------------------------------------------- */ { displayName: 'Lead ID', name: 'leadId', @@ -699,7 +766,7 @@ export const leadFields = [ ], }, }, - description: 'Id of contact that needs to be fetched', + description: 'ID of contact that needs to be fetched.', }, { displayName: 'Campaign', @@ -720,7 +787,7 @@ export const leadFields = [ ], }, }, - description: 'Id of the campaign that needs to be fetched', + description: 'ID of the campaign that needs to be fetched.', }, { displayName: 'Options', @@ -744,13 +811,14 @@ export const leadFields = [ name: 'status', type: 'string', default: '', - description: 'Controls the HasResponded flag on this object', + description: 'Controls the HasResponded flag on this object.', }, ], }, -/* -------------------------------------------------------------------------- */ -/* lead:addNote */ -/* -------------------------------------------------------------------------- */ + + /* -------------------------------------------------------------------------- */ + /* lead:addNote */ + /* -------------------------------------------------------------------------- */ { displayName: 'Lead ID', name: 'leadId', @@ -767,7 +835,7 @@ export const leadFields = [ ], }, }, - description: 'Id of lead that needs to be fetched', + description: 'ID of lead that needs to be fetched.', }, { displayName: 'Title', diff --git a/packages/nodes-base/nodes/Salesforce/LeadInterface.ts b/packages/nodes-base/nodes/Salesforce/LeadInterface.ts index c6cd047394..227e5fe255 100644 --- a/packages/nodes-base/nodes/Salesforce/LeadInterface.ts +++ b/packages/nodes-base/nodes/Salesforce/LeadInterface.ts @@ -1,4 +1,3 @@ - export interface ILead { Company?: string; LastName?: string; diff --git a/packages/nodes-base/nodes/Salesforce/NoteInterface.ts b/packages/nodes-base/nodes/Salesforce/NoteInterface.ts index 2036cfea21..b3b38158f6 100644 --- a/packages/nodes-base/nodes/Salesforce/NoteInterface.ts +++ b/packages/nodes-base/nodes/Salesforce/NoteInterface.ts @@ -1,4 +1,3 @@ - export interface INote { Title?: string; ParentId?: string; diff --git a/packages/nodes-base/nodes/Salesforce/OpportunityDescription.ts b/packages/nodes-base/nodes/Salesforce/OpportunityDescription.ts index cd9ac0642e..0529207a48 100644 --- a/packages/nodes-base/nodes/Salesforce/OpportunityDescription.ts +++ b/packages/nodes-base/nodes/Salesforce/OpportunityDescription.ts @@ -43,7 +43,7 @@ export const opportunityOperations = [ { name: 'Get Summary', value: 'getSummary', - description: `Returns an overview of opportunity's metadata.`, + description: `Returns an overview of opportunity's metadata`, }, { name: 'Update', @@ -58,9 +58,9 @@ export const opportunityOperations = [ export const opportunityFields = [ -/* -------------------------------------------------------------------------- */ -/* opportunity:create */ -/* -------------------------------------------------------------------------- */ + /* -------------------------------------------------------------------------- */ + /* opportunity:create */ + /* -------------------------------------------------------------------------- */ { displayName: 'Name', name: 'name', @@ -163,7 +163,7 @@ export const opportunityFields = [ loadOptionsMethod: 'getCampaigns', }, default: '', - description: 'Id of the campaign that needs to be fetched', + description: 'ID of the campaign that needs to be fetched.', }, { displayName: 'Custom Fields', @@ -250,7 +250,7 @@ export const opportunityFields = [ description: 'Phone number for the opportunity.', }, { - displayName: 'Pricebook2 Id', + displayName: 'Pricebook2 ID', name: 'pricebook2Id', type: 'string', default: '', @@ -285,9 +285,10 @@ export const opportunityFields = [ }, ], }, -/* -------------------------------------------------------------------------- */ -/* opportunity:update */ -/* -------------------------------------------------------------------------- */ + + /* -------------------------------------------------------------------------- */ + /* opportunity:update */ + /* -------------------------------------------------------------------------- */ { displayName: 'Opportunity ID', name: 'opportunityId', @@ -304,7 +305,7 @@ export const opportunityFields = [ ], }, }, - description: 'Id of opportunity that needs to be fetched', + description: 'ID of opportunity that needs to be fetched.', }, { displayName: 'Update Fields', @@ -341,7 +342,7 @@ export const opportunityFields = [ numberPrecision: 2, }, default: '', - description: 'Estimated total sale amount', + description: 'Estimated total sale amount.', }, { displayName: 'Campaign', @@ -351,7 +352,7 @@ export const opportunityFields = [ loadOptionsMethod: 'getCampaigns', }, default: '', - description: 'Id of the campaign that needs to be fetched', + description: 'ID of the campaign that needs to be fetched.', }, { displayName: 'Close Date', @@ -408,7 +409,7 @@ export const opportunityFields = [ name: 'forecastCategoryName', type: 'string', default: '', - description: 'It is implied, but not directly controlled, by the StageName field', + description: 'It is implied, but not directly controlled, by the StageName field.', }, { displayName: 'Lead Source', @@ -452,7 +453,7 @@ export const opportunityFields = [ description: 'Phone number for the opportunity.', }, { - displayName: 'Pricebook2 Id', + displayName: 'Pricebook2 ID', name: 'pricebook2Id', type: 'string', default: '', @@ -466,7 +467,7 @@ export const opportunityFields = [ numberPrecision: 1, }, default: '', - description: 'Percentage of estimated confidence in closing the opportunity', + description: 'Percentage of estimated confidence in closing the opportunity.', }, { displayName: 'Stage Name', @@ -498,9 +499,9 @@ export const opportunityFields = [ ], }, -/* -------------------------------------------------------------------------- */ -/* opportunity:get */ -/* -------------------------------------------------------------------------- */ + /* -------------------------------------------------------------------------- */ + /* opportunity:get */ + /* -------------------------------------------------------------------------- */ { displayName: 'Opportunity ID', name: 'opportunityId', @@ -517,11 +518,12 @@ export const opportunityFields = [ ], }, }, - description: 'Id of opportunity that needs to be fetched', + description: 'ID of opportunity that needs to be fetched.', }, -/* -------------------------------------------------------------------------- */ -/* opportunity:delete */ -/* -------------------------------------------------------------------------- */ + + /* -------------------------------------------------------------------------- */ + /* opportunity:delete */ + /* -------------------------------------------------------------------------- */ { displayName: 'Opportunity ID', name: 'opportunityId', @@ -538,11 +540,12 @@ export const opportunityFields = [ ], }, }, - description: 'Id of opportunity that needs to be fetched', + description: 'ID of opportunity that needs to be fetched.', }, -/* -------------------------------------------------------------------------- */ -/* opportunity:getAll */ -/* -------------------------------------------------------------------------- */ + + /* -------------------------------------------------------------------------- */ + /* opportunity:getAll */ + /* -------------------------------------------------------------------------- */ { displayName: 'Return All', name: 'returnAll', @@ -601,6 +604,69 @@ export const opportunityFields = [ }, }, options: [ + { + displayName: 'Conditions', + name: 'conditionsUi', + placeholder: 'Add Condition', + type: 'fixedCollection', + typeOptions: { + multipleValues: true, + }, + description: 'The condition to set.', + default: {}, + options: [ + { + name: 'conditionValues', + displayName: 'Condition', + values: [ + { + displayName: 'Field', + name: 'field', + type: 'options', + typeOptions: { + loadOptionsMethod: 'getOpportunityFields', + }, + default: '', + description: 'For date, number, or boolean, please use expressions', + }, + { + displayName: 'Operation', + name: 'operation', + type: 'options', + options: [ + { + name: '=', + value: 'equal', + }, + { + name: '>', + value: '>', + }, + { + name: '<', + value: '<', + }, + { + name: '>=', + value: '>=', + }, + { + name: '<=', + value: '<=', + }, + ], + default: 'equal', + }, + { + displayName: 'Value', + name: 'value', + type: 'string', + default: '', + }, + ], + }, + ], + }, { displayName: 'Fields', name: 'fields', @@ -611,9 +677,9 @@ export const opportunityFields = [ ], }, -/* -------------------------------------------------------------------------- */ -/* opportunity:addNote */ -/* -------------------------------------------------------------------------- */ + /* -------------------------------------------------------------------------- */ + /* opportunity:addNote */ + /* -------------------------------------------------------------------------- */ { displayName: 'Opportunity ID', name: 'opportunityId', @@ -630,7 +696,7 @@ export const opportunityFields = [ ], }, }, - description: 'Id of opportunity that needs to be fetched', + description: 'ID of opportunity that needs to be fetched.', }, { displayName: 'Title', diff --git a/packages/nodes-base/nodes/Salesforce/OpportunityInterface.ts b/packages/nodes-base/nodes/Salesforce/OpportunityInterface.ts index bad4852648..4155587820 100644 --- a/packages/nodes-base/nodes/Salesforce/OpportunityInterface.ts +++ b/packages/nodes-base/nodes/Salesforce/OpportunityInterface.ts @@ -1,4 +1,3 @@ - export interface IOpportunity { Name?: string; StageName?: string; @@ -12,6 +11,6 @@ export interface IOpportunity { LeadSource?: string; Description?: string; Probability?: number; - Pricebook2Id?:string; + Pricebook2Id?: string; ForecastCategoryName?: string; } diff --git a/packages/nodes-base/nodes/Salesforce/Salesforce.node.ts b/packages/nodes-base/nodes/Salesforce/Salesforce.node.ts index 9cf20ef9b6..3afec9ae58 100644 --- a/packages/nodes-base/nodes/Salesforce/Salesforce.node.ts +++ b/packages/nodes-base/nodes/Salesforce/Salesforce.node.ts @@ -63,6 +63,7 @@ import { } from './FlowDescription'; import { + getQuery, salesforceApiRequest, salesforceApiRequestAllItems, sortOptions, @@ -90,6 +91,11 @@ import { IOpportunity, } from './OpportunityInterface'; +import { + searchFields, + searchOperations, +} from './SearchDescription'; + import { taskFields, taskOperations, @@ -104,10 +110,6 @@ import { userOperations, } from './UserDescription'; -import { - IUser, -} from './UserInterface'; - export class Salesforce implements INodeType { description: INodeTypeDescription = { displayName: 'Salesforce', @@ -210,6 +212,11 @@ export class Salesforce implements INodeType { value: 'opportunity', description: 'Represents an opportunity, which is a sale or pending deal.', }, + { + name: 'Search', + value: 'search', + description: 'Search records', + }, { name: 'Task', value: 'task', @@ -234,6 +241,8 @@ export class Salesforce implements INodeType { ...opportunityFields, ...accountOperations, ...accountFields, + ...searchOperations, + ...searchFields, ...caseOperations, ...caseFields, ...taskOperations, @@ -700,6 +709,142 @@ export class Salesforce implements INodeType { sortOptions(returnData); return returnData; }, + // Get all the account fields recurrence instances to display them to user so that he can + // select them easily + async getAccountFields(this: ILoadOptionsFunctions): Promise { + const returnData: INodePropertyOptions[] = []; + // TODO: find a way to filter this object to get just the lead sources instead of the whole object + const { fields } = await salesforceApiRequest.call(this, 'GET', `/sobjects/account/describe`); + for (const field of fields) { + const fieldName = field.label; + const fieldId = field.name; + returnData.push({ + name: fieldName, + value: fieldId, + }); + } + sortOptions(returnData); + return returnData; + }, + // Get all the attachment fields recurrence instances to display them to user so that he can + // select them easily + async getAtachmentFields(this: ILoadOptionsFunctions): Promise { + const returnData: INodePropertyOptions[] = []; + // TODO: find a way to filter this object to get just the lead sources instead of the whole object + const { fields } = await salesforceApiRequest.call(this, 'GET', `/sobjects/attachment/describe`); + for (const field of fields) { + const fieldName = field.label; + const fieldId = field.name; + returnData.push({ + name: fieldName, + value: fieldId, + }); + } + sortOptions(returnData); + return returnData; + }, + // Get all the case fields recurrence instances to display them to user so that he can + // select them easily + async getCaseFields(this: ILoadOptionsFunctions): Promise { + const returnData: INodePropertyOptions[] = []; + // TODO: find a way to filter this object to get just the lead sources instead of the whole object + const { fields } = await salesforceApiRequest.call(this, 'GET', `/sobjects/case/describe`); + for (const field of fields) { + const fieldName = field.label; + const fieldId = field.name; + returnData.push({ + name: fieldName, + value: fieldId, + }); + } + sortOptions(returnData); + return returnData; + }, + // Get all the lead fields recurrence instances to display them to user so that he can + // select them easily + async getLeadFields(this: ILoadOptionsFunctions): Promise { + const returnData: INodePropertyOptions[] = []; + // TODO: find a way to filter this object to get just the lead sources instead of the whole object + const { fields } = await salesforceApiRequest.call(this, 'GET', `/sobjects/lead/describe`); + for (const field of fields) { + const fieldName = field.label; + const fieldId = field.name; + returnData.push({ + name: fieldName, + value: fieldId, + }); + } + sortOptions(returnData); + return returnData; + }, + // Get all the opportunity fields recurrence instances to display them to user so that he can + // select them easily + async getOpportunityFields(this: ILoadOptionsFunctions): Promise { + const returnData: INodePropertyOptions[] = []; + // TODO: find a way to filter this object to get just the lead sources instead of the whole object + const { fields } = await salesforceApiRequest.call(this, 'GET', `/sobjects/opportunity/describe`); + for (const field of fields) { + const fieldName = field.label; + const fieldId = field.name; + returnData.push({ + name: fieldName, + value: fieldId, + }); + } + sortOptions(returnData); + return returnData; + }, + // Get all the opportunity fields recurrence instances to display them to user so that he can + // select them easily + async getTaskFields(this: ILoadOptionsFunctions): Promise { + const returnData: INodePropertyOptions[] = []; + // TODO: find a way to filter this object to get just the lead sources instead of the whole object + const { fields } = await salesforceApiRequest.call(this, 'GET', `/sobjects/task/describe`); + for (const field of fields) { + const fieldName = field.label; + const fieldId = field.name; + returnData.push({ + name: fieldName, + value: fieldId, + }); + } + sortOptions(returnData); + return returnData; + }, + // Get all the users fields recurrence instances to display them to user so that he can + // select them easily + async getUserFields(this: ILoadOptionsFunctions): Promise { + const returnData: INodePropertyOptions[] = []; + // TODO: find a way to filter this object to get just the lead sources instead of the whole object + const { fields } = await salesforceApiRequest.call(this, 'GET', `/sobjects/user/describe`); + for (const field of fields) { + const fieldName = field.label; + const fieldId = field.name; + returnData.push({ + name: fieldName, + value: fieldId, + }); + } + sortOptions(returnData); + return returnData; + }, + // Get all the contact fields recurrence instances to display them to user so that he can + // select them easily + async getContactFields(this: ILoadOptionsFunctions): Promise { + const returnData: INodePropertyOptions[] = []; + // TODO: find a way to filter this object to get just the lead sources instead of the whole object + const { fields } = await salesforceApiRequest.call(this, 'GET', `/sobjects/contact/describe`); + for (const field of fields) { + const fieldName = field.label; + const fieldId = field.name; + returnData.push({ + name: fieldName, + value: fieldId, + }); + } + sortOptions(returnData); + return returnData; + }, }, }; @@ -894,21 +1039,16 @@ export class Salesforce implements INodeType { if (operation === 'getAll') { const returnAll = this.getNodeParameter('returnAll', i) as boolean; const options = this.getNodeParameter('options', i) as IDataObject; - const fields = ['id,company,firstname,lastname,street,postalCode,city,email,status']; - if (options.fields) { - // @ts-ignore - fields.push(...options.fields.split(',')); - } try { if (returnAll) { - qs.q = `SELECT ${fields.join(',')} FROM Lead`; + qs.q = getQuery(options, 'Lead', returnAll) as string; responseData = await salesforceApiRequestAllItems.call(this, 'records', 'GET', '/query', {}, qs); } else { const limit = this.getNodeParameter('limit', i) as number; - qs.q = `SELECT ${fields.join(',')} FROM Lead Limit ${limit}`; + qs.q = getQuery(options, 'Lead', returnAll, limit) as string; responseData = await salesforceApiRequestAllItems.call(this, 'records', 'GET', '/query', {}, qs); } - } catch(err) { + } catch (err) { throw new Error(`Salesforce Error: ${err}`); } } @@ -917,7 +1057,7 @@ export class Salesforce implements INodeType { const leadId = this.getNodeParameter('leadId', i) as string; try { responseData = await salesforceApiRequest.call(this, 'DELETE', `/sobjects/lead/${leadId}`); - } catch(err) { + } catch (err) { throw new Error(`Salesforce Error: ${err}`); } } @@ -1187,21 +1327,16 @@ export class Salesforce implements INodeType { if (operation === 'getAll') { const returnAll = this.getNodeParameter('returnAll', i) as boolean; const options = this.getNodeParameter('options', i) as IDataObject; - const fields = ['id,firstname,lastname,email']; - if (options.fields) { - // @ts-ignore - fields.push(...options.fields.split(',')); - } try { if (returnAll) { - qs.q = `SELECT ${fields.join(',')} FROM Contact`; + qs.q = getQuery(options, 'Contact', returnAll) as string; responseData = await salesforceApiRequestAllItems.call(this, 'records', 'GET', '/query', {}, qs); } else { const limit = this.getNodeParameter('limit', i) as number; - qs.q = `SELECT ${fields.join(',')} FROM Contact Limit ${limit}`; + qs.q = getQuery(options, 'Contact', returnAll, limit) as string; responseData = await salesforceApiRequestAllItems.call(this, 'records', 'GET', '/query', {}, qs); } - } catch(err) { + } catch (err) { throw new Error(`Salesforce Error: ${err}`); } } @@ -1210,7 +1345,7 @@ export class Salesforce implements INodeType { const contactId = this.getNodeParameter('contactId', i) as string; try { responseData = await salesforceApiRequest.call(this, 'DELETE', `/sobjects/contact/${contactId}`); - } catch(err) { + } catch (err) { throw new Error(`Salesforce Error: ${err}`); } } @@ -1294,20 +1429,16 @@ export class Salesforce implements INodeType { const customObject = this.getNodeParameter('customObject', i) as string; const returnAll = this.getNodeParameter('returnAll', i) as boolean; const options = this.getNodeParameter('options', i) as IDataObject; - let fields = ['id']; - if (options.fields) { - fields = options.fields as string[]; - } try { if (returnAll) { - qs.q = `SELECT ${fields.join(',')} FROM ${customObject}`; + qs.q = getQuery(options, customObject, returnAll) as string; responseData = await salesforceApiRequestAllItems.call(this, 'records', 'GET', '/query', {}, qs); } else { const limit = this.getNodeParameter('limit', i) as number; - qs.q = `SELECT ${fields.join(',')} FROM ${customObject} Limit ${limit}`; + qs.q = getQuery(options, customObject, returnAll, limit) as string; responseData = await salesforceApiRequestAllItems.call(this, 'records', 'GET', '/query', {}, qs); } - } catch(err) { + } catch (err) { throw new Error(`Salesforce Error: ${err}`); } } @@ -1316,7 +1447,7 @@ export class Salesforce implements INodeType { const recordId = this.getNodeParameter('recordId', i) as string; try { responseData = await salesforceApiRequest.call(this, 'DELETE', `/sobjects/${customObject}/${recordId}`); - } catch(err) { + } catch (err) { throw new Error(`Salesforce Error: ${err}`); } } @@ -1444,21 +1575,16 @@ export class Salesforce implements INodeType { if (operation === 'getAll') { const returnAll = this.getNodeParameter('returnAll', i) as boolean; const options = this.getNodeParameter('options', i) as IDataObject; - const fields = ['id,accountId,amount,probability,type']; - if (options.fields) { - // @ts-ignore - fields.push(...options.fields.split(',')); - } try { if (returnAll) { - qs.q = `SELECT ${fields.join(',')} FROM Opportunity`; + qs.q = getQuery(options, 'Opportunity', returnAll) as string; responseData = await salesforceApiRequestAllItems.call(this, 'records', 'GET', '/query', {}, qs); } else { const limit = this.getNodeParameter('limit', i) as number; - qs.q = `SELECT ${fields.join(',')} FROM Opportunity Limit ${limit}`; + qs.q = getQuery(options, 'Opportunity', returnAll, limit) as string; responseData = await salesforceApiRequestAllItems.call(this, 'records', 'GET', '/query', {}, qs); } - } catch(err) { + } catch (err) { throw new Error(`Salesforce Error: ${err}`); } } @@ -1467,7 +1593,7 @@ export class Salesforce implements INodeType { const opportunityId = this.getNodeParameter('opportunityId', i) as string; try { responseData = await salesforceApiRequest.call(this, 'DELETE', `/sobjects/opportunity/${opportunityId}`); - } catch(err) { + } catch (err) { throw new Error(`Salesforce Error: ${err}`); } } @@ -1687,21 +1813,16 @@ export class Salesforce implements INodeType { if (operation === 'getAll') { const returnAll = this.getNodeParameter('returnAll', i) as boolean; const options = this.getNodeParameter('options', i) as IDataObject; - const fields = ['id,name,type']; - if (options.fields) { - // @ts-ignore - fields.push(...options.fields.split(',')); - } try { if (returnAll) { - qs.q = `SELECT ${fields.join(',')} FROM Account`; + qs.q = getQuery(options, 'Account', returnAll) as string; responseData = await salesforceApiRequestAllItems.call(this, 'records', 'GET', '/query', {}, qs); } else { const limit = this.getNodeParameter('limit', i) as number; - qs.q = `SELECT ${fields.join(',')} FROM Account Limit ${limit}`; + qs.q = getQuery(options, 'Account', returnAll, limit) as string; responseData = await salesforceApiRequestAllItems.call(this, 'records', 'GET', '/query', {}, qs); } - } catch(err) { + } catch (err) { throw new Error(`Salesforce Error: ${err}`); } } @@ -1710,7 +1831,7 @@ export class Salesforce implements INodeType { const accountId = this.getNodeParameter('accountId', i) as string; try { responseData = await salesforceApiRequest.call(this, 'DELETE', `/sobjects/account/${accountId}`); - } catch(err) { + } catch (err) { throw new Error(`Salesforce Error: ${err}`); } } @@ -1852,21 +1973,16 @@ export class Salesforce implements INodeType { if (operation === 'getAll') { const returnAll = this.getNodeParameter('returnAll', i) as boolean; const options = this.getNodeParameter('options', i) as IDataObject; - const fields = ['id,accountId,contactId,priority,status,subject,type']; - if (options.fields) { - // @ts-ignore - fields.push(...options.fields.split(',')); - } try { if (returnAll) { - qs.q = `SELECT ${fields.join(',')} FROM Case`; + qs.q = getQuery(options, 'Case', returnAll) as string; responseData = await salesforceApiRequestAllItems.call(this, 'records', 'GET', '/query', {}, qs); } else { const limit = this.getNodeParameter('limit', i) as number; - qs.q = `SELECT ${fields.join(',')} FROM Case Limit ${limit}`; + qs.q = getQuery(options, 'Case', returnAll, limit) as string; responseData = await salesforceApiRequestAllItems.call(this, 'records', 'GET', '/query', {}, qs); } - } catch(err) { + } catch (err) { throw new Error(`Salesforce Error: ${err}`); } } @@ -1875,7 +1991,7 @@ export class Salesforce implements INodeType { const caseId = this.getNodeParameter('caseId', i) as string; try { responseData = await salesforceApiRequest.call(this, 'DELETE', `/sobjects/case/${caseId}`); - } catch(err) { + } catch (err) { throw new Error(`Salesforce Error: ${err}`); } } @@ -2084,21 +2200,16 @@ export class Salesforce implements INodeType { if (operation === 'getAll') { const returnAll = this.getNodeParameter('returnAll', i) as boolean; const options = this.getNodeParameter('options', i) as IDataObject; - const fields = ['id,subject,status,priority']; - if (options.fields) { - // @ts-ignore - fields.push(...options.fields.split(',')); - } try { if (returnAll) { - qs.q = `SELECT ${fields.join(',')} FROM Task`; + qs.q = getQuery(options, 'Task', returnAll) as string; responseData = await salesforceApiRequestAllItems.call(this, 'records', 'GET', '/query', {}, qs); } else { const limit = this.getNodeParameter('limit', i) as number; - qs.q = `SELECT ${fields.join(',')} FROM Task Limit ${limit}`; + qs.q = getQuery(options, 'Task', returnAll, limit) as string; responseData = await salesforceApiRequestAllItems.call(this, 'records', 'GET', '/query', {}, qs); } - } catch(err) { + } catch (err) { throw new Error(`Salesforce Error: ${err}`); } } @@ -2107,7 +2218,7 @@ export class Salesforce implements INodeType { const taskId = this.getNodeParameter('taskId', i) as string; try { responseData = await salesforceApiRequest.call(this, 'DELETE', `/sobjects/task/${taskId}`); - } catch(err) { + } catch (err) { throw new Error(`Salesforce Error: ${err}`); } } @@ -2181,21 +2292,16 @@ export class Salesforce implements INodeType { if (operation === 'getAll') { const returnAll = this.getNodeParameter('returnAll', i) as boolean; const options = this.getNodeParameter('options', i) as IDataObject; - const fields = ['id,name']; - if (options.fields) { - // @ts-ignore - fields.push(...options.fields.split(',')); - } try { if (returnAll) { - qs.q = `SELECT ${fields.join(',')} FROM Attachment`; + qs.q = getQuery(options, 'Attachment', returnAll) as string; responseData = await salesforceApiRequestAllItems.call(this, 'records', 'GET', '/query', {}, qs); } else { const limit = this.getNodeParameter('limit', i) as number; - qs.q = `SELECT ${fields.join(',')} FROM Attachment Limit ${limit}`; + qs.q = getQuery(options, 'Attachment', returnAll, limit) as string; responseData = await salesforceApiRequestAllItems.call(this, 'records', 'GET', '/query', {}, qs); } - } catch(err) { + } catch (err) { throw new Error(`Salesforce Error: ${err}`); } } @@ -2204,7 +2310,7 @@ export class Salesforce implements INodeType { const attachmentId = this.getNodeParameter('attachmentId', i) as string; try { responseData = await salesforceApiRequest.call(this, 'DELETE', `/sobjects/attachment/${attachmentId}`); - } catch(err) { + } catch (err) { throw new Error(`Salesforce Error: ${err}`); } } @@ -2223,21 +2329,16 @@ export class Salesforce implements INodeType { if (operation === 'getAll') { const returnAll = this.getNodeParameter('returnAll', i) as boolean; const options = this.getNodeParameter('options', i) as IDataObject; - const fields = ['id,name,email']; - if (options.fields) { - // @ts-ignore - fields.push(...options.fields.split(',')); - } try { if (returnAll) { - qs.q = `SELECT ${fields.join(',')} FROM User`; + qs.q = getQuery(options, 'User', returnAll) as string; responseData = await salesforceApiRequestAllItems.call(this, 'records', 'GET', '/query', {}, qs); } else { const limit = this.getNodeParameter('limit', i) as number; - qs.q = `SELECT ${fields.join(',')} FROM User Limit ${limit}`; + qs.q = getQuery(options, 'User', returnAll, limit) as string; responseData = await salesforceApiRequestAllItems.call(this, 'records', 'GET', '/query', {}, qs); } - } catch(err) { + } catch (err) { throw new Error(`Salesforce Error: ${err}`); } } @@ -2278,6 +2379,13 @@ export class Salesforce implements INodeType { } } } + if (resource === 'search') { + //https://developer.salesforce.com/docs/atlas.en-us.api_rest.meta/api_rest/resources_query.htm + if (operation === 'query') { + qs.q = this.getNodeParameter('query', i) as string; + responseData = await salesforceApiRequestAllItems.call(this, 'records', 'GET', '/query', {}, qs); + } + } if (Array.isArray(responseData)) { returnData.push.apply(returnData, responseData as IDataObject[]); } else { diff --git a/packages/nodes-base/nodes/Salesforce/SearchDescription.ts b/packages/nodes-base/nodes/Salesforce/SearchDescription.ts new file mode 100644 index 0000000000..e13e8fa616 --- /dev/null +++ b/packages/nodes-base/nodes/Salesforce/SearchDescription.ts @@ -0,0 +1,52 @@ +import { + INodeProperties, +} from 'n8n-workflow'; + +export const searchOperations = [ + { + displayName: 'Operation', + name: 'operation', + type: 'options', + displayOptions: { + show: { + resource: [ + 'search', + ], + }, + }, + options: [ + { + name: 'Query', + value: 'query', + description: 'Execute a SOQL query that returns all the results in a single response', + }, + ], + default: 'query', + description: 'The operation to perform.', + }, +] as INodeProperties[]; + +export const searchFields = [ + + /* -------------------------------------------------------------------------- */ + /* search:query */ + /* -------------------------------------------------------------------------- */ + { + displayName: 'Query', + name: 'query', + type: 'string', + required: true, + default: '', + displayOptions: { + show: { + resource: [ + 'search', + ], + operation: [ + 'query', + ], + }, + }, + description: 'A SOQL query. An example query parameter string might look like: “SELECT+Name+FROM+MyObject”. If the SOQL query string is invalid, a MALFORMED_QUERY response is returned.', + }, +] as INodeProperties[]; diff --git a/packages/nodes-base/nodes/Salesforce/TaskDescription.ts b/packages/nodes-base/nodes/Salesforce/TaskDescription.ts index a91c817407..2fb83f7579 100644 --- a/packages/nodes-base/nodes/Salesforce/TaskDescription.ts +++ b/packages/nodes-base/nodes/Salesforce/TaskDescription.ts @@ -38,7 +38,7 @@ export const taskOperations = [ { name: 'Get Summary', value: 'getSummary', - description: `Returns an overview of task's metadata.`, + description: `Returns an overview of task's metadata`, }, { name: 'Update', @@ -53,9 +53,9 @@ export const taskOperations = [ export const taskFields = [ -/* -------------------------------------------------------------------------- */ -/* task:create */ -/* -------------------------------------------------------------------------- */ + /* -------------------------------------------------------------------------- */ + /* task:create */ + /* -------------------------------------------------------------------------- */ { displayName: 'Status', name: 'status', @@ -407,9 +407,10 @@ export const taskFields = [ }, ], }, -/* -------------------------------------------------------------------------- */ -/* task:update */ -/* -------------------------------------------------------------------------- */ + + /* -------------------------------------------------------------------------- */ + /* task:update */ + /* -------------------------------------------------------------------------- */ { displayName: 'Task ID', name: 'taskId', @@ -426,7 +427,7 @@ export const taskFields = [ ], }, }, - description: 'Id of task that needs to be fetched', + description: 'ID of task that needs to be fetched.', }, { displayName: 'Update Fields', @@ -769,9 +770,9 @@ export const taskFields = [ ], }, -/* -------------------------------------------------------------------------- */ -/* task:get */ -/* -------------------------------------------------------------------------- */ + /* -------------------------------------------------------------------------- */ + /* task:get */ + /* -------------------------------------------------------------------------- */ { displayName: 'Task ID', name: 'taskId', @@ -788,11 +789,12 @@ export const taskFields = [ ], }, }, - description: 'Id of task that needs to be fetched', + description: 'ID of task that needs to be fetched.', }, -/* -------------------------------------------------------------------------- */ -/* task:delete */ -/* -------------------------------------------------------------------------- */ + + /* -------------------------------------------------------------------------- */ + /* task:delete */ + /* -------------------------------------------------------------------------- */ { displayName: 'Task ID', name: 'taskId', @@ -809,11 +811,12 @@ export const taskFields = [ ], }, }, - description: 'Id of task that needs to be fetched', + description: 'ID of task that needs to be fetched.', }, -/* -------------------------------------------------------------------------- */ -/* task:getAll */ -/* -------------------------------------------------------------------------- */ + + /* -------------------------------------------------------------------------- */ + /* task:getAll */ + /* -------------------------------------------------------------------------- */ { displayName: 'Return All', name: 'returnAll', @@ -872,6 +875,69 @@ export const taskFields = [ }, }, options: [ + { + displayName: 'Conditions', + name: 'conditionsUi', + placeholder: 'Add Condition', + type: 'fixedCollection', + typeOptions: { + multipleValues: true, + }, + description: 'The condition to set.', + default: {}, + options: [ + { + name: 'conditionValues', + displayName: 'Condition', + values: [ + { + displayName: 'Field', + name: 'field', + type: 'options', + typeOptions: { + loadOptionsMethod: 'getTaskFields', + }, + default: '', + description: 'For date, number, or boolean, please use expressions.', + }, + { + displayName: 'Operation', + name: 'operation', + type: 'options', + options: [ + { + name: '=', + value: 'equal', + }, + { + name: '>', + value: '>', + }, + { + name: '<', + value: '<', + }, + { + name: '>=', + value: '>=', + }, + { + name: '<=', + value: '<=', + }, + ], + default: 'equal', + }, + { + displayName: 'Value', + name: 'value', + type: 'string', + default: '', + }, + ], + }, + ], + }, { displayName: 'Fields', name: 'fields', diff --git a/packages/nodes-base/nodes/Salesforce/TaskInterface.ts b/packages/nodes-base/nodes/Salesforce/TaskInterface.ts index 06f932e799..218c905eab 100644 --- a/packages/nodes-base/nodes/Salesforce/TaskInterface.ts +++ b/packages/nodes-base/nodes/Salesforce/TaskInterface.ts @@ -1,4 +1,3 @@ - export interface ITask { WhoId?: string; Status?: string; @@ -12,7 +11,7 @@ export interface ITask { ActivityDate?: string; IsReminderSet?: boolean; RecurrenceType?: string; - CallDisposition?:string; + CallDisposition?: string; ReminderDateTime?: string; RecurrenceInstance?: string; RecurrenceInterval?: number; diff --git a/packages/nodes-base/nodes/Salesforce/UserDescription.ts b/packages/nodes-base/nodes/Salesforce/UserDescription.ts index b58175a141..ecfc95bf78 100644 --- a/packages/nodes-base/nodes/Salesforce/UserDescription.ts +++ b/packages/nodes-base/nodes/Salesforce/UserDescription.ts @@ -1,5 +1,5 @@ import { - INodeProperties, + INodeProperties, } from 'n8n-workflow'; export const userOperations = [ @@ -32,6 +32,7 @@ export const userOperations = [ ] as INodeProperties[]; export const userFields = [ + /* -------------------------------------------------------------------------- */ /* user:get */ /* -------------------------------------------------------------------------- */ @@ -51,8 +52,9 @@ export const userFields = [ ], }, }, - description: 'Id of user that needs to be fetched', + description: 'ID of user that needs to be fetched.', }, + /* -------------------------------------------------------------------------- */ /* user:getAll */ /* -------------------------------------------------------------------------- */ @@ -114,6 +116,69 @@ export const userFields = [ }, }, options: [ + { + displayName: 'Conditions', + name: 'conditionsUi', + placeholder: 'Add Condition', + type: 'fixedCollection', + typeOptions: { + multipleValues: true, + }, + description: 'The condition to set.', + default: {}, + options: [ + { + name: 'conditionValues', + displayName: 'Condition', + values: [ + { + displayName: 'Field', + name: 'field', + type: 'options', + typeOptions: { + loadOptionsMethod: 'getUserFields', + }, + default: '', + description: 'For date, number, or boolean, please use expressions.', + }, + { + displayName: 'Operation', + name: 'operation', + type: 'options', + options: [ + { + name: '=', + value: 'equal', + }, + { + name: '>', + value: '>', + }, + { + name: '<', + value: '<', + }, + { + name: '>=', + value: '>=', + }, + { + name: '<=', + value: '<=', + }, + ], + default: 'equal', + }, + { + displayName: 'Value', + name: 'value', + type: 'string', + default: '', + }, + ], + }, + ], + }, { displayName: 'Fields', name: 'fields',