1. Nachrichten
  2. Forum
    1. Unerledigte Themen
    2. Forenregeln
  3. Spenden
  • Anmelden
  • Registrieren
  • Suche
Alles
  • Alles
  • Artikel
  • Seiten
  • Forum
  • Erweiterte Suche
  1. camp-firefox.de
  2. Endor

Beiträge von Endor

  • Div. Skripte funktionieren im aktuellem Nightly nicht mehr

    • Endor
    • 23. Januar 2025 um 13:57

    milupo
    Deine Version aus #468 funktioniert hier überhaupt nicht.
    Komisch.
    Mfg.
    Endor

  • Div. Skripte funktionieren im aktuellem Nightly nicht mehr

    • Endor
    • 23. Januar 2025 um 11:43
    Zitat von milupo

    Funktioniert bei mir nicht.

    Heißt das die Version von Github funktioniert bei Dir nicht?
    Teste mal diese Version ob die geht:

    JavaScript
    // ==UserScript==
    // @name       Firefox_ToolBarButtons.uc.js
    // @charset    UTF-8
    // Date        2025/01/20 Firefox 135+ Anpassung und Fehlerbehebung 
    // Date		   2024/06/11 Firefox 127.0 Cyber-UI-Umschaltname wurde von SidebarUI in SidebarController geändert.
    // Date		   2020/04/29 Firefox Nightly 77.0a1 Gespeicherte Zugangsdaten(chrome://passwordmgr/content/passwordManager.xhtml) Schaltfläche zum 
    // Date        öffnen der gespeicherten Zugangsdaten hinzugefügt (about:logins).
    // Date        2019‎/12/15 Firefox Nightly 73.0a1 xul in .xhtml umgeschrieben. Vor der Konvertierung von Label- und Tooltip-Text, die in Unicode
    // Note        konvertiert wurden, habe ich in jeden Button geschrieben. Der Cookie-Manager (für Firefox60ESR) wurde entfernt, da Firefox60ESR
    // Note        nicht mehr unterstützt wird.
    // Date        2019‎/06/12 Firefox Nightly 69.0a1 document.createXULElement('toolbarbutton'); → aDocument.createXULElement('toolbarbutton'); gändert.
    // Date        2019‎/05/26 Firefox Nightly 69.0a1 createElement → createXULElement geändert.
    // Date        2019‎/02/25 Ich hatte vergessen, die beiden IDs der Seiteninformationsschaltfläche auf dieselbe ID zu setzen, ist nun behoben.
    // Date        2019‎/02/20 Der Fokus der Schaltfläche zum Verschieben von Tabs wird durch Scrollen mit dem Rad nach links und rechts verschoben. 
    // Date        2019‎/02/20 Die Zoom-Steuertasten werden jetzt durch Scrollen mit dem Rad skaliert. Es wurden eine Schaltfläche für Entwicklerwerkzeuge,
    // Date        2019‎/02/20 sowie eine Schaltfläche zum Verwalten von Cookies und Standortdaten hinzugefügt. Diverse andere Änderungen.
    // Date        2019‎/02/04 Cookie-Anzeige versuchte, Entwicklerwerkzeuge anzuzeigen
    // Date        2019‎/02/02 Korrektur der doppelten ID der Cookie-Anzeige
    // Date        2018‎/07/10 Weitere Schaltflächen hinzugefügt。
    // Date        2018‎/05/03 Es wurde eine Schaltfläche zum Verschieben des aktiven Tabs hinzugefügt. Nützlich zum Verschieben von Tabs in CSS-Multi-Tabs? 
    // Date        2018‎/05/03 Tabs können auch mit der Tastenkombination (Strg + Umschalt + Bild auf / Bild ab) verschoben werden.
    // Date        2018‎/04/04 Skalierungsschaltflächen hinzugefügt.
    // Date        2018‎/02/05 Das Script wurde bei Endor8 auf GitHub hochgeladen, ich habe es ins Japanische übersetzt.
    // Date        2018/01/16 2017/11/09 Die Schaltflächen wurden gruppiert. Bei der ersten Installation wird, nur die Neustarten Schaltfläche
    // Date        2018/01/16 2017/11/09 in der Symbolleiste eingefügt. Alle weitern müssen über den Anpassen Dialog hinzugefügt werden.
    // Date        2017/11/23 Schaltfläche zum Öffnen und Schließen der Seitenleiste, der Untermenüs "Lesezeichen", "Chronik" und "Synchronisieren" 
    // Date        2017/11/23 hinzugefügt, damit sie separat implementiert werden können.
    // Date        2017/11/09 Basierend auf "RestartFirefoxButton_Movable.uc.js" habe ich eine Schaltfläche für "Neustarten + about" festgelegt: 
    // Date        2017/11/09 "about:config", "Profilordner", "Cookies-Verwaltung" öffnen.
    // @note    
    // @note    Bei der Erstinstallation wird nur die Schaltfläche zum Neustarten in der Symbolleiste angezeigt.
    // @note    Die anderen Schaltflächen werden im Anpassen Fenster gespeichert.
    // @note    Die Schaltflächen können frei, platziert werden.
    // @note    
    // @note    Beschreibung und Tooltiptext sind je nach Umgebung unleserlich und werden daher in Unicode konvertiert.
    // @note    
    // @note    Firefox Neustarten
    // @note    about:config öffnen
    // @note    Neuer Tab öffnen
    // @note    Profilordner öffnen
    // @note    Lesezeichen-Seitenleiste öffnen
    // @note    Chronik-Seitenleiste öffnen
    // @note    Synchronisierte Tabs-Seitenleiste öffnen
    // @note    Bibliothek "Downloads" öffnen
    // @note    Tab "Aktualisieren" (gespeicherten Cache ignorieren)
    // @note    Weitere:
    // @note    about:plugins öffnen
    // @note    Bibliothek "Lesezeichen" öffnen
    // @note    Chromeordner öffnen
    // @note    Seiteninformationen anzeigen
    // @note    Zertifikate Verwaltung öffnen
    // @note    Gespeicherte Zugangsdaten öffnen
    // @note    Chronik löschen
    // @note    Zoom vergrößern  (Strg + +)
    // @note    Zoom verkleinern (Strg + -)
    // @note    Tab bewegen (Links: Tab nach links bewegen | Rechts: Tab nach rechts bewegen | Rad ↑: Tab nach links bewegen | Rad ↓: Tab nach rechts bewegen)
    // @note    Zoomsteuerung (Links oder Rad ↑: Vergrößern | Mitte: Zurücksetzen | Rechts oder Rad ↓: Verkleinern)
    // @note    Entwickler Werkzeuge öffnen
    // @note    Cookies und Websitedaten verwalten (Cookies und Websitedaten werden anscheinend erst nach einmaligem Öffnen der Firefox-Option angezeigt.)
    // @note    Benutzerdefinierte Schaltfläche (Linksklick oder mit dem Rad ↑ ↓: Neuen Tab | Mittelklick: About: Config | Rechtsklick: Chrome-Ordner) öffnen
    																																
    // @note    
    // @note    Firefox Nightly 73.0a1 kompatibel
    // @note    http://wiki.nothing.sh/page?userChrome.js%CD%D1%A5%B9%A5%AF%A5%EA%A5%D7%A5%C8#r7140ba6
    // @note    "Verwendung des userChrome.js Scripts auch nach 72, wenn die XBL-Bindung deaktiviert ist".
    // @note    
    // @note    Bei Verwendung des Script in Firefox 68 oder niedriger, muss aDocument.createXULElement ⇒ zu document.createElement geändert werden.
    																																									
    // @note    
    // @note    Bei Verwendung des Script in Firefox 72 oder niedriger, muss die Endung xhtml ⇒ zu xul geändert werden.
    // ==/UserScript==
    "use strict";
    (function() {
    
        if (location != "chrome://browser/content/browser.xhtml") return;
    
        try {
    
    //     Neustart
    //     Unicode-Konvertierung → label: 'Neustart, tooltiptext: 'Linksklick: Neustart, Mittel- und Rechtsklick: Neustart und Leeren des Skript-Caches',
            CustomizableUI.createWidget({
                id: 'restart-ToolBarButton',
                type: 'custom',
                defaultArea: CustomizableUI.AREA_NAVBAR,
                onBuild: function(aDocument) {
                    let toolbaritem = aDocument.createXULElement('toolbarbutton');
                    let props = {
                        id: 'restart-ToolBarButton',
                        class: 'toolbarbutton-1 chromeclass-toolbar-additional',
                        label: 'Firefox-Neustart',
                        tooltiptext: 'Linksklick: Neustart, Mittel- und Rechtsklick: Neustart und Leeren des Skript-Caches',
                        style: 'list-style-image: url("")',
                    };
                    for (let p in props)
                        toolbaritem.setAttribute(p, props[p]);
    					toolbaritem.addEventListener('click', event => {
    					if (event.button == 0) { 
    						Services.startup.quit(Ci.nsIAppStartup.eRestart | Ci.nsIAppStartup.eAttemptQuit); 
    					}; 
    					if (event.button == 1) { 
    					    Services.appinfo.invalidateCachesOnRestart(); 
    					    Services.startup.quit(Ci.nsIAppStartup.eRestart | Ci.nsIAppStartup.eAttemptQuit);
    					};
    				});
                    return toolbaritem;
                }
            });
    //      about:config
    //     Unicode-Konvertierung  → tooltiptext: 'About:Config anzeigen',
            CustomizableUI.createWidget({
                id: 'aboutconfig-ToolBarButton',
                type: 'custom',
                onBuild: function(aDocument) {
                    let toolbaritem = aDocument.createXULElement('toolbarbutton');
                    let props = {
                        id: 'aboutconfig-ToolBarButton',
                        class: 'toolbarbutton-1 chromeclass-toolbar-additional',
                        label: 'About:Config',
                        tooltiptext: 'About:Config öffnen',
                        style: 'list-style-image: url()',
                    };
                    for (let p in props)
                        toolbaritem.setAttribute(p, props[p]);
    					toolbaritem.addEventListener('click', event => {
    					if (event.button == 0) { 
                                openTrustedLinkIn("about:config", "tab");
                                     }
    				});
                    return toolbaritem;
                }
            });
    //      Neuer Tab
    //      Unicode-Konvertierung  → label: 'Neuer Tab', tooltiptext: 'Neuen Tab öffnen',
            CustomizableUI.createWidget({
                id: 'newtab-ToolBarButton',
                type: 'custom',
                onBuild: function(aDocument) {
                    let toolbaritem = aDocument.createXULElement('toolbarbutton');
                    let props = {
                        id: 'newtab-ToolBarButton',
                        class: 'toolbarbutton-1 chromeclass-toolbar-additional',
                        label: 'Neuer Tab',
                        tooltiptext: 'Neuen Tab öffnen',
                        style: 'list-style-image: url()',
                    };
                    for (let p in props)
                        toolbaritem.setAttribute(p, props[p]);
    					toolbaritem.addEventListener('click', event => {
    					if (event.button == 0) { 
                                openTrustedLinkIn("about:newtab", "tabshifted");
                                     }
    				});
                    return toolbaritem;
                }
            });
    //      Profilordner
    //      Unicode-Konvertierung  → label: 'Profilordner', tooltiptext: 'Profilordner öffnen',
            CustomizableUI.createWidget({
                id: 'profilefolder-ToolBarButton',
                type: 'custom',
                onBuild: function(aDocument) {
                    let toolbaritem = aDocument.createXULElement('toolbarbutton');
                    let props = {
                        id: 'profilefolder-ToolBarButton',
                        class: 'toolbarbutton-1 chromeclass-toolbar-additional',
                        label: 'Profilordner',
                        tooltiptext: 'Profilordner öffnen',
                        style: 'list-style-image: url()',
                    };
                    for (let p in props)
                        toolbaritem.setAttribute(p, props[p]);
    					toolbaritem.addEventListener('click', event => {
    					if (event.button == 0) { 
                                Services.dirsvc.get("ProfD", Ci.nsIFile).launch();
                                     }
    				});								 
                    return toolbaritem;
                }
            });
    //      Lesezeichen-Sidebar
    //      Unicode-Konvertierung  → label: 'Lesezeichen-Sidebar', tooltiptext: 'Lesezeichen-Sidebar öffnen/schließen',
            CustomizableUI.createWidget({
                id: 'BookmarksSidebar-ToolBarButton',
                type: 'custom',
                onBuild: function(aDocument) {
                    let toolbaritem = aDocument.createXULElement('toolbarbutton');
                    let props = {
                        id: 'BookmarksSidebar-ToolBarButton',
                        class: 'toolbarbutton-1 chromeclass-toolbar-additional',
                        label: 'Lesezeichen-Sidebar',
                        tooltiptext: 'Lesezeichen-Sidebar öffnen/schließen',
                        style: 'list-style-image: url()',
                    };
                    for (let p in props)
                        toolbaritem.setAttribute(p, props[p]);
    					toolbaritem.addEventListener('click', event => {
    					if (event.button == 0) { 
                                SidebarController.toggle("viewBookmarksSidebar");
                        }				
    					});
    					return toolbaritem;
                }
            });
    //      Chronik-Sidebar
    //      Unicode-Konvertierung  → label: 'Chronik-Sidebar', tooltiptext: 'Chronik-sidebar öffnen/schließen',
            CustomizableUI.createWidget({
                id: 'HistorySidebar-ToolBarButton',
                type: 'custom',
                onBuild: function(aDocument) {
                    let toolbaritem = aDocument.createXULElement('toolbarbutton');
                    let props = {
                        id: 'HistorySidebar-ToolBarButton',
                        class: 'toolbarbutton-1 chromeclass-toolbar-additional',
                        label: 'Chronik-Sidebar',
                        tooltiptext: 'Chronik-Sidebar öffnen/schließen',
                        style: 'list-style-image: url()',
                    };
                    for (let p in props)
                        toolbaritem.setAttribute(p, props[p]);
    					toolbaritem.addEventListener('click', event => {
    					if (event.button == 0) { 
                                SidebarController.toggle("viewHistorySidebar");
                        }
                    });								 
                    return toolbaritem;
                }
            });
    //      Sync-Tab-Sidebar
    //      Unicode-Konvertierung  → label: 'Sync-Tab-Sidebar', tooltiptext: 'Sync-Tab-Sidebar öffnen/schließen',
            CustomizableUI.createWidget({
                id: 'viewTabsSidebar-ToolBarButton',
                type: 'custom',
                onBuild: function(aDocument) {
                    let toolbaritem = aDocument.createXULElement('toolbarbutton');
                    let props = {
                        id: 'viewTabsSidebar-ToolBarButton',
                        class: 'toolbarbutton-1 chromeclass-toolbar-additional',
                        label: 'Sync-Tab-Sidebar',
                        tooltiptext: 'Sync-Tab-Sidebar öffnen/schließen',
                        style: 'list-style-image: url()',
                    };
                    for (let p in props)
                        toolbaritem.setAttribute(p, props[p]);
    					toolbaritem.addEventListener('click', event => {
    					if (event.button == 0) { 
                                SidebarController.toggle("viewTabsSidebar");
                                     }
    				});								 
                    return toolbaritem;
                }
            });
    //      Andere Schaltflächen
    //      Downloads im Bibliotheksfenster
    //      Unicode-Konvertierung  → label: 'Downloads im Bibliotheksfenster, tooltiptext: 'Downloads im Bibliotheksfenster öffnen',
            CustomizableUI.createWidget({
                id: 'Download-ToolBarButton',
                type: 'custom',
                onBuild: function(aDocument) {
                    let toolbaritem = aDocument.createXULElement('toolbarbutton');
                    let props = {
                        id: 'Download-ToolBarButton',
                        class: 'toolbarbutton-1 chromeclass-toolbar-additional',
                        label: 'Downloads',
                        accesskey: 'D',
                        tooltiptext: 'Download-Fenster öffnen',
                        style: 'list-style-image: url()',
                    };
                    for (let p in props)
                        toolbaritem.setAttribute(p, props[p]);
    					toolbaritem.addEventListener('click', event => {
    					if (event.button == 0) { 
                                DownloadsPanel.showDownloadsHistory();
                                     }		
    				});								 
                    return toolbaritem;
                }
            });
    //      Lesezeichen im Bibliotheksfenster
    //      Unicode-Konvertierung  → label: 'Lesezeichen im Bibliotheksfenster', tooltiptext: 'Lesezeichen im Bibliotheksfenster öffnen',
            CustomizableUI.createWidget({
                id: 'bookmarks-manager-ToolBarButton',
                type: 'custom',
                onBuild: function(aDocument) {
                    let toolbaritem = aDocument.createXULElement('toolbarbutton');
                    let props = {
                        id: 'bookmarks-manager-ToolBarButton',
                        class: 'toolbarbutton-1 chromeclass-toolbar-additional',
                        label: 'Lesezeichen-Manager',
                        tooltiptext: 'Lesezeichen-Manager öffnen',
                        style: 'list-style-image: url()',
                    };
                    for (let p in props)
                        toolbaritem.setAttribute(p, props[p]);
    					toolbaritem.addEventListener('click', event => {
    					if (event.button == 0) { 
                                PlacesCommandHook.showPlacesOrganizer('AllBookmarks');
                                     }
    				});			 
                    return toolbaritem;
                }
            });
    //      Tab neuladen, ohne Cache zu benutzen
    //      Unicode-Konvertierung → label: 'Tab neu laden', tooltiptext: 'Tab neuladen, ohne Cache zu benutzen',
            CustomizableUI.createWidget({
                id: 'reload-skip-cache-ToolBarButton',
                type: 'custom',
                onBuild: function(aDocument) {
                    let toolbaritem = aDocument.createXULElement('toolbarbutton');
                    let props = {
                        id: 'reload-skip-cache-ToolBarButton',
                        class: 'toolbarbutton-1 chromeclass-toolbar-additional',
                        label: 'Tab neu laden',
                        tooltiptext: 'Tab neu laden, ohne den Browsercache zu benutzen',
                        style: 'list-style-image: url()',
                    };
                    for (let p in props)
                        toolbaritem.setAttribute(p, props[p]);
    					toolbaritem.addEventListener('click', event => {
    					if (event.button == 0) { 
                                BrowserCommands.reloadSkipCache();
                                     }
    			});		 
                    return toolbaritem;
                }
            });
    //      Einstellungen
    //      Unicode-Konvertierung  → label: 'Einstellungen', tooltiptext: 'Einstellungen öffnen',
            CustomizableUI.createWidget({
                id: 'Einstellungen-ToolBarButton',
                type: 'custom',
                onBuild: function(aDocument) {
                    let toolbaritem = aDocument.createXULElement('toolbarbutton');
                    let props = {
                        id: 'Einstellungen-ToolBarButton',
                        class: 'toolbarbutton-1 chromeclass-toolbar-additional',
                        label: 'Einstellungen',
                        tooltiptext: 'Einstellungen öffnen',
                        style: 'list-style-image: url()',
                    };
                    for (let p in props)
                        toolbaritem.setAttribute(p, props[p]);
    					toolbaritem.addEventListener('click', event => {
    					if (event.button == 0) { 
                        openPreferences();
                    }
    			});			 
                    return toolbaritem;
                }
            });
    //      About:About
    //      Unicode-Konvertierung  → label: 'About:About', tooltiptext: 'About:About öffnen',
            CustomizableUI.createWidget({
                id: 'aboutabout-ToolBarButton',
                type: 'custom',
                onBuild: function(aDocument) {
                    let toolbaritem = aDocument.createXULElement('toolbarbutton');
                    let props = {
                        id: 'aboutabout-ToolBarButton',
                        class: 'toolbarbutton-1 chromeclass-toolbar-additional',
                        label: 'About:about',
                        tooltiptext: 'About:About öffnen',
                        style: 'list-style-image: url()',
                    };
                    for (let p in props)
                        toolbaritem.setAttribute(p, props[p]);
    					toolbaritem.addEventListener('click', event => {
    					if (event.button == 0) { 
                                openTrustedLinkIn("about:about", "tab");
                                     }
    			});								 
                    return toolbaritem;
                }
            });
    //      Chrome-Ordner
    //      Unicode-Konvertierung → label: 'Chrome-Ordner', tooltiptext: 'Chrome-Ordner öffnen',
            CustomizableUI.createWidget({
                id: 'Open-Chrome-Folder-ToolBarButton',
                type: 'custom',
                onBuild: function(aDocument) {
                    let toolbaritem = aDocument.createXULElement('toolbarbutton');
                    let props = {
                        id: 'Open-Chrome-Folder-ToolBarButton',
                        class: 'toolbarbutton-1 chromeclass-toolbar-additional',
                        label: 'Chrome-Ordner',
                        tooltiptext: 'Chrome-Ordner öffnen',
                        style: 'list-style-image: url()',
                    };
                    for (let p in props)
                        toolbaritem.setAttribute(p, props[p]);
    					toolbaritem.addEventListener('click', event => {
    					if (event.button == 0) { 
                        Services.dirsvc.get("UChrm", Ci.nsIFile).launch();
                                     }
    				});			 
    				
                    return toolbaritem;
                }
            });
    //      Seiteninformationen
    //      Unicode-Konvertierung  → label: 'Seiteninformationen', tooltiptext: 'Seiteninformationen öffnen',
            CustomizableUI.createWidget({
                id: 'context-viewinfo-ToolBarButton',
                type: 'custom',
                onBuild: function(aDocument) {
                    let toolbaritem = aDocument.createXULElement('toolbarbutton');
                    let props = {
                        id: 'context-viewinfo-ToolBarButton',
                        class: 'toolbarbutton-1 chromeclass-toolbar-additional',
                        label: 'Seiteninformationen',
                        accesskey: 'i',
                        tooltiptext: 'Seiteninformationen anzeigen',
                        style: 'list-style-image: url()',
                    };
                    for (let p in props)
                        toolbaritem.setAttribute(p, props[p]);
    					toolbaritem.addEventListener('click', event => {
    					if (event.button == 0) { 
    					View:PageInfo();
                        }
    				});
                    return toolbaritem;
                }
            });
    //      Zertifikate-Manager
    //      Unicode-Konvertierung → label: 'Zertifikate-Manager', tooltiptext: 'Zertifikate-Manager öffnen',
            CustomizableUI.createWidget({
                id: 'context-viewcert-ToolBarButton',
                type: 'custom',
                onBuild: function(aDocument) {
                    let toolbaritem = aDocument.createXULElement('toolbarbutton');
                    let props = {
                        id: 'context-viewcert-ToolBarButton',
                        class: 'toolbarbutton-1 chromeclass-toolbar-additional',
                        label: 'Zertifikate',
                        tooltiptext: 'Zertifikate anzeigen',
                        style: 'list-style-image: url()',
                    };
                    for (let p in props)
                        toolbaritem.setAttribute(p, props[p]);
    					toolbaritem.addEventListener('click', event => {
    					if (event.button == 0) { 
                        window.open( 'chrome://pippki/content/certManager.xhtml', 'mozilla:certmanager', "chrome,dialog,centerscreen,dependent,resizable=yes,width=700,min-height=760");
                                 }
    				});			 
                    return toolbaritem;
                }
            });
    //      Gespeicherte Zugangsdaten
    //      Unicode-Konvertierung  → label: 'Gespeicherte Zugangsdaten', tooltiptext: 'Gespeicherte Zugangsdaten öffnen',
            CustomizableUI.createWidget({
                id: 'context-viewpassword-ToolBarButton',
                type: 'custom',
                onBuild: function(aDocument) {
                    let toolbaritem = aDocument.createXULElement('toolbarbutton');
                    let props = {
                        id: 'context-viewpassword-ToolBarButton',
                        class: 'toolbarbutton-1 chromeclass-toolbar-additional',
                        label: 'Passwörter',
                        tooltiptext: 'Passwörter anzeigen',
                        style: 'list-style-image: url()',
                    };
                    for (let p in props)
                        toolbaritem.setAttribute(p, props[p]);
    					toolbaritem.addEventListener('click', event => {
    					if (event.button == 0) { 
    					openTrustedLinkIn("about:logins", "tab")
                                     }	
    			});								 
                    return toolbaritem;
                }
            });
    
    //      Verlauf löschen
    //      Vor der Unicode-Konvertierung → Beschriftung: 'Verlauf löschen', Tooltiptext: 'Löschverlauf öffnen',   
            CustomizableUI.createWidget({
                id: 'context-deletehistory-ToolBarButton',
                type: 'custom',
                onBuild: function(aDocument) {
                    let toolbaritem = aDocument.createXULElement('toolbarbutton');
                    let props = {
                        id: 'context-deletehistory-ToolBarButton',
                        class: 'toolbarbutton-1 chromeclass-toolbar-additional',
                        label: 'Chronik löschen',
                        tooltiptext: '"Chronik löschen" anzeigen',
                        style: 'list-style-image: url()',
                    };
                    for (let p in props)
                        toolbaritem.setAttribute(p, props[p]);
    					toolbaritem.addEventListener('click', event => {
    					if (event.button == 0) { 
                        window.open('chrome://browser/content/sanitize.xhtml', 'Toolkit:SanitizeDialog', 'chrome,resizable=yes');
                                     }
    				});	
                    return toolbaritem;
                }
            });
    //      Vergrößern (Strg++)
    //      label: 'Vergrößern (Strg++)', tooltiptext: 'Vergrößern (Strg++)',
            CustomizableUI.createWidget({
                id: 'zoom-in-ToolBarbutton',
                type: 'custom',
                onBuild: function(aDocument) {
                    let toolbaritem = aDocument.createXULElement('toolbarbutton');
                    let props = {
                        id: 'zoom-in-ToolBarbutton',
                        class: 'toolbarbutton-1 chromeclass-toolbar-additional',
                        label: 'Vergrößern (Strg++)',
                        tooltiptext: 'Vergrößern (Strg++)',
                        style: 'list-style-image: url()',
                    };
                    for (let p in props)
                        toolbaritem.setAttribute(p, props[p]);
    					toolbaritem.addEventListener('click', event => {
    					if (event.button == 0) { 
                        FullZoom.enlarge();
                        }				
    					  });
                    return toolbaritem;
                }
            });
    //      Verkleinern (Strg+-)
    //      Unicode-Konvertierung → label: 'Verkleinern (Strg+-)', tooltiptext: 'Verkleinern (Strg+-)',
            CustomizableUI.createWidget({
                id: 'zoom-out-ToolBarbutton',
                type: 'custom',
                onBuild: function(aDocument) {
                    let toolbaritem = aDocument.createXULElement('toolbarbutton');
                    let props = {
                        id: 'zoom-out-ToolBarbutton',
                        class: 'toolbarbutton-1 chromeclass-toolbar-additional',
                        label: 'Verkleinern (Strg+-)',
                        tooltiptext: 'Verkleinern (Strg+-)',
                        style: 'list-style-image: url()',
                    };
                    for (let p in props)
                        toolbaritem.setAttribute(p, props[p]);
    					toolbaritem.addEventListener('click', event => {
    					if (event.button == 0) { 
                        FullZoom.reduce();
                        }				
    					  });
                    return toolbaritem;
                }
            });
    //      Tab verschieben
    //      Unicode-Konvertierung  → label: 'Tab verschieben', tooltiptext: 'Tabs verschieben - Linksklick: Tab nach links, 
    //      Rechtsklick: Tab nach rechts, Rad nach oben: Zum Tab links, Rad nach unten: Zum Tab rechts',
            CustomizableUI.createWidget({
                id: 'moveTab-ToolBarButton1',
                type: 'custom',
                onBuild: function(aDocument) {
                    let toolbaritem = aDocument.createXULElement('toolbarbutton');
                    let props = {
                        id: 'moveTab-ToolBarButton1',
                        class: 'toolbarbutton-1 chromeclass-toolbar-additional',
                        label: 'Tab verschieben',
                        tooltiptext: 'Tabs verschieben - Linksklick: Tab nach links, Rechtsklick: Tab nach rechts, Rad nach oben: Zum Tab links, Rad nach unten: Zum Tab rechts',
                        style: 'list-style-image: url()',
                    };
                    for (let p in props)
                        toolbaritem.setAttribute(p, props[p]);
    					toolbaritem.addEventListener('click', event => {
    						event.preventDefault();
    					    if (event.button == 0) { 
    						gBrowser.moveTabBackward(); 
    					    }; 
    					    if (event.button == 2) { 
    						gBrowser.moveTabForward(); 
    					    }
    					});
    
    					toolbaritem.addEventListener('wheel', event => {
    						event.preventDefault();
    						if (event.deltaY < 0) { 
                            gBrowser.tabContainer.advanceSelectedTab(-1, true); 
                            } else { 
                            gBrowser.tabContainer.advanceSelectedTab(1, true);
                        }
    				});						 
                    return toolbaritem;
                }
            });
    //      Zoom-Steuerung
    //      Unicode-Konvertierung  → label: 'Zoom-Steuerung', tooltiptext: 'Linksklick oder Rad ↑: vergrößern | Mittelklick: zurücksetzen | 
    //      Rechtsklick oder Rad ↓: verkleinern',
            CustomizableUI.createWidget({
                id: 'zoom-control-ToolBarbutton',
                type: 'custom',
                onBuild: function(aDocument) {
                    let toolbaritem = aDocument.createXULElement('toolbarbutton');
                    let props = {
                        id: 'zoom-control-ToolBarbutton',
                        class: 'toolbarbutton-1 chromeclass-toolbar-additional',
                        label: 'Zoom-Steuerung',
                        tooltiptext: 'Linksklick oder Rad ↑: vergrößern | Mittelklick: zurücksetzen | Rechtsklick oder Rad ↓: verkleinern',
                        style: 'list-style-image: url()',
                    };
                    for (let p in props)
                        toolbaritem.setAttribute(p, props[p]);
    					toolbaritem.addEventListener('click', event => {
    						event.preventDefault();
    					if (event.button === 0) { 
    						FullZoom.enlarge(); 
    					} else if (event.button === 1) { 
    						FullZoom.reset(); 
    					} else if (event.button === 2) { 
    						FullZoom.reduce(); 
    					}
    				});
    
    				toolbaritem.addEventListener('wheel', event => {
    					event.preventDefault();
    					if (event.deltaY < 0) { 
    						FullZoom.enlarge(); 
    					} else { 
    						FullZoom.reduce(); 
    					}
    				});
                    return toolbaritem;
                }
            });
    //      Verwaltung der Cookies und Website-Daten anzeigen (die Daten werden allem Anschein nach nur gezeigt, wenn der Dialog einmal geöffnet worden ist)
    //      Unicode-Konvertierung  → label: 'Cookies und Website-Daten verwalten', tooltiptext: 'Verwaltung der Cookies und Website-Daten anzeigen (die Daten 
    //      werden allem Anschein nach nur gezeigt, wenn der Dialog einmal geöffnet worden ist)',
            CustomizableUI.createWidget({
                id: 'siteDataSettings-ToolBarButton',
                type: 'custom',
                onBuild: function(aDocument) {
                    let toolbaritem = aDocument.createXULElement('toolbarbutton');
                    let props = {
                        id: 'siteDataSettings-ToolBarButton',
                        class: 'toolbarbutton-1 chromeclass-toolbar-additional',
                        label: 'Cookies und Website-Daten verwalten',
                        tooltiptext: 'Verwaltung der Cookies und Website-Daten anzeigen (die Daten werden allem Anschein nach nur gezeigt, wenn der Dialog einmal geöffnet worden ist)',
                        style: 'list-style-image: url()',
                    };
                    for (let p in props)
                        toolbaritem.setAttribute(p, props[p]);
    				    toolbaritem.addEventListener('click', event => {
    					if (event.button == 0) { 
    					window.open("chrome://browser/content/preferences/dialogs/siteDataSettings.xhtml","cookie","chrome,dialog,centerscreen,dependent,resizable=yes,width=700,height=560");					
    					}
    				});	
                    return toolbaritem;
                }
            });
    //      Eigene Schaltfläche
    //      Unicode-Konvertierung  → label: 'Eigene Schaltfläche', tooltiptext: 'Linksklick oder Rad ↑ ↓: Neuer Tab | Mittelklick: about: config | 
    //      Rechtsklick: Ordner chrome',
            CustomizableUI.createWidget({
                id: 'three-ToolBarButton',
                type: 'custom',
                onBuild: function(aDocument) {
                    let toolbaritem = aDocument.createXULElement('toolbarbutton');
                    let props = {
                        id: 'three-ToolBarButton',
                        class: 'toolbarbutton-1 chromeclass-toolbar-additional',
                        label: 'Eigener Button',
                        tooltiptext: 'Linksklick oder Rad ↑ ↓: Neuer Tab | Mittelklick: about: config | Rechtsklick: Ordner chrome',
                        style: 'list-style-image: url()',
                    };
                    for (let p in props)
                        toolbaritem.setAttribute(p, props[p]);
    					toolbaritem.addEventListener('click', event => {
    							event.preventDefault();
    							if (event.button === 0) { 
    								openTrustedLinkIn("about:newtab", "tabshifted"); 
                                }; 
                                if (event.button == 1) {
                                    openTrustedLinkIn("about:config", "tab"); 
                                }; 
                                if (event.button == 2) {
                                    Services.dirsvc.get("UChrm", Ci.nsIFile).launch(); 
                                };
    						});
    
    						toolbaritem.addEventListener('wheel', event => {
    							event.preventDefault();
    							if (event.deltaY < 0) { 
                                    openTrustedLinkIn("about:newtab", "tabshifted");
                                  } else { 
                                    openTrustedLinkIn("about:newtab", "tabshifted");
    					          }
    						});			
                    return toolbaritem;
                }
            });
    
        } catch(e){};
    
    })();
    Alles anzeigen

    Die läuft bei mir im aktuellen Nightly einwandfrei.
    Mfg.
    Endor

  • Div. Skripte funktionieren im aktuellem Nightly nicht mehr

    • Endor
    • 22. Januar 2025 um 17:54

    Boersenfeger.
    Ich habe dieses Script Firefox_ToolBarButtons.uc.js am 20.01.2025
    nochmals aktualisiert. Teste bitte diese Version nochmals:

    userChrome.js/Firefox 135/Firefox_ToolBarButtons.uc.js at master · Endor8/userChrome.js
    Skripte für die Firefox-Erweiterung userChromeJS. Contribute to Endor8/userChrome.js development by creating an account on GitHub.
    github.com

    Hier funktionieren alle Schaltflächen.
    Mfg.
    Endor

  • Div. Skripte funktionieren im aktuellem Nightly nicht mehr

    • Endor
    • 21. Januar 2025 um 11:45

    Alle Funktionen funktionieren so wie im Script angegeben.
    Auch in Nightly. Daher müsste es passen.
    Danke für Deine Mühe.
    Mfg.
    Endor

  • Div. Skripte funktionieren im aktuellem Nightly nicht mehr

    • Endor
    • 21. Januar 2025 um 11:37

    Danke Sören Hentzschel

    Ich habe gesehen, dass weiter unten im Code bereits die Zeile:
    event.preventDefault();
    vorhanden ist. Daher habe ich oben den Eintrag entfernt.

    Code:

    Code
    CustomizableUI.createWidget({
                id: 'three-ToolBarButton',
                type: 'custom',
                onBuild: function(aDocument) {
                    let toolbaritem = aDocument.createXULElement('toolbarbutton');
                    let props = {
                        id: 'three-ToolBarButton',
                        class: 'toolbarbutton-1 chromeclass-toolbar-additional',
                        label: 'Eigener Button',
                        tooltiptext: 'Linksklick oder Rad ↑ ↓: Neuer Tab | Mittelklick: about: config | Rechtsklick: Ordner chrome',
                        style: 'list-style-image: url()',
                    };
                    for (let p in props)
                        toolbaritem.setAttribute(p, props[p]);
    					toolbaritem.addEventListener('click', event => {
    							event.preventDefault();
    							if (event.button === 0) { 
    								openTrustedLinkIn("about:newtab", "tabshifted"); 
                                  }; 
                                  if (event.button == 1) {
                                      openTrustedLinkIn("about:config", "tab"); 
                                  }; 
                                  if (event.button == 2) {
                                      Services.dirsvc.get("UChrm", Ci.nsIFile).launch(); 
                                  };
    						});
    
    						toolbaritem.addEventListener('wheel', event => {
    							event.preventDefault();
    							if (event.deltaY < 0) { 
                                      openTrustedLinkIn("about:newtab", "tabshifted");
                                  } else { 
                                      openTrustedLinkIn("about:newtab", "tabshifted");
    					          }
    						});			
                    return toolbaritem;
                }
            });
    
        } catch(e){};
    
    })();
    Alles anzeigen

    funktioniert jedenfalls einwandfrei.
    Müsste dann ja passen, oder?
    Mfg.
    Endor

  • Div. Skripte funktionieren im aktuellem Nightly nicht mehr

    • Endor
    • 21. Januar 2025 um 10:52

    Sören Hentzschel kann ich gerne machen, wenn Du mir sagst wie
    man das ändern muss.
    Mfg.
    Endor

  • Div. Skripte funktionieren im aktuellem Nightly nicht mehr

    • Endor
    • 20. Januar 2025 um 18:09

    Hallo bugger.
    Perfekt!!
    Funktioniert einwandfrei.
    Vielen Dank.
    Mfg.
    Endor

  • Div. Skripte funktionieren im aktuellem Nightly nicht mehr

    • Endor
    • 20. Januar 2025 um 17:38

    Hallo zusammen.
    Eine Frage habe hier ein Script welches einen onwheel Teil enthält.
    Der funktioniert aber nicht mehr.

    JavaScript
    (function() {
    
        if (location != "chrome://browser/content/browser.xhtml") return;
    
        try {
    //      Zoom-Steuerung, tooltiptext: 'Linksklick oder Rad ↑: vergrößern | Mittelklick: zurücksetzen | 
    //      Rechtsklick oder Rad ↓: verkleinern',
            CustomizableUI.createWidget({
                id: 'zoom-control-ToolBarbutton',
                type: 'custom',
                onBuild: function(aDocument) {
                    let toolbaritem = aDocument.createXULElement('toolbarbutton');
                    let props = {
                        id: 'zoom-control-ToolBarbutton',
                        class: 'toolbarbutton-1 chromeclass-toolbar-additional',
                        oncontextmenu: 'return(false);',
                        label: 'Zoom-Steuerung',
                        tooltiptext: 'Linksklick oder Rad ↑: vergrößern | Mittelklick: zurücksetzen | Rechtsklick oder Rad ↓: verkleinern',
                        style: 'list-style-image: url()',
                    };
                    for (let p in props)
                        toolbaritem.setAttribute(p, props[p]);
    					toolbaritem.addEventListener('click', event => {
    					if (event.button == 0) { 
                                  if (event.button == 0) { 
                                      FullZoom.enlarge(); 
                                  }; 
                                  if (event.button == 1) { 
                                      FullZoom.reset(); 
                                  }; 
                                  if (event.button == 2) { 
                                      FullZoom.reduce(); 
                                  };
                        onwheel:  if (event.deltaY < 0) { 
                                      FullZoom.enlarge(); 
                                  } else { 
                                      FullZoom.reduce(); 
                                  };
    					}
    				});	
    			    for (let p in props)
                    toolbaritem.setAttribute(p, props[p]);	
                    return toolbaritem;
                }
            });
    
        } catch(e){};
    
    })();
    Alles anzeigen

    Das original sieht so aus:

    JavaScript
    (function() {
    
        if (location != "chrome://browser/content/browser.xhtml") return;
    
        try {
    //    Zoom-Steuerung, tooltiptext: 'Linksklick oder Rad ↑: vergrößern | Mittelklick: zurücksetzen | 
    //    Rechtsklick oder Rad ↓: verkleinern',
            CustomizableUI.createWidget({
                id: 'zoom-control-ToolBarbutton',
                type: 'custom',
                onBuild: function(aDocument) {
                    let toolbaritem = aDocument.createXULElement('toolbarbutton');
                    let props = {
                        id: 'zoom-control-ToolBarbutton',
                        class: 'toolbarbutton-1 chromeclass-toolbar-additional',
                        oncontextmenu: 'return(false);',
                        label: 'Zoom-Steuerung',
                        tooltiptext: 'Linksklick oder Rad ↑: vergrößern | Mittelklick: zurücksetzen | Rechtsklick oder Rad ↓: verkleinern',
                        style: 'list-style-image: url()',
                        onclick: 'if (event.button == 0) { \
                                      FullZoom.enlarge(); \
                                  }; \
                                  if (event.button == 1) { \
                                      FullZoom.reset(); \
                                  }; \
                                  if (event.button == 2) { \
                                      FullZoom.reduce(); \
                                  };',
                        onwheel: 'if (event.deltaY < 0) { \
                                      FullZoom.enlarge(); \
                                  } else { \
                                      FullZoom.reduce(); \
                                  };'
                    };
                    for (let p in props)
                        toolbaritem.setAttribute(p, props[p]);
                    return toolbaritem;
                }
            });
        } catch(e){};
    
    })();
    Alles anzeigen

    Habe ich wohl falsch geändert.
    Mfg.
    Endor

  • Div. Skripte funktionieren im aktuellem Nightly nicht mehr

    • Endor
    • 20. Januar 2025 um 10:23

    Hallo Speravir.
    Vielen Dank funktioniert wieder einwandfrei.
    Das Script zum aktivieren - deaktivieren von Javascript
    lade ich dann auch gleich mit hoch.

    Vielen Dank für Deine Mühe.
    Mfg.
    Endor

  • Div. Skripte funktionieren im aktuellem Nightly nicht mehr

    • Endor
    • 19. Januar 2025 um 19:24

    Hallo zusammen.
    Dieses Script geht hier im Nightly auch nicht mehr richtig:

    CSS
    // ==UserScript==
    // @name           moveReloadIntoUrl.uc.js
    // @description    Neuladen Schaltfläche in Adressleiste verschieben
    // @compatibility  Firefox 57
    // @author         Ryan, GOLF-AT
    // @include        main
    // @shutdown       window.moveReloadIntoURL.unload();
    // @homepageURL    https://github.com/benzBrake/FirefoxCustomize
    // @version        1.2.4
    // @note           1.2.4 Bug 1880914  Move Browser* helper functions used from global menubar and similar commands to a single object in a separate file, loaded as-needed and Bug 1820534 - Move front-end to modern flexbox
    // @note           1.2.3 Änderung wird in neuen Fenstern nicht wirksam und kann nicht verwendet werden, wenn Hot-Swapping stattfindet.
    // @note           1.2.2 Kompatibilität für Firefox 103
    // @note           1.2.0 Hot-Swap-fähig, kompatibel mit Nachtmodus und Bilder wurden ins Script integriert
    // @note           1.1 20220424 Fehler behoben, und Firefox 100 Kompatibel
    // @note           1.0 20171104
    // ==/UserScript==
    (function () {
        let { classes: Cc, interfaces: Ci, utils: Cu, results: Cr } = Components;
    
        const isGerman = (Services.locale.appLocaleAsBCP47 || Services.locale.getAppLocaleAsBCP47()).includes("de");
    
        if (window.moveReloadIntoURL) {
            window.moveReloadIntoURL.unload();
            delete window.moveReloadIntoURL;
        }
    
        window.moveReloadIntoURL = {
            handleEvent: function (aEvent) {
                if (aEvent.type === "MoveReloadIntoUrlUnload") {
                    let window = aEvent.originalTarget,
                        doc = window.document;
                    let RELOADBTN = CustomizableUI.getWidget("reload-button").forWindow(window).node;
                    if (RELOADBTN)
                        RELOADBTN.removeEventListener('DOMAttrModified', this.reloadBtnAttr);
                    let BTN = doc.getElementById("new-stop-reload-button");
                    if (BTN)
                        BTN.parentNode.removeChild(BTN);
                    if (this.STYLE) {
                        this.sss.unregisterSheet(this.STYLE.url, this.STYLE.type);
                    }
                    window.removeEventListener('MoveReloadIntoUrlUnload', this);
                    if (window.moveReloadIntoURL)
                        delete window.moveReloadIntoURL;
                }
            },
            init: function () {
                if (window.moveReloadIntoURL) {
                    this.sss = Cc["@mozilla.org/content/style-sheet-service;1"].getService(Ci.nsIStyleSheetService);
                    this.STYLE = {
                        url: Services.io.newURI('data:text/css;charset=UTF-8,' + encodeURIComponent(`
                    @-moz-document url-prefix('chrome://browser/content/browser.x') {
                        #stop-reload-button {
                            display: none;
                        }
                        #new-stop-reload-button {
                            display: flex !important;
                            order: 9999;
                        }
                        #new-stop-reload-button .urlbar-icon {
                            -moz-context-properties: fill, fill-opacity !important;
                            fill: currentColor !important;
                        }
                    }
                  `)),
                        type: this.sss.AGENT_SHEET
                    };
                    this.sss.loadAndRegisterSheet(this.STYLE.url, this.STYLE.type);
                }
                let PABTN = CustomizableUI.getWidget("pageActionButton").forWindow(window).node;
                let RELOADBTN = CustomizableUI.getWidget("reload-button").forWindow(window).node;
                let BTN = $C(document, 'hbox', {
                    id: "new-stop-reload-button",
                    class: "urlbar-page-action urlbar-addon-page-action",
                    "tooltiptext": isGerman ? 'Linksklick: Seite neuladen\r\nRechtsklick: Neu laden ohne Cache' : 'Left click: refresh page\nRight click: force refresh page',
                    style: "list-style-image: url('",
                    onclick: function (e) {
                        let r = CustomizableUI.getWidget("reload-button").forWindow(window).node;
                        e.preventDefault();
                        if (r && r.getAttribute('displaystop'))
                            gBrowser.stop();
                        else
                            if (e.button == 2) {
                                gBrowser.reloadWithFlags(Ci.nsIWebNavigation.LOAD_FLAGS_BYPASS_CACHE)
                            } else {
                                if (gBrowser.selectedBrowser._userTypedValue) {
                                    e.target.ownerGlobal.openTrustedLinkIn(gBrowser.selectedBrowser._userTypedValue, 'current', {
                                        postData: null,
                                        triggeringPrincipal: gBrowser.selectedBrowser.contentPrincipal
                                    });
                                } else {
                                    gBrowser.reload();
                                }
                            }
                    }
                })
    
                BTN.appendChild($C(document, 'image', {
                    class: 'urlbar-icon',
                }));
    
                PABTN.after(BTN);
                RELOADBTN.addEventListener('DOMAttrModified', this.reloadBtnAttr);
                this.reloadBtnAttr();
    
                window.addEventListener('MoveReloadIntoUrlUnload', this)
            },
            unload: function () {
                let windows = Services.wm.getEnumerator('navigator:browser');
                while (windows.hasMoreElements()) {
                    let win = windows.getNext();
                    win.dispatchEvent(new CustomEvent("MoveReloadIntoUrlUnload"));
                }
            },
            reloadBtnAttr: function (e) {
                let doc = e ? e.target.ownerDocument : document;
                btn = doc.getElementById('new-stop-reload-button');
                if (btn && (!e || e.attrName == 'displaystop')) {
                    var newVal = e ? e.newValue : doc.getElementById(
                        "reload-button").getAttribute('displaystop');
                    if (newVal)
                        btn.style.listStyleImage = "url('')";
                    else
                        btn.style.listStyleImage = "url('')";
                }
            },
        }
    
        function $C(aDoc, tag, attrs, skipAttrs) {
            let d = (aDoc || document);
            attrs = attrs || {};
            skipAttrs = skipAttrs || [];
            var el = "createXULElement" in d ? d.createXULElement(tag) : d.createElement(tag);
            return $A(el, attrs, skipAttrs);
        }
    
        function $A(el, obj, skipAttrs) {
            skipAttrs = skipAttrs || [];
            if (obj) Object.keys(obj).forEach(function (key) {
                if (!skipAttrs.includes(key)) {
                    if (typeof obj[key] === 'function') {
                        el.setAttribute(key, "(" + obj[key].toString() + ").call(this, event);");
                    } else {
                        el.setAttribute(key, obj[key]);
                    }
                }
            });
            return el;
        }
    
        "canLoadToolbarContentPromise" in PlacesUIUtils ? PlacesUIUtils.canLoadToolbarContentPromise.then(_ => moveReloadIntoURL.init()) : moveReloadIntoURL.init();
    })();
    Alles anzeigen

    ab Zeile 76 gibt es diesen Bereich den man wahrscheinlich ändern muss:

    Code
                    onclick: function (e) {
                        let r = CustomizableUI.getWidget("reload-button").forWindow(window).node;
                        e.preventDefault();
                        if (r && r.getAttribute('displaystop'))
                            gBrowser.stop();
                        else
                            if (e.button == 2) {
                                gBrowser.reloadWithFlags(Ci.nsIWebNavigation.LOAD_FLAGS_BYPASS_CACHE)
                            } else {
                                if (gBrowser.selectedBrowser._userTypedValue) {
                                    e.target.ownerGlobal.openTrustedLinkIn(gBrowser.selectedBrowser._userTypedValue, 'current', {
                                        postData: null,
                                        triggeringPrincipal: gBrowser.selectedBrowser.contentPrincipal
                                    });
                                } else {
                                    gBrowser.reload();
                                }
                            }
                    }
    Alles anzeigen

    oncommand gibt es keine nur diesen onclick Bereich.
    Wie muss man das ändern?
    Mfg.
    Endor

  • Div. Skripte funktionieren im aktuellem Nightly nicht mehr

    • Endor
    • 19. Januar 2025 um 10:41

    Alice wird antworten sobald er eine funktionierende Version hat.
    Geduld ist angesagt.

    Mfg.
    Endor

  • Div. Skripte funktionieren im aktuellem Nightly nicht mehr

    • Endor
    • 17. Januar 2025 um 19:15

    Ich schreibe gerade Alice, dem Autor.
    Erledigt:

    ucjsDownloadsStatusModoki.uc.js not works in Firefox 135 and 136 · Issue #90 · alice0775/userChrome.js
    Dear Alice0775-san. Please excuse me for disturbing you, i tried this Version of your Script ucjsDownloadsStatusModoki.uc.js.…
    github.com

    Mfg.
    Endor

  • Div. Skripte funktionieren im aktuellem Nightly nicht mehr

    • Endor
    • 17. Januar 2025 um 18:57

    BrokenHeart

    ja dieser CSS Code gehört dazu, bzw. es steht auch im Script dass er dazu
    über userchrome.css geladen werden muss:

    CSS
    @charset "utf-8";
    /*@version       2023/05/18 fix for firefox113, flex-direction, frex-wrap*/
    /*@version       2023/04/25 fix for firefox113, inline-block firefox 113*/
    /*@version       2023/03/09 Bug 1820534 - Move front-end to modern flexbox.*/
    /*@version       2022/11/24 21:00 Bug 1802142 - Remove no longer used browser-bottombox*/
    /*@version       2022/11/20 19:00 107+ wip*/
    /*@version       2022/02/16 Bug 1747422 - Remove preprocessor variable use from downloads CSS*/
    /*@version       2020/03/13 fix for 74, broken listitem orient due to Bug 1606130
    /*@version       2019/12/11 fix for 73 Bug 1601094 - Rename remaining .xul files to .xhtml in browser */
    /*@version       2019/10/20 12:30*/
    
    /*FullScreen*/
    /*DOMFullScreen*/
    :root[inFullscreen] #downloadsStatusModokiBar,
    :root[inDOMFullscreen] #downloadsStatusModokiBar {
      display: none !important;
    }
    
    #contentAreaDownloadsView[ucjsDownloadsStatusModoki] { 
      flex-direction: row !important;
      background-color: var(--in-content-box-background) !important; 
      padding: 0 !important; 
    } 
    
    #contentAreaDownloadsView[ucjsDownloadsStatusModoki] > stack:first-child {
    }
    
     #ucjsDownloadsStatusModoki{
      border-top-width: 1px !important;
      border-top-style: solid !important;
      border-top-color: #646473 !important;
    } 
    
    #contentAreaDownloadsView[ucjsDownloadsStatusModoki] #downloadsListBox { 
      background-color: #fffff0 !important; 
      flex-direction: row;
      flex-wrap: wrap;
      overflow-y: auto !important; 
      scrollbar-width: thin;
      border: none !important;
    } 
    
    #contentAreaDownloadsView[ucjsDownloadsStatusModoki] richlistitem:not([hidden]) { 
      border-width: 0 1px 0 0  !important; 
      border-style: solid !important; 
      border-color: black !important;
      width: 276px !important;
      height: 3.0em !important;
      min-height: 3.0em !important;
      font-size: 12px !important; 
    }
    
    #contentAreaDownloadsView[ucjsDownloadsStatusModoki] .downloadMainArea {
    }
    
    #contentAreaDownloadsView[ucjsDownloadsStatusModoki] .downloadContainer {
    	max-width: 200px !important;
    }
    
    #contentAreaDownloadsView[ucjsDownloadsStatusModoki] .downloadTypeIcon {
    	margin-inline-end: 4px !important;
    	margin-inline-start: 4px !important;
    }
    
    #contentAreaDownloadsView[ucjsDownloadsStatusModoki] .downloadButton {
    	width: 36px !important;
    	padding-inline-end: 4px !important;
    	padding-inline-start: 4px !important;
    }
    #contentAreaDownloadsView[ucjsDownloadsStatusModoki] #downloadsListEmptyDescription
    {
    	flex: 1 !important;
    }
    Alles anzeigen

    Deine Version funktioniert nicht richtig. Standardmäßig ist diese Leiste nicht sichtbar.
    Sie kann manuell über Ansicht - Symbolleisten ein und ausgeblendet werden bzw.
    bei Download öffnet sich diese automatisch. Eintrag unter Ansicht - Symbolleisten fehlt bei
    deiner Version und Darstellung passt auch nicht. Werde den Autor mal kontaktieren, mal sehen was er sagt.

    Trotzdem vielen Dank für Deine Mühe.
    Mfg.
    Endor

  • Div. Skripte funktionieren im aktuellem Nightly nicht mehr

    • Endor
    • 17. Januar 2025 um 16:32

    Hallo Boersenfeger .
    Vom Script ucjsDownloadsStatusModoki.uc.js gibt es auch eine neue Version.
    Muss ich erst noch fertig machen und hochladen.

    Edit:
    Das ist die neueste Version davon, aber funktioniert hier noch nicht
    nicht richtig. Überhaupt nicht. Unter Ansicht ist kein Eintrag zum ein und ausblenden der
    Downloadleiste.

    Code
    // ==UserScript==
    // @name           ucjsDownloadsStatusModoki.uc.js
    // @namespace      http://space.geocities.yahoo.co.jp/gl/alice0775
    // @description    Downloads Status Modoki
    // @include        main
    // @compatibility  Firefox 120
    // @author         Alice0775
    // @note           ucjsDownloadsStatusModoki.uc.js.css をuserChrome.cssに読み込ませる必要あり
    // @version        2023/10/10 00:00 Stop using xml-stylesheet processing instructions
    // @version        2023/07/17 00:00 use ES module imports
    // @version        2023/06/20 remove Bug 1780695 - Remove Services.jsm
    // @version        2023/06/18 21:00 null
    // @version        2023/05/18 21:00 
    // @version        2022/11/24 21:00 Bug 1802142 - Remove no longer used browser-bottombox
    // @version        2022/11/22 Bug 877389 - [meta] Replace calls to Cu.reportError, etc. from browser code, replace with console.error, etc.
    // @version        2022/11/20 19:00 107+ wip
    // @version        2022/04/01 23:00 Convert Components.utils.import to ChromeUtils.import
    // @version       2022/02/16 Bug 1747422 - Remove preprocessor variable use from downloads CSS
    // @version       2019/12/11 fix for 73 Bug 1601094 - Rename remaining .xul files to .xhtml in browser
    // @version        2019/10/20 12:30 workaround Bug 1497200: Apply Meta CSP to about:downloads, Bug 1513325 - Remove textbox binding
    // @version        2019/09/08 19:30 fix scrollbox
    // @version        2019/05/21 08:30 fix 69.0a1 Bug 1551320 - Replace all createElement calls in XUL documents with createXULElement
    // @version        2018/10/27 12:00 fix for 64+
    // @version        2018/06/12 21:00 fix for private window mode
    // @version        2018/06/07 12:00 fix file name for history
    // @version        2018/02/10 12:00 try catch error when DO_NOT_DELETE_HISTORY = true
    // @version        2017/12/10 12:00 fix error when DO_NOT_DELETE_HISTORY = true
    // @version        2017/12/10 12:00 remove workaround Bug 1279329. Disable btn while clear list is doing, close button styling for 57.
    // @version        2016/06/10 12:00 modify style independent of font-family
    // @version        2016/06/10 07:00 modify style of close button, fix typo
    // @version        2016/06/10 00:00 Workaround Bug 1279329. adjust some padding
    // @version        2015/05/08 00:00 remove padding due to Bug 1160734
    // @version        2014/03/31 00:00 fix for browser.download.manager.showWhenStarting
    // @version        2013/12/22 13:00 chromehidden
    // @version        2013/12/19 17:10 rename REMEMBERHISTOTY to DO_NOT_DELETE_HISTORY
    // @version        2013/12/16 23:28 fixed initialize numDls
    // @version        2013/12/16 23:24 open only download added
    // @version        2013/12/16 23:10 open only download started
    // @version        2013/12/16 21:20 modify css Windows7 Aero
    // @version        2013/12/16 21:00 modify css
    // @version        2013/12/16 19:30 add autocheck false
    // @version        2013/12/16 18:31 fix pref name
    // @version        2013/12/16 18:30
    // @note
    // ==/UserScript== 
    var ucjsDownloadsStatusModoki = {
      _summary: null,
      _list: null,
    
      get downloadsStatusModokiBar() {
        delete downloadsStatusModokiBar;
        return this.downloadsStatusModokiBar = document.getElementById("downloadsStatusModokiBar");
      },
    
      get toggleMenuitem() {
        delete toggleMenuitem;
        return this.toggleMenuitem = document.getElementById("toggle_downloadsStatusModokiBar");
      },
    
      init: function() {
        if (document.documentElement.getAttribute("chromehidden") !="" )
          return;
    
    
        ChromeUtils.defineESModuleGetters(this, {
          Downloads: "resource://gre/modules/Downloads.sys.mjs",
        });
    
        var style = ` 
          @namespace url(http://www.mozilla.org/keymaster/gatekeeper/there.is.only.xul); 
    
          #ucjsDownloadsStatusModoki { 
            width: 100%; 
            max-height: 100px; 
            height: 3.35em; 
          } 
         `.replace(/\s+/g, " ");
    
        var sss = Cc['@mozilla.org/content/style-sheet-service;1']
                  .getService(Ci.nsIStyleSheetService);
        var uri = makeURI('data:text/css;charset=UTF=8,' + encodeURIComponent(style));
        if(!sss.sheetRegistered(uri, sss.USER_SHEET))
          sss.loadAndRegisterSheet(uri, sss.USER_SHEET);
    /*
        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);
        };
    */
    
        var toolbar = document.createXULElement("vbox");
        toolbar.setAttribute("id", "downloadsStatusModokiBar");
        toolbar.collapsed = true;
        var ref = document.getElementById("fullscreen-and-pointerlock-wrapper");
        ref.parentNode.insertBefore(toolbar, ref.nextSibling)
    //    var bottombox = document.getElementById("browser-bottombox");
    //    bottombox.insertBefore(toolbar, bottombox.firstChild);
        var browser = toolbar.appendChild(document.createXULElement("browser"));
        browser.setAttribute("disablehistory", true);
        browser.setAttribute("remote", false);
        browser.setAttribute("id", "ucjsDownloadsStatusModoki");
        browser.addEventListener("load", function(event){ucjsDownloadsStatusModoki.onload(event)}, true);
        browser.setAttribute("src", "chrome://browser/content/downloads/contentAreaDownloadsView.xhtml?StatusModoki");
        var menuitem = document.createXULElement("menuitem");
        menuitem.setAttribute("id", "toggle_downloadsStatusModokiBar");
        menuitem.setAttribute("type", "checkbox");
        menuitem.setAttribute("autocheck", false);
        menuitem.setAttribute("label", "Downloads Status Modoki Bar");
        menuitem.setAttribute("checked", false);
        menuitem.setAttribute("accesskey", "D");
        //menuitem.setAttribute("oncommand", "ucjsDownloadsStatusModoki.toggleDownloadsStatusModokiBar()");
        ref = document.getElementById("menu_customizeToolbars");
        ref.parentNode.insertBefore(menuitem, ref.previousSibling);
        document.getElementById("toggle_downloadsStatusModokiBar").addEventListener("command", () => ucjsDownloadsStatusModoki.toggleDownloadsStatusModokiBar());
    
        // Ensure that the DownloadSummary object will be created asynchronously.
        if (!this._summary) {
          this.Downloads.getSummary(this.Downloads.ALL).then(summary => {
            this._summary = summary;
            return this._summary.addView(this);
          }).then(null, console.error);
        }
        if (!this._list) {
          this.Downloads.getList(this.Downloads.ALL).then(list => {
            this._list = list;
            return this._list.addView(this);
          }).then(null, console.error);
        }
    
        window.addEventListener("unload", this, false);
      },
    
      uninit: function() {
        window.removeEventListener("unload", this, false);
        if (this._summary) {
          this._summary.removeView(this);
        }
        if (this._list) {
          this._list.removeView(this);
        }
      },
    
      handleEvent: function(event) {
        switch (event.type) {
          case "unload":
            this.uninit();
            break;
        }
      },
    
      toggleDownloadsStatusModokiBar: function() {
        var collapsed = this.downloadsStatusModokiBar.collapsed;
        this.downloadsStatusModokiBar.collapsed = !collapsed;
        this.toggleMenuitem.setAttribute("checked", collapsed);
      },
    
      openDownloadsStatusModoki: function() {
        this.downloadsStatusModokiBar.collapsed = false;
        this.toggleMenuitem.setAttribute("checked", true);
      },
    
      hideDownloadsStatusModoki: function() {
        this.downloadsStatusModokiBar.collapsed = true;
        this.toggleMenuitem.setAttribute("checked", false);
      },
    
      onDownloadAdded: function (aDownload) {
        var showWhenStarting = true;
        try {
          showWhenStarting = Services.prefs.getBoolPref("userChrome.downloadsStatusModoki.showWhenStarting");
        } catch(e) {}
        this.numDls = 0;
        if (showWhenStarting) {
          if (this._list) {
            this._list.getAll().then(downloads => {
              for (let download of downloads) {
                if (!download.stopped)
                  this.numDls++;
              }
              if (this.numDls > 0)
                this.openDownloadsStatusModoki(false);
            }).then(null, console.error);
          }
        }
      },
    
      onSummaryChanged: function () {
        if (!this._summary)
          return;
        if (this._summary.allHaveStopped || this._summary.progressTotalBytes == 0) {
          var closeWhenDone = false;
          try {
            closeWhenDone = Services.prefs.getBoolPref("userChrome.downloadsStatusModoki.closeWhenDone");
          } catch(e) {}
          if (closeWhenDone) {
            this.hideDownloadsStatusModoki();
          }
        }
      },
    
    
    
      // chrome://browser/content/downloads/contentAreaDownloadsView.xhtml
      onload: function(event) {
        var doc = event.originalTarget;
        var win = doc.defaultView;
        doc.documentElement.setAttribute("ucjsDownloadsStatusModoki", "true");
    
        var button = doc.createXULElement("button");
        button.setAttribute("label", "Clear");
        button.setAttribute("id", "ucjs_clearListButton");
        button.setAttribute("accesskey", "C");
        var ref = doc.getElementById("downloadsListEmptyDescription");
        var vbox = doc.createXULElement("vbox");
        var box = vbox.appendChild(doc.createXULElement("hbox"));
        box.appendChild(button);
        box.appendChild(doc.createXULElement("spacer")).setAttribute("flex", 1);
        var textbox = doc.createElementNS("http://www.w3.org/1999/xhtml", "input");
        textbox.setAttribute("id", "downloadFilter");
        textbox.setAttribute("clickSelectsAll", true);
        textbox.setAttribute("type", "search");
        textbox.setAttribute("placeholder", "Search...");
        box.appendChild(textbox);
        var closebtn = doc.createXULElement("toolbarbutton");
        closebtn.setAttribute("id", "ucjsDownloadsStatusModoki-closebutton");
        closebtn.setAttribute("class", "close-icon");
        closebtn.setAttribute("tooltiptext", "Close this bar");
        box.appendChild(closebtn);
        ref.parentNode.insertBefore(vbox, ref.nextSibling);
        doc.getElementById("ucjs_clearListButton").addEventListener("command", function(event) {
            win.ucjsDownloadsStatusModoki_clearDownloads();
          });
        doc.getElementById("downloadFilter")
                .addEventListener("input", function(event) {
            win.ucjsDownloadsStatusModoki_doSearch(event.target.value);
          });
        doc.getElementById("ucjsDownloadsStatusModoki-closebutton")
                .addEventListener("command", function(event) {
            win.ucjsDownloadsStatusModoki_doClose();
          });
    
    /*
        // xxx Bug 1279329 "Copy Download Link" of context menu in Library is grayed out
        var listBox = doc.getElementById("downloadsListBox");
        var placesView = listBox._placesView;
        if (placesView) {
          var place = placesView.place;
          placesView.place= null;
          placesView.place = place;
        }
    */
        win.ucjsDownloadsStatusModoki_clearDownloads = function ucjs_clearDownloads() {
          var DO_NOT_DELETE_HISTORY = true; /* custmizable true or false */
          var richListBox = doc.getElementById("downloadsListBox");
    
          var places = [];
          function addPlace(aURI, aTitle, aVisitDate) {
            places.push({
              uri: aURI,
              title: aTitle,
              visits: [{
                visitDate: (aVisitDate || Date.now()) * 1000,
                transitionType: Ci.nsINavHistoryService.TRANSITION_LINK
              }]
            });
          }
          function moveDownloads2History() {
            if (DO_NOT_DELETE_HISTORY &&
                !PrivateBrowsingUtils.isWindowPrivate(window)) {
              try {
                for (let element of richListBox.childNodes) {
                  let download = element._shell.download;
                  let aURI = makeURI(download.source.url);
                  // let aTitle = document.getAnonymousElementByAttribute(element, "class", "downloadTarget").value
                  let aTitle = download.target.path;
                  aTitle = aTitle.match( /[^\\]+$/i )[0];
                  aTitle = aTitle.match( /[^/]+$/i )[0];
    
                  let aVisitDate = download.endTime || download.startTime;
                  addPlace(aURI, aTitle, aVisitDate)
                }
              } catch(ex) {}
            }
    
            // Clear List
            richListBox._placesView.doCommand('downloadsCmd_clearDownloads');
    
            if (DO_NOT_DELETE_HISTORY &&
                !PrivateBrowsingUtils.isWindowPrivate(window)) {
              try {
                if (places.length > 0) {
                  var asyncHistory = Components.classes["@mozilla.org/browser/history;1"]
                           .getService(Components.interfaces.mozIAsyncHistory);
                    asyncHistory.updatePlaces(places);
                }
              } catch(ex) {}
            }
          }
          var btn = doc.getElementById("ucjs_clearListButton");
          btn.setAttribute("disabled", true);
          moveDownloads2History();
          btn.removeAttribute("disabled");
    
          // close toolbar
          var closeWhenDone = false;
          try {
            closeWhenDone = Services.prefs.getBoolPref("userChrome.downloadsStatusModoki.closeWhenDone");
          } catch(e) {}
          if (closeWhenDone) {
            top.ucjsDownloadsStatusModoki.hideDownloadsStatusModoki();
          }
        };
    
        win.ucjsDownloadsStatusModoki_doSearch = function ucjs_doSearch(filterString) {
          var richListBox = doc.getElementById("downloadsListBox");
          richListBox._placesView.searchTerm = filterString;
        };
    
        win.ucjsDownloadsStatusModoki_doClose = function ucjs_doClose() {
          top.ucjsDownloadsStatusModoki.hideDownloadsStatusModoki();
        };
    
      }
    
    }
    ucjsDownloadsStatusModoki.init();
    Alles anzeigen

    Mfg.
    Endor

  • Div. Skripte funktionieren im aktuellem Nightly nicht mehr

    • Endor
    • 16. Januar 2025 um 20:14

    Hallo 2002Andreas

    Habe ich ja gemacht. Aber meine Version ist etwas anders.
    Da sind die Schaltflächen frei verschiebbar.
    Hat aborix mal eingebaut.

    Daher klemmt es irgendwo.

    Mfg.
    Endor

  • Div. Skripte funktionieren im aktuellem Nightly nicht mehr

    • Endor
    • 16. Januar 2025 um 20:05

    Nö, zu dritt.;)

    Denn sonst würde meine Version funktionieren.
    Wer mag sich das mal anschauen:

    Code
    // ==UserScript==
    // @name           externalApplications.uc.js
    // @namespace      ithinc#mozine.cn
    // @description    External Applications
    // @include        main
    // @compatibility  Firefox 3.5.x 3.6.x 17.01
    // @author         ithinc
    // @Version        Fix by aborix
    // @Version        20190108.2.0.0 Frei verschiebbare Schaltflächen von aborix
    // @version        20091216.1.0.0 Final release
    // @version        20091215.0.0.2 Handle toolbar apps and menu apps separately
    // @version        20091212.0.0.1 Initial release
    // ==/UserScript==
    
    /* :::: External Applications :::: */
    
    var gExternalApplications = {
      toolbar: {
        apps: [
          {name: 'Photoshop', path: 'C:\\Program Files (x86)\\Adobe\\Adobe Photoshop CS2\\Photoshop.exe'},
    	  {name: 'Wetter', path: 'C:\\Users\\xxx\\Wetter'},
          {name: 'Notepad++', path: 'C:\\Program Files\\Notepad++\\notepad++.exe'},
    	  {name: 'Microsoft Outlook', path: 'C:\\Program Files (x86)\\Microsoft Office\\OFFICE14\\Outlook.exe'},
    	  {name: 'Phoenix Hotel', path: 'C:\\Program Files (x86)\\PCS Phoenix\\Phoenix.exe'},
    	  {name: 'Videolan Player', path: 'C:\\Program Files\\VideoLAN\\VLC\\vlc.exe'},
    	  {name: 'Windows Explorer', path: 'C:\\Windows\\explorer.exe'},
    	  {name: 'WinMergeU', path: 'F:\\Adaten\\Downloads\\Freecomander\\WinMerge-2.14.0\\WinMerge-2.16.12-x64-exe\\WinMerge\\WinMergeU.exe'},
    	  {name: 'Filezilla', path: 'F:\\Adaten\\Downloads\\Filezilla\\FileZilla_3.10.3_win64\\FileZilla-3.56.2\\filezilla.exe'},
    	  {name: 'CarotDAV', path: 'F:\\Adaten\\Downloads\\Dropbox\\CarotDAV1.9.9.portable\\CarotDAV\\CarotDAV.exe'},	  
    	  {name: 'Pickpick', path: 'F:\\Adaten\\Downloads\\picpick\\picpick.exe'},
    	  {name: 'Profilmanager', path: 'F:\\Adaten\\Downloads\\Firefox\\Profile-Manager\\profilemanager.exe'},
    	  {name: 'Profile', path: 'C:\\Users\\xxx\\AppData\\Roaming\\Mozilla\\Firefox\\Profiles'},
    	  {name: 'FreeCommander', path: 'F:\\Adaten\\Downloads\\FreeComander\\FreeCommanderPortable\\FreeCommanderPortable.exe'},
    	  {name: 'TV Browser', path: 'F:\\Adaten\\Downloads\\TVBrowser\\tvbrowser_3.2.1_bin_transportable\\tvbrowser-transportable\\tvbrowser-transportable.exe'},
    	  {name: 'Radio Sure', path: 'F:\\Adaten\\Downloads\\Radio\\RadioSure.exe'},
       ]
      },
    // Menü für Firefox Extras - Externe Anwendungen
      menu: {
        apps: [
          {name: 'Notepad', path: 'C:\\WINDOWS\\system32\\notepad.exe'},
          {name: 'Rechner', path: 'C:\\WINDOWS\\system32\\calc.exe'},
          {name: 'DOS', path: 'C:\\WINDOWS\\system32\\cmd.exe'},
          {name: 'separator'},
          {name: 'UltraSearch', path: 'F:\\Adaten\\Downloads\\FreeComander\\UltraSearch\\UltraSearch.exe'},
          {name: 'CarotDAV', path: 'F:\\Adaten\\Downloads\\Dropbox\\CarotDAV1.9.9.portable\\CarotDAV\\CarotDAV.exe'},
          {name: 'Windows Explorer', path: 'c:\\windows\\explorer.exe'},/*x?????*/
          {name: 'Internet Explorer', path: 'C:\\Program Files\\Internet Explorer\\IEXPLORE.EXE', args: ['%u']},
          {name: 'Firefox', path: 'F:\\Adaten\\Downloads\\Firefox'},
    	  {name: 'Videos', path: 'F:\\Video'},
    	  {name: 'Videos2', path: 'F:\\Adaten\\Müll'},
        ],
      id: 'ExternalApplicationsMenu',
        insertafter: 'menu_openAddons', // 'helpMenu', 'tools-menu' oder 'browserToolsSeparator'
        label: 'Externe Anwendungen',
        accesskey: 'A'
      },
    
      init: function() {
        this.handleRelativePath(this.toolbar.apps);
        this.handleRelativePath(this.menu.apps);
    
        this.createToolbarbuttons(this.toolbar.apps);
    
        if (this.menu.apps.length > 0) {
          var refNode = document.getElementById(this.menu.insertafter);
          if (refNode) {
            var menu = refNode.parentNode.insertBefore(document.createXULElement('menu'), refNode.nextSibling);
            menu.setAttribute('id', this.menu.id);
            menu.setAttribute('label', this.menu.label);
            menu.setAttribute('accesskey', this.menu.accesskey);
            menu.appendChild(this.createMenupopup(this.menu.apps));
          }
        }
      },
    
      handleRelativePath: function(apps) {
        for (var i=0; i<apps.length; i++) {
          var app = apps[i];
          if (app.path) {
            app.path = app.path.replace(/\//g, '\\');
    
            var ffdir = Cc['@mozilla.org/file/directory_service;1'].getService(Ci.nsIProperties).get('CurProcD', Ci.nsIFile).path;
            if (/^(\.)/.test(app.path)) {
              app.path = ffdir + '\\' + app.path;
            }
            else if (/^(\\)/.test(app.path)) {
              app.path = ffdir.substr(0,2) + app.path;
            }
          }
        }
      },
    
      exec: function(path, args) {
        args = args || [];
        for (var i=0; i<args.length; i++) {
          args[i] = args[i].replace(/%u/g, gBrowser.currentURI.spec);
        }
    
        var file = Cc['@mozilla.org/file/local;1'].createInstance(Ci.nsIFile);
        file.initWithPath(path);
        if (!file.exists()) {
          Cu.reportError('File Not Found: ' + path);
          return;
        }
    
        if (!file.isExecutable()) {
          file.launch();
        }
        else {
          var process = Cc['@mozilla.org/process/util;1'].createInstance(Ci.nsIProcess);
          process.init(file);
          process.run(false, args, args.length);
        }
      },
    
      createToolbarbuttons: function(apps) {
        for (var i=0; i<apps.length; i++) {
          var app = apps[i];
          if (app.name != 'separator') {
            createButton(app);
          }
        };
        function createButton(app) {
          var buttonId = app.name.replace(/ /g, '_').replace(/\+/g, 'Plus') + '-ExtApp-button';
          try {
            CustomizableUI.createWidget({
              id: buttonId,
              type: 'custom',
              defaultArea: CustomizableUI.AREA_NAVBAR,
              onBuild: function(aDocument) {
                var toolbaritem = aDocument.createElementNS('http://www.mozilla.org/keymaster/gatekeeper/there.is.only.xul', 'toolbarbutton');
                var attributes = {
                  id: buttonId,
                  class: 'toolbarbutton-1 chromeclass-toolbar-additional',
                  label: app.name,
                  tooltiptext: app.name,
                  image: 'moz-icon:file:///' + app.path + '?size=16',
                  //oncommand: 'gExternalApplications.exec(this.path, this.args);',
    
                };
                for (var a in attributes) {
                  toolbaritem.setAttribute(a, attributes[a]);
    			  toolbaritem.addEventListener('click', event => {
    					if (event.button == 0) { 
                                gExternalApplications.exec(this.path, this.args).click();	  
                }
    		    });	
                toolbaritem.path = app.path;
                toolbaritem.args = app.args;
                return toolbaritem;
    			}
    		  }
            });
          } catch(e) {};
        }
      },
      createMenupopup: function(apps) {
        var menupopup = document.createXULElement('menupopup');
        for (var i=0; i<apps.length; i++) {
          var app = apps[i];
          if (app.name == 'separator') {
            menupopup.appendChild(document.createXULElement('menuseparator'));
          }
          else {
            var item = menupopup.appendChild(document.createXULElement('menuitem'));
            item.setAttribute('class', 'menuitem-iconic');
            item.setAttribute('label', app.name);
            item.setAttribute('image', 'moz-icon:file://' + app.path + '?size=16');
            item.addEventListener ('command', function (event) {
    	    if (event.button == 0) {
    		   gExternalApplications.exec(this.path, this.args);
    	    }
    		});
            item.path = app.path;
            item.args = app.args;
    		return menupopup;
    		}
    	}
      };
    };
    gExternalApplications.init();
    Alles anzeigen

    Mfg.
    Endor

  • Div. Skripte funktionieren im aktuellem Nightly nicht mehr

    • Endor
    • 16. Januar 2025 um 17:03

    FuchsFan
    Teste mal meines:

    Code
    //  browsertoolbox.uc.js
    
    (function() {
    
    	if (location != 'chrome://browser/content/browser.xhtml')
    		return;
    
    	try {
    		CustomizableUI.createWidget({
    			id: 'browser-toolbox-button',
    			type: 'custom',
    			defaultArea: CustomizableUI.AREA_MENUBAR,
    			onBuild: function(aDocument) {
    				var toolbaritem = aDocument.createElementNS('http://www.mozilla.org/keymaster/gatekeeper/there.is.only.xul', 'toolbarbutton');
    				var props = {
    					id: 'browser-toolbox-button',
    					class: 'toolbarbutton-1 chromeclass-toolbar-additional',
    					label: 'Browser-Werkzeuge',
    					tooltiptext: 'Browser-Werkzeuge',
    					style: 'list-style-image: url()',
    				};
    				for (var p in props)
    					toolbaritem.setAttribute(p, props[p]);
    					toolbaritem.addEventListener('click', event => {
    				    if (event.button == 0) {
                             onCommand()
                        }
    				});
    				return toolbaritem;
    			}
    		});
           } catch(e) { };  
    
    	function onCommand() {
    		var document = event.target.ownerDocument;
    		if (!document.getElementById('menu_browserToolbox')) {
    			let { require } = ChromeUtils.importESModule("resource://devtools/shared/loader/Loader.sys.mjs", {});
    			require("devtools/client/framework/devtools-browser");
    		};
    		document.getElementById('menu_browserToolbox').click();
    	};
    
    })();
    Alles anzeigen

    Dafür hat mir Horstmann doch geholfen.
    Nochmals vielen Dank dafür.
    Mfg.
    Endor

  • Div. Skripte funktionieren im aktuellem Nightly nicht mehr

    • Endor
    • 16. Januar 2025 um 16:57

    Hallo Horstmann .

    Vielen Dank. Das passt jetzt.
    Script funktioniert wieder einwandfrei.
    :thumbup::thumbup:

    Mfg.
    Endor

  • Div. Skripte funktionieren im aktuellem Nightly nicht mehr

    • Endor
    • 16. Januar 2025 um 13:42

    Hallo Horstmann .
    Leider nein.
    Mit dem was Speravir hier geschrieben hat, komme ich nicht klar:

    Beitrag

    RE: Div. Skripte funktionieren im aktuellem Nightly nicht mehr

    […]

    Das kommt so ähnlich zum Beispiel im von mir ganz zu Anfang erwähnten AnimationToggleButton-Skript vor, von dir zuletzt hier aktualisiert (soweit mir bekannt).

    Ich hab da bis eben länger dran gesessen. Die Lösung besteht darin, die Funktion onCommand aufzulösen und deren Code in die vom Eventhandler aufgerufene anonyme Funktion einzufügen. In AnimationToggleButton heißt die Funktion onClick, aber das spielt hier keine Rolle.

    alt:

    (Quelltext, 5 Zeilen)

    neu:

    (Quelltext, 3 Zeilen)

    Speravir
    15. Januar 2025 um 02:24

    Mfg.
    Endor

  • userChrome.js Scripte für den Fuchs (Diskussion)

    • Endor
    • 16. Januar 2025 um 12:03

    Ah. Danke für den Hinweis.

Unterstütze uns!

Jährlich (2025)

101,9 %

101,9% (662,48 von 650 EUR)

Jetzt spenden
  1. Kontakt
  2. Datenschutz
  3. Impressum
Community-Software: WoltLab Suite™
Mastodon