|
@@ -21,12 +21,12 @@
|
|
|
* Source.
|
|
* Source.
|
|
|
*/
|
|
*/
|
|
|
|
|
|
|
|
-/* global document, Node, window, top, getComputedStyle, setTimeout, XPathResult */
|
|
|
|
|
|
|
+/* global document, Node, window, top, getComputedStyle, XPathResult */
|
|
|
|
|
|
|
|
(() => {
|
|
(() => {
|
|
|
|
|
|
|
|
const INFOBAR_TAGNAME = "singlefile-infobar";
|
|
const INFOBAR_TAGNAME = "singlefile-infobar";
|
|
|
- const LINK_ICON = "";
|
|
|
|
|
|
|
+ const LINK_ICON = "";
|
|
|
const IMAGE_ICON = "";
|
|
const IMAGE_ICON = "";
|
|
|
const SINGLEFILE_COMMENT = "SingleFile";
|
|
const SINGLEFILE_COMMENT = "SingleFile";
|
|
|
const SINGLE_FILE_UI_ELEMENT_CLASS = "single-file-ui-element";
|
|
const SINGLE_FILE_UI_ELEMENT_CLASS = "single-file-ui-element";
|
|
@@ -81,65 +81,131 @@
|
|
|
}
|
|
}
|
|
|
infobarElement = createElement(INFOBAR_TAGNAME, document.body);
|
|
infobarElement = createElement(INFOBAR_TAGNAME, document.body);
|
|
|
infobarElement.className = SINGLE_FILE_UI_ELEMENT_CLASS;
|
|
infobarElement.className = SINGLE_FILE_UI_ELEMENT_CLASS;
|
|
|
- setProperty(infobarElement, "background-color", "#f9f9f9");
|
|
|
|
|
- setProperty(infobarElement, "display", "flex");
|
|
|
|
|
- setProperty(infobarElement, "position", "fixed");
|
|
|
|
|
- setProperty(infobarElement, "top", "16px");
|
|
|
|
|
- setProperty(infobarElement, "right", "16px");
|
|
|
|
|
- setProperty(infobarElement, "height", "auto");
|
|
|
|
|
- setProperty(infobarElement, "min-height", "24px");
|
|
|
|
|
- setProperty(infobarElement, "min-width", "24px");
|
|
|
|
|
- setProperty(infobarElement, "background-position", "center");
|
|
|
|
|
- setProperty(infobarElement, "background-repeat", "no-repeat");
|
|
|
|
|
- setProperty(infobarElement, "z-index", 2147483647);
|
|
|
|
|
- setProperty(infobarElement, "text-align", "center");
|
|
|
|
|
- setProperty(infobarElement, "will-change", "opacity, padding-left, padding-right, width, background-color, color");
|
|
|
|
|
- setProperty(infobarElement, "margin", "0 0 0 16px");
|
|
|
|
|
- const closeElement = createElement("span", infobarElement);
|
|
|
|
|
|
|
+ const shadowRoot = infobarElement.attachShadow({ mode: "open" });
|
|
|
|
|
+ const styleElement = document.createElement("style");
|
|
|
|
|
+ styleElement.textContent = `
|
|
|
|
|
+ .infobar {
|
|
|
|
|
+ background-color: #737373;
|
|
|
|
|
+ color: white;
|
|
|
|
|
+ display: flex;
|
|
|
|
|
+ position: fixed;
|
|
|
|
|
+ top: 16px;
|
|
|
|
|
+ right: 16px;
|
|
|
|
|
+ height: auto;
|
|
|
|
|
+ width: auto;
|
|
|
|
|
+ min-height: 24px;
|
|
|
|
|
+ min-width: 24px;
|
|
|
|
|
+ background-position: center;
|
|
|
|
|
+ background-repeat: no-repeat;
|
|
|
|
|
+ z-index: 2147483647;
|
|
|
|
|
+ text-align: center;
|
|
|
|
|
+ margin: 0 0 0 16px;
|
|
|
|
|
+ background-image: url(${IMAGE_ICON});
|
|
|
|
|
+ border-radius: 16px;
|
|
|
|
|
+ user-select: none;
|
|
|
|
|
+ opacity: .7;
|
|
|
|
|
+ cursor: pointer;
|
|
|
|
|
+ padding-left: 0;
|
|
|
|
|
+ padding-right: 0;
|
|
|
|
|
+ padding-top: 0;
|
|
|
|
|
+ padding-bottom: 0;
|
|
|
|
|
+ border: 2px solid #eee;
|
|
|
|
|
+ background-size: 70% 70%;
|
|
|
|
|
+ transition: all 250ms;
|
|
|
|
|
+ font-size: 13px;
|
|
|
|
|
+ }
|
|
|
|
|
+ .infobar:hover {
|
|
|
|
|
+ opacity: 1;
|
|
|
|
|
+ }
|
|
|
|
|
+ .infobar-open {
|
|
|
|
|
+ opacity: 1;
|
|
|
|
|
+ background-color: #f9f9f9;
|
|
|
|
|
+ cursor: auto;
|
|
|
|
|
+ color: #2d2d2d;
|
|
|
|
|
+ padding-top: 2px;
|
|
|
|
|
+ padding-bottom: 2px;
|
|
|
|
|
+ -webkit-padding-start: 8px;
|
|
|
|
|
+ -webkit-padding-end: 4px;
|
|
|
|
|
+ border: 2px solid #878787;
|
|
|
|
|
+ background-image: none;
|
|
|
|
|
+ border-radius: 8px;
|
|
|
|
|
+ user-select: initial;
|
|
|
|
|
+ -moz-user-select: initial;
|
|
|
|
|
+ }
|
|
|
|
|
+ .infobar-close-button {
|
|
|
|
|
+ display: none;
|
|
|
|
|
+ opacity: .7;
|
|
|
|
|
+ padding-right: 8px;
|
|
|
|
|
+ cursor: pointer;
|
|
|
|
|
+ color: rgb(126 135 140);
|
|
|
|
|
+ line-height: 24px;
|
|
|
|
|
+ font-size: 16px;
|
|
|
|
|
+ transition: opacity 250ms;
|
|
|
|
|
+ }
|
|
|
|
|
+ .infobar-close-button:hover {
|
|
|
|
|
+ opacity: 1;
|
|
|
|
|
+ }
|
|
|
|
|
+ .infobar-content {
|
|
|
|
|
+ display: none;
|
|
|
|
|
+ font-family: Arial;
|
|
|
|
|
+ font-size: 14px;
|
|
|
|
|
+ line-height: 22px;
|
|
|
|
|
+ word-break: break-word;
|
|
|
|
|
+ white-space: pre-wrap;
|
|
|
|
|
+ position: relative;
|
|
|
|
|
+ top: 1px;
|
|
|
|
|
+ }
|
|
|
|
|
+ .infobar-link {
|
|
|
|
|
+ display: none;
|
|
|
|
|
+ padding-left: 8px;
|
|
|
|
|
+ line-height: 11px;
|
|
|
|
|
+ cursor: pointer;
|
|
|
|
|
+ user-select: none;
|
|
|
|
|
+ }
|
|
|
|
|
+ .infobar-link-icon {
|
|
|
|
|
+ padding-top: 3px;
|
|
|
|
|
+ padding-left: 2px;
|
|
|
|
|
+ cursor: pointer;
|
|
|
|
|
+ opacity: .7;
|
|
|
|
|
+ transition: opacity 250ms;
|
|
|
|
|
+ }
|
|
|
|
|
+ .infobar-link-icon:hover {
|
|
|
|
|
+ opacity: 1;
|
|
|
|
|
+ }
|
|
|
|
|
+ .infobar-open .infobar-close-button, .infobar-open .infobar-content, .infobar-open .infobar-link {
|
|
|
|
|
+ display: inline-block;
|
|
|
|
|
+ }
|
|
|
|
|
+ `;
|
|
|
|
|
+ shadowRoot.appendChild(styleElement);
|
|
|
|
|
+ const infobarContent = document.createElement("div");
|
|
|
|
|
+ infobarContent.classList.add("infobar");
|
|
|
|
|
+ shadowRoot.appendChild(infobarContent);
|
|
|
|
|
+ const closeElement = document.createElement("span");
|
|
|
|
|
+ closeElement.classList.add("infobar-close-button");
|
|
|
|
|
+ infobarContent.appendChild(closeElement);
|
|
|
closeElement.textContent = "✕";
|
|
closeElement.textContent = "✕";
|
|
|
- setProperty(closeElement, "display", "none");
|
|
|
|
|
- setProperty(closeElement, "opacity", .7);
|
|
|
|
|
- setProperty(closeElement, "padding-right", "8px");
|
|
|
|
|
- setProperty(closeElement, "cursor", "pointer");
|
|
|
|
|
- setProperty(closeElement, "color", "rgb(126 135 140)");
|
|
|
|
|
- setProperty(closeElement, "line-height", "24px");
|
|
|
|
|
- closeElement.onmouseover = () => setProperty(closeElement, "opacity", 1);
|
|
|
|
|
- closeElement.onmouseout = () => setProperty(closeElement, "opacity", .7);
|
|
|
|
|
closeElement.onclick = event => {
|
|
closeElement.onclick = event => {
|
|
|
if (event.button === 0) {
|
|
if (event.button === 0) {
|
|
|
infobarElement.remove();
|
|
infobarElement.remove();
|
|
|
}
|
|
}
|
|
|
};
|
|
};
|
|
|
- const infoElement = createElement("span", infobarElement);
|
|
|
|
|
- setProperty(infoElement, "font-family", "Arial");
|
|
|
|
|
- setProperty(infoElement, "color", "#2d2d2d");
|
|
|
|
|
- setProperty(infoElement, "font-size", "14px");
|
|
|
|
|
- setProperty(infoElement, "line-height", "22px");
|
|
|
|
|
- setProperty(infoElement, "word-break", "break-word");
|
|
|
|
|
- setProperty(infoElement, "white-space", "pre-wrap");
|
|
|
|
|
- setProperty(infoElement, "position", "relative");
|
|
|
|
|
- setProperty(infoElement, "top", "1px");
|
|
|
|
|
|
|
+ const infoElement = document.createElement("span");
|
|
|
|
|
+ infobarContent.appendChild(infoElement);
|
|
|
|
|
+ infoElement.classList.add("infobar-content");
|
|
|
infoElement.textContent = infoData;
|
|
infoElement.textContent = infoData;
|
|
|
- const linkElement = createElement("a", infobarElement);
|
|
|
|
|
- setProperty(linkElement, "display", "inline-block");
|
|
|
|
|
- setProperty(linkElement, "padding-left", "8px");
|
|
|
|
|
- setProperty(linkElement, "line-height", "11px");
|
|
|
|
|
- setProperty(linkElement, "cursor", "pointer");
|
|
|
|
|
- setProperty(linkElement, "user-select", "none");
|
|
|
|
|
|
|
+ const linkElement = document.createElement("a");
|
|
|
|
|
+ linkElement.classList.add("infobar-link");
|
|
|
|
|
+ infobarContent.appendChild(linkElement);
|
|
|
linkElement.target = "_blank";
|
|
linkElement.target = "_blank";
|
|
|
linkElement.rel = "noopener noreferrer";
|
|
linkElement.rel = "noopener noreferrer";
|
|
|
linkElement.title = "Open source URL: " + url;
|
|
linkElement.title = "Open source URL: " + url;
|
|
|
linkElement.href = url;
|
|
linkElement.href = url;
|
|
|
- const imgElement = createElement("img", linkElement);
|
|
|
|
|
- setProperty(imgElement, "padding-top", "3px");
|
|
|
|
|
- setProperty(imgElement, "-webkit-padding-after", "2px");
|
|
|
|
|
- setProperty(imgElement, "padding-left", "2px");
|
|
|
|
|
- setProperty(imgElement, "-webkit-padding-start", "2px");
|
|
|
|
|
- setProperty(imgElement, "cursor", "pointer");
|
|
|
|
|
- setProperty(infobarElement, "text-align", "right");
|
|
|
|
|
|
|
+ const imgElement = document.createElement("img");
|
|
|
|
|
+ imgElement.classList.add("infobar-link-icon");
|
|
|
|
|
+ linkElement.appendChild(imgElement);
|
|
|
imgElement.src = LINK_ICON;
|
|
imgElement.src = LINK_ICON;
|
|
|
- hideInfobar(infobarElement, linkElement, infoElement, closeElement);
|
|
|
|
|
- infobarElement.onmouseover = () => setProperty(infobarElement, "opacity", 1);
|
|
|
|
|
|
|
+ hideInfobar(infobarContent);
|
|
|
|
|
+
|
|
|
document.addEventListener("click", event => {
|
|
document.addEventListener("click", event => {
|
|
|
if (event.button === 0) {
|
|
if (event.button === 0) {
|
|
|
let element = event.target;
|
|
let element = event.target;
|
|
@@ -147,75 +213,24 @@
|
|
|
element = element.parentElement;
|
|
element = element.parentElement;
|
|
|
}
|
|
}
|
|
|
if (element != infobarElement) {
|
|
if (element != infobarElement) {
|
|
|
- hideInfobar(infobarElement, linkElement, infoElement, closeElement);
|
|
|
|
|
|
|
+ hideInfobar(infobarContent);
|
|
|
}
|
|
}
|
|
|
}
|
|
}
|
|
|
});
|
|
});
|
|
|
- setTimeout(() => {
|
|
|
|
|
- setProperty(infobarElement, "transition-property", "opacity");
|
|
|
|
|
- setProperty(infobarElement, "transition-duration", "250ms");
|
|
|
|
|
- });
|
|
|
|
|
}
|
|
}
|
|
|
}
|
|
}
|
|
|
|
|
|
|
|
- function displayInfobar(infobarElement, linkElement, infoElement, closeElement) {
|
|
|
|
|
- setProperty(infobarElement, "font-size", "13px");
|
|
|
|
|
- setProperty(infobarElement, "opacity", 1);
|
|
|
|
|
- setProperty(infobarElement, "width", "auto");
|
|
|
|
|
- setProperty(infobarElement, "background-color", "#f9f9f9");
|
|
|
|
|
- setProperty(infobarElement, "cursor", "auto");
|
|
|
|
|
- setProperty(infobarElement, "color", "#2d2d2d");
|
|
|
|
|
- setProperty(infobarElement, "padding-left", "8px");
|
|
|
|
|
- setProperty(infobarElement, "padding-right", "4px");
|
|
|
|
|
- setProperty(infobarElement, "padding-top", "2px");
|
|
|
|
|
- setProperty(infobarElement, "padding-bottom", "2px");
|
|
|
|
|
- setProperty(infobarElement, "-webkit-padding-start", "8px");
|
|
|
|
|
- setProperty(infobarElement, "-webkit-padding-end", "4px");
|
|
|
|
|
- setProperty(infobarElement, "border", "2px solid #555");
|
|
|
|
|
- setProperty(infobarElement, "-webkit-border-start", "2px solid #555");
|
|
|
|
|
- setProperty(infobarElement, "-webkit-border-before", "2px solid #555");
|
|
|
|
|
- setProperty(infobarElement, "-webkit-border-end", "2px solid #555");
|
|
|
|
|
- setProperty(infobarElement, "-webkit-border-after", "2px solid #555");
|
|
|
|
|
- setProperty(infobarElement, "background-image", "none");
|
|
|
|
|
- setProperty(infobarElement, "border-radius", "8px");
|
|
|
|
|
- setProperty(infoElement, "display", "inline-block");
|
|
|
|
|
- setProperty(linkElement, "display", "inline-block");
|
|
|
|
|
- setProperty(closeElement, "display", "inline-block");
|
|
|
|
|
- setProperty(infobarElement, "user-select", "initial");
|
|
|
|
|
- setProperty(infobarElement, "-moz-user-select", "initial");
|
|
|
|
|
- infobarElement.onclick = null;
|
|
|
|
|
- infobarElement.onmouseout = null;
|
|
|
|
|
|
|
+ function displayInfobar(infobarContent) {
|
|
|
|
|
+ infobarContent.classList.add("infobar-open");
|
|
|
|
|
+ infobarContent.onclick = null;
|
|
|
|
|
+ infobarContent.onmouseout = null;
|
|
|
}
|
|
}
|
|
|
|
|
|
|
|
- function hideInfobar(infobarElement, linkElement, infoElement, closeElement) {
|
|
|
|
|
- setProperty(infobarElement, "user-select", "none");
|
|
|
|
|
- setProperty(infobarElement, "-moz-user-select", "none");
|
|
|
|
|
- setProperty(infobarElement, "opacity", .7);
|
|
|
|
|
- infobarElement.onmouseout = () => setProperty(infobarElement, "opacity", .7);
|
|
|
|
|
- setProperty(infobarElement, "width", "24px");
|
|
|
|
|
- setProperty(infobarElement, "background-color", "#737373");
|
|
|
|
|
- setProperty(infobarElement, "cursor", "pointer");
|
|
|
|
|
- setProperty(infobarElement, "color", "white");
|
|
|
|
|
- setProperty(infobarElement, "padding-left", 0);
|
|
|
|
|
- setProperty(infobarElement, "padding-right", 0);
|
|
|
|
|
- setProperty(infobarElement, "padding-top", 0);
|
|
|
|
|
- setProperty(infobarElement, "padding-bottom", 0);
|
|
|
|
|
- setProperty(infobarElement, "-webkit-padding-start", 0);
|
|
|
|
|
- setProperty(infobarElement, "-webkit-padding-end", 0);
|
|
|
|
|
- setProperty(infobarElement, "border", "2px solid #eee");
|
|
|
|
|
- setProperty(infobarElement, "-webkit-border-start", "2px solid #eee");
|
|
|
|
|
- setProperty(infobarElement, "-webkit-border-before", "2px solid #eee");
|
|
|
|
|
- setProperty(infobarElement, "-webkit-border-end", "2px solid #eee");
|
|
|
|
|
- setProperty(infobarElement, "-webkit-border-after", "2px solid #eee");
|
|
|
|
|
- setProperty(infobarElement, "background-image", "url(" + IMAGE_ICON + ")");
|
|
|
|
|
- setProperty(infobarElement, "background-size", "70% 70%");
|
|
|
|
|
- setProperty(infobarElement, "border-radius", "16px");
|
|
|
|
|
- setProperty(closeElement, "display", "none");
|
|
|
|
|
- setProperty(linkElement, "display", "none");
|
|
|
|
|
- setProperty(infoElement, "display", "none");
|
|
|
|
|
- infobarElement.onclick = event => {
|
|
|
|
|
|
|
+ function hideInfobar(infobarContent) {
|
|
|
|
|
+ infobarContent.classList.remove("infobar-open");
|
|
|
|
|
+ infobarContent.onclick = event => {
|
|
|
if (event.button === 0) {
|
|
if (event.button === 0) {
|
|
|
- displayInfobar(infobarElement, linkElement, infoElement, closeElement);
|
|
|
|
|
|
|
+ displayInfobar(infobarContent);
|
|
|
return false;
|
|
return false;
|
|
|
}
|
|
}
|
|
|
};
|
|
};
|
|
@@ -224,12 +239,8 @@
|
|
|
function createElement(tagName, parentElement) {
|
|
function createElement(tagName, parentElement) {
|
|
|
const element = document.createElement(tagName);
|
|
const element = document.createElement(tagName);
|
|
|
parentElement.appendChild(element);
|
|
parentElement.appendChild(element);
|
|
|
- Array.from(getComputedStyle(element)).forEach(property => setProperty(element, property, "initial"));
|
|
|
|
|
|
|
+ Array.from(getComputedStyle(element)).forEach(property => element.style.setProperty(property, "initial", "important"));
|
|
|
return element;
|
|
return element;
|
|
|
}
|
|
}
|
|
|
|
|
|
|
|
- function setProperty(element, name, value) {
|
|
|
|
|
- element.style.setProperty(name, value, "important");
|
|
|
|
|
- }
|
|
|
|
|
-
|
|
|
|
|
})();
|
|
})();
|