|
@@ -21,10 +21,12 @@
|
|
|
* Source.
|
|
* Source.
|
|
|
*/
|
|
*/
|
|
|
|
|
|
|
|
-/* global browser, window, document, localStorage, FileReader, location */
|
|
|
|
|
|
|
+/* global browser, window, document, localStorage, FileReader, location, fetch, TextDecoder, DOMParser, HTMLElement */
|
|
|
|
|
|
|
|
(async () => {
|
|
(async () => {
|
|
|
|
|
|
|
|
|
|
+ const HELP_ICON_URL = "";
|
|
|
|
|
+ const HELP_PAGE_PATH = "/extension/ui/pages/help.html";
|
|
|
const { DEFAULT_PROFILE_NAME, DISABLED_PROFILE_NAME, CURRENT_PROFILE_NAME } = await browser.runtime.sendMessage({ method: "config.getConstants" });
|
|
const { DEFAULT_PROFILE_NAME, DISABLED_PROFILE_NAME, CURRENT_PROFILE_NAME } = await browser.runtime.sendMessage({ method: "config.getConstants" });
|
|
|
const removeHiddenElementsLabel = document.getElementById("removeHiddenElementsLabel");
|
|
const removeHiddenElementsLabel = document.getElementById("removeHiddenElementsLabel");
|
|
|
const removeUnusedStylesLabel = document.getElementById("removeUnusedStylesLabel");
|
|
const removeUnusedStylesLabel = document.getElementById("removeUnusedStylesLabel");
|
|
@@ -158,6 +160,7 @@
|
|
|
});
|
|
});
|
|
|
let pendingSave = Promise.resolve();
|
|
let pendingSave = Promise.resolve();
|
|
|
let autoSaveProfileChanged;
|
|
let autoSaveProfileChanged;
|
|
|
|
|
+ getHelpContents();
|
|
|
ruleProfileInput.onchange = () => {
|
|
ruleProfileInput.onchange = () => {
|
|
|
if (!autoSaveProfileChanged && ruleProfileInput.value != CURRENT_PROFILE_NAME) {
|
|
if (!autoSaveProfileChanged && ruleProfileInput.value != CURRENT_PROFILE_NAME) {
|
|
|
ruleAutoSaveProfileInput.value = ruleProfileInput.value;
|
|
ruleAutoSaveProfileInput.value = ruleProfileInput.value;
|
|
@@ -711,6 +714,40 @@
|
|
|
});
|
|
});
|
|
|
}
|
|
}
|
|
|
|
|
|
|
|
|
|
+ async function getHelpContents() {
|
|
|
|
|
+ const helpPage = await fetch(browser.runtime.getURL(HELP_PAGE_PATH));
|
|
|
|
|
+ const content = new TextDecoder().decode(await helpPage.arrayBuffer());
|
|
|
|
|
+ const doc = (new DOMParser()).parseFromString(content, "text/html");
|
|
|
|
|
+ const items = doc.querySelectorAll("[data-options-label]");
|
|
|
|
|
+ items.forEach(itemElement => {
|
|
|
|
|
+ const optionLabel = document.getElementById(itemElement.dataset.optionsLabel);
|
|
|
|
|
+ const helpIcon = document.createElement("img");
|
|
|
|
|
+ helpIcon.className = "help-icon";
|
|
|
|
|
+ helpIcon.src = HELP_ICON_URL;
|
|
|
|
|
+ helpIcon.onclick = () => {
|
|
|
|
|
+ helpContent.hidden = !helpContent.hidden;
|
|
|
|
|
+ return false;
|
|
|
|
|
+ };
|
|
|
|
|
+ optionLabel.appendChild(helpIcon);
|
|
|
|
|
+ const helpContent = document.createElement("div");
|
|
|
|
|
+ helpContent.hidden = true;
|
|
|
|
|
+ helpContent.className = "help-content";
|
|
|
|
|
+ itemElement.childNodes.forEach(node => {
|
|
|
|
|
+ if (node instanceof HTMLElement && node.className != "option") {
|
|
|
|
|
+ helpContent.appendChild(document.importNode(node, true));
|
|
|
|
|
+ }
|
|
|
|
|
+ });
|
|
|
|
|
+ helpContent.querySelectorAll("a[href]").forEach(linkElement => {
|
|
|
|
|
+ const hrefValue = linkElement.getAttribute("href");
|
|
|
|
|
+ if (hrefValue.startsWith("#")) {
|
|
|
|
|
+ linkElement.href = browser.runtime.getURL(HELP_PAGE_PATH + linkElement.getAttribute("href"));
|
|
|
|
|
+ linkElement.target = "_blank";
|
|
|
|
|
+ }
|
|
|
|
|
+ });
|
|
|
|
|
+ optionLabel.parentElement.insertAdjacentElement("afterEnd", helpContent);
|
|
|
|
|
+ });
|
|
|
|
|
+ }
|
|
|
|
|
+
|
|
|
function getLocalStorageItem(key) {
|
|
function getLocalStorageItem(key) {
|
|
|
try {
|
|
try {
|
|
|
return localStorage.getItem(key);
|
|
return localStorage.getItem(key);
|