/* * Copyright 2010-2020 Gildas Lormeau * contact : gildas.lormeau gmail.com * * This file is part of SingleFile. * * The code in this file is free software: you can redistribute it and/or * modify it under the terms of the GNU Affero General Public License * (GNU AGPL) as published by the Free Software Foundation, either version 3 * of the License, or (at your option) any later version. * * The code in this file is distributed in the hope that it will be useful, * but WITHOUT ANY WARRANTY; without even the implied warranty of * MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the GNU Affero * General Public License for more details. * * As additional permission under GNU AGPL version 3 section 7, you may * distribute UNMODIFIED VERSIONS OF THIS file without the copy of the GNU * AGPL normally required by section 4, provided you include this license * notice and a URL through which recipients can access the Corresponding * Source. */ /* global document, globalThis, getComputedStyle */ const singlefile = globalThis.singlefile; const CLOSE_ICON = ""; const SINGLE_FILE_UI_ELEMENT_CLASS = singlefile.helper.SINGLE_FILE_UI_ELEMENT_CLASS; const ERROR_BAR_TAGNAME = "singlefile-error-bar"; const CSS_PROPERTIES = new Set(Array.from(getComputedStyle(document.body))); let errorBarElement; export { onError }; function onError(message) { try { console.error("SingleFile", message); // eslint-disable-line no-console errorBarElement = document.querySelector(ERROR_BAR_TAGNAME); if (!errorBarElement) { errorBarElement = createElement(ERROR_BAR_TAGNAME); const shadowRoot = errorBarElement.attachShadow({ mode: "open" }); const styleElement = document.createElement("style"); styleElement.textContent = ` .container { background-color: #ff6c00; color: white; display: flex; position: fixed; top: 0px; left: 0px; right: 0px; height: auto; width: auto; min-height: 24px; min-width: 24px; z-index: 2147483647; margin: 0; padding: 2px; font-family: Arial; } .text { flex: 1; padding-top: 4px; padding-bottom: 4px; padding-left: 8px; } .close-button { opacity: .7; padding-top: 4px; padding-left: 8px; padding-right: 8px; cursor: pointer; transition: opacity 250ms; height: 16px; } .close-button:hover { opacity: 1; } `; shadowRoot.appendChild(styleElement); const containerElement = document.createElement("div"); containerElement.className = "container"; const errorTextElement = document.createElement("span"); errorTextElement.classList.add("text"); errorTextElement.textContent = "SingleFile error: " + message; containerElement.appendChild(errorTextElement); const closeElement = document.createElement("img"); closeElement.classList.add("close-button"); containerElement.appendChild(closeElement); shadowRoot.appendChild(containerElement); closeElement.src = CLOSE_ICON; closeElement.onclick = event => { if (event.button === 0) { errorBarElement.remove(); } }; document.body.appendChild(errorBarElement); } } catch (error) { // iignored } } function createElement(tagName, parentElement) { const element = document.createElement(tagName); element.className = SINGLE_FILE_UI_ELEMENT_CLASS; if (parentElement) { parentElement.appendChild(element); } CSS_PROPERTIES.forEach(property => element.style.setProperty(property, "initial", "important")); return element; }