UNPKG

boast-init

Version:

The initialisation script for the boast product

103 lines (90 loc) 7.62 kB
'use strict'; exports.__esModule = true; exports.closeFeed = undefined; var _build = require('./build'); var _build2 = _interopRequireDefault(_build); function _interopRequireDefault(obj) { return obj && obj.__esModule ? obj : { default: obj }; } 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); }; var closeFeed = exports.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 = (0, _build2.default)('button', [{ name: 'class', value: 'nff-default-button' }], boastApp.buttonText); var img = (0, _build2.default)('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 = (0, _build2.default)('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 = (0, _build2.default)('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); } })();