Add Reply To parameter to Mailjet node (#1732)

*  Add Reply To parameter

*  Add svg logo
This commit is contained in:
Ricardo Espinoza
2021-05-07 19:46:50 -04:00
committed by GitHub
parent fc3ebf1a4c
commit f6fdf6b5e1
6 changed files with 148 additions and 98 deletions

View File

@@ -1,19 +1,26 @@
import {
IExecuteFunctions,
} from 'n8n-core';
import {
IDataObject,
ILoadOptionsFunctions,
INodeExecutionData,
INodePropertyOptions,
INodeType,
INodeTypeDescription,
} from 'n8n-workflow';
import {
IMessage,
mailjetApiRequest,
} from './GenericFunctions';
import {
emailFields,
emailOperations,
} from './EmailDescription';
import {
smsFields,
smsOperations,
@@ -23,7 +30,7 @@ export class Mailjet implements INodeType {
description: INodeTypeDescription = {
displayName: 'Mailjet',
name: 'mailjet',
icon: 'file:mailjet.png',
icon: 'file:mailjet.svg',
group: ['output'],
version: 1,
subtitle: '={{$parameter["operation"] + ": " + $parameter["resource"]}}',
@@ -83,6 +90,24 @@ export class Mailjet implements INodeType {
],
};
methods = {
loadOptions: {
// Get all the available custom fields to display them to user so that he can
// select them easily
async getTemplates(this: ILoadOptionsFunctions): Promise<INodePropertyOptions[]> {
const returnData: INodePropertyOptions[] = [];
const { Data: templates } = await mailjetApiRequest.call(this, 'GET', '/v3/REST/template');
for (const template of templates) {
returnData.push({
name: template.Name,
value: template.ID,
});
}
return returnData;
},
},
};
async execute(this: IExecuteFunctions): Promise<INodeExecutionData[][]> {
const items = this.getInputData();
const returnData: IDataObject[] = [];
@@ -103,80 +128,71 @@ export class Mailjet implements INodeType {
const toEmail = (this.getNodeParameter('toEmail', i) as string).split(',') as string[];
const variables = (this.getNodeParameter('variablesUi', i) as IDataObject).variablesValues as IDataObject[];
const body: IDataObject = {
Messages: [
{
From: {
email: fromEmail,
},
subject,
to: [],
Cc: [],
Bcc: [],
Variables: {},
},
],
//SandboxMode: true,
const body: IMessage = {
From: {
Email: fromEmail,
},
Subject: subject,
To: [],
Cc: [],
Bcc: [],
Variables: {},
};
for (const email of toEmail) {
//@ts-ignore
body.Messages[0].to.push({
email,
body.To?.push({
Email: email,
});
}
if (variables) {
for (const variable of variables) {
//@ts-ignore
body.Messages[0].Variables[variable.name] = variable.value;
body.Variables![variable.name as string] = variable.value;
}
}
if (htmlBody) {
//@ts-ignore
body.Messages[0].HTMLPart = htmlBody;
body.HTMLPart = htmlBody;
}
if (textBody) {
//@ts-ignore
body.Messages[0].TextPart = textBody;
body.TextPart = textBody;
}
if (additionalFields.bccEmail) {
const bccEmail = (additionalFields.bccEmail as string).split(',') as string[];
for (const email of bccEmail) {
//@ts-ignore
body.Messages[0].Bcc.push({
email,
body.Bcc!.push({
Email: email,
});
}
}
if (additionalFields.ccEmail) {
const ccEmail = (additionalFields.ccEmail as string).split(',') as string[];
if (additionalFields.ccAddresses) {
const ccEmail = (additionalFields.ccAddresses as string).split(',') as string[];
for (const email of ccEmail) {
//@ts-ignore
body.Messages[0].Cc.push({
email,
body.Cc!.push({
Email: email,
});
}
}
if (additionalFields.trackOpens) {
//@ts-ignore
body.Messages[0].TrackOpens = additionalFields.trackOpens as string;
body.TrackOpens = additionalFields.trackOpens as string;
}
if (additionalFields.replyTo) {
const replyTo = additionalFields.replyTo as string;
body['ReplyTo'] = {
Email: replyTo,
};
}
if (additionalFields.trackClicks) {
//@ts-ignore
body.Messages[0].TrackClicks = additionalFields.trackClicks as string;
body.TrackClicks = additionalFields.trackClicks as string;
}
if (additionalFields.fromName) {
//@ts-ignore
body.Messages[0].From.name = additionalFields.fromName as string;
body.From!.Name = additionalFields.fromName as string;
}
if (additionalFields.templateLanguage) {
//@ts-ignore
body.Messages[0].From.TemplateLanguage = additionalFields.templateLanguage as boolean;
body.TemplateLanguage = additionalFields.templateLanguage as boolean;
}
if (additionalFields.priority) {
//@ts-ignore
body.Messages[0].Priority = additionalFields.priority as number;
body.Priority = additionalFields.priority as number;
}
responseData = await mailjetApiRequest.call(this, 'POST', '/v3.1/send', body);
responseData = await mailjetApiRequest.call(this, 'POST', '/v3.1/send', { Messages: [body] });
responseData = responseData.Messages;
}
@@ -189,73 +205,66 @@ export class Mailjet implements INodeType {
const additionalFields = this.getNodeParameter('additionalFields', i) as IDataObject;
const toEmail = (this.getNodeParameter('toEmail', i) as string).split(',') as string[];
const body: IDataObject = {
Messages: [
{
From: {
email: fromEmail,
},
Subject: subject,
to: [],
Cc: [],
Bcc: [],
Variables: {},
TemplateID: templateId,
},
],
//SandboxMode: true,
const body: IMessage = {
From: {
Email: fromEmail,
},
Subject: subject,
To: [],
Cc: [],
Bcc: [],
Variables: {},
TemplateID: templateId,
};
for (const email of toEmail) {
//@ts-ignore
body.Messages[0].to.push({
email,
body.To!.push({
Email: email,
});
}
if (variables) {
for (const variable of variables) {
//@ts-ignore
body.Messages[0].Variables[variable.name] = variable.value;
body.Variables![variable.name as string] = variable.value;
}
}
if (additionalFields.bccEmail) {
const bccEmail = (additionalFields.bccEmail as string).split(',') as string[];
for (const email of bccEmail) {
//@ts-ignore
body.Messages[0].Bcc.push({
email,
body.Bcc!.push({
Email: email,
});
}
}
if (additionalFields.ccEmail) {
const ccEmail = (additionalFields.ccEmail as string).split(',') as string[];
for (const email of ccEmail) {
//@ts-ignore
body.Messages[0].Cc.push({
email,
body.Cc!.push({
Email: email,
});
}
}
if (additionalFields.replyTo) {
const replyTo = additionalFields.replyTo as string;
body['ReplyTo'] = {
Email: replyTo,
};
}
if (additionalFields.trackOpens) {
//@ts-ignore
body.Messages[0].TrackOpens = additionalFields.trackOpens as string;
body.TrackOpens = additionalFields.trackOpens as string;
}
if (additionalFields.trackClicks) {
//@ts-ignore
body.Messages[0].TrackClicks = additionalFields.trackClicks as string;
body.TrackClicks = additionalFields.trackClicks as string;
}
if (additionalFields.fromName) {
//@ts-ignore
body.Messages[0].From.name = additionalFields.fromName as string;
body.From!.Name = additionalFields.fromName as string;
}
if (additionalFields.templateLanguage) {
//@ts-ignore
body.Messages[0].From.TemplateLanguage = additionalFields.templateLanguage as boolean;
body.TemplateLanguage = additionalFields.templateLanguage as boolean;
}
if (additionalFields.priority) {
//@ts-ignore
body.Messages[0].Priority = additionalFields.priority as number;
body.Priority = additionalFields.priority as number;
}
responseData = await mailjetApiRequest.call(this, 'POST', '/v3.1/send', body);
responseData = await mailjetApiRequest.call(this, 'POST', '/v3.1/send', { Messages: [body] });
responseData = responseData.Messages;
}
}