-
Notifications
You must be signed in to change notification settings - Fork 1
/
Copy pathemail.js
166 lines (140 loc) · 5.36 KB
/
email.js
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
24
25
26
27
28
29
30
31
32
33
34
35
36
37
38
39
40
41
42
43
44
45
46
47
48
49
50
51
52
53
54
55
56
57
58
59
60
61
62
63
64
65
66
67
68
69
70
71
72
73
74
75
76
77
78
79
80
81
82
83
84
85
86
87
88
89
90
91
92
93
94
95
96
97
98
99
100
101
102
103
104
105
106
107
108
109
110
111
112
113
114
115
116
117
118
119
120
121
122
123
124
125
126
127
128
129
130
131
132
133
134
135
136
137
138
139
140
141
142
143
144
145
146
147
148
149
150
151
152
153
154
155
156
157
158
159
160
161
162
163
164
165
166
document.addEventListener("DOMContentLoaded", function() {
// get all data in form and return object
function getFormData(form) {
var elements = form.elements;
var honeypot;
var fields = Object.keys(elements).filter(function(k) {
if (elements[k].name === "honeypot") {
honeypot = elements[k].value;
return false;
}
return true;
}).map(function(k) {
if (elements[k].name !== undefined) return elements[k].name;
// special case for Edge's html collection
else if (elements[k].length > 0) return elements[k].item(0).name;
}).filter(function(item, pos, self) {
return self.indexOf(item) == pos && item;
});
var formData = {};
fields.forEach(function(name){
var element = elements[name];
// singular form elements just have one value
formData[name] = element.value;
// when our element has multiple items, get their values
if (element.length) {
var data = [];
for (let i = 0; i < element.length; i++) {
var item = element.item(i);
if (item.checked || item.selected) data.push(item.value);
}
formData[name] = data.join(", ");
}
});
// add form-specific values into the data
formData.formDataNameOrder = JSON.stringify(fields);
formData.formGoogleSheetName = form.dataset.sheet || "responses"; // default sheet name
formData.formGoogleSendEmail = form.dataset.email || ""; // no email by default
formData.gRecaptchaResponse = document.getElementById("g-recaptcha-response").value;
return { data: formData, honeypot: honeypot };
}
function handleFormSubmit(event) { // handles form submit without any jquery
loadingCursor(); // Show spinner while sending email
event.preventDefault(); // Submitting via xhr below
var form = event.target;
var formData = getFormData(form);
var data = formData.data;
// If a honeypot field is filled, assume it was done so by a spam bot
if (formData.honeypot) return false;
// Only load Toastify once
if (typeof Toastify === "undefined") loadToastify();
disableAllButtons(form);
var url = form.action;
var xhr = new XMLHttpRequest();
xhr.open("POST", url);
// xhr.withCredentials = true;
xhr.setRequestHeader("Content-Type", "application/x-www-form-urlencoded");
xhr.onreadystatechange = function() {
if (xhr.readyState === 4 && xhr.status === 200) {
form.reset();
var formElements = form.querySelector("#email");
// Hide email form
if (formElements) formElements.style.display = "none";
// Revert cursor to normal once sent
revertCursor();
// Show success message
Toastify({
text: "Message sent successfully!",
duration: 2500,
style: {
width: "25rem",
"font-size": "1.4rem"
},
offset: {
x: 0,
y: "3rem" // Height of menubar
},
}).showToast();
}
};
// url encode form data for sending as post data
var encoded = Object.keys(data).map(function(k) {
return encodeURIComponent(k) + "=" + encodeURIComponent(data[k]);
}).join("&");
xhr.send(encoded);
}
// Show spinner while sending email
function loadingCursor() {
document.body.style.cursor = "none";
$(".loader").show();
document.addEventListener("mousemove", moveMouse);
};
// Revert cursor to normal once sent
function revertCursor() {
document.body.style.cursor = "auto";
$(".loader").hide(); // formElements.style.display = "none";
document.removeEventListener("mousemove", moveMouse);
};
function moveMouse(e) {
var cursor = document.querySelector(".loader");
cursor.style.left = e.clientX + "px";
cursor.style.top = e.clientY + "px";
}
// Bind to the submit event of our form
function loaded() {
var forms = document.querySelectorAll("form.gform");
for (let i = 0; i < forms.length; i++) {
forms[i].addEventListener("submit", handleFormSubmit, false);
}
};
document.addEventListener("DOMContentLoaded", loaded, false);
function disableAllButtons(form) {
var buttons = form.querySelectorAll("button");
for (let i = 0; i < buttons.length; i++) {
buttons[i].disabled = true;
}
}
// Load script
function loadScript(url, defer = false, async = false) {
const script = document.createElement("script");
script.type = "text/javascript";
script.src = url;
if (defer) script.defer = true;
if (async) script.async = true;
document.head.appendChild(script);
}
// Load Toastify if not already loaded
function loadToastify() {
loadScript("https://cdn.jsdelivr.net/npm/toastify-js");
}
// Load reCAPTCHA when mail form is opened (i.e. mail icon is clicked)
function loadRecaptcha() {
loadScript("https://www.google.com/recaptcha/api.js");
// Remove event listener to avoid js error
document.getElementById("mailDockIcon").removeEventListener("click", loadRecaptcha);
document.getElementById("mailLaunch").removeEventListener("click", loadRecaptcha);
};
// Add initial event listener to mail form
document.getElementById("mailDockIcon").addEventListener("click", loadRecaptcha, false);
document.getElementById("mailLaunch").addEventListener("click", loadRecaptcha, false);
});