Die Forumssoftware ist doch komplizierter als ich dachte.. learning by doing..sorry..
userChrome.js Scripte für den Fuchs (Diskussion)
-
Endor -
12. Mai 2015 um 14:19 -
Erledigt
-
-
Hallo,
ich will das erweiterte Skript ExtensionOptionsMenu für den Fx87 fit machen und deshalb die Restart-Funktion aus dem Skript RestartFirefox_plus einbauen. In Zeile 178 funktioniert das auch (s.u.), aber wenn ich das entsprechend in Zeile 474 eintrage, macht die Funktion ihrem Namen alle Ehre: Der Firefox startet endlos neu, ohne dass ich etwas dazu tue. Wie muss die Zeile 474 richtig lauten (hier noch nicht geändert)?:
JavaScript: ExtensionOptionsMenu+.uc.js
Alles anzeigen// ==UserScript== // @name ExtensionOptionsMenu.uc.js // @description Symbolleistenschaltfläche zur Add-ons-Verwaltung // @include main // @charset UTF-8 // @version.......3.1.7 Einstellbarer Dateimanager (Z. 48,49), alle Einstellungsseiten können geöffnet werden // @version 3.1.6 Anpassung an Firefox 65 von aborix // @version 3.1.5 Deaktivieren der Erweiterungen mit Rechtsklick repariert von aborix // @version 3.1.4 Anpassung an Firefox 61+ von aborix // @version 3.1.2 Auf Grund von Problemen, wurde die Fensteranzeige der Erweiterungseinstellungen entfernt // @version 3.1.1 Öffnen des Erweiterungen-Ordners funktionierte nicht // @version 3.1.0 Unterstützt Fx 57 oder später. System Add-ons, konnten nicht deaktiviert werden // @version 3.0.10 Fx52以降で右クリック時に出る既存メニューを出ないように修正 (2ch該当スレより拝借) // @version 3.0.9 表示したくないアドオンを設定できるように(コメントアウト内の説明参照)、選択アドオンのidをAlt+左クリックでコピーできるように // @version 3.0.8 再起動に関する修正 // @version 3.0.7 メニューにアイコンが出ていなかったのを修正 // @version 3.0.6 互換性を考慮して書き換え デフォルトでボタンはカスタマイズパレットに配置 // @version 3.0.5 ツールチップに操作法を表示するように コメントアウト内CSSを更新 // @version 3.0.4 一部アドオンの設定画面が機能していなかったのを修正、メニューパネル内でドロップマーカーが出ないようにするCSSを追記 // @version 3.0.3 ボタンをツールバーパレットから自由に配置できるように変更(メニューパネル内への配置にも対応 ※コメントアウト内のcssを追加するように) // ==/UserScript== /* Schaltflächensymbol: Linksklick: Erweiterungsliste anzeigen Mittelklick: Firefox neustarten Rechtsklick: Add-ons-Manager öffnen Erweiterungen: Linksklick: Erweiterungseinstellungen öffnen, wenn vorhanden Shift+Linksklick: Einstellngs-URL kopieren Mittelklick: Internetseite der Erweiterung öffnen Rechtsklick: Erweiterungen aktivieren/deaktivieren Strg + Linksklick: Erweiterungsordner öffnen Strg + Mittelklick: Erweiterungs-ID in Zwischenablage kopieren Strg + Rechtsklick: Erweiterung entfernen / Deinstallation rückgängig machen *Nach Firefox-Neustart kann dies nicht mehr Rückgängig gemacht werden. Es werden auch die Einstellungsseiten in einem neuen Tab geöffnet, die sonst innerhalb des Add-on-Managers öffnen. Falls das nicht gewünscht ist, die Zeilen 395 - 397 auskommentieren. Bei "blackListArray" ab Zeile 68 können Add-ons, die nicht im Menü angezeigt werden sollen, mit der ID des Add-ons eingegeben werden. Sie können die ID mit Strg + Mittelklick kopieren. Einige Systemerweiterungen werden standardmäßig hinzugefügt. Dateimanager: Die Erweiterungs-Ordner können mit einem eigenen Dateimanager geöffnet werden. Dazu den Pfad in Zeile 59 und eventuell einen Parameter in Zeile 60 eintragen. Falls der Standard-Dateimanager des Systems verwendet werden soll, diese Zeilen auskommentieren. Sortierung: Zeilen 93 - 94 */ 'use strict'; var EOM = { vFileManager: 'C:\\Program Files\\FreeCommander XE\\FreeCommander.exe', vFMParameter: '/T', showVersion: true, // Versionsinfo anzeigen (true = Versionsinfo anzeigen, false = nicht anzeigen) showAll: true, // Alles anzeigen, auch bei Erweiterungen ohne Einstellungen showDisabled: true, // deaktivierte Erweiterungen anzeigen (deaktivierte Add-ons anzeigen) autoRestart: false, // Firefox nach Installation bzw. Deinstallation automatisch neu starten iconURL: '', blackListArray: [ "clicktoplay-rollout@mozilla.org", "firefox@getpocket.com", "screenshots@mozilla.org", "followonsearch@mozilla.com", "formautofill@mozilla.org", "onboarding@mozilla.org", "shield-recipe-client@mozilla.org", "webcompat@mozilla.org", "activity-stream@mozilla.org", "presentation@mozilla.org", "aushelper@mozilla.org", "webcompat-reporter@mozilla.org", "e10srollout@mozilla.org", "google@search.mozilla.org", "ecosia@search.mozilla.org", "ebay@search.mozilla.org", "doh-rollout@mozilla.org", "bing@search.mozilla.org", "amazon@search.mozilla.org", "ddg@search.mozilla.org", "leo_ende_de@search.mozilla.org", "wikipedia@search.mozilla.org" ], sort: { enabled: 0, disabled: 1 // 0, 0 - In alphabetischer Reihenfolge // 0, 1 - Reihenfolge wie im Add-On-Manager }, init: function() { var style = ` @namespace url('http://www.mozilla.org/keymaster/gatekeeper/there.is.only.xul'); /* #eom-button { list-style-image: url(''); } */ .addon-disabled > .menu-iconic-left { filter: grayscale(1); } .addon-disabled label { color: Gray !important; } .addon-uninstall label { font-weight: bold !important; } .addon-uninstall label:after { content: '-'; } // #eom-button[cui-areatype="menu-panel"], // toolbarpaletteitem[place="palette"] > #eom-button { // list-style-image: url(''); // } `; style = style.replace(/\s+/g, " "); var sspi = document.createProcessingInstruction( 'xml-stylesheet', 'type="text/css" href="data:text/css,' + encodeURIComponent(style) + '"' ); document.insertBefore(sspi, document.documentElement); sspi.getAttribute = function(name) { return document.documentElement.getAttribute(name); }; const XUL_NS = 'http://www.mozilla.org/keymaster/gatekeeper/there.is.only.xul'; const eombutton = $C("menu", { id: "eom-button", label: "Add-ons", tooltiptext: "Extension Options Menu\n\nLinksklick: Erweiterungsliste anzeigen\nMittelklick: Firefox neu starten\nRechtsklick: Add-ons-Manager öffnen", className: "menu-iconic", accesskey: "O" }); CustomizableUI.createWidget({ id: 'eom-button-item', type: 'custom', defaultArea: CustomizableUI.AREA_NAVBAR, onBuild: function(aDocument) { let toolbaritem = aDocument.createElementNS(XUL_NS, 'toolbaritem'); toolbaritem.id = 'eom-button-item'; toolbaritem.className = 'chromeclass-toolbar-additional'; toolbaritem.label = 'Extension Options Menu'; toolbaritem.tooltiptext = 'Extension Options Menu\n\nLinksklick: Erweiterungsliste anzeigen\nMittelklick: Firefox neu starten\nRechtsklick: Add-ons-Manager öffnen'; return toolbaritem; } }); $('eom-button-item').appendChild(eombutton); var btn = document.getElementById('eom-button'); btn.addEventListener('click', EOM.iconClick); var mp = btn.appendChild(document.createElementNS(XUL_NS, 'menupopup')); mp.setAttribute('id', 'eom-button-popup'); mp.setAttribute('onclick', 'event.preventDefault(); event.stopPropagation();'); mp.addEventListener('popupshowing', (event) => EOM.populateMenu(event)); function copyList() { AddonManager.getAddonsByTypes(["extension"]).then(function(extensions) { Cc['@mozilla.org/widget/clipboardhelper;1'].getService(Ci.nsIClipboardHelper).copyString(extensions.map(function(item, id) { return (id + 1 + ". " + item.name + " [" + item.version + "]" + "\nID:" + item.id + "\naktiv:" + item.isActive + "\n----------"); }).join("\n")); }); var alertsService = Cc['@mozilla.org/alerts-service;1'].getService(Ci.nsIAlertsService); alertsService.showAlertNotification("", "Add-ons-Liste", "Add-ons-Liste\nin die Zwischenablage kopiert.", null, null, null, "copyList"); setTimeout(function() { alertsService.closeAlert("copyList"); }, 5000); }; var mMenus = [ { alabel: 'Firefox neu starten', label: 'Script-Cache löschen', image: "", oncommand: "Services.appinfo.invalidateCachesOnRestart() || Services.startup.quit(Ci.nsIAppStartup.eRestart | Ci.nsIAppStartup.eAttemptQuit);", style: "min-width: 260px;" }, { label: "Erweiterungsordner öffnen", image: "", oncommand: "EOM.browseExtDir();" }, { label: "Add-ons-Liste in die Zwischenablage kopieren", image: "", oncommand: '(' + copyList.toString() + ')()' } ]; var menugroup = mp.appendChild($C("menugroup", { id: "eom-menugroup" })); mp.appendChild($C('menuseparator')); for (let i = 0, menu; menu = mMenus[i]; i++) { menugroup.appendChild($C("menuitem", { label: menu.alabel, tooltiptext: menu.label, image: menu.image, class: "menuitem-iconic", oncommand: menu.oncommand, style: menu.style || "max-width: 10px;" })); }; function $C(name, attr) { var el = document.createXULElement(name); if (attr) { Object.keys(attr).forEach(function(n) { el.setAttribute(n, attr[n]); }); }; return el; }; }, populateMenu: function(event) { var prevState; var showItem = true; var popup = event.target; if (popup !== event.currentTarget) { return; } while (popup.childElementCount > 2) { popup.removeChild(popup.lastChild); } var addons; AddonManager.getAddonsByTypes(['extension']).then(function(aAddons) { addons = aAddons; }); var thread = Services.tm.mainThread; while (addons === void 0) { thread.processNextEvent(true); } addons.sort((a, b) => { var ka = this.key(a); var kb = this.key(b); return (ka < kb) ? -1 : 1; }).forEach((addon) => { if (!addon.appDisabled && ((addon.isActive && addon.optionsURL) || ((addon.userDisabled && this.showDisabled) || (!addon.userDisabled && this.showAll)))) { var state = addon.isActive; if (this.sort.disabled === 1 && (prevState && state !== prevState)) { popup.appendChild(document.createXULElement('menuseparator')); } prevState = state; var mi = document.createXULElement('menuitem'); var label = addon.name; if (this.showVersion) label = label += ' ' + '[' + addon.version + ']'; mi.setAttribute('label', label); mi.setAttribute('class', 'menuitem-iconic'); mi.setAttribute('tooltiptext', 'ID: ' + addon.id + '\nEinstellungen: ' + addon.optionsURL + ' (Typ ' + Number(addon.optionsType) + ')\nHomepage: ' + addon.homepageURL + '\n\nLinksklick = Add-on-Einstellungen öffnen\nMittelklick = Add-on-Homepage öffnen\nRechtsklick = Add-on aktivieren / deaktivieren\nShift+Linksklick = Einstellungs-URL kopieren\nStrg + Linksklick = Add-on-Ordner öffnen\nStrg + Mittelklick = Add-on ID kopieren\nStrg + Rechtsklick = Add-on deinstallieren *\n* Diese Aktion kann nicht rückgängig gemacht werden.'); // '\nGröße: ' + Math.floor(addon.size / 1024) + ' KB' //funktioniert nicht var icon = addon.iconURL || addon.iconURL64 || this.iconURL || ''; mi.setAttribute('image', icon); mi.addEventListener('click', (event) => this.handleClick(event)); mi._Addon = addon; if (!addon.optionsURL && addon.isActive) { mi.setAttribute('style', 'font-style: italic'); } else { if (!addon.operationsRequiringRestart) { mi.setAttribute('style', 'color: Blue'); } } this.setDisable(mi, addon.userDisabled); this.setUninstall(mi, this.isPending(addon)); if (this.blackListArray) { for (var i = 0; i < this.blackListArray.length; i++) { if (this.blackListArray[i] == addon.id.toLowerCase()) { showItem = false; break; } else { showItem = true; } } } if (showItem) popup.appendChild(mi); } }); }, iconClick: function(event) { if (event.target !== event.currentTarget) { return; } if (event.button === 1) { EOM.restart(); } else if (event.button === 2) { BrowserOpenAddonsMgr('addons://list/extension'); } }, handleClick: function(event) { var mi = event.target; if (mi !== event.currentTarget) { return; } if (!('_Addon' in mi)) { return; } var addon = mi._Addon; var pending = this.isPending(addon); var hasMdf = event.ctrlKey || event.shiftKey || event.altKey || event.metaKey; switch (event.button) { case 0: if (!addon.optionsURL && addon.isActive && !hasMdf) { // window.alert('"' + addon.name + '" hat keine Einstellungen.'); var alertsService = Cc['@mozilla.org/alerts-service;1'].getService(Ci.nsIAlertsService); var icon = addon.iconURL || addon.iconURL64 || this.iconURL || ''; alertsService.showAlertNotification(icon, '"' + addon.name + '"', ' HAT KEINE EINSTELLUNGEN.', null, null, null, "noOptions"); function beep() { var snd = new Audio("data:audio/wav;base64,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qJrx4KOQjahZxWbcZgztj2c49nKmkId44S71j0c8eV9yDK6uPRzx5X18eDvjvQ6yKo9ZSS6l//8elePK/Lf//IInrOF/FvDoADYAGBMGb7FtErm5MXMlmPAJQVgWta7Zx2go+8xJ0UiCb8LHHdftWyLJE0QIAIsI+UbXu67dZMjmgDGCGl1H+vpF4NSDckSIkk7Vd+sxEhBQMRU8j/12UIRhzSaUdQ+rQU5kGeFxm+hb1oh6pWWmv3uvmReDl0UnvtapVaIzo1jZbf/pD6ElLqSX+rUmOQNpJFa/r+sa4e/pBlAABoAAAAA3CUgShLdGIxsY7AUABPRrgCABdDuQ5GC7DqPQCgbbJUAoRSUj+NIEig0YfyWUho1VBBBA//uQZB4ABZx5zfMakeAAAAmwAAAAF5F3P0w9GtAAACfAAAAAwLhMDmAYWMgVEG1U0FIGCBgXBXAtfMH10000EEEEEECUBYln03TTTdNBDZopopYvrTTdNa325mImNg3TTPV9q3pmY0xoO6bv3r00y+IDGid/9aaaZTGMuj9mpu9Mpio1dXrr5HERTZSmqU36A3CumzN/9Robv/Xx4v9ijkSRSNLQhAWumap82WRSBUqXStV/YcS+XVLnSS+WLDroqArFkMEsAS+eWmrUzrO0oEmE40RlMZ5+ODIkAyKAGUwZ3mVKmcamcJnMW26MRPgUw6j+LkhyHGVGYjSUUKNpuJUQoOIAyDvEyG8S5yfK6dhZc0Tx1KI/gviKL6qvvFs1+bWtaz58uUNnryq6kt5RzOCkPWlVqVX2a/EEBUdU1KrXLf40GoiiFXK///qpoiDXrOgqDR38JB0bw7SoL+ZB9o1RCkQjQ2CBYZKd/+VJxZRRZlqSkKiws0WFxUyCwsKiMy7hUVFhIaCrNQsKkTIsLivwKKigsj8XYlwt/WKi2N4d//uQRCSAAjURNIHpMZBGYiaQPSYyAAABLAAAAAAAACWAAAAApUF/Mg+0aohSIRobBAsMlO//Kk4soosy1JSFRYWaLC4qZBYWFRGZdwqKiwkNBVmoWFSJkWFxX4FFRQWR+LsS4W/rFRb/////////////////////////////////////////////////////////////////////////////////////////////////////////////////////////////////////////////////////////////////////////////////////////////////////////////////////////////////////////////////////////////////////////////////////////////////////////////////////////////////////////////////////////////////////////////////////////////////////////////////////////////////VEFHAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAU291bmRib3kuZGUAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAMjAwNGh0dHA6Ly93d3cuc291bmRib3kuZGUAAAAAAAAAACU="); snd.play(); } beep(); setTimeout(function() { alertsService.closeAlert("noOptions"); }, 8000); } else if (addon.optionsURL && !hasMdf && Number(addon.optionsType)) { this.openAddonOptions(addon); } else if (event.ctrlKey) { this.browseDir(addon); } else if (event.shiftKey) { Cc['@mozilla.org/widget/clipboardhelper;1'].getService(Ci.nsIClipboardHelper).copyString(addon.optionsURL); } break; case 1: if (addon.homepageURL && !hasMdf) { openURL(addon.homepageURL); } else if (event.ctrlKey) { Cc['@mozilla.org/widget/clipboardhelper;1'].getService(Ci.nsIClipboardHelper).copyString(addon.id); } break; case 2: if (!hasMdf) { var stateDisabled = !addon.userDisabled; stateDisabled ? addon.disable() : addon.enable(); this.setDisable(mi, stateDisabled); if (addon.operationsRequiringRestart && this.autoRestart) { EOM.restart(); } } else if (event.ctrlKey) { if (pending) { addon.cancelUninstall(); } else { addon.uninstall(); } this.setUninstall(mi, pending); } break; } }, setDisable: function(mi, dis) { var cls = mi.classList; dis ? cls.add('addon-disabled') : cls.remove('addon-disabled'); }, setUninstall: function(mi, uninst) { var cls = mi.classList; uninst ? cls.add('addon-uninstall') : cls.remove('addon-uninstall'); }, isPending: function(addon) { return addon.pendingOperations & AddonManager.PENDING_UNINSTALL; }, openAddonOptions: function(addon) { var optionsURL = addon.optionsURL || ''; if (!addon.isActive || !optionsURL) { return; } switch (Number(addon.optionsType)) { case 3: "switchToTabHavingURI" in window ? switchToTabHavingURI(optionsURL, true) : openTab("contentTab", { contentPage: optionsURL }); break; // auch nicht eigenständige Einstellungsseiten in neuem Tab öffnen ... case 5: "switchToTabHavingURI" in window ? switchToTabHavingURI(optionsURL, true) : openTab("contentTab", { contentPage: optionsURL }); break; // ... falls das nicht gewünscht ist, zwischen diesen Kommentaren auskommentieren. default: openDialog(optionsURL, addon.name, 'chrome,titlebar,toolbar,resizable,scrollbars,centerscreen,dialog=no,modal=no'); } }, browseExtDir: function() { var extDir = Services.dirsvc.get('ProfD', Ci.nsIFile); var nsLocalDir = Components.Constructor('@mozilla.org/file/local;1', 'nsIFile', 'initWithPath'); extDir.append('extensions'); if (this.vFileManager.length != 0) { var file = Cc['@mozilla.org/file/local;1'].createInstance(Ci.nsIFile); var process = Cc['@mozilla.org/process/util;1'].createInstance(Ci.nsIProcess); var args=[this.vFMParameter,extDir.path]; file.initWithPath(this.vFileManager); process.init(file); // Verzeichnis mit anderem Dateimanager öffnen process.run(false, args, args.length); } else { // Verzeichnis mit Dateimanager des Systems öffnen new nsLocalDir(extDir).reveal(); } }, browseDir: function(addon) { var dir = Services.dirsvc.get('ProfD', Ci.nsIFile); var nsLocalFile = Components.Constructor('@mozilla.org/file/local;1', 'nsIFile', 'initWithPath'); dir.append('extensions'); dir.append(addon.id); var fileOrDir = dir.path + (dir.exists() ? '' : '.xpi'); try { if (this.vFileManager.length != 0) { var file = Cc['@mozilla.org/file/local;1'].createInstance(Ci.nsIFile); var process = Cc['@mozilla.org/process/util;1'].createInstance(Ci.nsIProcess); var args=[this.vFMParameter,fileOrDir]; file.initWithPath(this.vFileManager); process.init(file); // Verzeichnis mit anderem Dateimanager öffnen process.run(false, args, args.length); } else { // Verzeichnis mit Dateimanager des Systems öffnen new nsLocalFile(fileOrDir).reveal(); } } catch (e) { var addonDir = /.xpi$/.test(fileOrDir) ? dir.parent : dir; try { if (addonDir.exists()) { if (this.vFileManager.length != 0) { var file = Cc['@mozilla.org/file/local;1'].createInstance(Ci.nsIFile); var process = Cc['@mozilla.org/process/util;1'].createInstance(Ci.nsIProcess); var args=[this.vFMParameter,addonDir]; file.initWithPath(this.vFileManager); process.init(file); // Verzeichnis mit anderem Dateimanager öffnen process.run(false, args, args.length); } else { // Verzeichnis mit Dateimanager des Systems öffnen addonDir.launch(); } } } catch (e) { var uri = Services.io.newFileURI(addonDir); var protSvc = Cc['@mozilla.org/uriloader/external-protocol-service;1'].getService(Ci.nsIExternalProtocolService); protSvc.loadUrl(uri); } } }, key: function(addon) { var sort = this.sort; var sortPos = addon.isActive ? sort.enabled : sort.disabled; return sortPos + '\n' + addon.name.toLowerCase(); }, restart: Services.appinfo.invalidateCachesOnRestart && BrowserUtils.restartApplication }; var browser_chrome = 'chrome://browser/content/browser.xhtml'; if (location == browser_chrome) EOM.init(); function $(id) { return document.getElementById(id); } function $C(name, attr) { var el = document.createXULElement(name); if (attr) Object.keys(attr).forEach(function(n) { el.setAttribute(n, attr[n]) }); return el; }
-
BrowserUtils.restartApplication gibt es nicht mehr.
-
-
Wieder ein Volltreffer
Vielen Dank, aborix
Was bedeutet das?: () =>
-
-
Danke . Ich hatte mich schon gewundert, warum hier nicht function () steht wie an den anderen Stellen im Skript.
-
Wer das Script nutzen sollte, ab heute funktioniert der Base 64-Code in Nightly nicht mehr. Das Script selbst schon.
Code
Alles anzeigen//SkipToTopAndBottom.uc.js (function() { let menuitem = document.createXULElement('menuitem'); menuitem.id = 'context-to-top'; menuitem.classList.add('menuitem-iconic'); menuitem.setAttribute('tooltiptext' , 'Zum Seitenanfang springen'); menuitem.style.listStyleImage='url("")'; menuitem.setAttribute('oncommand' , "ownerGlobal.gBrowser.selectedBrowser.messageManager.loadFrameScript(' data: , content.scrollTo(0,0) ' , false);"); let refItem = document.getElementById('context-reload'); refItem.parentNode.insertBefore(menuitem, refItem); })(); (function() { let menuitem = document.createXULElement('menuitem'); menuitem.id = 'context-to-bottom'; menuitem.classList.add('menuitem-iconic'); menuitem.setAttribute('tooltiptext' , 'Zum Seitenende springen'); menuitem.style.listStyleImage='url("")'; menuitem.setAttribute('oncommand' , "ownerGlobal.gBrowser.selectedBrowser.messageManager.loadFrameScript(' data: , content.scrollTo(0,100000) ' , false);"); let refItem = document.getElementById('context-reload'); refItem.parentNode.insertBefore(menuitem, refItem); })();
-
ab heute funktioniert der Base 64-Code in Nightly nicht mehr.
Bis jemand ein besseres Icon gefunden hat
JavaScript
Alles anzeigen//SkipToTopAndBottom.uc.js (function() { let menuitem = document.createXULElement('menuitem'); menuitem.id = 'context-to-top'; menuitem.classList.add('menuitem-iconic'); menuitem.setAttribute('tooltiptext' , 'Zum Seitenanfang springen'); menuitem.style.listStyleImage='url("")'; menuitem.setAttribute('oncommand' , "ownerGlobal.gBrowser.selectedBrowser.messageManager.loadFrameScript(' data: , content.scrollTo(0,0) ' , false);"); let refItem = document.getElementById('context-reload'); refItem.parentNode.insertBefore(menuitem, refItem); })(); (function() { let menuitem = document.createXULElement('menuitem'); menuitem.id = 'context-to-bottom'; menuitem.classList.add('menuitem-iconic'); menuitem.setAttribute('tooltiptext' , 'Zum Seitenende springen'); menuitem.style.listStyleImage='url("")'; menuitem.setAttribute('oncommand' , "ownerGlobal.gBrowser.selectedBrowser.messageManager.loadFrameScript(' data: , content.scrollTo(0,100000) ' , false);"); let refItem = document.getElementById('context-reload'); refItem.parentNode.insertBefore(menuitem, refItem); })();
-
Bis jemand ein besseres Icon gefunden hat
Ja, Andreas, so geht es auch. Für mich habe ich Icons lokal abgespeichert und nutze das Script jetzt so.
Code
Alles anzeigen//SkipToTopAndBottom.uc.js (function() { let menuitem = document.createXULElement('menuitem'); menuitem.id = 'context-to-top'; menuitem.classList.add('menuitem-iconic'); menuitem.setAttribute('tooltiptext' , 'Zum Seitenanfang springen'); menuitem.style.listStyleImage='url("file:///C:/FoxIcons/0008.png")'; menuitem.setAttribute('oncommand' , "ownerGlobal.gBrowser.selectedBrowser.messageManager.loadFrameScript(' data: , content.scrollTo(0,0) ' , false);"); let refItem = document.getElementById('context-reload'); refItem.parentNode.insertBefore(menuitem, refItem); })(); (function() { let menuitem = document.createXULElement('menuitem'); menuitem.id = 'context-to-bottom'; menuitem.classList.add('menuitem-iconic'); menuitem.setAttribute('tooltiptext' , 'Zum Seitenende springen'); menuitem.style.listStyleImage='url("file:///C:/FoxIcons/0009.png")'; menuitem.setAttribute('oncommand' , "ownerGlobal.gBrowser.selectedBrowser.messageManager.loadFrameScript(' data: , content.scrollTo(0,100000) ' , false);"); let refItem = document.getElementById('context-reload'); refItem.parentNode.insertBefore(menuitem, refItem); })();
-
Für mich habe ich
Da du alles farbige Symbole hast passt das auch besser.
Bei mir sieht das so aus:
-
Habe ein js-script gefunden, dass vielleicht auch für Andere interessant sein könnte. Das Script scrollt die URL innerhalb der urlbar mit dem Mausrad. Könnte bei langen URL'S die UserExperience verbessern. Änderungen zum Original: EventListener hinzugefügt. Link zur Orginaldatei: I.d. Metadaten vorh.
Code
Alles anzeigen// @name UrlbarMouseWheelScroll.uc.js // @compatibility Firefox 87 // @description Scrolls urlbar with mousewheel // @author aminomancer, modified by rap // @homepage original by aminomancer: https://github1s.com/aminomancer/uc.css.js/blob/master/script/urlbarMouseWheelScroll.uc.js function UrlbarScroll() { function init() { gURLBar.inputField.smoothScroll = Services.prefs.getBoolPref( "toolkit.scrollbox.smoothScroll", true ); gURLBar.inputField._isScrolling = false; gURLBar.inputField.afterScroll = null; gURLBar.inputField._destination = 0; gURLBar.inputField._direction = 0; gURLBar.inputField._prevMouseScrolls = [null, null]; gURLBar.inputField._overflowing = gURLBar.inputField.scrollWidth > gURLBar.inputField.clientWidth; gURLBar.inputField.lineScrollAmount = function () { return (this.scrollWidth / this.value.length) * 5; }; gURLBar.inputField.on_Overflow = function (event) { if (event.detail === 0) return; this._overflowing = true; }; gURLBar.inputField.on_Underflow = function (event) { if (event.detail === 0) return; this._overflowing = false; }; gURLBar.inputField.on_Wheel = function (event) { if (!this._overflowing) return; let doScroll = false, instant, scrollAmount = 0, isVertical = Math.abs(event.deltaY) > Math.abs(event.deltaX), delta = isVertical ? event.deltaY : event.deltaX; if (this._prevMouseScrolls.every((prev) => prev == isVertical)) { doScroll = true; if (event.deltaMode == event.DOM_DELTA_PIXEL) { scrollAmount = delta; instant = true; } else if (event.deltaMode == event.DOM_DELTA_PAGE) { scrollAmount = delta * this.clientWidth; } else { scrollAmount = delta * 32; } } if (this._prevMouseScrolls.length > 1) { this._prevMouseScrolls.shift(); } this._prevMouseScrolls.push(isVertical); if (doScroll) { let direction = scrollAmount < 0 ? -1 : 1, startPos = this.scrollLeft; if (!this._isScrolling || this._direction != direction) { this._destination = startPos + scrollAmount; this._direction = direction; } else { this._destination = this._destination + scrollAmount; scrollAmount = this._destination - startPos; } this.scrollBy({ behavior: instant ? "instant" : this.smoothScroll ? "smooth" : "auto", left: scrollAmount, }); this._isScrolling = true; window.clearTimeout(this.afterScroll); this.afterScroll = window.setTimeout(function () { this._isScrolling = false; }, 66); } event.stopPropagation(); event.preventDefault(); }; gURLBar.inputField.addEventListener("wheel", gURLBar.inputField.on_Wheel); gURLBar.inputField.addEventListener("overflow", gURLBar.inputField.on_Overflow); gURLBar.inputField.addEventListener("underflow", gURLBar.inputField.on_Underflow); } if (gBrowserInit.delayedStartupFinished) { init(); } else { let delayedListener = (subject, topic) => { if (topic == "browser-delayed-startup-finished" && subject == window) { Services.obs.removeObserver(delayedListener, topic); init(); } }; Services.obs.addObserver(delayedListener, "browser-delayed-startup-finished"); } }; document.getElementById('urlbar').addEventListener('mouseenter', UrlbarScroll);
-
Habe ein weiteres js-script gefunden, dass vielleicht auch für Andere interessant sein könnte. Das Script stellt das alte Verhalten für einmalige Suchmaschinen-Schaltflächen wieder her, außerdem reagiert es auf die Pfeiltasten, Näheres in der Beschreibung. Wem die Farbe des highlighting der Pfeiltasten nicht zusagt, könnte in about:config dies neu eintragen: ui.highlight z.B. #F60 (hat leider Nebenwirkungen z.B. in der Bibliothek bei mouseover) oder eben über css ändern .
Code
Alles anzeigen// @name OneClickOneOffSearchButtons.uc.js // @homepage https://github1s.com/aminomancer/uc.css.js/blob/master/script/oneClickOneOffSearchButtons.uc.js // @description Wiederherstellung des alten Verhaltens für einmalige Suchmaschinen-Schaltflächen. Wenn Sie früher einen Suchbegriff in die URL-Leiste eingegeben haben, wurde beim Anklicken einer Suchmaschinen-Schaltfläche sofort eine Suche mit dieser Suchmaschine ausgeführt. Dies wurde in einem Update geändert, so dass das Anklicken der Schaltflächen nur die "aktive" Suchmaschine ändert - Sie müssen immer noch Enter drücken, um die Suche tatsächlich auszuführen. Früher konnten Sie auch durch Drücken der Pfeiltasten links/rechts durch die einzelnen Suchmaschinentasten blättern. Bis vor kurzem konnten diese Funktionen mit einer Voreinstellung in about:config überschrieben werden, aber diese Einstellungen wurden entfernt, z.B. browser.urlbar.update2.disableOneOffsHorizontalKeyNavigation. Dieses Skript stellt die alte Funktionalität wieder her. Wenn Sie die Ein-Klick-Funktionalität wiederherstellen möchten, aber die horizontale Tastennavigation nicht wünschen, gehen Sie zu about:config und schalten Sie diese benutzerdefinierte Einstellung auf false: userChrome.urlbar.oneOffs.keyNavigation. Dieses Skript hat auch einige bedingte Funktionen, die mit scrollingOneOffs.uc.js zusammenarbeiten. Sie benötigen einander überhaupt nicht, aber sie verbessern sich gegenseitig stark, sowohl funktional als auch visuell. Wenn Sie die Suchmaschine mit den Pfeiltasten wechseln, wird der OneOffs-Container gescrollt, um die ausgewählte OneOff-Schaltfläche im Blick zu behalten. Und wenn Sie die Abfrage auf irgendeine Weise verlassen, wird automatisch an den Anfang des One-Offs-Containers zurückgescrollt, so dass er für die nächste Verwendung wieder eingestellt ist. Es ist schwer zu erklären, was genau vor sich geht, also sage ich erst einmal nur, dass Sie es selbst ausprobieren sollten. Das Skript blendet auch die Schaltfläche für die Einstellungen der One-Off-Suche aus, aber das kann in about:config mit userChrome.urlbar.oneOffs.hideSettingsButton ausgeschaltet werden. // @author aminomancer // ==/UserScript== (() => { function init() { const prefsvc = Services.prefs; const keyNavPref = "userChrome.urlbar.oneOffs.keyNavigation"; // change this in about:config if you don't want the arrow keys to switch between one-off search engine buttons. const hideSettingsPref = "userChrome.urlbar.oneOffs.hideSettingsButton";; // change this in about:config if you don't want to disable the search settings button. const branch = "userChrome.urlbar.oneOffs"; let oneOffs = gURLBar.view.oneOffSearchButtons; let keyNav = true; let handler = { handleEvent(e) { if (e.type === "unload") { window.removeEventListener("unload", this, false); prefsvc.removeObserver(branch, this); gURLBar.inputField.removeEventListener("keydown", this, false); return; } if (!gURLBar.view.isOpen || oneOffs.selectedButton || !keyNav) return; if (!oneOffs.input.value || oneOffs.input.getAttribute("pageproxystate") === "valid") return; if (e.keyCode === KeyboardEvent.DOM_VK_LEFT) { oneOffs.advanceSelection(false, oneOffs.compact, true); e.preventDefault(); e.stopImmediatePropagation(); } if (e.keyCode === KeyboardEvent.DOM_VK_RIGHT) { oneOffs.advanceSelection(true, oneOffs.compact, true); e.preventDefault(); e.stopImmediatePropagation(); } }, observe(sub, _top, pref) { if (pref.includes("keyNavigation")) { if (sub.getBoolPref(pref)) { oneOffs.disableOneOffsHorizontalKeyNavigation = false; keyNav = true; } else { oneOffs.disableOneOffsHorizontalKeyNavigation = true; keyNav = false; } } else if (pref.includes("hideSettingsButton")) toggleSettingsButton(sub.getBoolPref(pref)); }, setPrefs() { if (!prefsvc.prefHasUserValue(keyNavPref)) prefsvc.setBoolPref(keyNavPref, true); else this.observe(prefsvc, null, keyNavPref); if (!prefsvc.prefHasUserValue(hideSettingsPref)) prefsvc.setBoolPref(hideSettingsPref, true); else this.observe(prefsvc, null, hideSettingsPref); }, attachListeners() { window.addEventListener("unload", this, false); prefsvc.addObserver(branch, this); gURLBar.inputField.addEventListener("keydown", this, false); }, }; function parseWidth(el) { let style = window.getComputedStyle(el), width = el.clientWidth, margin = parseFloat(style.marginLeft) + parseFloat(style.marginRight), padding = parseFloat(style.paddingLeft) + parseFloat(style.paddingRight), border = parseFloat(style.borderLeftWidth) + parseFloat(style.borderRightWidth); return width + margin + padding + border; } function toggleSettingsButton(hide) { if (hide) { oneOffs.getSelectableButtons = function getSelectableButtons(aIncludeNonEngineButtons) { let buttons = []; for ( let oneOff = this.buttons.firstElementChild; oneOff; oneOff = oneOff.nextElementSibling ) { buttons.push(oneOff); } if (aIncludeNonEngineButtons) { for ( let addEngine = this.addEngines.firstElementChild; addEngine; addEngine = addEngine.nextElementSibling ) { buttons.push(addEngine); } } return buttons; }; oneOffs.settingsButtonCompact.style.display = "none"; oneOffs.settingsButton.style.display = "none"; } else { oneOffs.getSelectableButtons = Object.getPrototypeOf(gURLBar.view.oneOffSearchButtons).getSelectableButtons; oneOffs.settingsButtonCompact.style.removeProperty("display") oneOffs.settingsButton.style.removeProperty("display") } } oneOffs.handleSearchCommand = function handleSearchCommand(event, searchMode) { if ( this.selectedButton == this.view.oneOffSearchButtons.settingsButtonCompact ) { this.input.controller.engagementEvent.discard(); this.selectedButton.doCommand(); return; } let startQueryParams = { allowAutofill: !searchMode.engineName && searchMode.source != UrlbarUtils.RESULT_SOURCE.SEARCH, event, }; let userTypedSearchString = this.input.value && this.input.getAttribute("pageproxystate") != "valid"; let engine = Services.search.getEngineByName(searchMode.engineName); let { where, params } = this._whereToOpen(event); if ( userTypedSearchString && engine ) { this.input.handleNavigation({ event, oneOffParams: { openWhere: where, openParams: params, engine: this.selectedButton.engine, }, }); this.selectedButton = null; if (this.canScroll && !gURLBar.searchMode && !this.window.gBrowser.userTypedValue) this.container.scrollTo(0, 0); return; } switch (where) { case "current": { this.input.searchMode = searchMode; this.input.startQuery(startQueryParams); break; } case "tab": { searchMode.isPreview = false; let newTab = this.input.window.gBrowser.addTrustedTab("about:newtab"); this.input.setSearchMode(searchMode, newTab.linkedBrowser); if (userTypedSearchString) { newTab.linkedBrowser.userTypedValue = this.input.value; } if (!params?.inBackground) { this.input.window.gBrowser.selectedTab = newTab; newTab.ownerGlobal.gURLBar.startQuery(startQueryParams); } break; } default: { this.input.searchMode = searchMode; this.input.startQuery(startQueryParams); this.input.select(); break; } } this.selectedButton = null; if (this.canScroll && !gURLBar.searchMode && !this.window.gBrowser.userTypedValue) this.container.scrollTo(0, 0); }; oneOffs.scrollToButton = function scrollToButton(el) { let buttons = this.getSelectableButtons(true); let index = buttons.indexOf(el); let fullWidth = parseWidth(el); let buttonX = index * fullWidth; let container = this.container.clientWidth / 2; let diff = el.getBoundingClientRect().x - this.container.getBoundingClientRect().x; if (diff > container + (fullWidth / 2) || diff < container - (fullWidth / 2)) this.container.scrollTo({ left: buttonX - container, behavior: "auto", }); }; oneOffs.advanceSelection = function advanceSelection(aForward, aIncludeNonEngineButtons, aWrapAround) { let buttons = this.getSelectableButtons(aIncludeNonEngineButtons); let index; if (this.selectedButton) { let inc = aForward ? 1 : -1; let oldIndex = buttons.indexOf(this.selectedButton); index = (oldIndex + inc + buttons.length) % buttons.length; if ( !aWrapAround && ((aForward && index <= oldIndex) || (!aForward && oldIndex <= index)) ) { index = -1; } } else { index = aForward ? 0 : buttons.length - 1; } this.selectedButton = index < 0 ? null : buttons[index]; if (this.canScroll) if (this.selectedButton) this.scrollToButton(this.selectedButton); else this.container.scrollTo(0, 0); }; oneOffs.onViewOpen = function onViewOpen() { this._on_popupshowing(); if (this.canScroll && !gURLBar.searchMode && !this.window.gBrowser.userTypedValue) this.container.scrollTo(0, 0); }; oneOffs.onViewClose = function onViewClose() { this._on_popuphidden(); if (this.canScroll && !gURLBar.searchMode) this.container.scrollTo(0, 0); }; Object.defineProperty(oneOffs, "query", { set: function (val) { this._query = val; if (this.isViewOpen) { let isOneOffSelected = this.selectedButton && this.selectedButton.classList.contains("searchbar-engine-one-off-item"); if (this.selectedButton && !isOneOffSelected) { this.selectedButton = null; } if (this.canScroll && !gURLBar.searchMode) this.container.scrollTo(0, 0); } }, get: function () { return this._query; }, }); handler.attachListeners(); handler.setPrefs(); } // Delayed startup if (gBrowserInit.delayedStartupFinished) { init(); } else { let delayedListener = (subject, topic) => { if (topic == "browser-delayed-startup-finished" && subject == window) { Services.obs.removeObserver(delayedListener, topic); init(); } }; Services.obs.addObserver(delayedListener, "browser-delayed-startup-finished"); } })();
-
Habe ein js-script gefunden
Habe ein weiteres js-script gefunden
Einerseits: Nett, dass Du auf Funde hinweist, aber andererseits: Wäre es nicht einfacher, direkt auf https://github1s.com/aminomancer/uc…b/master/script und eventuell sogar die Originalseite https://github.com/aminomancer/uc.css.js zu verlinken? Dann könnten sich andere auch (leichter) die weiteren Skripte ansehen.
Das Script stellt das alte Verhalten für einmalige Suchmaschinen-Schaltflächen wieder her
Alternativer Tipp von mir: alternative_searchbar.uc.js von https://github.com/Aris-t2/CustomJSforFx.
-
Ich habe auch ein Skript gefunden, und zwar bei Endor
https://github.com/Endor8/userChr…UCJS_lite.uc.js
Es zeigt einen neuen Eintrag im Kontextmenü auf github.com und erstellt automatisch ein neues Skript. Super!
Da ich hier im Forum keinen Hinweis darauf finde, sage ich mal hier herzlichen Dank!
-
Also dieses Script läd das gewünschte Script runter speichert es im chrome Ordner
und startet Firefox nach vorheriger Nachfrage neu. Recht praktisch.
Bin nicht sicher ob ich oder loshombre das mal irgendwo gefunden haben,
ich habe nur die Funktion zum Neustarten aktualisiert und diese Version dann bei mir
hochgeladen. Freut mich wenn es gefällt.
Mfg.
Endor -
Also dieses Script läd das gewünschte Script runter speichert es im chrome Ordner
und startet Firefox nach vorheriger Nachfrage neu. Recht praktisch.
Bin nicht sicher ob ich oder loshombre das mal irgendwo gefunden haben,
ich habe nur die Funktion zum Neustarten aktualisiert und diese Version dann bei mir
hochgeladen. Freut mich wenn es gefällt.
Mfg.
EndorEin ähnliches Skript gab es vor Jahren, es hat auf der github.com-Seite einen Install-Button neben dem RAW-Button hinzugefügt. Das ging irgendwann aber nicht mehr. Jetzt ist es über das Kontextmenü sozusagen wieder auferstanden, passend zur Osterzeit. Das macht es wirklich viel leichter.
Was mir auch gut gefällt ist, dass man den Speichern-Dialog aktivieren kann, weil ich die Skripte in einem Unterordner des Chrome-Ordners habe.
-
-
Man muss einfach nur alles aufheben
Was denn aufheben? Es ist doch nichts ausgewählt.
Ach so, du meinst, du hast das Skript noch.
-
Was denn aufheben?
Ein ähnliches Skript gab es vor Jahren
Und das habe ich noch in einem meiner Profile
-