|
|
@@ -31,6 +31,7 @@
|
|
|
const IMAGE_ICON = "";
|
|
|
const SINGLEFILE_COMMENT = "SingleFile";
|
|
|
const SINGLE_FILE_UI_ELEMENT_CLASS = "single-file-ui-element";
|
|
|
+ let SHADOW_DOM_SUPPORTED = true;
|
|
|
|
|
|
const browser = this.browser;
|
|
|
|
|
|
@@ -56,7 +57,7 @@
|
|
|
options = { displayInfobar: true };
|
|
|
}
|
|
|
if (options.displayInfobar) {
|
|
|
- initInfobar(url, saveDate, infoData);
|
|
|
+ await initInfobar(url, saveDate, infoData);
|
|
|
}
|
|
|
}
|
|
|
}
|
|
|
@@ -66,7 +67,7 @@
|
|
|
return node.nodeType == Node.COMMENT_NODE && node.textContent.includes(SINGLEFILE_COMMENT);
|
|
|
}
|
|
|
|
|
|
- function initInfobar(url, saveDate, infoData) {
|
|
|
+ async function initInfobar(url, saveDate, infoData) {
|
|
|
let infobarElement = document.querySelector(INFOBAR_TAGNAME);
|
|
|
if (!infobarElement) {
|
|
|
url = url.split("url: ")[1];
|
|
|
@@ -82,7 +83,7 @@
|
|
|
}
|
|
|
infobarElement = createElement(INFOBAR_TAGNAME, document.body);
|
|
|
infobarElement.className = SINGLE_FILE_UI_ELEMENT_CLASS;
|
|
|
- const shadowRoot = infobarElement.attachShadow({ mode: "open" });
|
|
|
+ const shadowRoot = await getShadowRoot(infobarElement);
|
|
|
const styleElement = document.createElement("style");
|
|
|
styleElement.textContent = `
|
|
|
.infobar {
|
|
|
@@ -223,9 +224,22 @@
|
|
|
}
|
|
|
|
|
|
function displayInfobar(infobarContent) {
|
|
|
+ if (!SHADOW_DOM_SUPPORTED) {
|
|
|
+ const infobarElement = document.querySelector(INFOBAR_TAGNAME);
|
|
|
+ const frameElement = infobarElement.childNodes[0];
|
|
|
+ frameElement.contentWindow.getSelection().removeAllRanges();
|
|
|
+ }
|
|
|
infobarContent.classList.add("infobar-open");
|
|
|
infobarContent.onclick = null;
|
|
|
infobarContent.onmouseout = null;
|
|
|
+ if (!SHADOW_DOM_SUPPORTED) {
|
|
|
+ const infobarElement = document.querySelector(INFOBAR_TAGNAME);
|
|
|
+ const frameElement = infobarElement.childNodes[0];
|
|
|
+ frameElement.style.setProperty("width", "100vw", "important");
|
|
|
+ frameElement.style.setProperty("height", "100vh", "important");
|
|
|
+ frameElement.style.setProperty("width", (infobarContent.getBoundingClientRect().width + 33) + "px", "important");
|
|
|
+ frameElement.style.setProperty("height", (infobarContent.getBoundingClientRect().height + 21) + "px", "important");
|
|
|
+ }
|
|
|
}
|
|
|
|
|
|
function hideInfobar(infobarContent) {
|
|
|
@@ -236,6 +250,12 @@
|
|
|
return false;
|
|
|
}
|
|
|
};
|
|
|
+ if (!SHADOW_DOM_SUPPORTED) {
|
|
|
+ const infobarElement = document.querySelector(INFOBAR_TAGNAME);
|
|
|
+ const frameElement = infobarElement.childNodes[0];
|
|
|
+ frameElement.style.setProperty("width", "44px", "important");
|
|
|
+ frameElement.style.setProperty("height", "48px", "important");
|
|
|
+ }
|
|
|
}
|
|
|
|
|
|
function createElement(tagName, parentElement) {
|
|
|
@@ -245,4 +265,24 @@
|
|
|
return element;
|
|
|
}
|
|
|
|
|
|
+ async function getShadowRoot(element) {
|
|
|
+ if (element.attachShadow) {
|
|
|
+ return element.attachShadow({ mode: "open" });
|
|
|
+ } else {
|
|
|
+ SHADOW_DOM_SUPPORTED = false;
|
|
|
+ const iframe = createElement("iframe", element);
|
|
|
+ iframe.style.setProperty("background-color", "transparent", "important");
|
|
|
+ iframe.style.setProperty("position", "fixed", "important");
|
|
|
+ iframe.style.setProperty("top", 0, "important");
|
|
|
+ iframe.style.setProperty("right", 0, "important");
|
|
|
+ iframe.style.setProperty("width", "44px", "important");
|
|
|
+ iframe.style.setProperty("height", "48px", "important");
|
|
|
+ iframe.style.setProperty("z-index", 2147483647, "important");
|
|
|
+ return new Promise(resolve => {
|
|
|
+ iframe.contentDocument.body.style.setProperty("margin", 0);
|
|
|
+ iframe.onload = () => resolve(iframe.contentDocument.body);
|
|
|
+ });
|
|
|
+ }
|
|
|
+ }
|
|
|
+
|
|
|
})();
|