Приветствую. Можно кнопку Red Links https://forum.mozilla-russia.org/viewto … 26#p544526 адаптировать под FF 100?
На форуме
Dumby
Подскажите пожалуйста, что в коде не так? На FF108 W10 не работает, хотя на W8.1 работал? Даже ОС может влиять на функции браузера? Та же портабельная сборка от PortableApps.
addEventListener("contextmenu", { handleEvent(e) { if (e.detail != 2 || !gContextMenu?.onImage) return; var pl = "browser.download.folderList"; var pu = "browser.download.useDownloadDir"; var cl = Services.prefs.getIntPref(pl), sl = cl == 2; var cu = Services.prefs.getBoolPref(pu); sl || Services.prefs.setIntPref(pl, 2); cu || Services.prefs.setBoolPref(pu, true); try { this.save(); e.preventDefault(); this.hide(); } finally { sl || Services.prefs.setIntPref(pl, cl); cu || Services.prefs.setBoolPref(pu, cu); } }, get hide() { delete this.hide; var popup = document.getElementById("contentAreaContextMenu"); return this.hide = popup.hidePopup.bind(popup); }, get save() { var func = eval(`(function ${gContextMenu.saveMedia})`.replace( /^( )(?:false, \/\/ don't)( skip prompt for where to save)/m, "$1true, //$2" )); delete this.save; return this.save = () => func.call(gContextMenu); } }, false, gBrowser.tabpanels || 1);
Отсутствует
Кнопка "Отображать картинки" в FF100 работает, но кривовато (иконка не меняет вид при переключении).
this._handleClick =()=> BrowserReload( custombuttons.setPrefs(s, custombuttons.getPrefs(s) == 1 ? 2 : 1) ); var s = 'permissions.default.image'; function toggleImage() { var icon = self.ownerDocument.getAnonymousElementByAttribute(self, "class", "toolbarbutton-icon"); icon.src = custombuttons.getPrefs(s) == 1 ? self.image : ''; }; toggleImage(); gPrefService.addObserver(s, toggleImage, false); addDestructor(()=> gPrefService.removeObserver(s, toggleImage) );
Отредактировано manuk (25-07-2023 16:52:17)
На форуме
Это окно виндовское никак не раскрасить ?(w10)
@-moz-document url(chrome://global/content/commonDialog.xhtml) {
:root {
background-color: salmon !important;
}
}
Или о чём речь?
Можно кнопку Red Links https://forum.mozilla-russia.org/viewto … 26#p544526 адаптировать под FF 100?
Теоретически, не исключено. Но, казалось бы, все уже давно усвоили,
что «Links» в другом процессе, а с этим душниловом никто связываться не будет,
поэтому таких вопросов больше не задают.
Все, да, видимо, не все.
На FF108 W10 не работает
Ух ты, я вижу это!
Можно попробовать перенести обработчик в окно
Отсутствует
manuk как вариант
var button = this; const imgFalse=""; const imgTrue = ""; this.onclick = function(event) { if(event.button == 0) { gBrowser.fixupAndLoadURIString(`javascript:(function(){var i,x; for (i=0;x=document.links[i];++i)x.style.color=["red","blue","green"][sim(x,location)]; function sim(a,b) { if (a.hostname!=b.hostname) return 0; if (fixPath(a.pathname)!=fixPath(b.pathname) || a.search!=b.search) return 1; return 2; } function fixPath(p){ p = (p.charAt(0)=="/" ? "" : "/") + p; } })()`, { triggeringPrincipal: Services.scriptSecurityManager.getSystemPrincipal()}); button.image = imgTrue; } else if(event.button == 1) { gBrowser.fixupAndLoadURIString(`javascript:(function(){var i,x; for (i=0;x=document.links[i];++i)x.style.color=["","",""][sim(x,location)]; function sim(a,b) { if (a.hostname!=b.hostname) return 0; if (fixPath(a.pathname)!=fixPath(b.pathname) || a.search!=b.search) return 1; return 2; } function fixPath(p){ p = (p.charAt(0)=="/" ? "" : "/") + p } })()`, { triggeringPrincipal: Services.scriptSecurityManager.getSystemPrincipal()}); button.image = imgFalse; } }; this.tooltipText="ЛКМ - Подсветить ссылки:\n красный - внешние сайты\n голубой - внутри сайта\n зеленый - внутри страницы\nСКМ - Вернуть исходный вид\nПКМ - Меню кнопки";
Отсутствует
Ух ты, я вижу это!
Можно попробовать перенести обработчик в окно
Спасибо огромное!
manuk
Попробуйте эту кнопку от Dumby, очень удобно.
addEventListener("contextmenu", { handleEvent(e) { if (e.detail != 2 || !gContextMenu?.onImage) return; var pl = "browser.download.folderList"; var pu = "browser.download.useDownloadDir"; var cl = Services.prefs.getIntPref(pl), sl = cl == 2; var cu = Services.prefs.getBoolPref(pu); sl || Services.prefs.setIntPref(pl, 2); cu || Services.prefs.setBoolPref(pu, true); try { this.save(); e.preventDefault(); this.hide(); } finally { sl || Services.prefs.setIntPref(pl, cl); cu || Services.prefs.setBoolPref(pu, cu); } }, get hide() { delete this.hide; var popup = document.getElementById("contentAreaContextMenu"); return this.hide = popup.hidePopup.bind(popup); }, get save() { var func = eval(`(function ${gContextMenu.saveMedia})`.replace( /^( )(?:false, \/\/ don't)( skip prompt for where to save)/m, "$1true, //$2" )); delete this.save; return this.save = () => func.call(gContextMenu); } //}, false, gBrowser.tabpanels || 1); });
b0ttle
Сохранение изображения по двойному ПКМ на нём без запроса.
Отсутствует
мне не сохранять картинки нужно, а кнопкой отключать-включать их показ на страницах сайтов. (permissions.default.image)
Когда-то делал себе на FF91, но потом за невостребованностью удалил.
Попробуйте, может будет работать на FF100.
/*Initialization Code*/ self.image = ""; // Настройка функций кликов мыши для кнопки ..... this.onmousedown =e=> { this.onmouseup =e=> { // левый клик if (e.button) return; switch(cbu.getPrefs("permissions.default.image")) { case 0: var data = 1; break; case 1: var data = 2; break; default: var data = 1; } cbu.setPrefs("permissions.default.image", data); } this.onclick =e=> { // правый клик if (e.button == 2) gShowPopup(this); } } self.onclick =e=> e.preventDefault(); // Подсказка для кнопки ..... this.onmouseover =()=> { if (cbu.getPrefs("permissions.default.image") == 1) { statusPrefs = "Показ включен"; } else { statusPrefs = "Показ выключен"; } this.tooltipText = "Вкл/Откл показ картинок на страницах сайтов \nЛКМ: Вкл/Откл картинки \nПКМ: CB меню \n----------------------------------------------\nТекущее состояние: " + statusPrefs; } // Установливать нужную иконку кнопки при старте баузера или при изменениях в 'about:config' ..... var s = "permissions.default.image"; function toggleImage() { var icon = self.getElementsByClassName("toolbarbutton-icon")[0]; switch( cbu.getPrefs(s)) { case 1: icon.src = self.image; break; case 2: icon.src = ''; break; default:icon.src = self.image; } } toggleImage(); var gPrefService = Cc["@mozilla.org/preferences-service;1"].getService(Ci.nsIPrefBranch); gPrefService.addObserver(s, toggleImage, false); addDestructor(()=> gPrefService.removeObserver(s, toggleImage));
«The Truth Is Out There»
Отсутствует
manuk все работает перезагрузи браузер
Отсутствует
manuk посмотри пост https://forum.mozilla-russia.org/viewtopic.php?pid=804278#p804278 и все поймешь и на сотке заработает. На старших версиях - заменить loadURI на fixupAndLoadURIString, а ты обратно поменяй местами
Отсутствует
Andrey_Krropotkin, понял. Заменил. Работает. Спасибо большое! А можно сделать, чтобы все страницы сразу грузились с настроенными цветами без клика по кнопке?
Отредактировано manuk (25-07-2023 23:52:07)
На форуме
manuk нет, каждая вкладка отдельный процесс
Отсутствует
заменить loadURI на fixupAndLoadURIString
Это везде или только для данного скрипта? Просто нашел у себя в одном скрипте, но разницы не вижу, возможно неиспользуемый мной функционал.
иначе не работало
ОК, посмотрю.
Отредактировано _zt (27-07-2023 01:56:10)
Отсутствует
_zt я везде заменял, иначе не работало
Отсутствует
Dumby
@-moz-document url(chrome://global/content/commonDialog.xhtml) {
:root {
background-color: salmon !important;
}
}
Не того...Display: none -реагирует , на окрас - нет. Заголовок окна,имею ввиду.
Отсутствует
Отсутствует
Пожалуйста, помогите мне с решением.
Я хочу заменить mainWindow.gBrowser.addTab("https://vk.com/") на element.click().
То что у меня есть сейчас (когда выполняю в window.console.log ниже строку из кода, то получаю [object XULElement]):
mainWindow.gBrowser.addTab("https://vk.com/")
А мне нужно что-то вроде (см. ниже, знаю что неверно, но суть понятна)... перейти по ссылке со стороннего сайта, на сайт вк через клик, но чтобы функционал соответствовал mainWindow.gBrowser.addTab("https://vk.com/"), то есть я получал в window.console.log ответ в виде [object XULElement].
window.document.querySelector('селектор').click()
Отредактировано Deriax (02-08-2023 22:52:03)
Отсутствует
Перешел на 116, в кнопке
/*Initialization Code*/ ({ title: "Консоль браузера", url: "chrome://devtools/content/webconsole/index.html", icon: "chrome://devtools/skin/images/tool-webconsole.svg", init() { var trg = document.getElementById("browser"); trg && addEventListener("DOMContentLoaded", this, false, trg); var id = "viewBrowserConsoleSidebar"; var menuitem = this.element("menuitem", { type: "checkbox", label: this.title, id: "menu_browserConsoleSidebar", oncommand: `SidebarUI.toggle("${id}");` }, document.getElementById("viewSidebarMenu")); var btn = this.element("toolbarbutton", { type: "checkbox", label: this.title, id: "sidebar-switcher-browserConsole", oncommand: `SidebarUI.show("${id}");`, class: "subviewbutton subviewbutton-iconic" }); document.querySelector( 'toolbarbutton[id^="sidebar-switcher-"] + toolbarseparator' ).before(btn); SidebarUI.sidebars.set(id, { url: this.url, buttonId: btn.id, title: this.title, menuId: menuitem.id }); SidebarUI.isOpen && SidebarUI.currentID == id && SidebarUI.selectMenuItem(id); var popupset = this.popupset = this.element("popupset", { id: `CB${_id.slice(20)}-browserConsole-popupset` }, document.documentElement); var css = `\ #${btn.id} > .toolbarbutton-icon, #sidebar-box[sidebarcommand="${id}"] > #sidebar-header > #sidebar-switcher-target > #sidebar-icon { list-style-image: url(${this.icon}); }`; var str = (cbu.cb || "") + "data:text/css," + encodeURIComponent(css), type = windowUtils.USER_SHEET; windowUtils.loadSheetUsingURIString(str, type); addDestructor(() => { SidebarUI.sidebars.delete(id); btn.remove(); menuitem.remove(); popupset.remove(); windowUtils.removeSheetUsingURIString(str, type); }); parseInt(Services.appinfo.platformVersion) < 73 && "insertFTLIfNeeded" in MozXULElement && MozXULElement.insertFTLIfNeeded("toolkit/main-window/editmenu.ftl"); self.onclick = e => { if (e.button == 2) return; if (!e.button && !e.shiftKey) return SidebarUI.toggle(id); var st = gBrowser.selectedTab, tab; if (!e.ctrlKey) tab = gBrowser.visibleTabs.find(tab => { var br = gBrowser.getBrowserForTab(tab); return br.currentURI.spec == this.url || ( "_cachedCurrentURI" in br && br._cachedCurrentURI.spec == this.url ) }); if (tab == st) return; if (!tab) tab = gBrowser.addTrustedTab(this.url); gBrowser.moveTabTo(tab, st._tPos + 1); gBrowser.selectedTab = tab; } for(var br of gBrowser.browsers) { if (br.currentURI.spec != this.url) continue; var doc = br.contentDocument; if (doc && ( doc.readyState == "complete" || doc.readyState == "interactive" )) doc.querySelector( "main#app-wrapper,div#output-container" ).childElementCount ? this.defineDocPopupset(doc) : this.handleEvent({target: doc}); } if (!btn.hasAttribute("checked")) return; var doc = SidebarUI.browser.contentDocument; if (doc.documentURI != this.url) btn.doCommand(); else if (doc.readyState == "complete") this.defineDocPopupset(doc); }, defineDocPopupset(doc) { this.definePopupset( doc.querySelector("popupset") || doc.documentElement.appendChild(doc.createXULElement("popupset")) ); }, get definePopupset() { var append = customElements.get("menuitem") ? popup => { this.popupset.appendChild(popup); popup.setAttribute("oncommand", "event.target.cmd()"); for(var node of [...popup.querySelectorAll("menuitem")]) { var menuitem = document.importNode(node, true); menuitem.cmd = Services.els.getListenerInfoFor(node) .find(inf => inf.type == "command").listenerObject; popup.replaceChild(menuitem, node); } return popup; } : this.popupset.appendChild.bind(this.popupset); delete this.definePopupset; return this.definePopupset = popupset => popupset.appendChild = append; }, lss: Services.scriptloader.loadSubScript, async handleEvent({target: doc}) { if (!doc || doc.documentURI != this.url) return; var win = doc.defaultView; if ( win.docShell.name == "toolbox-panel-iframe-webconsole" || doc.DOMContentLoadedEventHandled ) return; doc.DOMContentLoadedEventHandled = true; "custombuttonsConsole" in win || this.lss( "chrome://custombuttons/content/consoleOverlay.js", win ); var cw = win.isChromeWindow, bc; if (!cw) { if (doc.visibilityState == "hidden") { var {focus} = win; win.focus = () => win.focus = focus; } doc.title = this.title; var link = doc.createElement("link"); link.setAttribute("rel", "shortcut icon"); link.setAttribute("href", this.icon); doc.head.prepend(link); var br = win.docShell.chromeEventHandler; var cmAttr = br.getAttribute("contextmenu"); cmAttr && br.removeAttribute("contextmenu"); win.onbeforeunload = () => { if (bc) bc.chromeWindow = {close() {}}; cmAttr && br.setAttribute("contextmenu", cmAttr); } } bc = await this.console(win); }, get console() { // Bug 1579090 - WebConsole should handle ObjectFront when needed (for non-primitive Console API args + Evaluation results) (Firefox 73+) https://bugzilla.mozilla.org/show_bug.cgi?id=1579090 var vers = parseInt(Services.appinfo.platformVersion); this.bug1579090 = vers > 73 || (vers == 73 && !( "_setCurrentURI" in gBrowser.selectedBrowser // https://bugzil.la/1431214 )); delete this.console; return this.console = this.bug1579090 ? async win => { //await this.loader.bcm._browserConsoleInitializing; var key = "CBBrowserConsolePromise", {wins} = this.loader; win[key] = win.Object.create(null); win[key].promise = new win.Promise(resolve => win[key].resolve = resolve); win[key].destroy = () => { win[key].resolve(); delete win[key]; wins.splice(wins.indexOf(win), 1); } wins.unshift(win); wins.length > 1 && await wins[1][key].promise; var bc = await new this.loader.console(win).toggleBrowserConsole(); win[key].destroy(); return bc; } : async win => { this.loader.Services.ww.wins.push(win); return await new this.loader.HUDService().toggleBrowserConsole(); } }, get loader() { delete this.loader; // var url = "resource://devtools/shared/Loader.jsm"; var url, pver = parseInt(Services.appinfo.platformVersion); if (pver < 98) url = "resource://devtools/shared/Loader.jsm"; else url= "resource://devtools/shared/loader/Loader.jsm"; if (this.bug1579090) { var g = Cu.import(url, {}), key = "CBBrowserConsoleLoader"; addDestructor(reason => reason[5] == e && key in g && g[key].destroy()); if (key in g) return this.loader = g[key]; var {BrowserConsoleManager} = g.require( "devtools/client/webconsole/browser-console-manager" ); return this.loader = g[key] = { wins: [], bcm: BrowserConsoleManager, console: class extends BrowserConsoleManager.constructor { constructor(win) { super(); this.win = win; } openWindow() { var {win} = this; win.addEventListener("unload", () => { win.CBBrowserConsolePromise && win.CBBrowserConsolePromise.destroy(); this.closeBrowserConsole.call(this); }, {once: true}); delete this.win; return win; } }, destroy() { this.wins = null; delete g[key]; } }; } var id = _id + "-browser-console"; url += "?" + id; var loader = {exports: {}}, nsvo = Cu.import(url, loader); addDestructor(reason => reason[5] == "e" && Cu.unload(url)); if (id in nsvo) return this.loader = nsvo[id]; var dir = "resource://devtools/client/webconsole/"; try { this.lss(dir + "hudservice.js", loader); } catch(ex) { // Bug 1570320 - Rename hudservice.js into browser-console-manager.js (Firefox 70+) // https://bugzilla.mozilla.org/show_bug.cgi?id=1570320 this.lss(dir + "browser-console-manager.js", loader); this.lss("data:,this.HUDService=BrowserConsoleManager", loader); } var e = new CustomEvent("DOMContentLoaded", {bubbles: false}), ww = loader.Services.ww; loader.Services.ww = Cu.getGlobalForObject(nsvo).Object.create(ww, { wins: {value: []}, openWindow: {value: function() { var win = this.wins.shift(); win.setTimeout(() => win.dispatchEvent(e), 0); return win; }} }); return this.loader = nsvo[id] = loader; }, element(name, attrs, parent) { var node = document.createXULElement(name); for(var attr in attrs) node.setAttribute(attr, attrs[attr]); parent && parent.append(node); return node; } }).init(); this.tooltipText = "Консоль браузера" +"\n"+"\n"+ "ЛКМ: В боковой панели" +"\n"+ "СКМ: В новой вкладке" +"\n"+ "ПКМ: Стандартное меню "
Отредактировано Andrey_Krropotkin (03-08-2023 07:51:19)
Отсутствует
Andrey_Krropotkin
а если так...
/* document.querySelector( 'toolbarbutton[id^="sidebar-switcher-"] + toolbarseparator' ).before(btn); */ document.querySelector( parseInt(Services.appinfo.platformVersion) >= 116 ? 'menuitem[id^="sidebar-switcher-"] + menuseparator' : 'toolbarbutton[id^="sidebar-switcher-"] + toolbarseparator' ).before(btn);
Отредактировано Farby (03-08-2023 10:06:47)
Жизнь иногда такое выкидывает, что хочется подобрать...
На форуме
Farby так все работает спасибо
Отсутствует