boast-init
Version:
The initialisation script for the boast product
94 lines (85 loc) • 7.32 kB
JavaScript
import build from './build';
var styles = '\n.nff-default-button {\n width: 80px;\n height: 80px;\n cursor: pointer;\n border-radius: 50%;\n position: fixed;\n bottom: 30px;\n right: 50px;\n background: #122a42;\n color: white;\n font-weight: bold;\n font-family: Arial;\n font-size: 22px;\n border: none;\n display: flex;\n justify-content:center;\n box-shadow: 0px 3px 15px rgba(0,0,0,0.3);\n}\n\n.nff-iframe-display-none {\n display: none;\n}\n\n.nff-iframe-display {\n display: block;\n}\n\n\n.nff-overlay {\n position: fixed;\n top: 0;\n left: 0;\n background: rgba(17, 103, 250, 0.5);\n width: 100%;\n height: 100%;\n z-index: 10000;\n animation: appear 0.1s;\n}\n\n.nff-container {\n border: none;\n position: fixed;\n right: 0;\n top: 0;\n width: 324px;\n background: transparent;\n height: 100vh;\n z-index: 10001;\n animation: appear 0.1s;\n}\n\n@media(min-width: 420px) {\n.nff-container {\n width: 400px;\n }\n}\n.gift {\n margin: auto 0;\n padding-top: 5px;\n max-width: 50px;\n}\n ';
var boastApp = {
openState: false,
userId: document.currentScript.attributes['data-userId'].value,
defaultButton: document.currentScript.attributes['data-defaultButton'] && document.currentScript.attributes['data-defaultButton'].value
};
var initStyles = function initStyles() {
var style = document.createElement('style');
style.innerHTML = styles;
document.querySelector('head').appendChild(style);
};
export var closeFeed = function closeFeed(event) {
try {
boastApp.openState = false;
var body = document.querySelector('body');
var feed = document.querySelector('.nff-container');
feed.setAttribute('class', 'nff-iframe-display-none');
body.removeChild(document.querySelector('#nff-overlay-id'));
} catch (exception) {
console.log(exception);
}
};
var createFeedButton = function createFeedButton() {
try {
var feedButton = build('button', [{ name: 'class', value: 'nff-default-button' }], boastApp.buttonText);
var img = build('img', [{ name: 'class', value: 'gift' }]);
img.setAttribute('src', "data:image/svg+xml;utf8;base64,PD94bWwgdmVyc2lvbj0iMS4wIiBlbmNvZGluZz0iaXNvLTg4NTktMSI/Pgo8IS0tIEdlbmVyYXRvcjogQWRvYmUgSWxsdXN0cmF0b3IgMTkuMC4wLCBTVkcgRXhwb3J0IFBsdWctSW4gLiBTVkcgVmVyc2lvbjogNi4wMCBCdWlsZCAwKSAgLS0+CjxzdmcgeG1sbnM9Imh0dHA6Ly93d3cudzMub3JnLzIwMDAvc3ZnIiB4bWxuczp4bGluaz0iaHR0cDovL3d3dy53My5vcmcvMTk5OS94bGluayIgdmVyc2lvbj0iMS4xIiBpZD0iTGF5ZXJfMSIgeD0iMHB4IiB5PSIwcHgiIHZpZXdCb3g9IjAgMCA1MDQuMTI0IDUwNC4xMjQiIHN0eWxlPSJlbmFibGUtYmFja2dyb3VuZDpuZXcgMCAwIDUwNC4xMjQgNTA0LjEyNDsiIHhtbDpzcGFjZT0icHJlc2VydmUiIHdpZHRoPSI1MTJweCIgaGVpZ2h0PSI1MTJweCI+CjxwYXRoIHN0eWxlPSJmaWxsOiNEQjU0NDk7IiBkPSJNMTUuNzU0LDEzMy45MDlsMjM2LjMwOCwxMTguMTU0TDQ4OC4zNywxMzMuOTA5djI1Mi4wNjJMMjUyLjA2Miw1MDQuMTIzTDE1Ljc1NCwzODUuOTY5VjEzMy45MDl6Ii8+CjxwYXRoIHN0eWxlPSJmaWxsOiNDNTRCNDI7IiBkPSJNMTUuNzU0LDE1Ny41Mzh2NzMuNjQ5bDIzNS41MiwxMTUuMzk3bDIzNy4wOTUtMTE1Ljc5MXYtNzMuMjU1TDI1Mi4wNjIsMjczLjMzTDE1Ljc1NCwxNTcuNTM4eiIvPgo8cGF0aCBzdHlsZT0iZmlsbDojRDA1MDQ1OyIgZD0iTTI1Mi4wNjIsNTA0LjEyM1YyNTIuMDYzTDMxLjUwOCwxNDEuNzg2SDE1Ljc1NHYyNDQuMTg1TDI1Mi4wNjIsNTA0LjEyM3oiLz4KPHBhdGggc3R5bGU9ImZpbGw6I0JCNDgzRTsiIGQ9Ik0xNS43NTQsMTU3LjUzOHY3My42NDlsMjM1LjUyLDExNS4zOTdsMC43ODgtMC4zOTR2LTczLjI1NXYwLjM5NEwxNS43NTQsMTU3LjUzOHoiLz4KPHBhdGggc3R5bGU9ImZpbGw6I0VCNjI1ODsiIGQ9Ik0wLDEyNS42MzhMMjUyLjA2MiwwLjAwMWwyNTIuMDYyLDEyNS42Mzd2MTYuNTQyTDI1Mi4wNjIsMjY3LjgxNUwwLDE0Mi41NzNWMTI1LjYzOHoiLz4KPHBhdGggc3R5bGU9ImZpbGw6I0VGRUZFRjsiIGQ9Ik0zOTYuNjAzLDM5Ljc3OWMtOC4yNzEtMTQuOTY2LTI1Ljk5NC0yNC4wMjUtNDYuODY4LTI0LjAyNWMtNDcuNjU1LDAtODEuMTMyLDQ0LjUwNS05Ny42NzQsNzIuODYyICBjLTE2LjU0Mi0yOC4zNTctNTAuNDEyLTcyLjQ2OC05Ny42NzQtNzIuNDY4Yy0zMC4zMjYsMC01MS45ODgsMTguNTExLTUxLjk4OCw0My43MTdjMCw0NC44OTgsNDkuMjMxLDc0LjA0MywxNDguMDg2LDc0LjA0MyAgczE1MS4yMzctMzcuNDE1LDE1MS4yMzctNzMuNjQ5QzQwMS43MjMsNTMuMTcsNDAwLjE0OCw0Ni4wODEsMzk2LjYwMywzOS43Nzl6IE0xNjQuNjI4LDg4LjIyMyAgYy0xMS4wMjgtNy40ODMtMTQuOTY2LTE1Ljc1NC0xNC45NjYtMjEuMjY4YzAtNi42OTUsNi4zMDItMTEuODE1LDE1LjM2LTExLjgxNWMyMS4yNjgsMCwzOC4yMDMsMjcuOTYzLDQ3LjY1NSw0Ny4yNjIgIEMxODcuODY1LDEwMC40MzIsMTczLjI5Miw5My43MzYsMTY0LjYyOCw4OC4yMjN6IE0zMzkuNDk1LDg4LjIyM2MtOC42NjUsNS41MTQtMjMuMjM3LDEyLjIwOS00OC4wNDksMTQuMTc4ICBjOS4wNTgtMTkuMjk4LDI1Ljk5NC00Ny4yNjIsNDcuNjU1LTQ3LjI2MmM5LjA1OCwwLDE1LjM2LDUuMTIsMTUuMzYsMTEuODE1QzM1NC40NjIsNzIuNDY5LDM1MC41MjMsODAuNzM5LDMzOS40OTUsODguMjIzeiIvPgo8cGF0aCBzdHlsZT0iZmlsbDojRTI1NzRDOyIgZD0iTTAsMTI2LjAzMmwyNTIuMDYyLDEyMy4yNzRsMjUyLjA2Mi0xMjMuMjc0djgxLjUyNmwtMjUyLjg1LDEyMy4yNzRMMCwyMDcuNTU4VjEyNi4wMzJ6Ii8+CjxwYXRoIHN0eWxlPSJmaWxsOiNFRkVGRUY7IiBkPSJNMzQ2LjU4NSwyMTMuODU5di05LjA1OGwtOTQuNTIzLTUxLjJsLTk0LjUyMyw1MS4ydjkuMDU4TDk0LjUyNCwxODYuMjl2LTEyLjYwM2wxNTQuMzg3LTgxLjUyNiAgbDMuMTUxLDEuNTc1bDMuMTUxLTEuNTc1TDQwOS42LDE3My4yOTN2MTIuNjAzTDM0Ni41ODUsMjEzLjg1OXoiLz4KPHBhdGggc3R5bGU9ImZpbGw6I0RDRENEQzsiIGQ9Ik0zNDYuNTg1LDIwNC44MDF2MjUxLjY2OGw2My4wMTUtMzEuNTA4VjE3My4yOTNMMzQ2LjU4NSwyMDQuODAxeiIvPgo8cGF0aCBzdHlsZT0iZmlsbDojRDFEMUQxOyIgZD0iTTk0LjUyMyw0MjUuMzU0bDYzLjAxNSwzMS41MDhWMjA1LjE5NWwtNjMuMDE1LTMxLjkwMkM5NC41MjMsMTczLjI5Miw5NC41MjMsNDI1LjM1NCw5NC41MjMsNDI1LjM1NCAgeiIvPgo8Zz4KPC9nPgo8Zz4KPC9nPgo8Zz4KPC9nPgo8Zz4KPC9nPgo8Zz4KPC9nPgo8Zz4KPC9nPgo8Zz4KPC9nPgo8Zz4KPC9nPgo8Zz4KPC9nPgo8Zz4KPC9nPgo8Zz4KPC9nPgo8Zz4KPC9nPgo8Zz4KPC9nPgo8Zz4KPC9nPgo8Zz4KPC9nPgo8L3N2Zz4K");
feedButton.append(img);
document.body.appendChild(feedButton);
return [feedButton];
} catch (exception) {
console.log(exception);
}
};
var showNewFeatureFeed = function showNewFeatureFeed(userId, origin, feed) {
try {
if (boastApp.openState === false) {
var overlay = build('div', [{ name: 'class', value: 'nff-overlay' }, { name: 'id', value: 'nff-overlay-id' }]);
overlay.addEventListener('click', closeFeed);
var body = document.querySelector('body');
body.append(overlay);
feed.setAttribute('class', 'nff-container');
boastApp.openState = true;
} else {
closeFeed();
}
} catch (exception) {
console.log(exception);
}
};
(function initFeed() {
try {
var userId = boastApp.userId,
defaultButton = boastApp.defaultButton;
window.addEventListener('message', function (e) {
if (e.origin === 'https://getboast.co') {
var task = e.data['task'];
if (task = 'close') closeFeed();
}
});
var feedButtons = document.getElementsByClassName('boast-button-init');
feedButtons = Array.from(feedButtons);
console.log(feedButtons);
initStyles();
if (!userId) throw new Error('Make sure a userId is included in the snippet');
if (defaultButton) {
feedButtons = createFeedButton(userId);
}
var _origin = window.location.origin;
var feedContainer = build('iframe', [{ name: 'class', value: 'nff-iframe-display-none' }, { name: 'id', value: 'nff-container-id' }, { name: 'src', value: 'https://getboast.co/feed/' + userId + '?origin=' + _origin }]);
feedContainer.addEventListener('click', function (event) {
return event.stopPropagation();
});
document.body.append(feedContainer);
var _origin = window.location.href;
feedButtons.forEach(function (button) {
button.addEventListener('click', function () {
showNewFeatureFeed(userId, _origin, feedContainer);
});
});
} catch (exception) {
console.log(exception);
}
})();