/* * Copyright 2018 Gildas Lormeau * contact : gildas.lormeau gmail.com * * This file is part of SingleFile. * * SingleFile is free software: you can redistribute it and/or modify * it under the terms of the GNU Lesser General Public License as published by * the Free Software Foundation, either version 3 of the License, or * (at your option) any later version. * * SingleFile 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 Lesser General Public License for more details. * * You should have received a copy of the GNU Lesser General Public License * along with SingleFile. If not, see . */ /* global browser, document, Node, window, top, getComputedStyle */ this.singlefile.infobar = this.singlefile.infobar || (() => { const INFOBAR_TAGNAME = "singlefile-infobar"; const LINK_ICON = ""; const SINGLEFILE_COMMENT = "Archive processed by SingleFile"; if (window == top) { document.addEventListener("DOMContentLoaded", async () => { const singleFileComment = document.documentElement.childNodes[0]; if (singleFileComment.nodeType == Node.COMMENT_NODE && singleFileComment.textContent.includes(SINGLEFILE_COMMENT)) { const info = singleFileComment.textContent.split("\n"); const [, , url, saveDate] = info; const config = await browser.runtime.sendMessage({ getConfig: true }); if (config.displayInfobar) { initInfobar(url, saveDate); } } }); } return true; function initInfobar(url, saveDate) { let infobarElement = document.querySelector(INFOBAR_TAGNAME); if (!infobarElement) { infobarElement = createElement(INFOBAR_TAGNAME, document.body); infobarElement.style.display = "block"; infobarElement.style.fontSize = "15px"; infobarElement.style.color = "#9aa0a6"; infobarElement.style.position = "fixed"; infobarElement.style.top = "16px"; infobarElement.style.right = "16px"; infobarElement.style.height = "auto"; infobarElement.style.width = "36px"; infobarElement.style.lineHeight = "28px"; infobarElement.style.borderRadius = "16px"; infobarElement.style.border = infobarElement.style["-webkit-border-start"] = infobarElement.style["-webkit-border-end"] = infobarElement.style["-webkit-border-before"] = infobarElement.style["-webkit-border-after"] = "2px solid #737373"; infobarElement.style.zIndex = 2147483647; infobarElement.style.textAlign = "center"; infobarElement.style.transition = "all 250ms"; infobarElement.style.fontFamily = "Arial"; infobarElement.style.willChange = "opacity, padding-left, padding-right, width, background-color"; const linkElement = createElement("a", infobarElement); linkElement.style.display = "inline-block"; linkElement.style.paddingLeft = "8px"; linkElement.style.lineHeight = "28px"; linkElement.style.cursor = "pointer"; linkElement.target = "_blank"; linkElement.rel = "noopener noreferrer"; linkElement.title = "Open original page"; linkElement.href = url.split("url: ")[1]; const imgElement = createElement("img", linkElement); imgElement.style.verticalAlign = "middle"; imgElement.style.paddingBottom = imgElement.style["-webkit-padding-after"] = "2px"; imgElement.style.paddingLeft = imgElement.style["-webkit-padding-start"] = "2px"; imgElement.style.cursor = "pointer"; imgElement.src = LINK_ICON; hideInfobar(infobarElement, linkElement, saveDate); infobarElement.onmouseover = () => infobarElement.style.opacity = 1; document.addEventListener("click", event => { if (event.button === 0) { let element = event.target; while (element && element != infobarElement) { element = element.parentElement; } if (element != infobarElement) { hideInfobar(infobarElement, linkElement, saveDate); } } }); } } function displayInfobar(infobarElement, linkElement, saveDate) { infobarElement.style.opacity = 1; infobarElement.onmouseout = null; infobarElement.style.paddingLeft = infobarElement.style.paddingRight = infobarElement.style["-webkit-padding-end"] = infobarElement.style["-webkit-padding-start"] = "16px"; infobarElement.textContent = saveDate.split("saved date: ")[1]; infobarElement.style.width = "auto"; infobarElement.style.backgroundColor = "#f9f9f9"; infobarElement.style.cursor = "auto"; infobarElement.appendChild(linkElement); infobarElement.onclick = null; } function hideInfobar(infobarElement, linkElement, saveDate) { infobarElement.style.opacity = .7; infobarElement.onmouseout = () => infobarElement.style.opacity = .7; infobarElement.style.paddingLeft = infobarElement.style.paddingRight = infobarElement.style["-webkit-padding-end"] = infobarElement.style["-webkit-padding-start"] = "0px"; infobarElement.style.width = "28px"; infobarElement.style.backgroundColor = "#737373"; infobarElement.style.cursor = "pointer"; infobarElement.textContent = "❔"; infobarElement.onclick = event => { if (event.button === 0) { displayInfobar(infobarElement, linkElement, saveDate); return false; } }; } function createElement(tagName, parentElement) { const element = document.createElement(tagName); parentElement.appendChild(element); Array.from(getComputedStyle(element)).forEach(property => element.style[property] = "initial"); return element; } })();