Dumby
Что с ней не так?
У меня не показывала адрес закладки при наведении на звездочку. ХЗ что произошло, но теперь всё работает. Сорри.
Совсем недавно Андрей спрашивал.
Спасибо.
Сколько можно одну и ту же xul-xhtml тему мусолить?
Спасибо.
Отредактировано voqabuhe (15-05-2020 14:35:26)
Отсутствует
есть такие коды для CB, прекрасно работающие на FF 52 esr
можно ли адаптировать их для user_chrome_files на последнем FF 76?
// ЕСЛИ ТЕКУЩАЯ ВКЛАДКА ПУСТАЯ, ТО ОТКРЫВАТЬ ЗАКЛАДКИ ПО СКМ В ТЕКУЩЕЙ ВКЛАДКЕ function openBookmark(e) { var type = e.type; var target = e.originalTarget; var bookMenu = target.parentNode; // стоп, если не закладка из меню закладок if ( target.localName !== "menuitem" || !target._placesNode ) return; // если левый клик открыть закладку в новой вкладке if ( type == 'click' && e.button == 1 ) { e.preventDefault(); e.stopPropagation(); var itemUri = target._placesNode.uri; // получить адрес закладки var bookmarklet = ( itemUri.substr(0, 11) == "javascript:"); if ( !gBrowser.webProgress.isLoadingDocument && ( "isBlankPageURL" in window ? isBlankPageURL(content.location.href) : content.location.href == "about:blank" ) ) { gBrowser.loadURI( itemUri ); } else { gBrowser.selectedTab = gBrowser.addTab( itemUri ); }; }; }; addEventListener("click", openBookmark, true, window );
// FindBar, листание результатов поиска колесиком мыши (FindBar, Mouse Scroll find) addEventListener("wheel", (e, findbar = gBrowser.selectedTab._findBar) => findbar && findbar.matches(":hover") && e.deltaY && findbar.onFindAgainCommand(e.deltaY < 0) , false, gBrowser);
Отредактировано Inko7 (15-05-2020 15:19:35)
Отсутствует
Inko7
try {({ init(tabpanels) { var dsp = e => this[e.type](e); addEventListener("click", dsp, true); tabpanels.addEventListener("wheel", dsp); addEventListener("unload", () => { removeEventListener("click", dsp, true); tabpanels.removeEventListener("wheel", dsp); }, {once: true}); }, click(e) { var url = e.button == 1 && e.target.nodeName == "menuitem" && e.target._placesNode?.uri; if (url) e.stopPropagation(), isBlankPageURL(gBrowser.currentURI.spec) && !gBrowser.webProgress.isLoadingDocument ? gBrowser.loadURI(url, this.p) : gBrowser.selectedTab = gBrowser.addTab(url, this.p); }, p: {triggeringPrincipal: document.nodePrincipal}, wheel(e) { var findbar = gBrowser.selectedTab._findBar; findbar?.matches(":hover") && e.deltaY && findbar.onFindAgainCommand(e.deltaY < 0); } }).init(document.getElementById("tabbrowser-tabpanels"))} catch(ex) {Cu.reportError(ex);}
Отсутствует
Dumby
пробовал помещать этот код и в custom_script.js и в custom_script_win.js - эффекта не увидел
Отредактировано Inko7 (16-05-2020 13:02:05)
Отсутствует
Dumby
Эту бы кнопку в скрипт "Нет псевосессиям"
/*Initialization Code*/ ((topic, id) => { var obs, getObserver = () => { for(var o of Services.obs.enumerateObservers(topic)) { var res = o.wrappedJSObject; if (res && id in res) return res; } } addDestructor(reason => { if (reason[5] != "e") return; var obs = getObserver(); obs && obs.destroy(); }); (obs = getObserver()) || Services.obs.addObserver(obs = { [id]: true, __proto__: null, destroyed: false, destroy() { Services.obs.removeObserver(this, topic); this.destroyed = true; }, get wins() { return Array.from(Services.wm.getEnumerator("navigator:browser")) .filter(win => win.toolbar.visible); }, observe(cancelQuit, t, data) { data != "restart" && !cancelQuit.data && this.onQuit(true); }, handleEvent() { this.destroyed || this.onQuit(); }, onQuit(fromObs) { var {wins} = this, multi = wins.length > 1; if (multi) return fromObs && this.destroy(); this.destroy(); var {tabs} = wins[0].gBrowser; if (tabs.length > 1 ) return; var es = JSON.parse(SessionStore.getTabState(tabs[0])).entries; es.length == 1 && wins[0].isBlankPageURL(es[0].url) && this.erase(); }, erase() { Services.obs.notifyObservers(null, "browser:purge-session-history"); Cu.import("resource:///modules/sessionstore/SessionFile.jsm", {}) .SessionFileInternal.write = () => {}; } }, topic, false); addEventListener("DOMWindowClose", obs); })("quit-application-requested", `${_id}:quitApplicationRequestedObserver1`);
Отсутствует
Dumby.
Вы когда-то по моей просьбе написали вот такой код:
// Убрать замыливание последних букв и вернуть многоточие в названии вкладок. // https://forum.mozilla-russia.org/viewtopic.php?pid=749234#p749234 ((func, destroy) => { [...gBrowser.tabs].forEach(func); addEventListener("TabOpen", func, false, gBrowser.tabContainer); addEventListener("TabAttrModified", func, false, gBrowser.tabContainer); addDestructor(() => [...gBrowser.tabs].forEach(destroy)); })(e => { var tab = e.target || e; var lab = document.getAnonymousElementByAttribute(tab, "class", "tab-text tab-label"); if (!lab.hasAttribute("crop")) { lab.setAttribute("crop", "end"); lab.setAttribute("flex", "1"); } else if (lab.value == tab.label) return; lab.setAttribute("value", tab.label); }, tab => { var lab = document.getAnonymousElementByAttribute(tab, "class", "tab-text tab-label"); for(var attr of ["crop", "flex", "value"]) lab.removeAttribute(attr); });
«The Truth Is Out There»
Отсутствует
при нажатии СКМ по папкам в меню закладок или на панели закладок
==> код позволяет
И как же такое может быть, ведь это будет <menu> или <toolbarbutton>,
а в коде написано
if ( target.localName !== "menuitem" || !target._placesNode ) return;
Эту бы кнопку в скрипт
try {Services.obs.addObserver(function qar(cancelQuit, topic, data) { if (cancelQuit.data) return; Services.obs.removeObserver(qar, topic); if (data == "restart") return; var wins = Array.from(Services.wm.getEnumerator("navigator:browser")).filter( win => win.toolbar.visible && !win.PrivateBrowsingUtils.isWindowPrivate(win) ); if (wins.length > 1) return; var [win] = wins, {tabs} = win.gBrowser; if (tabs.length > 1 ) return; var es = JSON.parse(win.SessionStore.getTabState(tabs[0])).entries; if (es.length == 1 && win.isBlankPageURL(es[0].url)) Services.obs.notifyObservers(null, "browser:purge-session-history"), Cu.import("resource:///modules/sessionstore/SessionFile.jsm", {}) .SessionFileInternal.write = () => {}; }, "quit-application-requested", false);} catch(ex) {Cu.reportError(ex);}
В ночном похоже отвалился CB?
Было дело. Bug 1558635
Возможно ли его переделать под последнюю версию ?
Ну, <label> вкладки нынче предлагается получать так: var lab = tab.textLabel;
соответственно, можно попробовать заменить в коде (в двух местах).
Отсутствует
Ну, <label> вкладки нынче предлагается получать так: var lab = tab.textLabel;
соответственно, можно попробовать заменить в коде (в двух местах).
Спасибо, все получилось.
Есть ещё просьба по одной из ваших кнопок.
((main, parts) => this._handleClick = () => { var df = MozXULElement.parseXULToFragment(` <menupopup> <menuitem class="menuitem-iconic" image="" label="Сохранить всю страницу как PNG" value="all"/> <menuitem class="menuitem-iconic" image="" label="Сохранить видимую часть страницы как PNG" value="page"/> <menuitem class="menuitem-iconic" image="" label="Сохранить выбранный элемент страницы как PNG" value="click"/> <menuitem class="menuitem-iconic" image="" label="Сохранить выбранную область страницы как PNG" value="clipping"/> </menupopup> `); var popup = df.firstChild; popup.setAttribute("context", ""); popup.setAttribute("oncommand", "handleCommand(event);"); popup.handleCommand = e => { var name = _id + ":DataURLReady"; main = main.replace("%MESSAGE_NAME%", name); var urls = {}, configurable = true, enumerable = true; Object.entries(parts).forEach(([key, part]) => Object.defineProperty(urls, key, { configurable, enumerable, get() { var value = `data:;charset=utf-8,({${ encodeURIComponent(main + part) }%0A}).init("${key}")`; Object.defineProperty(urls, key, {configurable, enumerable, value}); return value; }})); var getTabLabel = () => { var label = gBrowser.selectedTab.label; var label = label.replace(/[:+.\\\/<>?*|"]+/g, " ").replace(/\s\s+/g, " "); return label.substring(0, 50); } var listener = msg => { var fp = makeFilePicker(); fp.init(window, "Сохранить как…", fp.modeSave); fp.appendFilter("", "*.png"); fp.defaultString = getTabLabel() + ".png"; fp.open(res => res == fp.returnCancel || !fp.file || makeWebBrowserPersist().saveURI( Services.io.newURI(msg.data), document.nodePrincipal, null, null, null, null, null, fp.file, null )); } messageManager.addMessageListener(name, listener); addDestructor(() => messageManager.removeMessageListener(name, listener)); (popup.handleCommand = e => gBrowser.selectedBrowser.messageManager .loadFrameScript(urls[e.target.value], false) )(e); } this.append(df); (this._handleClick = () => popup.openPopup(this, "after_start"))(); })(` init(cmd) { cmd.startsWith("c") ? this[cmd].init(this[cmd].parent = this) : this[cmd](); }, capture(win, x, y, width, height) { var canvas = win.document.createElementNS("${xhtmlns}", "canvas"); canvas.width = width; canvas.height = height; var ctx = canvas.getContext("2d"); var tryDraw = ind => { try {ctx.drawWindow(win, x, y, canvas.width, canvas.height, "white")} catch(ex) {canvas.height = ind * canvas.width; tryDraw(--ind);} } tryDraw(17); sendAsyncMessage("%MESSAGE_NAME%", canvas.toDataURL("image/png")); }, `, { all: `all() { var win = content; this.capture(win, 0, 0, win.innerWidth + win.scrollMaxX, win.innerHeight + win.scrollMaxY); }`, page: `page() { var win = content, doc = win.document, body = doc.body, html = doc.documentElement; var scrX = (body.scrollLeft || html.scrollLeft) - html.clientLeft; var scrY = (body.scrollTop || html.scrollTop) - html.clientTop; this.capture(win, scrX, scrY, win.innerWidth, win.innerHeight); }`, clipping: `clipping: { handleEvent(e) { if (e.button) return false; e.preventDefault(); e.stopPropagation(); switch(e.type) { case "mousedown": this.downX = e.pageX; this.downY = e.pageY; this.bs.left = this.downX + "px"; this.bs.top = this.downY + "px"; this.body.appendChild(this.box); this.flag = true; break; case "mousemove": if (!this.flag) return; this.moveX = e.pageX; this.moveY = e.pageY; if (this.downX > this.moveX) this.bs.left = this.moveX + "px"; if (this.downY > this.moveY) this.bs.top = this.moveY + "px"; this.bs.width = Math.abs(this.moveX - this.downX) + "px"; this.bs.height = Math.abs(this.moveY - this.downY) + "px"; break; case "mouseup": this.uninit(); break; } }, init() { var win = {}; Cc["@mozilla.org/focus-manager;1"].getService(Ci.nsIFocusManager) .getFocusedElementForWindow(content, true, win); this.win = win.value; this.doc = this.win.document; this.body = this.doc.body; if (!HTMLBodyElement.isInstance(this.body)) { Cc["@mozilla.org/alerts-service;1"].getService(Ci.nsIAlertsService) .showAlertNotification("${self.image}", ${JSON.stringify(self.label)}, "Не удается захватить!"); return false; } this.flag = null; this.box = this.doc.createElement("div"); this.bs = this.box.style; this.bs.border = "#0f0 dashed 2px"; this.bs.position = "absolute"; this.bs.zIndex = "2147483647"; this.defaultCursor = this.win.getComputedStyle(this.body, "").cursor; this.body.style.cursor = "crosshair"; ["click", "mouseup", "mousemove", "mousedown"].forEach(type=> this.doc.addEventListener(type, this, true)); }, uninit() { var pos = [this.win, parseInt(this.bs.left), parseInt(this.bs.top), parseInt(this.bs.width), parseInt(this.bs.height)]; this.body.style.cursor = this.defaultCursor; this.body.removeChild(this.box); this.parent.capture.apply(this, pos); ["click", "mouseup", "mousemove", "mousedown"].forEach(type=> this.doc.removeEventListener(type, this, true)); } }`, click: `click: { getPosition() { var html = this.doc.documentElement; var body = this.doc.body; var rect = this.target.getBoundingClientRect(); return [ this.win, Math.round(rect.left) + (body.scrollLeft || html.scrollLeft) - html.clientLeft, Math.round(rect.top) + (body.scrollTop || html.scrollTop) - html.clientTop, parseInt(rect.width), parseInt(rect.height) ]; }, highlight() { this.orgStyle = this.target.hasAttribute("style") ? this.target.style.cssText : false; this.target.style.cssText += "outline: red 2px solid; outline-offset: 2px; -moz-outline-radius: 2px;"; }, lowlight() { if (this.orgStyle) this.target.style.cssText = this.orgStyle; else this.target.removeAttribute("style"); }, handleEvent(e) { switch(e.type){ case "click": if (e.button) return; e.preventDefault(); e.stopPropagation(); this.lowlight(); this.parent.capture.apply(this, this.getPosition()); this.uninit(); break; case "mouseover": if (this.target) this.lowlight(); this.target = e.target; this.highlight(); break; } }, init() { this.win = content; this.doc = content.document; ["click", "mouseover"].forEach(type=> this.doc.addEventListener(type, this, true)); }, uninit() { this.target = false; ["click", "mouseover"].forEach(type=> this.doc.removeEventListener(type, this, true)); } }` });
NS_ERROR_ILLEGAL_VALUE: Component returned failure code: 0x80070057 (NS_ERROR_ILLEGAL_VALUE) [nsIWebBrowserPersist.saveURI]
Можно как-то поправить?
Отредактировано unter_officer (20-05-2020 14:41:06)
«The Truth Is Out There»
Отсутствует
Есть ещё просьба по одной из ваших кнопок.
Не, код не мой, с меня только e10s-оболочка, какая-то.
А перестановки аргументов в nsIWebBrowserPersist.saveURI() обсуждались не раз.
Если нужно, например, под текущий релиз — принцип прост:
открываем релизную idl'ку, смотрим какие аргументы принимает метод saveURI(),
и пытаемся подогнать. Попробуй сам. Если не получится, или просто затем свериться
̣ fp.open(res => res == fp.returnCancel || !fp.file || makeWebBrowserPersist().saveURI( Services.io.newURI(msg.data), document.nodePrincipal, //null, null, null, null, null, fp.file, null null, null, null, null, fp.file, null, null ));
Отсутствует
Dumby, спасибо большое.
Не подскажите ещё вот с этим.
// Открыть новую вкладку двойным кликом по панели вкладок addEventListener("dblclick", e => { if ( e.button || e.ctrlKey || e.shiftKey || e.altKey ) return; try { BrowserOpenTab(); } catch(e) { }; }, false, document.getElementById("TabsToolbar"));
Суть в том, что на крайней версии новая вкладка почему-то открывается не только при двойным кликом по панели вкладок, но и при двойном клике по самим табам. Можно это как-то подправить?
Отредактировано unter_officer (20-05-2020 23:40:32)
«The Truth Is Out There»
Отсутствует
новая вкладка почему-то открывается не только при двойным кликом по панели вкладок, но и при двойном клике по самим табам
Ну да, сами табы же на панели вкладок.
Можно, например, какой-нибудь проверочный селектор
подобрать, чтоб подходил под задачу. Что-то типа
(sel => addEventListener("dblclick", e => !(e.button || e.ctrlKey || e.shiftKey || e.altKey) && e.target.matches(sel) && BrowserOpenTab() , false, document.getElementById("TabsToolbar") || 1))( "#tabbrowser-arrowscrollbox,toolbarspring,#TabsToolbar" );
Отсутствует
И как же такое может быть, ведь это будет <menu> или <toolbarbutton>,
а в коде написано
if ( target.localName !== "menuitem" || !target._placesNode ) return;
не совсем понял про что конкретно речь...
код вроде давно-давно писал bunda1 и он работает до сих пор у меня на FF52esr, лежит в какой-то кнопке в инициализации
может для FF76 его нужно вначале адаптировать?
мне главнее получить работоспособность второго кода - "прокручивать найденные результаты на странице колесиком мышки"
Отсутствует
Ну да, сами табы же на панели вкладок.
Можно, например, какой-нибудь проверочный селектор
подобрать, чтоб подходил под задачу. Что-то типаскрытый текстВыделить кодКод:
(sel => addEventListener("dblclick", e => !(e.button || e.ctrlKey || e.shiftKey || e.altKey) && e.target.matches(sel) && BrowserOpenTab() , false, document.getElementById("TabsToolbar") || 1))( "#tabbrowser-arrowscrollbox,toolbarspring,#TabsToolbar" );
Dumby, большое спасибо за помощь.
«The Truth Is Out There»
Отсутствует
может для FF76 его нужно вначале адаптировать?
мне главнее получить работоспособность второго кода - "прокручивать найденные результаты на странице колесиком мышки"
А речь о чём? Если о FindBar, то его Dumby уже адаптировал.
Отредактировано voqabuhe (21-05-2020 21:48:35)
Отсутствует
А речь о чём?
вопрос был про адаптацию кодов для user_chrome_files
пост с запросом
Отсутствует
Dumby. Возможно ли подправить вот эту кнопочку под крайнюю версию ?
// "Автоматически перезагружать" в контекстном меню вкладки, от 19.11.2015. ................. ((tabContextMenu, tabs, attr) => { const reloadInterval = 60000; // интервал перезагрузки, 60 sek = 60000 ms const throbber = [".tab-progress-box", ".tab-progress"]; // индикаторы загрузки скрываемые при автоперегрузке const reloadButtonStyle = "pointer-events: auto !important; -moz-appearance: none !important; -moz-box-ordinal-group: 0 !important; margin-left: -1px !important; margin-right: -1px !important; padding: 0 !important; border: none !important;"; const reloadButtonIcon = ""; // Создать новый пункт контекстного меню вкладки .... const menuitem = document.createElement("menuitem"); menuitem.setAttribute("type", "checkbox"); menuitem.setAttribute("label", "Автоматически перезагружать"); menuitem.onclick =()=> toggleAutoReload(document.popupNode); tabContextMenu.insertBefore(menuitem, document.getElementById("context_bookmarkAllTabs")); // над каким пунктом меню показывать // Устанавливаем где показывать пункт меню и чекбокс у пункта .... addEventListener("popupshowing", (e)=> { var tab = e.target.triggerNode; menuitem.hidden = !tab.linkedBrowser.currentURI.scheme.startsWith("http") menuitem.setAttribute("checked", tab.hasAttribute(attr)); }, false, tabContextMenu); // Добавлять или удалять кнопку и атрибут перегрузки на вкладку, добавлять обработчик на кнопку .... function toggleIconAndAttribute(tab) { var hbox = document.getAnonymousElementByAttribute(tab, "class", "tab-content"); if ( tab.hasAttribute(attr) ) { // удалить кнопку и атрибут hbox.removeChild(tab.querySelector("#tabReloadButton")); tab.removeAttribute(attr); return; } var reloadButton = document.createElement("toolbarbutton"); // создать кнопку reloadButton.setAttribute('image', reloadButtonIcon); reloadButton.setAttribute('style', reloadButtonStyle); reloadButton.setAttribute('id', 'tabReloadButton'); hbox.appendChild(reloadButton); tab.setAttribute(attr, 'true'); // добавить атрибут и обработчик reloadButton.onclick =()=> toggleAutoReload(tab); }; // Восстановить авто перегрузку табов и иконку после старта браузера и после перемещения вкладки .... function restoreAutoReload(e) { var tab = e.target; if ( !tab.hasAttribute(attr) || tab.querySelector("#tabReloadButton") ) return; tab.removeAttribute(attr); toggleAutoReload(tab); }; addEventListener('TabMove', restoreAutoReload, false, tabs); addEventListener('SSTabRestored', restoreAutoReload, false, tabs); // Стиль удаляет разные индикаторы загрузки вкладки при автоперегрузке .... throbber.forEach((m,i)=> throbber[i] = '.tabbrowser-tab[autoReload]:not([busy]) ' + m); var str = throbber + '{-moz-appearance: none !important; display: none !important;}'; const sss = Cc["@mozilla.org/content/style-sheet-service;1"].getService(Ci.nsIStyleSheetService); var uri = makeURI("data:text/css," + encodeURIComponent(str)); sss.loadAndRegisterSheet(uri, 0); // Переключать авто перегрузку таба .... function toggleAutoReload(tab) { clearInterval(tab.interval), toggleIconAndAttribute(tab); if ( !tab.hasAttribute(attr) ) return; tab.interval = setInterval(()=> { if (tab.collapsed || !menuitem.parentNode) clearInterval(tab.interval); gBrowser.reloadTab(tab); tab.removeAttribute("busy"); }, reloadInterval ); }; // Удалить изменения при удаления кода .... addDestructor(()=> { menuitem.remove(); sss.unregisterSheet(uri, 0); try{ document.querySelector("#tabReloadButton").remove() } catch(e){} }); })(document.getElementById("tabContextMenu"), gBrowser.tabContainer, "autoReload");
«The Truth Is Out There»
Отсутствует
katana
проверьте вот этот код для user-chrome-files кто-нибудь у себя? правда, я так и не разобрался в какой именно файл его поместить...
проверил еще раз после обновления user_chrome_files и частично код ЗАРАБОТАЛ! - прокрутка результатов поиска на странице листается колесом мыши
(код помещал в конец custom_script_win.js)
Отредактировано Inko7 (23-05-2020 09:56:49)
Отсутствует
Dumby
Что необходимо добавить (изменить) в этом скрипте:
Отредактировано kokoss (25-05-2020 02:11:43)
Win7
Отсутствует
Dumby. Возможно ли подправить вот эту кнопочку под крайнюю версию ?
Что-то не соображу как сделать, чтобы favicon таба
не дёргался, если есть, но был скрыт, если нет.
({ interval: 6e4, id: "cb-auto-reload", init(popup) { this.tabs(this.initTab, true) && this.addStyle(); addDestructor(this.destroy, this); var dsp = e => this[e.type](e); for(var type of ["popupshowing", "TabClose", "SSTabRestored"]) addEventListener(type, dsp, false, ( type[0] == "p" ? this.popup = popup : gBrowser.tabContainer ) || 1); }, destroy(reason) { this.tabs(this.destroyTab, reason != "delete"); this.menuitem?.remove(); }, tabs(callback, arg) { var res; for(var tab of gBrowser.tabs) { var has = SessionStore.getCustomTabValue(tab, this.id); has && callback.call(this, tab, arg, res = true); } return res; }, initTab(tab, arg) { arg || SessionStore.setCustomTabValue(tab, this.id, "1"); var img = document.createXULElement("hbox"); img.className = this.id; img.setAttribute("onclick", 'linkedObject.destroyTab(this.closest("tab"))'); img.linkedObject = this; tab.throbber.before(img); tab.setAttribute(this.id, setInterval(this.reload, this.interval, tab)); }, destroyTab(tab, arg) { clearInterval(tab.getAttribute(this.id)); arg || SessionStore.deleteCustomTabValue(tab, this.id); tab.removeAttribute(this.id); tab.querySelector("." + this.id).remove(); }, addStyle() { this.addStyle = () => {}; var css = ` tab.tabbrowser-tab:not([pinned]) .${this.id} { width: 16px; height: 16px; margin-left: -5px; background-position: center; background-repeat: no-repeat; background-image: url(""); } tab.tabbrowser-tab[${this.id}] :-moz-any(.tab-throbber, .tab-icon-pending) { display: none; } tab.tabbrowser-tab[${this.id}]/*[image]*/ .tab-icon-image { display: -moz-box; } `.replace(/;/g, " !important;"); var args = ["data:text/css," + encodeURIComponent(css), windowUtils.USER_SHEET]; windowUtils.loadSheetUsingURIString(...args); addDestructor(() => windowUtils.removeSheetUsingURIString(...args)); }, checked(tab = TabContextMenu.contextTab) { return tab.hasAttribute(this.id); }, cmd(tab) { this.addStyle(); (this.cmd = tab => this.checked(tab) ? this.destroyTab(tab) : this.initTab(tab))(tab); }, reload(tab) { gBrowser.reloadTab(tab); }, get shouldHide() { return !TabContextMenu.contextTab .linkedBrowser.currentURI.scheme.startsWith("http"); }, popupshowing(e) { if (this.shouldHide) return; var menuitem = this.menuitem = document.createXULElement("menuitem"); menuitem.id = "context_cbAutoReloadTab"; menuitem.setAttribute("type", "checkbox"); menuitem.setAttribute("label", "Автоматически перезагружать"); menuitem.setAttribute("oncommand", "linkedObject.cmd(TabContextMenu.contextTab)"); menuitem.linkedObject = this; this.popup.querySelector("#context_duplicateTab").after(menuitem); (this.popupshowing = e => e.target == this.popup && !(menuitem.hidden = this.shouldHide) && menuitem.setAttribute("checked", this.checked()) )(e); }, TabClose(e) { var intervalId = e.target.getAttribute(this.id); if (!intervalId) return; clearInterval(intervalId); var tab = e.detail.adoptedBy; tab && SessionStore.setCustomTabValue(tab, this.id, "1"); }, SSTabRestored(e) { var tab = e.target; SessionStore.getCustomTabValue(tab, this.id) && !tab.hasAttribute(this.id) && this.initTab(tab, true); } }).init(document.getElementById("tabContextMenu"));
частично код ЗАРАБОТАЛ!
Это так кажется из-за упорствования в ереси,
что код делает то, чего он не делает.
Под скудное описание того, что он якобы делает,
возможно, в какой-то степени, подойдёт нечто вроде
try {({ init(tabpanels) { var dsp = e => this[e.type](e); addEventListener("click", dsp, true); tabpanels.addEventListener("wheel", dsp); addEventListener("unload", () => { removeEventListener("click", dsp, true); tabpanels.removeEventListener("wheel", dsp); }, {once: true}); }, e: {ctrlKey: true, shiftKey: true}, p: {triggeringPrincipal: document.nodePrincipal}, s: "menu.bookmark-item,toolbarbutton.bookmark-item[type=menu]", click(e) { if ( e.button == 1 && isBlankPageURL(gBrowser.currentURI.spec) && !e.ctrlKey && !e.shiftKey && !e.altKey && e.target.matches(this.s) && !gBrowser.webProgress.isLoadingDocument ) { var trg = e.target, pn = trg._placesNode; if (!pn) return; e.stopPropagation(); var urls = PlacesUtils.getURLsForContainerNode(pn); PlacesUIUtils.openInTabClosesMenu && trg.tagName == "menu" && closeMenus(trg); if (urls.length && OpenInTabsUtils.confirmOpenInTabs(urls.length, window)) gBrowser.loadURI(urls.shift().uri, this.p), urls.length && PlacesUIUtils._openTabset(urls, this.e, window); } }, wheel(e) { var findbar = gBrowser.selectedTab._findBar; findbar?.matches(":hover") && e.deltaY && findbar.onFindAgainCommand(e.deltaY < 0); } }).init(document.getElementById("tabbrowser-tabpanels"))} catch(ex) {Cu.reportError(ex);}
Что необходимо добавить (изменить) в этом скрипте:
https://github.com/ardiman/userChrome.js/blob/master/autopopup/AutoPopup.uc.js
что бы он реагировал и на кнопки CB ? В 76
Ну, если заменить парочку подряд идущих функций,
то будет реагировать на всякие там менюшки #main-menubar'a, папок закладок
на панели закладок, и CB-кнопок, сделанных по стандарту «this.type = "menu";».
Но телепатии коду это не прибавит, пользовательская кнопка может быть сделана как угодно.
̣ function getPopupMenu(elt) { if (whitesInx > -1 && PopElt) return PopElt; var popup = elt.querySelector(":scope > menupopup"); if (popup) return popup; var id = elt.getAttribute("popup"); return id && document.getElementById(id); } function getPopupPos(elt) { var x = elt.screenX, y = elt.screenY, pos = 0; var trg = elt.closest("toolbar,hbox,vbox"); if (trg) { var {width, height} = (elt = trg).getBoundingClientRect(); if (height >= 3 * width) { if (height >= 45) pos = 9; } else if (width >= 3 * height && width >= 45) pos = 8; } else elt = elt.closest("window"); try { var {width, height} = elt.getBoundingClientRect(); x = pos & 1 ? x <= width / 2 + elt.screenX ? 1 : 3 : y <= height / 2 + elt.screenY ? 0 : 2; } catch {x = 0;} return popupPos[x]; }
У меня на ночном так и не заработал CB
А почему он должен был заработать? Что-то предпринималось?
Отсутствует