mirror of
https://github.com/n8n-io/n8n.git
synced 2025-01-12 05:17:28 -08:00
⚡ Add custom fields for Salesforce case create/update and alphabetize fields for update (#1688)
This commit is contained in:
parent
adad513718
commit
9271e73777
|
@ -111,6 +111,42 @@ export const caseFields = [
|
||||||
default: '',
|
default: '',
|
||||||
description: 'ID of the associated Contact.',
|
description: 'ID of the associated Contact.',
|
||||||
},
|
},
|
||||||
|
{
|
||||||
|
displayName: 'Custom Fields',
|
||||||
|
name: 'customFieldsUi',
|
||||||
|
placeholder: 'Add Custom Field',
|
||||||
|
type: 'fixedCollection',
|
||||||
|
typeOptions: {
|
||||||
|
multipleValues: true,
|
||||||
|
},
|
||||||
|
description: 'Filter by custom fields ',
|
||||||
|
default: {},
|
||||||
|
options: [
|
||||||
|
{
|
||||||
|
name: 'customFieldsValues',
|
||||||
|
displayName: 'Custom Field',
|
||||||
|
values: [
|
||||||
|
{
|
||||||
|
displayName: 'Field ID',
|
||||||
|
name: 'fieldId',
|
||||||
|
type: 'options',
|
||||||
|
typeOptions: {
|
||||||
|
loadOptionsMethod: 'getCustomFields',
|
||||||
|
},
|
||||||
|
default: '',
|
||||||
|
description: 'The ID of the field to add custom field to.',
|
||||||
|
},
|
||||||
|
{
|
||||||
|
displayName: 'Value',
|
||||||
|
name: 'value',
|
||||||
|
type: 'string',
|
||||||
|
default: '',
|
||||||
|
description: 'The value to set on custom field.',
|
||||||
|
},
|
||||||
|
],
|
||||||
|
},
|
||||||
|
],
|
||||||
|
},
|
||||||
{
|
{
|
||||||
displayName: 'Description',
|
displayName: 'Description',
|
||||||
name: 'description',
|
name: 'description',
|
||||||
|
@ -259,14 +295,68 @@ export const caseFields = [
|
||||||
},
|
},
|
||||||
options: [
|
options: [
|
||||||
{
|
{
|
||||||
displayName: 'Type',
|
displayName: 'Account ID',
|
||||||
name: 'type',
|
name: 'accountId',
|
||||||
type: 'options',
|
type: 'string',
|
||||||
typeOptions: {
|
|
||||||
loadOptionsMethod: 'getCaseTypes',
|
|
||||||
},
|
|
||||||
default: '',
|
default: '',
|
||||||
description: 'The type of case',
|
description: 'ID of the account associated with this case.',
|
||||||
|
},
|
||||||
|
{
|
||||||
|
displayName: 'Contact ID',
|
||||||
|
name: 'contactId',
|
||||||
|
type: 'string',
|
||||||
|
default: '',
|
||||||
|
description: 'ID of the associated Contact.',
|
||||||
|
},
|
||||||
|
{
|
||||||
|
displayName: 'Custom Fields',
|
||||||
|
name: 'customFieldsUi',
|
||||||
|
placeholder: 'Add Custom Field',
|
||||||
|
type: 'fixedCollection',
|
||||||
|
typeOptions: {
|
||||||
|
multipleValues: true,
|
||||||
|
},
|
||||||
|
description: 'Filter by custom fields ',
|
||||||
|
default: {},
|
||||||
|
options: [
|
||||||
|
{
|
||||||
|
name: 'customFieldsValues',
|
||||||
|
displayName: 'Custom Field',
|
||||||
|
values: [
|
||||||
|
{
|
||||||
|
displayName: 'Field ID',
|
||||||
|
name: 'fieldId',
|
||||||
|
type: 'options',
|
||||||
|
typeOptions: {
|
||||||
|
loadOptionsMethod: 'getCustomFields',
|
||||||
|
},
|
||||||
|
default: '',
|
||||||
|
description: 'The ID of the field to add custom field to.',
|
||||||
|
},
|
||||||
|
{
|
||||||
|
displayName: 'Value',
|
||||||
|
name: 'value',
|
||||||
|
type: 'string',
|
||||||
|
default: '',
|
||||||
|
description: 'The value to set on custom field.',
|
||||||
|
},
|
||||||
|
],
|
||||||
|
},
|
||||||
|
],
|
||||||
|
},
|
||||||
|
{
|
||||||
|
displayName: 'Description',
|
||||||
|
name: 'description',
|
||||||
|
type: 'string',
|
||||||
|
default: '',
|
||||||
|
description: 'A text description of the case. Limit: 32 KB.',
|
||||||
|
},
|
||||||
|
{
|
||||||
|
displayName: 'Is Escalated',
|
||||||
|
name: 'isEscalated',
|
||||||
|
type: 'boolean',
|
||||||
|
default: false,
|
||||||
|
description: 'Indicates whether the case has been escalated (true) or not.',
|
||||||
},
|
},
|
||||||
{
|
{
|
||||||
displayName: 'Origin',
|
displayName: 'Origin',
|
||||||
|
@ -278,6 +368,33 @@ export const caseFields = [
|
||||||
default: '',
|
default: '',
|
||||||
description: 'The source of the case, such as Email, Phone, or Web. Label is Case Origin.',
|
description: 'The source of the case, such as Email, Phone, or Web. Label is Case Origin.',
|
||||||
},
|
},
|
||||||
|
{
|
||||||
|
displayName: 'Owner',
|
||||||
|
name: 'owner',
|
||||||
|
type: 'options',
|
||||||
|
typeOptions: {
|
||||||
|
loadOptionsMethod: 'getCaseOwners',
|
||||||
|
},
|
||||||
|
default: '',
|
||||||
|
description: 'The owner of the case.',
|
||||||
|
},
|
||||||
|
{
|
||||||
|
displayName: 'Parent ID',
|
||||||
|
name: 'ParentId',
|
||||||
|
type: 'string',
|
||||||
|
default: '',
|
||||||
|
description: 'The ID of the parent case in the hierarchy. The label is Parent Case.',
|
||||||
|
},
|
||||||
|
{
|
||||||
|
displayName: 'Priority',
|
||||||
|
name: 'priority',
|
||||||
|
type: 'options',
|
||||||
|
typeOptions: {
|
||||||
|
loadOptionsMethod: 'getCasePriorities',
|
||||||
|
},
|
||||||
|
default: '',
|
||||||
|
description: 'The importance or urgency of the case, such as High, Medium, or Low.',
|
||||||
|
},
|
||||||
{
|
{
|
||||||
displayName: 'Reason',
|
displayName: 'Reason',
|
||||||
name: 'reason',
|
name: 'reason',
|
||||||
|
@ -298,16 +415,6 @@ export const caseFields = [
|
||||||
default: '',
|
default: '',
|
||||||
description: 'The status of the case, such as “New,” “Closed,” or “Escalated.” This field directly controls the IsClosed flag',
|
description: 'The status of the case, such as “New,” “Closed,” or “Escalated.” This field directly controls the IsClosed flag',
|
||||||
},
|
},
|
||||||
{
|
|
||||||
displayName: 'Owner',
|
|
||||||
name: 'owner',
|
|
||||||
type: 'options',
|
|
||||||
typeOptions: {
|
|
||||||
loadOptionsMethod: 'getCaseOwners',
|
|
||||||
},
|
|
||||||
default: '',
|
|
||||||
description: 'The owner of the case.',
|
|
||||||
},
|
|
||||||
{
|
{
|
||||||
displayName: 'Subject',
|
displayName: 'Subject',
|
||||||
name: 'subject',
|
name: 'subject',
|
||||||
|
@ -316,56 +423,11 @@ export const caseFields = [
|
||||||
description: 'The subject of the case. Limit: 255 characters.',
|
description: 'The subject of the case. Limit: 255 characters.',
|
||||||
},
|
},
|
||||||
{
|
{
|
||||||
displayName: 'Parent ID',
|
displayName: 'Supplied Company',
|
||||||
name: 'ParentId',
|
name: 'suppliedCompany',
|
||||||
type: 'string',
|
type: 'string',
|
||||||
default: '',
|
default: '',
|
||||||
description: 'The ID of the parent case in the hierarchy. The label is Parent Case.',
|
description: `The company name that was entered when the case was created. This field can't be updated after the case has been created..`,
|
||||||
},
|
|
||||||
{
|
|
||||||
displayName: 'Priority',
|
|
||||||
name: 'priority',
|
|
||||||
type: 'options',
|
|
||||||
typeOptions: {
|
|
||||||
loadOptionsMethod: 'getCasePriorities',
|
|
||||||
},
|
|
||||||
default: '',
|
|
||||||
description: 'The importance or urgency of the case, such as High, Medium, or Low.',
|
|
||||||
},
|
|
||||||
{
|
|
||||||
displayName: 'Account ID',
|
|
||||||
name: 'accountId',
|
|
||||||
type: 'string',
|
|
||||||
default: '',
|
|
||||||
description: 'ID of the account associated with this case.',
|
|
||||||
},
|
|
||||||
{
|
|
||||||
displayName: 'Contact ID',
|
|
||||||
name: 'contactId',
|
|
||||||
type: 'string',
|
|
||||||
default: '',
|
|
||||||
description: 'ID of the associated Contact.',
|
|
||||||
},
|
|
||||||
{
|
|
||||||
displayName: 'Description',
|
|
||||||
name: 'description',
|
|
||||||
type: 'string',
|
|
||||||
default: '',
|
|
||||||
description: 'A text description of the case. Limit: 32 KB.',
|
|
||||||
},
|
|
||||||
{
|
|
||||||
displayName: 'Is Escalated',
|
|
||||||
name: 'isEscalated',
|
|
||||||
type: 'boolean',
|
|
||||||
default: false,
|
|
||||||
description: 'Indicates whether the case has been escalated (true) or not.',
|
|
||||||
},
|
|
||||||
{
|
|
||||||
displayName: 'Supplied Name',
|
|
||||||
name: 'suppliedName',
|
|
||||||
type: 'string',
|
|
||||||
default: '',
|
|
||||||
description: `The name that was entered when the case was created. This field can't be updated after the case has been created`,
|
|
||||||
},
|
},
|
||||||
{
|
{
|
||||||
displayName: 'Supplied Email',
|
displayName: 'Supplied Email',
|
||||||
|
@ -374,6 +436,13 @@ export const caseFields = [
|
||||||
default: '',
|
default: '',
|
||||||
description: `The email address that was entered when the case was created. This field can't be updated after the case has been created.`,
|
description: `The email address that was entered when the case was created. This field can't be updated after the case has been created.`,
|
||||||
},
|
},
|
||||||
|
{
|
||||||
|
displayName: 'Supplied Name',
|
||||||
|
name: 'suppliedName',
|
||||||
|
type: 'string',
|
||||||
|
default: '',
|
||||||
|
description: `The name that was entered when the case was created. This field can't be updated after the case has been created`,
|
||||||
|
},
|
||||||
{
|
{
|
||||||
displayName: 'Supplied Phone',
|
displayName: 'Supplied Phone',
|
||||||
name: 'suppliedPhone',
|
name: 'suppliedPhone',
|
||||||
|
@ -382,11 +451,14 @@ export const caseFields = [
|
||||||
description: `The phone number that was entered when the case was created. This field can't be updated after the case has been created.`,
|
description: `The phone number that was entered when the case was created. This field can't be updated after the case has been created.`,
|
||||||
},
|
},
|
||||||
{
|
{
|
||||||
displayName: 'Supplied Company',
|
displayName: 'Type',
|
||||||
name: 'suppliedCompany',
|
name: 'type',
|
||||||
type: 'string',
|
type: 'options',
|
||||||
|
typeOptions: {
|
||||||
|
loadOptionsMethod: 'getCaseTypes',
|
||||||
|
},
|
||||||
default: '',
|
default: '',
|
||||||
description: `The company name that was entered when the case was created. This field can't be updated after the case has been created..`,
|
description: 'The type of case',
|
||||||
},
|
},
|
||||||
],
|
],
|
||||||
},
|
},
|
||||||
|
|
|
@ -1982,6 +1982,15 @@ export class Salesforce implements INodeType {
|
||||||
if (additionalFields.suppliedCompany !== undefined) {
|
if (additionalFields.suppliedCompany !== undefined) {
|
||||||
body.SuppliedCompany = additionalFields.suppliedCompany as string;
|
body.SuppliedCompany = additionalFields.suppliedCompany as string;
|
||||||
}
|
}
|
||||||
|
if (additionalFields.customFieldsUi) {
|
||||||
|
const customFields = (additionalFields.customFieldsUi as IDataObject).customFieldsValues as IDataObject[];
|
||||||
|
if (customFields) {
|
||||||
|
for (const customField of customFields) {
|
||||||
|
//@ts-ignore
|
||||||
|
body[customField.fieldId] = customField.value;
|
||||||
|
}
|
||||||
|
}
|
||||||
|
}
|
||||||
responseData = await salesforceApiRequest.call(this, 'POST', '/sobjects/case', body);
|
responseData = await salesforceApiRequest.call(this, 'POST', '/sobjects/case', body);
|
||||||
}
|
}
|
||||||
//https://developer.salesforce.com/docs/api-explorer/sobject/Case/patch-case-id
|
//https://developer.salesforce.com/docs/api-explorer/sobject/Case/patch-case-id
|
||||||
|
@ -2034,6 +2043,15 @@ export class Salesforce implements INodeType {
|
||||||
if (updateFields.suppliedCompany !== undefined) {
|
if (updateFields.suppliedCompany !== undefined) {
|
||||||
body.SuppliedCompany = updateFields.suppliedCompany as string;
|
body.SuppliedCompany = updateFields.suppliedCompany as string;
|
||||||
}
|
}
|
||||||
|
if (updateFields.customFieldsUi) {
|
||||||
|
const customFields = (updateFields.customFieldsUi as IDataObject).customFieldsValues as IDataObject[];
|
||||||
|
if (customFields) {
|
||||||
|
for (const customField of customFields) {
|
||||||
|
//@ts-ignore
|
||||||
|
body[customField.fieldId] = customField.value;
|
||||||
|
}
|
||||||
|
}
|
||||||
|
}
|
||||||
responseData = await salesforceApiRequest.call(this, 'PATCH', `/sobjects/case/${caseId}`, body);
|
responseData = await salesforceApiRequest.call(this, 'PATCH', `/sobjects/case/${caseId}`, body);
|
||||||
}
|
}
|
||||||
//https://developer.salesforce.com/docs/api-explorer/sobject/Case/get-case-id
|
//https://developer.salesforce.com/docs/api-explorer/sobject/Case/get-case-id
|
||||||
|
|
Loading…
Reference in a new issue