Kaynağa Gözat

fix infobar in Waterfox Classic (see #540)

Gildas 5 yıl önce
ebeveyn
işleme
1dcd02e0a5
1 değiştirilmiş dosya ile 43 ekleme ve 3 silme
  1. 43 3
      common/ui/content/content-infobar-web.js

+ 43 - 3
common/ui/content/content-infobar-web.js

@@ -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);
+			});
+		}
+	}
+
 })();