Dumby
ваша кнопка: Консоль в сайдбаре хорошая, но как открыть обычную консоль браузера, которая в меню «Web-разработка» ?
Пробовал напрямую, но эта команда не работает: e.openBrowserConsole();
может имитировать клик по пункту меню, наподобии клика по urlbar?
document.getAnonymousElementByAttribute(document.getElementById('urlbar'),"class","textbox-input-box urlbar-input-box").click();
Вторая просьба: добавить дополнительный клик на стандартную кнопку «Загрузки» (для user_chrome_files), чтобы по Right или Middle-click запускался код сохранения страницы SaveHTML:
для старого FF я делал так:
addEventListener("click", function(event) { e.view.alert("downloads-button"); } event.preventDefault(); event.stopPropagation(); } }, false, document.getElementById("downloads-button") );
Отредактировано Dobrov (08-04-2021 11:18:15)
Отсутствует
Здравствуйте. Можно ли адаптировать кнопку
"При повторном открытии боковой панели закладок, все открытые папки автоматически сворачиваются"
для 87 версии Fierfox?
То, что кавычках, не совсем точно.
Этот код просто отключал запоминание состояния развёрнутости.
Поэтому, перед установкой, следует открыть боковую панель закладок,
и свернуть все папки вручную (ну, или, может, оставить, если какие нужно).
(sb => { var gv = () => sb.contentDocument ?.getElementById("bookmarks-view")?.view; var func = function(row) { var node = this._rows[row]; node.containerOpen = !node.containerOpen; } var set = () => { var view = gv(); if (view) view.toggleOpenState = func; } set(); addEventListener("pageshow", set, false, sb); addDestructor(() => { var view = gv(); if (view) delete view.toggleOpenState; }); })(document.getElementById("sidebar"));
а можно две поправки внести?
Чтобы контейнер не выбирать из списка, а создавался новый?
И можно ли указать чтобы вкладки не загружались?
(async (sel, self) => ({ icon: "circle", color: "turquoise", init(topic) { Services.obs.addObserver(self = this, topic); Services.obs.addObserver(function quit(s, t) { Services.obs.removeObserver(mm, topic); Services.obs.removeObserver(quit, t); }, "quit-application-granted"); }, observe(doc) { var list = doc.querySelectorAll(sel); if (!list.length) return; var menuitem = doc.createXULElement("menuitem"); for(var args of Object.entries({ selectiontype: "single", oncommand: "cmd(window)", nodetype: "folder|query", selection: "folder|query", label: "Открыть всё в контейнере", id: "placesContext_openContainer:tabs:newUsercontext" })) menuitem.setAttribute(...args); menuitem.cmd = this.cmd; menuitem.rnd = menuitem.constructor.prototype.render; menuitem.render = this.render; var [m1, m2] = menuitem.list = Array.from(list); (m2 || m1).after(menuitem); }, async render() { this.rnd(); await new Promise(this.ownerGlobal.requestAnimationFrame); this.hidden || (this.hidden = this.list.every(self.every)); }, every(node) { return node.disabled || node.hidden; }, cmd(win) { var view = this.parentNode._view; var node = win.document.popupNode; node = node._placesView && node._placesView.result.root; self.open(win, node || view.selectedNode || view.result.root); }, open(win, node) { var gbw = Cu.import("resource:///modules/PlacesUIUtils.jsm", {}).getBrowserWindow; var w = gbw(win); this.pu = w.PlacesUIUtils; this.fs = w.PlacesUtils.favicons; this.cis = w.ContextualIdentityService; this.sysp = w.E10SUtils.SERIALIZED_SYSTEMPRINCIPAL; this.pad = {pad: false}; (this.open = (win, node) => this.openURLs( gbw(win), win.PlacesUtils.getURLsForContainerNode(node) ))(w, node); }, async openURLs(win, urls) { var {userContextId} = this.cis.create( `[ ${this.cis._lastUserContextId + 1} ]`, this.icon, this.color ); var pos = win.gBrowser.selectedTab._tPos; var mark = !win.PrivateBrowsingUtils.isWindowPrivate(win); for(var {uri, title, isBookmark} of urls) try { if (mark) isBookmark ? this.pu.markPageAsFollowedBookmark(uri) : this.pu.markPageAsTyped(uri); var state = {entries: [{ url: uri, title: title || uri, triggeringPrincipal_base64: this.sysp }]}; var [,, data, mime] = await new Promise( resolve => this.fs.getFaviconDataForPage( Services.io.newURI(uri), (...args) => resolve(args), 16 ) ); if (data.length) state.image = `data:${ mime || "image/x-icon" };base64,${ btoa(String.fromCharCode(...data)) }`; var tab = win.gBrowser.addTrustedTab(null, {index: ++pos, userContextId}); win.SessionStore.setTabState(tab, state); } catch {}; } }).init("chrome-document-loaded"))( "#placesContext_openBookmarkContainer\\:tabs,#placesContext_openContainer\\:tabs" );
В 88 по-моему опять не работает кнопка по правому клику
https://forum.mozilla-russia.org/viewtopic.php?pid=789677#p789677
Посмотрите, пожалуйста.
На 89.0a1 не вижу. Синтетический STR в студию.
но как открыть обычную консоль браузера, которая в меню «Web-разработка» ?
Пробовал напрямую, но эта команда не работает: e.openBrowserConsole();
может имитировать клик по пункту меню, наподобии клика по urlbar?
document.getAnonymousElementByAttribute(document.getElementById('urlbar'),"class","textbox-input-box urlbar-input-box").click();
Клик не подойдёт, потому что пункта меню может ещё не быть,
больше подходит <key> — document.getElementById("key_browserConsole").doCommand();
для старого FF я делал так
Ну так в чём проблема, если кнопка вытащена, конечно.
(async id => { await window.delayedStartupPromise; var btn = document.getElementById("downloads-button"); if (!btn) return; var listener = e => { if (e.button == 1) { alert("Middle-click"); } else if (e.button == 2) { if (e.metaKey || e.ctrlKey || e.shiftKey) return; e.preventDefault(); alert("Right-click"); } } btn.addEventListener("click", listener); var ucf = window.ucf_custom_script_win || window.ucf_custom_script_all_win; ucf[id] = {destructor: () => btn.removeEventListener("click", listener)}; ucf.unloadlisteners.push(id); })("downloads-button-click-listener");
Отредактировано Dumby (08-04-2021 22:58:27)
Отсутствует
как открыть обычную консоль браузера, которая в меню «Web-разработка» ?
document.getElementById("key_browserConsole").doCommand();
Dumby - да, работает на МакОС в браузере Basilisk, (он называется Serpent), но ничего не происходит в Firefox 84.0.2
Uncaught ReferenceError: window is not defined
command chrome://user_chrome_files/content/custom_scripts/QuickToggle.js:465
oncommand chrome://browser/content/browser.xhtml:1
Отсутствует
Можно ли указать чтобы разных цветов были?
Допустим в коде, в массиве colors: [...], перебор по кругу.
(async (sel, self) => ({ icon: "circle", colors: [ "mediumseagreen", "silver", "crimson", "blue", "peru", ], initColors() { var colorName = "ucf-gen"; var css = "@-moz-document url(about:preferences#containers)," + " url-prefix(chrome://browser/content/browser.x) {\n"; this.colors.forEach((color, ind) => { var [ic, tc] = color.split(/\s*\|\s*/); css += `\t.identity-color-${colorName}${ind} {\n` + `\t\t--identity-tab-color: ${tc || ic};\n` + `\t\t--identity-icon-color: ${ic};\n\t}\n` }); var url = "data:text/css;charset=utf-8," + encodeURIComponent(css + "}"); var sss = Cc["@mozilla.org/content/style-sheet-service;1"] .getService(Ci.nsIStyleSheetService); sss.loadAndRegisterSheet(Services.io.newURI(url), sss.USER_SHEET); var len = this.colors.length; var pref = "ucf.openInGeneratedContainer.lastColor"; var ind = Math.min(Services.prefs.getIntPref(pref, -1), len - 1); this.nextColor = () => { var next = ind + 1; Services.prefs.setIntPref(pref, ind = next == len ? 0 : next); return colorName + ind; } }, init(topic) { Services.obs.addObserver(self = this, topic); Services.obs.addObserver(function quit(s, t) { Services.obs.removeObserver(self, topic); Services.obs.removeObserver(quit, t); }, "quit-application-granted"); this.initColors(); }, observe(doc) { var list = doc.querySelectorAll(sel); if (!list.length) return; var menuitem = doc.createXULElement("menuitem"); for(var args of Object.entries({ selectiontype: "single", oncommand: "cmd(window)", nodetype: "folder|query", selection: "folder|query", label: "Открыть всё в контейнере", id: "placesContext_openContainer:tabs:newUsercontext" })) menuitem.setAttribute(...args); menuitem.cmd = this.cmd; menuitem.rnd = menuitem.constructor.prototype.render; menuitem.render = this.render; var [m1, m2] = menuitem.list = Array.from(list); (m2 || m1).after(menuitem); }, async render() { this.rnd(); await new Promise(this.ownerGlobal.requestAnimationFrame); this.hidden || (this.hidden = this.list.every(self.every)); }, every(node) { return node.disabled || node.hidden; }, cmd(win) { var view = this.parentNode._view; var node = win.document.popupNode; node = node._placesView && node._placesView.result.root; self.open(win, node || view.selectedNode || view.result.root); }, open(win, node) { var gbw = Cu.import("resource:///modules/PlacesUIUtils.jsm", {}).getBrowserWindow; var w = gbw(win); this.pu = w.PlacesUIUtils; this.fs = w.PlacesUtils.favicons; this.cis = w.ContextualIdentityService; this.sysp = w.E10SUtils.SERIALIZED_SYSTEMPRINCIPAL; (this.open = (win, node) => this.openURLs( gbw(win), win.PlacesUtils.getURLsForContainerNode(node) ))(w, node); }, async openURLs(win, urls) { var {userContextId} = this.cis.create( `[ ${this.cis._lastUserContextId + 1} ]`, this.icon, this.nextColor() ); var pos = win.gBrowser.selectedTab._tPos; var mark = !win.PrivateBrowsingUtils.isWindowPrivate(win); for(var {uri, title, isBookmark} of urls) try { if (mark) isBookmark ? this.pu.markPageAsFollowedBookmark(uri) : this.pu.markPageAsTyped(uri); var state = {userContextId, entries: [{ url: uri, title: title || uri, triggeringPrincipal_base64: this.sysp }]}; var [,, data, mime] = await new Promise( resolve => this.fs.getFaviconDataForPage( Services.io.newURI(uri), (...args) => resolve(args), 16 ) ); if (data.length) state.image = `data:${ mime || "image/x-icon" };base64,${ btoa(String.fromCharCode(...data)) }`; var tab = win.gBrowser.addTrustedTab(null, {index: ++pos, userContextId}); win.SessionStore.setTabState(tab, state); } catch {}; } }).init("chrome-document-loaded"))( "#placesContext_openBookmarkContainer\\:tabs,#placesContext_openContainer\\:tabs" );
Uncaught ReferenceError: window is not defined
command chrome://user_chrome_files/content/custom_scripts/QuickToggle.js:465
Откуда в QuickToggle.js в command() взялось window?
Хорошо бы на весь код command(e) {...} посмотреть.
Отсутствует
Откуда в QuickToggle.js в command() взялось window?
Хорошо бы на весь код command(e) {...} посмотреть.
код всей кнопки для UCF я давал чуть раньше…
command(e) { // LMB var trg = e.target; if (trg.btn) { if(e.shiftKey) { // +Shift e.view.PlacesCommandHook.showPlacesOrganizer("History"); // Переключить боковую панель } else if (e.altKey) { // Control // e.openBrowserConsole(); // не работает // document.getElementById('menu_eyedropper').doCommand(); // Линза e.view.alert("Press " + trg.btn); } else { var win = e.target.ownerDocument.defaultView; var bar = e.target.ownerDocument.querySelector("#add-additional-vertical-bar"); // if (bar) win.setToolbarVisibility(bar, bar.collapsed); bar.collapsed ? win.SidebarUI.hide('viewHistorySidebar') : win.SidebarUI.show('viewHistorySidebar'); return; } } var menu = trg.closest("menu"), newVal = trg.val; this.maybeClosePopup(e, menu); if (newVal != menu.pref.val) menu.pref.set(menu.pref.pref, newVal), this.maybeRe(menu, true); },
Второй вопрос: greasyfork скрипт mhtml-reader не открывает mht-файл.
в меню Violentmonkey есть пункт: "Open MHTML file", но при его выборе ничего не происходит, а должен быть диалог открытия файла…
Отредактировано Dobrov (10-04-2021 05:09:23)
Отсутствует
Отсутствует
Допустим в коде, в массиве colors: [...], перебор по кругу.
Можно вас еще попросить добавить в этот код чтобы просле открытия папки закладок она удалялась?
Отредактировано Stkvsky (10-04-2021 21:10:50)
Отсутствует
command(e)
Ну и нет никакого «window is not defined».
SidebarUI.hide() — не зачищен, return — не на своём месте,
и что, разве на Mac #menu_eyedropper есть,
пока субменю «Веб-разработка» не откроешь?
Кстати, когда-то спрашивали про пипетку,
код сохранился, вот — вписал, на всякий случай.
... eyedropper(trg) { var obj = ChromeUtils.import("resource://devtools/shared/Loader.jsm") .require("devtools/client/menus").menuitems .find(menuitem => menuitem.id == "menu_eyedropper"); (this.eyedropper = target => obj.oncommand({target}))(trg); }, command(e) { var trg = e.target; if (trg.btn) { if (e.shiftKey) e.altKey ? this.eyedropper(trg) // Shift+Alt — Пипетка : e.view.PlacesCommandHook.showPlacesOrganizer("History"); // Shift — Библиотека (журнал) else if (e.altKey) trg.ownerDocument.getElementById("key_browserConsole").doCommand(); // Alt — Консоль браузера else { var bar = trg.ownerDocument.getElementById("add-additional-vertical-bar"); if (!bar) return; // включите вертикальную панель user_chrome_files var bc = bar.collapsed, win = e.view, su = win.SidebarUI; win.setToolbarVisibility(bar, bc); bc ? su.show("viewHistorySidebar") : su.hide(); } return; } var menu = trg.closest("menu"), newVal = trg.val; this.maybeClosePopup(e, menu); if (newVal != menu.pref.val) menu.pref.set(menu.pref.pref, newVal), this.maybeRe(menu, true); },
в меню Violentmonkey есть пункт: "Open MHTML file", но при его выборе ничего не происходит, а должен быть диалог открытия файла…
Наверно всплывающие окна не разрешены. Букмарклет должен работать.
добавить чтобы просле открытия папки закладок она удалялась
/* (this.open = (win, node) => this.openURLs( gbw(win), win.PlacesUtils.getURLsForContainerNode(node) ))(w, node); */ (this.open = (win, node) => { this.openURLs(gbw(win), win.PlacesUtils.getURLsForContainerNode(node)); node.bookmarkGuid && this.pu.doCommand(win, "placesCmd_delete"); })(win, node);
Отсутствует
Dumby - спасибо за помощь! Ещё просьба – нужна функция, которая открывает вкладку с url
(если его нет) и закрывает вкладку, если такая уже открыта в браузере. То есть, переключатель вкладки - открыть/закрыть.
Не могу исправить ошибку - код напрямую в кнопке работает, а обёрнутый в функцию нет!
switchToTab(url, e){ var e = e || this; // аргумент функции не указан e.view.switchToTabHavingURI(url, true, { relatedToCurrent: true, triggeringPrincipal: Services.scriptSecurityManager.getSystemPrincipal() }); };
command(e) { // нажатия мыши switchToTab('about:config', e); // так вкладка не открывается e.view.switchToTabHavingURI(url, true, { // а так открывается relatedToCurrent: true, triggeringPrincipal: Services.scriptSecurityManager.getSystemPrincipal()…
Отсутствует
Dobrov
Второй вопрос: greasyfork скрипт mhtml-reader не открывает mht-файл.
в меню Violentmonkey есть пункт: "Open MHTML file", но при его выборе ничего не происходит, а должен быть диалог открытия файла…
Объясни как должен работать этот скрипт. У меня ни скрипт ни Букмарклет не работает при попытке открыть локальный MHTML file.
Отсутствует
Отсутствует
Объясни как должен работать этот скрипт. У меня ни скрипт ни Букмарклет не работает при попытке открыть локальный MHTML file.
Проверял на Линуксе - диалог открытия файла вообще не появляется.
Greasyfork скрипт mhtml-reader - читает MHT-файл. При проверке Tampermonkey выдал 17 ошибок скрипта!
Ну, как-то должен работать, если код исправить!
Отсутствует
ВВП посмотри может поможет
//Дополнительные пункты контекстного меню на странице about:addons для аддонов, плагинов, тем, CB..................................................................................... ((id, g, iconizer) => addDestructor(r => r[5] == "e" && id in g && g[id].destroy()) + addEventListener("shown", { //------------------------------------------------------------------ "Копировать имя_i": "", "Копировать имя"(addon, hideOn) { if (hideOn) return false; gClipboard.write(addon.name); }, //------------------------------------------------------------------ "Копировать ID_i": "", "Копировать ID"(addon, hideOn) { if (hideOn) return false; gClipboard.write(addon.id); }, //------------------------------------------------------------------ "Копировать версию_i": "", "Копировать версию"(addon, hideOn) { if (hideOn) return ["custombuttons"]; gClipboard.write(addon.version); }, //------------------------------------------------------------------ "Копировать имя и версию_i": "", "Копировать имя и версию"(addon, hideOn) { if (hideOn) return ["custombuttons"]; gClipboard.write(addon.name + " " + addon.version); }, //------------------------------------------------------------------ "Домашняя страница_i": "", "Домашняя страница"(addon, hideOn) { if (hideOn) return !addon.homepageURL && !addon.reviewURL; openURL(addon.homepageURL || addon.reviewURL.replace(/\/reviews\/.*$/, "/")); }, //------------------------------------------------------------------ "Поиск на АМО_i": "", "Поиск на АМО"(addon, hideOn) { if (hideOn) return ["custombuttons", "theme", "plugin"]; openURL(addon.homepageURL || ( "https://addons.mozilla.org/search/?q=" + encodeURIComponent(addon.name) )); }, //------------------------------------------------------------------ "Папка установки_i": "", "Папка установки"(addon, hideOn) { if (hideOn) return ["custombuttons", "theme", "plugin"]; this.getFile(addon).reveal(); }, //------------------------------------------------------------------ "Файл установки_i": "", "Файл установки"(addon, hideOn) { if (hideOn) return ["custombuttons", "theme", "plugin"]; this.getFile(addon).launch(); }, //------------------------------------------------------------------ getFile(addon) { var file, uri = addon.getResourceURI(); if (uri instanceof Ci.nsIJARURI) uri = uri.JARFile; if (uri instanceof Ci.nsIFileURL) file = uri.file; return file; }, url: "about:addons", handleEvent(e) { if (e.target.baseURI != this.url) return; var item = this.getItem(e.target.ownerDocument); var addon = item.addon = e.target.closest("addon-card").addon; for(var child of item.children) { var res = this[child.textContent](addon, true); child.hidden = Array.isArray(res) ? res.includes(addon.type) : res; } e.target.contains(item) || requestAnimationFrame(() => e.target.prepend(item)); }, click(e) { e.stopPropagation(); iconizer.item.parentNode.hide(); this[e.target.textContent](iconizer.item.addon); }, getItem(doc) { if (iconizer.item) { if (iconizer.item.ownerDocument == doc) return iconizer.item; iconizer.handleEvent(); } var item = doc.createElement("div"); item.id = id; for(var lab of this.labels) item.appendChild(doc.createElement("panel-item")).append(lab); item.onclick = this.click; doc.ownerGlobal.addEventListener("unload", iconizer); return iconizer.item = item; }, get labels() { delete this.labels; this.click = this.click.bind(this); if (id in g) return this.labels = (iconizer = g[id]).labs; g[id] = iconizer; var css = "", ind = 0, arr = []; var push = (ind, icon) => { var chromeImg = `chrome://custombuttons/content/${id + ind}`; arr.push(["override", chromeImg, icon]); return chromeImg; } var labs = iconizer.labs = Object.keys(this).filter(key => { var res = String(this[key]).startsWith('"'); if (!res) return false; ind++; var icon = this[key + "_i"]; if (icon) css += `\n\t#${ id } > panel-item:nth-child(${ind}) {\n\t\t--icon: url(${ push(ind, icon) }) !important;\n\t}`; return true; }); var ams = Cc["@mozilla.org/addons/addon-manager-startup;1"].getService(Ci.amIAddonManagerStartup); var mUri = Services.io.getProtocolHandler("resource").getSubstitution("custombuttons-modules"); var md = `@-moz-document url(${this.url}) {`; var uri = Services.io.newURI(`chrome://custombuttons/content/${id}.css`); arr.push(["override", uri.spec, "data:text/css;charset=utf-8," + encodeURIComponent(md + css + "\n}")]); iconizer.iconHelper = ams.registerChrome(mUri, arr); var sss = Cc["@mozilla.org/content/style-sheet-service;1"].getService(Ci.nsIStyleSheetService); sss.loadAndRegisterSheet(uri, sss.USER_SHEET); iconizer.handleEvent = function() { if (!this.item) return; this.item.ownerGlobal.removeEventListener("unload", this); this.item.remove(); this.item = null; } iconizer.destroy = function() { delete g[id]; this.handleEvent(); sss.unregisterSheet(uri, sss.USER_SHEET); this.iconHelper.destruct(); } return this.labels = labs; } }, true, gBrowser.tabpanels || 1))("CBAddonsMenuExt", Cu.import("resource://gre/modules/AddonManager.jsm", {}), {});
Отсутствует
Подскажите как поставить Custom Buttons на 78
1) В папку, куда установлен Firefox, скопируй одноимённую папку из данного архива. (Костыли для FF)
2) ставь обычным способом расширение custom_buttons-0.0.7.0.0.17-fx-bootstrap.xpi
Отсутствует
Не могу исправить ошибку - код напрямую в кнопке работает, а обёрнутый в функцию нет!
По тем кускам непонятно, может this.switchToTab('about:config', e);
Не могу пункт добавить(копировать url кнопки)
((id, g, iconizer) => addDestructor(r => r[5] == "e" && id in g && g[id].destroy()) + addEventListener("showing", { //------------------------------------------------------------------ "Копировать имя_i": "", "Копировать имя"(addon, hideOn) { if (hideOn) return false; gClipboard.write(addon.name); }, //------------------------------------------------------------------ "Копировать ID_i": "", "Копировать ID"(addon, hideOn) { if (hideOn) return false; gClipboard.write(addon.id); }, //------------------------------------------------------------------ "Копировать версию_i": "", "Копировать версию"(addon, hideOn) { if (hideOn) return ["custombuttons"]; gClipboard.write(addon.version); }, //------------------------------------------------------------------ "Копировать имя и версию_i": "", "Копировать имя и версию"(addon, hideOn) { if (hideOn) return ["custombuttons"]; gClipboard.write(addon.name + " " + addon.version); }, //------------------------------------------------------------------ "Копировать URL кнопки_i": "", ncb: (arr => (arr.includes = arg => arg != "custombuttons") && arr)([]), "Копировать URL кнопки"(addon, hideOn) { if (hideOn) return this.ncb; var btn = Object.assign({ parameters: {}, get initcode() {return this.initCode;}, setText(doc, name, t, cds) { custombutton.buttonSetText(doc, name, this[name], cds); } }, custombuttons.cbService.getButtonParameters(addon.buttonLink)); gClipboard.write(custombutton.buttonGetURI(btn)); }, //------------------------------------------------------------------ "Домашняя страница_i": "", "Домашняя страница"(addon, hideOn) { if (hideOn) return !addon.homepageURL && !addon.reviewURL; openURL(addon.homepageURL || addon.reviewURL.replace(/\/reviews\/.*$/, "/")); }, //------------------------------------------------------------------ "Поиск на АМО_i": "", "Поиск на АМО"(addon, hideOn) { if (hideOn) return ["custombuttons", "theme", "plugin"]; openURL(addon.homepageURL || ( "https://addons.mozilla.org/search/?q=" + encodeURIComponent(addon.name) )); }, //------------------------------------------------------------------ "Папка установки_i": "", "Папка установки"(addon, hideOn) { if (hideOn) return ["custombuttons", "theme", "plugin"]; this.getFile(addon).reveal(); }, //------------------------------------------------------------------ "Файл установки_i": "", "Файл установки"(addon, hideOn) { if (hideOn) return ["custombuttons", "theme", "plugin"]; this.getFile(addon).launch(); }, //------------------------------------------------------------------ getFile(addon) { var file, uri = addon.getResourceURI(); if (uri instanceof Ci.nsIJARURI) uri = uri.JARFile; if (uri instanceof Ci.nsIFileURL) file = uri.file; return file; }, url: "about:addons", handleEvent(e) { if (e.target.baseURI != this.url) return; var card = e.target.closest("addon-card"); if (!card) return; var item = this.getItem(e.target.ownerDocument); var addon = item.addon = card.addon; for(var child of item.children) { var res = this[child.textContent](addon, true); child.hidden = Array.isArray(res) ? res.includes(addon.type) : res; } e.target.contains(item) || requestAnimationFrame(() => e.target.prepend(item)); }, click(e) { e.stopPropagation(); iconizer.item.parentNode.hide(); this[e.target.textContent](iconizer.item.addon); }, getItem(doc) { if (iconizer.item) { if (iconizer.item.ownerDocument == doc) return iconizer.item; iconizer.handleEvent(); } var item = doc.createElement("div"); item.id = id; for(var lab of this.labels) item.appendChild(doc.createElement("panel-item")).append(lab); item.onclick = this.click; doc.ownerGlobal.addEventListener("unload", iconizer); return iconizer.item = item; }, get labels() { delete this.labels; this.click = this.click.bind(this); if (id in g) return this.labels = (iconizer = g[id]).labs; g[id] = iconizer; var css = "", ind = 0, arr = []; var push = (ind, icon) => { var chromeImg = `chrome://custombuttons/content/${id + ind}`; arr.push(["override", chromeImg, icon]); return chromeImg; } var labs = iconizer.labs = Object.keys(this).filter(key => { var res = String(this[key]).startsWith('"'); if (!res) return false; ind++; var icon = this[key + "_i"]; if (icon) css += `\n\t#${ id } > panel-item:nth-child(${ind}) {\n\t\t--icon: url(${ push(ind, icon) }) !important;\n\t}`; return true; }); var ams = Cc["@mozilla.org/addons/addon-manager-startup;1"].getService(Ci.amIAddonManagerStartup); var mUri = Services.io.getProtocolHandler("resource").getSubstitution("custombuttons-modules"); var md = `@-moz-document url(${this.url}) {`; var uri = Services.io.newURI(`chrome://custombuttons/content/${id}.css`); arr.push(["override", uri.spec, "data:text/css;charset=utf-8," + encodeURIComponent(md + css + "\n}")]); iconizer.iconHelper = ams.registerChrome(mUri, arr); var sss = Cc["@mozilla.org/content/style-sheet-service;1"].getService(Ci.nsIStyleSheetService); sss.loadAndRegisterSheet(uri, sss.USER_SHEET); iconizer.handleEvent = function() { if (!this.item) return; this.item.ownerGlobal.removeEventListener("unload", this); this.item.remove(); this.item = null; } iconizer.destroy = function() { delete g[id]; this.handleEvent(); sss.unregisterSheet(uri, sss.USER_SHEET); this.iconHelper.destruct(); } return this.labels = labs; } }, true, gBrowser.tabpanels || 1))("CBAddonsMenuExt", Cu.import("resource://gre/modules/AddonManager.jsm", {}), {});
Отредактировано Dumby (12-04-2021 08:33:21)
Отсутствует
По тем кускам непонятно, может this.switchToTab('about:config', e);
Конкретный код - это твоя (с небольшими правками) кнопка QuickToggleAbout
Насколько я понимаю, здесь «e» это один и тот же объект, который передаётся в функцию: switchToTab(url, e)
e.view.switchToTabHavingURI - почему же в функции нет открытия таба, а в втором коде command(e) вкладка открывается?
switchToTab(url, e){ // в функции не работает e.view.switchToTabHavingURI(url, true, { ============== конец функции command(e) { // нажатия мыши >>>> e.view.switchToTabHavingURI(url, true, { // так открывается ………… switchToTab(url, e); // а так не работает
Отредактировано Dobrov (12-04-2021 09:59:27)
Отсутствует