some helpers

This commit is contained in:
Matteo Manzinello 2019-11-07 09:20:14 +01:00
parent e7e8235f64
commit 40928248af
3 changed files with 70 additions and 64 deletions

2
dist/mailgo.min.js vendored

File diff suppressed because one or more lines are too long

File diff suppressed because one or more lines are too long

View File

@ -51,75 +51,75 @@ const mailgoVersion = "MAILGO_VERSION";
// mailgo mail // mailgo mail
{ {
// modal // modal
let modal = document.createElement("div"); let modal = createElement("div");
modal.style.display = "none"; modal.style.display = "none";
modal.id = "mailgo"; modal.id = "mailgo";
modal.classList.add("m-modal"); modal.classList.add("m-modal");
// background // background
let modalBackground = document.createElement("div"); let modalBackground = createElement("div");
modalBackground.className = "m-modal-back"; modalBackground.className = "m-modal-back";
modal.appendChild(modalBackground); modal.appendChild(modalBackground);
// modal content // modal content
let modalContent = document.createElement("div"); let modalContent = createElement("div");
modalContent.className = "m-modal-content"; modalContent.className = "m-modal-content";
modal.appendChild(modalContent); modal.appendChild(modalContent);
// title (email address) // title (email address)
title = document.createElement("strong"); title = createElement("strong");
title.id = "m-title"; title.id = "m-title";
title.className = "m-title"; title.className = "m-title";
modalContent.appendChild(title); modalContent.appendChild(title);
// details // details
let details = document.createElement("div"); let details = createElement("div");
details.id = "m-details"; details.id = "m-details";
details.className = "m-details"; details.className = "m-details";
detailCc = document.createElement("p"); detailCc = createElement("p");
detailCc.id = "m-cc"; detailCc.id = "m-cc";
let ccSpan = document.createElement("span"); let ccSpan = createElement("span");
ccSpan.className = "w-500"; ccSpan.className = "w-500";
let ccContent = document.createTextNode("cc "); let ccContent = createTextNode("cc ");
ccSpan.appendChild(ccContent); ccSpan.appendChild(ccContent);
ccValue = document.createElement("span"); ccValue = createElement("span");
ccValue.id = "m-cc-value"; ccValue.id = "m-cc-value";
detailCc.appendChild(ccSpan); detailCc.appendChild(ccSpan);
detailCc.appendChild(ccValue); detailCc.appendChild(ccValue);
details.appendChild(detailCc); details.appendChild(detailCc);
detailBcc = document.createElement("p"); detailBcc = createElement("p");
detailBcc.id = "m-bcc"; detailBcc.id = "m-bcc";
let bccSpan = document.createElement("span"); let bccSpan = createElement("span");
bccSpan.className = "w-500"; bccSpan.className = "w-500";
let bccContent = document.createTextNode("bcc "); let bccContent = createTextNode("bcc ");
bccSpan.appendChild(bccContent); bccSpan.appendChild(bccContent);
bccValue = document.createElement("span"); bccValue = createElement("span");
bccValue.id = "m-bcc-value"; bccValue.id = "m-bcc-value";
detailBcc.appendChild(bccSpan); detailBcc.appendChild(bccSpan);
detailBcc.appendChild(bccValue); detailBcc.appendChild(bccValue);
details.appendChild(detailBcc); details.appendChild(detailBcc);
detailSubject = document.createElement("p"); detailSubject = createElement("p");
detailSubject.id = "m-subject"; detailSubject.id = "m-subject";
let subjectSpan = document.createElement("span"); let subjectSpan = createElement("span");
subjectSpan.className = "w-500"; subjectSpan.className = "w-500";
let subjectContent = document.createTextNode("subject "); let subjectContent = createTextNode("subject ");
subjectSpan.appendChild(subjectContent); subjectSpan.appendChild(subjectContent);
subjectValue = document.createElement("span"); subjectValue = createElement("span");
subjectValue.id = "m-subject-value"; subjectValue.id = "m-subject-value";
detailSubject.appendChild(subjectSpan); detailSubject.appendChild(subjectSpan);
detailSubject.appendChild(subjectValue); detailSubject.appendChild(subjectValue);
details.appendChild(detailSubject); details.appendChild(detailSubject);
detailBody = document.createElement("p"); detailBody = createElement("p");
detailBody.id = "m-body"; detailBody.id = "m-body";
let bodySpan = document.createElement("span"); let bodySpan = createElement("span");
bodySpan.className = "w-500"; bodySpan.className = "w-500";
let bodyContent = document.createTextNode("body "); let bodyContent = createTextNode("body ");
bodySpan.appendChild(bodyContent); bodySpan.appendChild(bodyContent);
bodyValue = document.createElement("span"); bodyValue = createElement("span");
bodyValue.id = "m-body-value"; bodyValue.id = "m-body-value";
detailBody.appendChild(bodySpan); detailBody.appendChild(bodySpan);
detailBody.appendChild(bodyValue); detailBody.appendChild(bodyValue);
@ -128,60 +128,60 @@ const mailgoVersion = "MAILGO_VERSION";
modalContent.appendChild(details); modalContent.appendChild(details);
// Gmail // Gmail
gmail = document.createElement("a"); gmail = createElement("a");
gmail.id = "m-gmail"; gmail.id = "m-gmail";
gmail.href = DEFAULT_BTN_HREF; gmail.href = DEFAULT_BTN_HREF;
gmail.classList.add("m-open"); gmail.classList.add("m-open");
gmail.classList.add("m-gmail"); gmail.classList.add("m-gmail");
let gmailContent = document.createTextNode("open in "); let gmailContent = createTextNode("open in ");
gmail.appendChild(gmailContent); gmail.appendChild(gmailContent);
let gmailSpan = document.createElement("span"); let gmailSpan = createElement("span");
gmailSpan.className = "w-500"; gmailSpan.className = "w-500";
let gmailSpanContent = document.createTextNode("Gmail"); let gmailSpanContent = createTextNode("Gmail");
gmailSpan.appendChild(gmailSpanContent); gmailSpan.appendChild(gmailSpanContent);
gmail.appendChild(gmailSpan); gmail.appendChild(gmailSpan);
modalContent.appendChild(gmail); modalContent.appendChild(gmail);
// Outlook // Outlook
outlook = document.createElement("a"); outlook = createElement("a");
outlook.id = "m-outlook"; outlook.id = "m-outlook";
outlook.href = DEFAULT_BTN_HREF; outlook.href = DEFAULT_BTN_HREF;
outlook.classList.add("m-open"); outlook.classList.add("m-open");
outlook.classList.add("m-outlook"); outlook.classList.add("m-outlook");
let outlookContent = document.createTextNode("open in "); let outlookContent = createTextNode("open in ");
outlook.appendChild(outlookContent); outlook.appendChild(outlookContent);
let outlookSpan = document.createElement("span"); let outlookSpan = createElement("span");
outlookSpan.className = "w-500"; outlookSpan.className = "w-500";
let outlookSpanContent = document.createTextNode("Outlook"); let outlookSpanContent = createTextNode("Outlook");
outlookSpan.appendChild(outlookSpanContent); outlookSpan.appendChild(outlookSpanContent);
outlook.appendChild(outlookSpan); outlook.appendChild(outlookSpan);
modalContent.appendChild(outlook); modalContent.appendChild(outlook);
// open default // open default
open = document.createElement("a"); open = createElement("a");
open.id = "m-open"; open.id = "m-open";
open.href = DEFAULT_BTN_HREF; open.href = DEFAULT_BTN_HREF;
open.classList.add("m-open"); open.classList.add("m-open");
open.classList.add("m-default"); open.classList.add("m-default");
let openSpan = document.createElement("span"); let openSpan = createElement("span");
openSpan.className = "w-500"; openSpan.className = "w-500";
let openSpanContent = document.createTextNode("open"); let openSpanContent = createTextNode("open");
openSpan.appendChild(openSpanContent); openSpan.appendChild(openSpanContent);
let openContent = document.createTextNode(" default"); let openContent = createTextNode(" default");
open.appendChild(openSpan); open.appendChild(openSpan);
open.appendChild(openContent); open.appendChild(openContent);
modalContent.appendChild(open); modalContent.appendChild(open);
// copy // copy
copyMail = document.createElement("a"); copyMail = createElement("a");
copyMail.id = "m-copy"; copyMail.id = "m-copy";
copyMail.href = DEFAULT_BTN_HREF; copyMail.href = DEFAULT_BTN_HREF;
copyMail.classList.add("m-copy"); copyMail.classList.add("m-copy");
copyMail.classList.add("w-500"); copyMail.classList.add("w-500");
let copyContent = document.createTextNode("copy"); let copyContent = createTextNode("copy");
copyMail.appendChild(copyContent); copyMail.appendChild(copyContent);
modalContent.appendChild(copyMail); modalContent.appendChild(copyMail);
@ -197,29 +197,29 @@ const mailgoVersion = "MAILGO_VERSION";
// mailgo tel // mailgo tel
{ {
// modal // modal
let modal = document.createElement("div"); let modal = createElement("div");
modal.style.display = "none"; modal.style.display = "none";
modal.id = "mailgo-tel"; modal.id = "mailgo-tel";
modal.classList.add("m-modal"); modal.classList.add("m-modal");
// background // background
let modalBackground = document.createElement("div"); let modalBackground = createElement("div");
modalBackground.className = "m-modal-back"; modalBackground.className = "m-modal-back";
modal.appendChild(modalBackground); modal.appendChild(modalBackground);
// modal content // modal content
let modalContent = document.createElement("div"); let modalContent = createElement("div");
modalContent.className = "m-modal-content"; modalContent.className = "m-modal-content";
modal.appendChild(modalContent); modal.appendChild(modalContent);
// title (telephone number) // title (telephone number)
titleTel = document.createElement("strong"); titleTel = createElement("strong");
titleTel.id = "m-tel-title"; titleTel.id = "m-tel-title";
titleTel.className = "m-title"; titleTel.className = "m-title";
modalContent.appendChild(titleTel); modalContent.appendChild(titleTel);
// Telegram // Telegram
telegram = document.createElement("a"); telegram = createElement("a");
telegram.id = "m-tg"; telegram.id = "m-tg";
telegram.href = DEFAULT_BTN_HREF; telegram.href = DEFAULT_BTN_HREF;
telegram.classList.add("m-open"); telegram.classList.add("m-open");
@ -228,71 +228,71 @@ const mailgoVersion = "MAILGO_VERSION";
// by default not display // by default not display
telegram.style.display = "none"; telegram.style.display = "none";
let telegramContent = document.createTextNode("open in "); let telegramContent = createTextNode("open in ");
telegram.appendChild(telegramContent); telegram.appendChild(telegramContent);
let telegramSpan = document.createElement("span"); let telegramSpan = createElement("span");
telegramSpan.className = "w-500"; telegramSpan.className = "w-500";
let telegramSpanContent = document.createTextNode("Telegram"); let telegramSpanContent = createTextNode("Telegram");
telegramSpan.appendChild(telegramSpanContent); telegramSpan.appendChild(telegramSpanContent);
telegram.appendChild(telegramSpan); telegram.appendChild(telegramSpan);
modalContent.appendChild(telegram); modalContent.appendChild(telegram);
// WhatsApp // WhatsApp
wa = document.createElement("a"); wa = createElement("a");
wa.id = "m-wa"; wa.id = "m-wa";
wa.href = DEFAULT_BTN_HREF; wa.href = DEFAULT_BTN_HREF;
wa.classList.add("m-open"); wa.classList.add("m-open");
wa.classList.add("m-wa"); wa.classList.add("m-wa");
let waContent = document.createTextNode("open in "); let waContent = createTextNode("open in ");
wa.appendChild(waContent); wa.appendChild(waContent);
let waSpan = document.createElement("span"); let waSpan = createElement("span");
waSpan.className = "w-500"; waSpan.className = "w-500";
let waSpanContent = document.createTextNode("WhatsApp"); let waSpanContent = createTextNode("WhatsApp");
waSpan.appendChild(waSpanContent); waSpan.appendChild(waSpanContent);
wa.appendChild(waSpan); wa.appendChild(waSpan);
modalContent.appendChild(wa); modalContent.appendChild(wa);
// Skype // Skype
skype = document.createElement("a"); skype = createElement("a");
skype.id = "m-skype"; skype.id = "m-skype";
skype.href = DEFAULT_BTN_HREF; skype.href = DEFAULT_BTN_HREF;
skype.classList.add("m-open"); skype.classList.add("m-open");
skype.classList.add("m-skype"); skype.classList.add("m-skype");
let skypeContent = document.createTextNode("open in "); let skypeContent = createTextNode("open in ");
skype.appendChild(skypeContent); skype.appendChild(skypeContent);
let skypeSpan = document.createElement("span"); let skypeSpan = createElement("span");
skypeSpan.className = "w-500"; skypeSpan.className = "w-500";
let skypeSpanContent = document.createTextNode("Skype"); let skypeSpanContent = createTextNode("Skype");
skypeSpan.appendChild(skypeSpanContent); skypeSpan.appendChild(skypeSpanContent);
skype.appendChild(skypeSpan); skype.appendChild(skypeSpan);
modalContent.appendChild(skype); modalContent.appendChild(skype);
// call default // call default
call = document.createElement("a"); call = createElement("a");
call.id = "m-call"; call.id = "m-call";
call.href = DEFAULT_BTN_HREF; call.href = DEFAULT_BTN_HREF;
call.classList.add("m-open"); call.classList.add("m-open");
call.classList.add("m-default"); call.classList.add("m-default");
let callSpan = document.createElement("span"); let callSpan = createElement("span");
callSpan.className = "w-500"; callSpan.className = "w-500";
let callSpanContent = document.createTextNode("call"); let callSpanContent = createTextNode("call");
callSpan.appendChild(callSpanContent); callSpan.appendChild(callSpanContent);
let callContent = document.createTextNode(" as default"); let callContent = createTextNode(" as default");
call.appendChild(callSpan); call.appendChild(callSpan);
call.appendChild(callContent); call.appendChild(callContent);
modalContent.appendChild(call); modalContent.appendChild(call);
// copy // copy
copyTel = document.createElement("a"); copyTel = createElement("a");
copyTel.id = "m-tel-copy"; copyTel.id = "m-tel-copy";
copyTel.href = DEFAULT_BTN_HREF; copyTel.href = DEFAULT_BTN_HREF;
copyTel.classList.add("m-copy"); copyTel.classList.add("m-copy");
copyTel.classList.add("w-500"); copyTel.classList.add("w-500");
let copyContent = document.createTextNode("copy"); let copyContent = createTextNode("copy");
copyTel.appendChild(copyContent); copyTel.appendChild(copyContent);
modalContent.appendChild(copyTel); modalContent.appendChild(copyTel);
@ -758,12 +758,12 @@ const mailgoVersion = "MAILGO_VERSION";
const byElement = () => { const byElement = () => {
// by // by
let by = document.createElement("a"); let by = createElement("a");
by.href = "https://mailgo.js.org?ref=mailgo-modal"; by.href = "https://mailgo.js.org?ref=mailgo-modal";
by.className = "m-by"; by.className = "m-by";
by.target = "_blank"; by.target = "_blank";
by.rel = "noopener noreferrer"; by.rel = "noopener noreferrer";
let textBy = document.createTextNode("mailgo.js.org"); let textBy = createTextNode("mailgo.js.org");
by.appendChild(textBy); by.appendChild(textBy);
return by; return by;
@ -772,6 +772,12 @@ const mailgoVersion = "MAILGO_VERSION";
// window exists // window exists
const windowExists = () => window && typeof window !== "undefined"; const windowExists = () => window && typeof window !== "undefined";
// create element
const createElement = element => document.createElement(element);
// create text node
const createTextNode = element => document.createTextNode(element);
// decrypt email // decrypt email
const mailToEncoded = encoded => const mailToEncoded = encoded =>
(window.location.href = MAILTO + atob(encoded)); (window.location.href = MAILTO + atob(encoded));
@ -816,7 +822,7 @@ const mailgoVersion = "MAILGO_VERSION";
// copy of a string // copy of a string
const copyToClipboard = str => { const copyToClipboard = str => {
let el = document.createElement("textarea"); let el = createElement("textarea");
el.value = str; el.value = str;
el.setAttribute("readonly", ""); el.setAttribute("readonly", "");
el.style.position = "absolute"; el.style.position = "absolute";
@ -840,10 +846,10 @@ const mailgoVersion = "MAILGO_VERSION";
// if the window object exists... // if the window object exists...
if (windowExists()) { if (windowExists()) {
// mailgo style (gulp) // mailgo style (gulp)
let mailgoCSS = document.createElement("style"); let mailgoCSS = createElement("style");
mailgoCSS.id = "mailgo-style"; mailgoCSS.id = "mailgo-style";
mailgoCSS.type = "text/css"; mailgoCSS.type = "text/css";
let mailgoCSSContent = document.createTextNode(`MAILGO_STYLE`); let mailgoCSSContent = createTextNode(`MAILGO_STYLE`);
mailgoCSS.appendChild(mailgoCSSContent); mailgoCSS.appendChild(mailgoCSSContent);
document.head.appendChild(mailgoCSS); document.head.appendChild(mailgoCSS);