268 lines
8.2 KiB
JavaScript
268 lines
8.2 KiB
JavaScript
var MapGuesser = {
|
|
isSecure: window.location.protocol === 'https:',
|
|
cookiesAgreed: false,
|
|
sessionAvailableHooks: {},
|
|
|
|
initGoogleAnalitics: function () {
|
|
if (typeof GOOGLE_ANALITICS_ID === 'undefined') {
|
|
return;
|
|
}
|
|
|
|
// Global site tag (gtag.js) - Google Analytics
|
|
var script = document.createElement('script');
|
|
script.src = 'https://www.googletagmanager.com/gtag/js?id=' + GOOGLE_ANALITICS_ID;
|
|
script.async = true;
|
|
|
|
document.head.appendChild(script);
|
|
|
|
window.dataLayer = window.dataLayer || [];
|
|
function gtag() { dataLayer.push(arguments); }
|
|
gtag('js', new Date());
|
|
gtag('config', GOOGLE_ANALITICS_ID);
|
|
},
|
|
|
|
agreeCookies: function () {
|
|
if (MapGuesser.cookiesAgreed) {
|
|
return;
|
|
}
|
|
|
|
var expirationDate = new Date(new Date().getTime() + 20 * 365 * 24 * 60 * 60 * 1000).toUTCString();
|
|
document.cookie = 'COOKIES_CONSENT=1; expires=' + expirationDate + '; path=/';
|
|
|
|
MapGuesser.initGoogleAnalitics();
|
|
MapGuesser.httpRequest('GET', '/startSession.json', function () {
|
|
ANTI_CSRF_TOKEN = this.response.antiCsrfToken;
|
|
|
|
for (var hookId in MapGuesser.sessionAvailableHooks) {
|
|
if (!MapGuesser.sessionAvailableHooks.hasOwnProperty(hookId)) {
|
|
continue;
|
|
}
|
|
|
|
MapGuesser.sessionAvailableHooks[hookId]();
|
|
}
|
|
});
|
|
|
|
MapGuesser.cookiesAgreed = true;
|
|
},
|
|
|
|
httpRequest: function (method, url, callback, data) {
|
|
var xhr = new XMLHttpRequest();
|
|
|
|
xhr.onload = callback;
|
|
|
|
xhr.open(method, url, true);
|
|
|
|
xhr.responseType = 'json';
|
|
|
|
if (method === 'POST') {
|
|
if (typeof data === 'undefined') {
|
|
data = new FormData();
|
|
}
|
|
|
|
data.append('anti_csrf_token', ANTI_CSRF_TOKEN);
|
|
|
|
xhr.send(data);
|
|
} else {
|
|
xhr.send();
|
|
}
|
|
},
|
|
|
|
setOnsubmitForForm: function (form) {
|
|
form.onsubmit = function (e) {
|
|
e.preventDefault();
|
|
|
|
document.getElementById('loading').style.visibility = 'visible';
|
|
|
|
var formData = new FormData(form);
|
|
var formError = form.getElementsByClassName('formError')[0];
|
|
var pageLeaveOnSuccess = form.dataset.redirectOnSuccess || form.dataset.reloadOnSuccess;
|
|
|
|
MapGuesser.httpRequest('POST', form.action, function () {
|
|
if (!pageLeaveOnSuccess) {
|
|
document.getElementById('loading').style.visibility = 'hidden';
|
|
}
|
|
|
|
if (this.response.error) {
|
|
if (pageLeaveOnSuccess) {
|
|
document.getElementById('loading').style.visibility = 'hidden';
|
|
}
|
|
|
|
formError.style.display = 'block';
|
|
formError.innerHTML = this.response.error.errorText;
|
|
|
|
return;
|
|
}
|
|
|
|
if (this.response.redirect) {
|
|
window.location.replace(this.response.redirect.target);
|
|
|
|
return;
|
|
}
|
|
|
|
if (!pageLeaveOnSuccess) {
|
|
formError.style.display = 'none';
|
|
form.reset();
|
|
} else {
|
|
if (form.dataset.redirectOnSuccess) {
|
|
window.location.replace(form.dataset.redirectOnSuccess);
|
|
} else if (form.dataset.reloadOnSuccess) {
|
|
window.location.reload();
|
|
}
|
|
}
|
|
}, formData);
|
|
}
|
|
},
|
|
|
|
showModal: function (id) {
|
|
document.getElementById(id).style.visibility = 'visible';
|
|
document.getElementById('cover').style.visibility = 'visible';
|
|
},
|
|
|
|
showModalWithContent: function (title, body, extraButtons) {
|
|
if (typeof extraButtons === 'undefined') {
|
|
extraButtons = [];
|
|
}
|
|
|
|
MapGuesser.showModal('modal');
|
|
|
|
document.getElementById('modalTitle').textContent = title;
|
|
|
|
if (typeof body === 'object') {
|
|
document.getElementById('modalText').appendChild(body);
|
|
} else {
|
|
document.getElementById('modalText').textContent = body;
|
|
}
|
|
|
|
var buttons = document.getElementById('modalButtons');
|
|
buttons.textContent = '';
|
|
|
|
for (var i = 0; i < extraButtons.length; i++) {
|
|
var extraButton = extraButtons[i];
|
|
var button = document.createElement(extraButton.type);
|
|
|
|
if (extraButton.type === 'a') {
|
|
button.classList.add('button');
|
|
}
|
|
|
|
for (var i = 0; i < extraButton.classNames.length; i++) {
|
|
button.classList.add(extraButton.classNames[i]);
|
|
}
|
|
|
|
button.classList.add('marginTop');
|
|
button.classList.add('marginRight');
|
|
button.textContent = extraButton.text;
|
|
|
|
if (extraButton.type === 'a') {
|
|
button.href = extraButton.href;
|
|
} else if (extraButton.type === 'button') {
|
|
button.onclick = extraButton.onclick;
|
|
}
|
|
|
|
buttons.appendChild(button);
|
|
}
|
|
|
|
var closeButton = document.createElement('button');
|
|
|
|
closeButton.classList.add('gray');
|
|
closeButton.classList.add('marginTop');
|
|
closeButton.textContent = 'Close';
|
|
closeButton.onclick = function () {
|
|
MapGuesser.hideModal();
|
|
};
|
|
|
|
buttons.appendChild(closeButton);
|
|
},
|
|
|
|
hideModal: function () {
|
|
var modals = document.getElementsByClassName('modal');
|
|
|
|
for (var i = 0; i < modals.length; i++) {
|
|
modals[i].style.visibility = 'hidden';
|
|
}
|
|
|
|
document.getElementById('cover').style.visibility = 'hidden';
|
|
},
|
|
|
|
observeInput: function (input, buttonToToggle) {
|
|
if (input.defaultValue !== input.value) {
|
|
buttonToToggle.disabled = false;
|
|
} else {
|
|
buttonToToggle.disabled = true;
|
|
}
|
|
},
|
|
|
|
observeInputsInForm: function (form, observedInputs) {
|
|
for (var i = 0; i < observedInputs.length; i++) {
|
|
var input = form.elements[observedInputs[i]];
|
|
|
|
switch (input.tagName) {
|
|
case 'INPUT':
|
|
case 'TEXTAREA':
|
|
input.oninput = function () {
|
|
MapGuesser.observeInput(this, form.elements.submit);
|
|
};
|
|
break;
|
|
case 'SELECT':
|
|
input.onchange = function () {
|
|
MapGuesser.observeInput(this, form.elements.submit);
|
|
};
|
|
break;
|
|
}
|
|
}
|
|
|
|
form.onreset = function () {
|
|
form.elements.submit.disabled = true;
|
|
}
|
|
}
|
|
};
|
|
|
|
(function () {
|
|
var anchors = document.getElementsByTagName('a');
|
|
for (var i = 0; i < anchors.length; i++) {
|
|
var a = anchors[i];
|
|
if (a.href !== 'javascript:;' && a.target !== '_blank') {
|
|
a.onclick = function () {
|
|
document.getElementById('loading').style.visibility = 'visible';
|
|
}
|
|
}
|
|
}
|
|
|
|
var forms = document.getElementsByTagName('form');
|
|
for (var i = 0; i < forms.length; i++) {
|
|
var form = forms[i];
|
|
|
|
if (form.dataset.noSubmit) {
|
|
continue;
|
|
}
|
|
|
|
MapGuesser.setOnsubmitForForm(form);
|
|
|
|
if (form.dataset.observeInputs) {
|
|
MapGuesser.observeInputsInForm(form, form.dataset.observeInputs.split(','));
|
|
}
|
|
}
|
|
|
|
document.getElementById('cover').onclick = function () {
|
|
MapGuesser.hideModal();
|
|
};
|
|
|
|
if (COOKIES_CONSENT) {
|
|
MapGuesser.initGoogleAnalitics();
|
|
} else {
|
|
// we don't want user to agree cookies when clicking on the notice itself
|
|
document.getElementById('cookiesNotice').onclick = function (e) {
|
|
e.stopPropagation();
|
|
};
|
|
|
|
document.getElementById('agreeCookiesButton').onclick = function () {
|
|
MapGuesser.agreeCookies();
|
|
|
|
document.getElementById('cookiesNotice').style.display = 'none';
|
|
};
|
|
|
|
window.onclick = function () {
|
|
MapGuesser.agreeCookies();
|
|
};
|
|
}
|
|
})();
|