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. Boersenfeger

Beiträge von Boersenfeger

  • Offenbar funktionieren alle Benutzerskripte nicht mehr im Nightly

    • Boersenfeger
    • 9. Juni 2023 um 18:23

    Mit 64 und 5 Monaten nach 45 Jahren ohne Abzüge ;)

  • Offenbar funktionieren alle Benutzerskripte nicht mehr im Nightly

    • Boersenfeger
    • 9. Juni 2023 um 18:19

    1.7.24 ist der 1. Tag

  • Offenbar funktionieren alle Benutzerskripte nicht mehr im Nightly

    • Boersenfeger
    • 9. Juni 2023 um 18:10

    ... aber ich schlage dann... :D ^^ :P

  • Offenbar funktionieren alle Benutzerskripte nicht mehr im Nightly

    • Boersenfeger
    • 9. Juni 2023 um 18:07

    Ich muss erst mal die Trainerentlassung bei Eintracht verdauen....


    Zitat von 2002Andreas
    Zitat von milupo

    Er soll ja dich schlagen.

    Er würde mir das Leben retten wenn es sein muss, aber niemals jemanden/mich schlagen. ;)

    ...aber nur noch 386 Tage...

  • Offenbar funktionieren alle Benutzerskripte nicht mehr im Nightly

    • Boersenfeger
    • 9. Juni 2023 um 17:35

    War auch nicht für dich gedacht... ;) habe editiert

  • Offenbar funktionieren alle Benutzerskripte nicht mehr im Nightly

    • Boersenfeger
    • 9. Juni 2023 um 16:30

    Als Abschluß dieses Kapitels poste ich nochmal Edit: ggf für Mitlesende Editende: den gesamten Code.

    JavaScript
    /* Suchfeld automatisch leeren */
    
        (function() {
        const lazy = {};
        
        ChromeUtils.defineESModuleGetters(lazy, {     
        FormHistory: "resource://gre/modules/FormHistory.sys.mjs",
        });
    
        var searchbar = document.getElementById("searchbar");
        
        searchbar.doSearch = function(aData, aWhere, aEngine, aParams, aOneOff) {
        let textBox = this._textbox;
    
    
          if (aData && !PrivateBrowsingUtils.isWindowPrivate(window) && lazy.FormHistory.enabled) {
            lazy.FormHistory.update({
                op: "bump",
                fieldname: textBox.getAttribute("autocompletesearchparam"),
                value: aData,
            }, {
                handleError(aError) {
                  Cu.reportError("Saving search to form history failed: " + aError.message);
                },
            });
          }
    
    
          let engine = aEngine || this.currentEngine;
          let submission = engine.getSubmission(aData, null, "searchbar");
          let telemetrySearchDetails = this.telemetrySearchDetails;
          this.telemetrySearchDetails = null;
          if (telemetrySearchDetails && telemetrySearchDetails.index == -1) {
            telemetrySearchDetails = null;
          }
    
    
          const details = {
            isOneOff: aOneOff,
            isSuggestion: (!aOneOff && telemetrySearchDetails),
            selection: telemetrySearchDetails,
          };
         // BrowserSearch.recordSearchInTelemetry(engine, "searchbar", details);
    
    
          let params = {
            postData: submission.postData,
          };
          if (aParams) {
            for (let key in aParams) {
              params[key] = aParams[key];
            }
          }
          openTrustedLinkIn(submission.uri.spec, "tab", params);
    
    
          this.value = '';
              
          this.currentEngine = this.engines ? this.engines[0] : this._engines[0];
        };
    
        }());
        
        /* Suchfeld leeren nach 5 Sekunden */
        /* Author @aborix */
    
        setTimeout(function() {
        if (!window.BrowserSearch)
          return;
        var searchbar = BrowserSearch.searchBar;
        if (!searchbar)
          return;
        var textbox = searchbar.textbox;
        var tId;
        textbox.addEventListener('input', function() {
          clearTimeout(tId);
          tId = setTimeout(function() {
             textbox.value = '';
             document.getElementById('PopupSearchAutoComplete').hidePopup();
          }, 5000);
        });
        }, 0);
    Alles anzeigen

    Damit leert sich das Suchfeld mit Auslösen der Suche sofort und bei Nichtauslösen nach 5 Sekunden.

    In Zeile 80 kann dieses Intervall angepasst werden.

    Bis demnäxt :D

  • Offenbar funktionieren alle Benutzerskripte nicht mehr im Nightly

    • Boersenfeger
    • 9. Juni 2023 um 16:23
    Zitat von 2002Andreas

    Funktioniert hier jetzt auch, warum auch immer. :thumbup: ;)

    ChromeUtils

    Mutmaßlich deswegen

  • Offenbar funktionieren alle Benutzerskripte nicht mehr im Nightly

    • Boersenfeger
    • 9. Juni 2023 um 16:22

    Ich habe beide Scripte jetzt in einer Datei und beides klappt. :P

  • Offenbar funktionieren alle Benutzerskripte nicht mehr im Nightly

    • Boersenfeger
    • 9. Juni 2023 um 16:18
    Zitat von milupo

    Also mit den folgenden Zeilen 6 - 8 wird wenigstens nach Enter geleert, aber nicht bei unterlassenem Start der Suche:

    Super, das kann ich bestätigen.... das das Suchfeld bei nicht abgegebenem Suchbefehl geleert werden soll, war auch vorher mit diesem Script nicht gegeben.

    Für mich gelöst! Danke milupo

  • Offenbar funktionieren alle Benutzerskripte nicht mehr im Nightly

    • Boersenfeger
    • 9. Juni 2023 um 16:14

    Wenn man ohne Brille arbeitet... :D

  • Offenbar funktionieren alle Benutzerskripte nicht mehr im Nightly

    • Boersenfeger
    • 9. Juni 2023 um 16:06

    Alles Gute, Sören... :)

    Ich habe gerade etwas Interessantes festgestellt.

    Aus einer Sicherung habe ich den Codeteil in das Profil gebracht, nun schaut Euch bitte mal das Komma in Zeile 10 an. Es sieht anders aus, als das in Zeile 6. Ich hatte Zeile 6 bis 8 neu getippt, mit dem Komma meiner Tastatur... und dann ging das Alte Script auch nicht mehr... kann das wirklich am Komma liegen? Und falls ja, wie kriege ich dieses Komma zustande?

    JavaScript
    /* Suchfeld automatisch leeren */
    
        (function() {
        const lazy = {};
    
        /*XPCOMUtils,defineLazyModuleGetters(lazy, {
        FormHistory: "resource://gre/modules/FormHistory.jsm",
        }); */
        
        XPCOMUtils.defineLazyModuleGetters(lazy, {
        FormHistory: "resource://gre/modules/FormHistory.jsm",
        });
        
        /* XPCOMUtils,defineESModuleGetters(lazy, {     
        FormHistory: "resource://gre/modules/FormHistory.sys.mjs",
        }); */
    
        var searchbar = document.getElementById("searchbar");
        
        searchbar.doSearch = function(aData, aWhere, aEngine, aParams, aOneOff) {
        let textBox = this._textbox;
    
    
          if (aData && !PrivateBrowsingUtils.isWindowPrivate(window) && lazy.FormHistory.enabled) {
            lazy.FormHistory.update({
                op: "bump",
                fieldname: textBox.getAttribute("autocompletesearchparam"),
                value: aData,
            }, {
                handleError(aError) {
                  Cu.reportError("Saving search to form history failed: " + aError.message);
                },
            });
          }
    
    
          let engine = aEngine || this.currentEngine;
          let submission = engine.getSubmission(aData, null, "searchbar");
          let telemetrySearchDetails = this.telemetrySearchDetails;
          this.telemetrySearchDetails = null;
          if (telemetrySearchDetails && telemetrySearchDetails.index == -1) {
            telemetrySearchDetails = null;
          }
    
    
          const details = {
            isOneOff: aOneOff,
            isSuggestion: (!aOneOff && telemetrySearchDetails),
            selection: telemetrySearchDetails,
          };
         // BrowserSearch.recordSearchInTelemetry(engine, "searchbar", details);
    
    
          let params = {
            postData: submission.postData,
          };
          if (aParams) {
            for (let key in aParams) {
              params[key] = aParams[key];
            }
          }
          openTrustedLinkIn(submission.uri.spec, "tab", params);
    
    
          this.value = '';
              
          this.currentEngine = this.engines ? this.engines[0] : this._engines[0];
        };
    
        }());
    Alles anzeigen
  • Offenbar funktionieren alle Benutzerskripte nicht mehr im Nightly

    • Boersenfeger
    • 9. Juni 2023 um 15:58

    Vielleicht kann ja Sören Hentzschel noch etwas Licht ins Dunkel bringen.. :)

  • Offenbar funktionieren alle Benutzerskripte nicht mehr im Nightly

    • Boersenfeger
    • 9. Juni 2023 um 15:56

    Die Suche wird gestartet aber das Suchfeld leert sich nicht... hier noch mal der jetzige Code:

    JavaScript
    /* Suchfeld automatisch leeren */
    
        (function() {
        const lazy = {};
    
        /* XPCOMUtils,defineLazyModuleGetters(lazy, {
        FormHistory: "resource://gre/modules/FormHistory.jsm",
        }); */
        
        XPCOMUtils,defineESModuleGetters(lazy, {     
        FormHistory: "resource://gre/modules/FormHistory.sys.mjs",
        });
    
        var searchbar = document.getElementById("searchbar");
        
        searchbar.doSearch = function(aData, aWhere, aEngine, aParams, aOneOff) {
        let textBox = this._textbox;
    
    
          if (aData && !PrivateBrowsingUtils.isWindowPrivate(window) && lazy.FormHistory.enabled) {
            lazy.FormHistory.update({
                op: "bump",
                fieldname: textBox.getAttribute("autocompletesearchparam"),
                value: aData,
            }, {
                handleError(aError) {
                  Cu.reportError("Saving search to form history failed: " + aError.message);
                },
            });
          }
    
    
          let engine = aEngine || this.currentEngine;
          let submission = engine.getSubmission(aData, null, "searchbar");
          let telemetrySearchDetails = this.telemetrySearchDetails;
          this.telemetrySearchDetails = null;
          if (telemetrySearchDetails && telemetrySearchDetails.index == -1) {
            telemetrySearchDetails = null;
          }
    
    
          const details = {
            isOneOff: aOneOff,
            isSuggestion: (!aOneOff && telemetrySearchDetails),
            selection: telemetrySearchDetails,
          };
         // BrowserSearch.recordSearchInTelemetry(engine, "searchbar", details);
    
    
          let params = {
            postData: submission.postData,
          };
          if (aParams) {
            for (let key in aParams) {
              params[key] = aParams[key];
            }
          }
          openTrustedLinkIn(submission.uri.spec, "tab", params);
    
    
          this.value = '';
              
          this.currentEngine = this.engines ? this.engines[0] : this._engines[0];
        };
    
        }());
    Alles anzeigen
  • Offenbar funktionieren alle Benutzerskripte nicht mehr im Nightly

    • Boersenfeger
    • 9. Juni 2023 um 15:43
    Zitat von milupo

    Hast du nach der Änderung den Skript-Cache beim Neustart von Firefox geleert?

    Natööörlich, mit dem RestartScript von Aris ;)

    Ich teste jetzt mal Sörens Hinweis...

  • Offenbar funktionieren alle Benutzerskripte nicht mehr im Nightly

    • Boersenfeger
    • 9. Juni 2023 um 15:01

    Ich nutze nachfolgendes Script, in dem FormHistory.jsm drin vorkommt. Mit dieser Schreibweise [Zeile 7] funktioniert es (im Nightly, Release nicht getestet) Wenn ich den Code umschreibe [Zeile 8], funktioniert es nicht mehr. Ist der Terminus (noch) nicht betroffen oder mache ich was falsch?

    JavaScript
    /* Suchfeld automatisch leeren */
    
        (function() {
        const lazy = {};
    
        XPCOMUtils.defineLazyModuleGetters(lazy, {
        FormHistory: "resource://gre/modules/FormHistory.jsm",
        //FormHistory: "resource://gre/modules/FormHistory.sys.mjs",
        });
    
        var searchbar = document.getElementById("searchbar");
        
        searchbar.doSearch = function(aData, aWhere, aEngine, aParams, aOneOff) {
        let textBox = this._textbox;
    
    
          if (aData && !PrivateBrowsingUtils.isWindowPrivate(window) && lazy.FormHistory.enabled) {
            lazy.FormHistory.update({
                op: "bump",
                fieldname: textBox.getAttribute("autocompletesearchparam"),
                value: aData,
            }, {
                handleError(aError) {
                  Cu.reportError("Saving search to form history failed: " + aError.message);
                },
            });
          }
    
    
          let engine = aEngine || this.currentEngine;
          let submission = engine.getSubmission(aData, null, "searchbar");
          let telemetrySearchDetails = this.telemetrySearchDetails;
          this.telemetrySearchDetails = null;
          if (telemetrySearchDetails && telemetrySearchDetails.index == -1) {
            telemetrySearchDetails = null;
          }
    
    
          const details = {
            isOneOff: aOneOff,
            isSuggestion: (!aOneOff && telemetrySearchDetails),
            selection: telemetrySearchDetails,
          };
         // BrowserSearch.recordSearchInTelemetry(engine, "searchbar", details);
    
    
          let params = {
            postData: submission.postData,
          };
          if (aParams) {
            for (let key in aParams) {
              params[key] = aParams[key];
            }
          }
          openTrustedLinkIn(submission.uri.spec, "tab", params);
    
    
          this.value = '';
              
          this.currentEngine = this.engines ? this.engines[0] : this._engines[0];
        };
    
        }());
    Alles anzeigen

    BTW: Nightly spricht mit der heutigen Version wieder Deutsch ;)

  • Offenbar funktionieren alle Benutzerskripte nicht mehr im Nightly

    • Boersenfeger
    • 8. Juni 2023 um 14:39
    Zitat von Endor

    Nur als Hinweis, davon gibt es eine neuere Version:

    https://github.com/Aris-t2/Custom…_restorer.uc.js

    Danke, installiert und Änderungen eingepflegt. :)

  • Offenbar funktionieren alle Benutzerskripte nicht mehr im Nightly

    • Boersenfeger
    • 8. Juni 2023 um 13:40

    Das genau wollte ich klären, danke; dann bin ich nun auf dem Laufendem :P

  • Offenbar funktionieren alle Benutzerskripte nicht mehr im Nightly

    • Boersenfeger
    • 8. Juni 2023 um 13:19

    Würde das Selbe auch für Aris Restart Script gelten.. Zeile 14+15? :)

  • Offenbar funktionieren alle Benutzerskripte nicht mehr im Nightly

    • Boersenfeger
    • 8. Juni 2023 um 12:23
    JavaScript
    /* Space_and_Separator_Restorer.uc.js*/
    
    // Restore 'Space & Separator' items script for Firefox 60+ by Aris
    //
    // Default browser scripts always remove spaces and separators from default palette, so
    // because of that they are added to an own toolbar now.
    //
    // - spaces and separators can be moved to any toolbar
    // - to remove spaces or separators move them into palette
    // - configuration toolbar behaves like a default toolbar, items and buttons can be placed on it
    // - configuration toolbar is not visible outside customizing mode
    // - default "Flexible Space" item is hidden from palette and added to configuration toolbar
    // [!] BUG: do not move spaces, flexible spaces or separator to configuration toolbar or it will cause glitches
    // [!] BUG: do not move main 'space'-item to palette or it will be hidden until customizing mode gets reopened
    
    // [!] Fix for WebExtensions with own windows by 黒仪大螃蟹 (for 1-N scripts)
    
    
    Components.utils.import("resource:///modules/CustomizableUI.jsm");
    var {Services} = Components.utils.import("resource://gre/modules/Services.jsm", {});
    var appversion = parseInt(Services.appinfo.version);
    
    var AddSeparator = {
      init: function() {
          
        /* blank tab workaround */
        try {
          if(gBrowser.selectedBrowser.getAttribute('blank')) gBrowser.selectedBrowser.removeAttribute('blank');
        } catch(e) {}
          
        var tb_config_label = "Configuration Toolbar";
        var tb_spacer_label = "Space";
        var tb_sep_label = "Separator";
        var tb_spring_label = "Flexible Space";
          
        try {
         if(document.getElementById('configuration_toolbar') == null) {
            
          if(appversion <= 62) var tb_config = document.createElement("toolbar");
          else var tb_config = document.createXULElement("toolbar");
          tb_config.setAttribute("id","configuration_toolbar");
          tb_config.setAttribute("customizable","true");
          tb_config.setAttribute("class","toolbar-primary chromeclass-toolbar browser-toolbar customization-target");
          tb_config.setAttribute("mode","icons");
          tb_config.setAttribute("iconsize","small");
          tb_config.setAttribute("toolboxid","navigator-toolbox");
          tb_config.setAttribute("lockiconsize","true");
          tb_config.setAttribute("ordinal","1005");
          tb_config.setAttribute("defaultset","toolbarspacer,toolbarseparator");
          
          document.querySelector('#navigator-toolbox').appendChild(tb_config);
          
          CustomizableUI.registerArea("configuration_toolbar", {legacy: true});
          if(appversion >= 65) CustomizableUI.registerToolbarNode(tb_config);
          
          if(appversion <= 62) var tb_label = document.createElement("label");
          else var tb_label = document.createXULElement("label");
          tb_label.setAttribute("label", tb_config_label+": ");
          tb_label.setAttribute("value", tb_config_label+": ");
          tb_label.setAttribute("id","tb_config_tb_label");
          tb_label.setAttribute("removable","false");
          
          tb_config.appendChild(tb_label);
          
          
          if(appversion <= 62) var tb_spacer = document.createElement("toolbarspacer");
          else var tb_spacer = document.createXULElement("toolbarspacer");
          tb_spacer.setAttribute("id","spacer");
          tb_spacer.setAttribute("class","chromeclass-toolbar-additional");
          tb_spacer.setAttribute("customizableui-areatype","toolbar");
          tb_spacer.setAttribute("removable","false");
          tb_spacer.setAttribute("label", tb_spacer_label);
          
          tb_config.appendChild(tb_spacer);
        
          
          if(appversion <= 62) var tb_sep = document.createElement("toolbarseparator");
          else var tb_sep = document.createXULElement("toolbarseparator");
          tb_sep.setAttribute("id","separator");
          tb_sep.setAttribute("class","chromeclass-toolbar-additional");
          tb_sep.setAttribute("customizableui-areatype","toolbar");
          tb_sep.setAttribute("removable","false");
          tb_sep.setAttribute("label", tb_sep_label);
           
          tb_config.appendChild(tb_sep);
          
         
          if(appversion <= 62) var tb_spring = document.createElement("toolbarspring");
          else var tb_spring = document.createXULElement("toolbarspring");
          tb_spring.setAttribute("id","spring");
          tb_spring.setAttribute("class","chromeclass-toolbar-additional");
          tb_spring.setAttribute("customizableui-areatype","toolbar");
          tb_spring.setAttribute("removable","false");
          tb_spring.setAttribute("label", tb_spring_label);
                
          tb_config.appendChild(tb_spring);
            
          // CSS
          var sss = Components.classes["@mozilla.org/content/style-sheet-service;1"].getService(Components.interfaces.nsIStyleSheetService);
    
          var uri = Services.io.newURI("data:text/css;charset=utf-8," + encodeURIComponent('\
          \
            #configuration_toolbar { \
              -moz-appearance: none !important; \
              background-color: var(--toolbar-bgcolor); \
              background-image: var(--toolbar-bgimage); \
              background-clip: padding-box; \
              color: var(--toolbar-color, inherit); \
            } \
            #main-window:not([customizing]) #configuration_toolbar { \
              visibility: collapse; \
            }\
            #main-window[customizing] #configuration_toolbar #tb_config_tb_label { \
              font-weight: bold !important; \
            }\
            #main-window[customizing] #configuration_toolbar :-moz-any(#spacer,#separator,#spring) { \
              -moz-margin-start: 20px; \
            }\
            #main-window[customizing] #configuration_toolbar :-moz-any(#wrapper-spacer,#wrapper-separator,#wrapper-spring) .toolbarpaletteitem-label { \
              display: block !important; \
              -moz-margin-end: 20px; \
            }\
            #main-window[customizing] #wrapper-spacer #spacer { \
              margin: 2px 0 !important; \
            }\
            #main-window[customizing] #configuration_toolbar #wrapper-spring #spring { \
              margin: -1px 0 !important; \
              min-width: 80px !important; \
            }\
            #main-window[customizing] #configuration_toolbar > * { \
              padding: 10px !important; \
            }\
            #main-window[customizing] #configuration_toolbar > :-moz-any(#wrapper-spacer,#wrapper-separator,#wrapper-spring) { \
              border: 1px dotted !important; \
              -moz-margin-start: 2px !important; \
              -moz-margin-end: 2px !important; \
            }\
            #main-window[customizing] toolbarspacer { \
              border: 1px solid !important; \
            }\
            toolbar[orient="vertical"] toolbarseparator { \
              -moz-appearance: none !important; \
              border-top: 1px solid rgba(15,17,38, 0.5) !important; \
              border-bottom: 1px solid rgba(255,255,255, 0.3) !important; \
              margin: 2px 2px !important; \
              height: 1px !important; \
              width: 18px !important; \
            }\
            toolbar[orient="vertical"] toolbarspacer { \
              -moz-appearance: none !important; \
              height: 18px !important; \
              width: 18px !important; \
            }\
            #customization-palette toolbarpaletteitem[id^="wrapper-customizableui-special-spring"], \
            #customization-palette-container :-moz-any(#spring,#wrapper-spring) { \
              display: none !important; \
            }\
          \
          '), null, null);
    
          sss.loadAndRegisterSheet(uri, sss.AGENT_SHEET);
         }
        } catch(e){}
    
      }
    
    }
    
    /* initialization delay workaround */
    document.addEventListener("DOMContentLoaded", AddSeparator.init(), false);
    /*
    setTimeout(function(){
      AddSeparator.init();
    },1000);
    */
    Alles anzeigen
  • Offenbar funktionieren alle Benutzerskripte nicht mehr im Nightly

    • Boersenfeger
    • 8. Juni 2023 um 12:23

    Ich habe noch 3 weitere Scripts mit diesem Eintrag:

    JavaScript
    // cssLive.uc.js
    (function() {
        if (location !=AppConstants.BROWSER_CHROME_URL) {
            return;
        }
    
    
        /*** OPTIONEN START *******************************************************/
        
        var cssLiveOptions = {
            /* Falls sich die Testdatei in einem Unterverzeichnis von "chrome" 
            befindet, bitte hier zwischen Anführungszeichen eintragen, ansonsten
            nur die Anführungszeichen */
            subdir: 'css',
            /* Name der Testdatei */
            file: 'Test.css'
        };
    
        /*** OPTIONEN ENDE ********************************************************/
        
        var buttonPath = '';
        var testFile = Services.dirsvc.get('UChrm', Ci.nsIFile);
        if( cssLiveOptions.subdir != '' ) {
            testFile.append( cssLiveOptions.subdir );
            buttonPath += cssLiveOptions.subdir + "/";
        }
        testFile.append( cssLiveOptions.file );
        buttonPath += cssLiveOptions.file;
        var buttonTxt_1 = buttonPath + " aufrufen";
        var buttonTxt_2 = buttonPath + " ausführen";
        var errorTxt = "Die Datei \n" + testFile.path + "\n existiert nicht.";
    
        Components.utils.import("resource:///modules/CustomizableUI.jsm");
    
        try {
            CustomizableUI.createWidget({
                id: "fp-get-css-file",
                defaultArea: CustomizableUI.AREA_NAVBAR,
                removable: true,
                label: buttonTxt_1,
                tooltiptext: buttonTxt_1,
                onClick: function() {
                    if( testFile.exists() ) {
                        testFile.launch();
                    } else {
                        alert( errorTxt );
                    }
                },
                onCreated: function(aNode) {
                    aNode.style.listStyleImage = 'url()';
                    return aNode;
                }
            });
        } catch (e) {
            Components.utils.reportError(e);
        };
    
    
        try {
            CustomizableUI.createWidget({
                id: "fp-register-css-file",
                defaultArea: CustomizableUI.AREA_NAVBAR,
                removable: true,
                label: buttonTxt_2,
                tooltiptext: buttonTxt_2,
                onClick: function() {
                    if( testFile.exists() ) {
                        var CI = Components.interfaces;
                        var CC = Components.classes;
                        let sss = CC["@mozilla.org/content/style-sheet-service;1"].getService( CI.nsIStyleSheetService );
                        let ios = CC["@mozilla.org/network/io-service;1"].getService( CI.nsIIOService );
                        let fileURL = Services.io.getProtocolHandler( 'file' ).QueryInterface( Ci.nsIFileProtocolHandler ).getURLSpecFromFile( testFile );
                        let uri = ios.newURI( fileURL , null , null );
                        sss.loadAndRegisterSheet( uri , sss.AGENT_SHEET );
                    } else {
                        alert( errorTxt );
                    }
                },
                onCreated: function(aNode) {
                    aNode.style.listStyleImage = 'url()';
                    return aNode;
                }
            });
        } catch (e) {
            Components.utils.reportError(e);
        }
    
    })();
    Alles anzeigen
    JavaScript
    // ==UserScript==
    // @name    Firefox_ToolBarButtons.uc.js
    // @charset UTF-8
    // Date        2019‎/06/12 Firefox Nightly 69.0a1 document.createXULElement('toolbarbutton'); → aDocument.createXULElement('toolbarbutton'); 書き換えました。
    // Date        2019‎/05/26 Firefox Nightly 69.0a1 createElement → createXULElement 書き換えました。
    // Date        2019‎/02/25 ページ情報ボタンの2つあるidを同じidにするのを忘れていたので修正しました。
    // Date        2019‎/02/20 タブ移動ボタンをホイールスクロールで左右のタブにフォーカスを移動(タブ切替え?)するようにしました。ズームコントロールボタンをホイールスクロールで拡大縮小するようにしました。開発ツールボタンとCookieとサイトデータを管理ボタンを追加しました。他いろいろ変更しました。
    // Date        2019‎/02/04 クッキー表示 は 開発ツールを表示するようにしてみた
    // Date        2019‎/02/02 idの重複修正 クッキー表示の修正
    // Date        2018‎/07/10 ボタンを追加+いろいろ変更しました。
    // Date        2018‎/05/03 アクティブタブを移動するボタンを追加しました。cssの多段タブでのタブ移動に便利? ショートカットキー(Ctrl+Shift+PageUp/PageDown)でタブ移動出来たりするので使うかはお好みで。
    // Date        2018‎/04/04 拡大縮小ボタンを追加しました。
    // Date        2018‎/02/05 GitHubのEndor8さんの所でボタンを増やしてくれていたのでそのまま日本語化だけしました。
    // Date     2018/01/16 2017/11/09版と同じようにボタンを一つにまとめ直しました。初期導入時、再起動するボタンのみツールバーに表示するようにしてみました。
    // Date     2017/11/23 ブックマーク、履歴、同期タブのサイドバーを開閉するボタンを追加して、個別に導入できるようにバラバラにしてみました。
    // Date     2017/11/09 RestartFirefoxButton_Movable.uc.js をベースに、再起動+ about:config、プロファイルフォルダ、クッキーマネージャのボタンをセットにしてみました。
    // @note    
    // @note    初期導入時、再起動するボタンのみツールバーに表示するようにしました。
    // @note    その他のボタンは、ツールバーのカスタマイズ内に格納されていると思います。
    // @note    カスタマイズから追加したいボタンを好きなところに出して使ってください。
    // @note    
    // @note    label と tooltiptext が環境によっては、文字化けするので、 Unicode に変換してます。
    // @note    
    // @note    再起動
    // @note    about:config
    // @note    新しいタブ
    // @note    プロファイルフォルダ
    // @note    クッキー (Firefox60ESR)
    // @note    ブックマーク サイドバー
    // @note    履歴 サイドバー
    // @note    同期タブ サイドバー
    // @note    ブラウジングライブラリー「ダウンロード」
    // @note    タブを更新(保存されているキャッシュを無視して更新)
    // @note    オプション
    // @note    プラグインについて
    // @note    ブラウジングライブラリー「ブックマーク」
    // @note    Chromeフォルダ
    // @note    ページ情報
    // @note    証明書マネージャー
    // @note    保存されたログイン情報
    // @note    履歴を削除
    // @note    拡大 (Ctrl++)
    // @note    縮小 (Ctrl+-)
    // @note    タブ移動(左:左にタブを移動|右:右にタブを移動|ホイール↑:左のタブに移動|ホイール↓:右のタブに移動)
    // @note    ズームコントロール (左 or ホイール↑: 拡大|中: リセット|右 or ホイール↓: 縮小)
    // @note    開発ツール
    // @note    Cookieとサイトデータを管理(一度Firefoxのオプションを開かないとCookieやサイトデータが表示されないようです。)
    // @note    カスタムボタン (左 or ホイール↑↓:新しいタブ | 中:about:config | 右:Chromeフォルダ)
    // @note    
    // @note    Firefox Nightly 69.0a1で動作確認しました。
    // @note    http://wiki.nothing.sh/page?userChrome.js%CD%D1%A5%B9%A5%AF%A5%EA%A5%D7%A5%C8#m5c944e2
    // @note    ↑ここの「サンドボックスが有効になった62以降でもuserChrome.js用スクリプトを利用する方法」を導入して確認しています。
    // @note
    // @note    Firefox60ESRなどでabout:系を使いたい場合 openTrustedLinkIn ⇒ openUILinkIn に変更してください。
    // @note
    // @note    Firefox61以降クッキーマネージャ?がCookieとサイトデータに変わり廃止されたのでクッキーマネージャ?を開くボタンが使え無くなります。
    // @note
    // @note    Firefox68以下でこのスクリプトを使いたい場合 aDocument.createXULElement ⇒ document.createElement に変更してください。
    // ==/UserScript==
    
    (function() {
        Components.utils.import("resource:///modules/CustomizableUI.jsm");
    
        try {
    //        Firefox neustarten
            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: 'Neustart',
                        tooltiptext: 'Linksklick: Firefox Neustart | Mittelklick: Firefox Neustart + Löschen des Skriptcaches',
                        style: 'list-style-image: url(%2F9hAAAACXBIWXMAAAsTAAALEwEAmpwYAAAKT2lDQ1BQaG90b3Nob3AgSUNDIHByb2ZpbGUAAHjanVNnVFPpFj333vRCS4iAlEtvUhUIIFJCi4AUkSYqIQkQSoghodkVUcERRUUEG8igiAOOjoCMFVEsDIoK2AfkIaKOg6OIisr74Xuja9a89%2BbN%2FrXXPues852zzwfACAyWSDNRNYAMqUIeEeCDx8TG4eQuQIEKJHAAEAizZCFz%2FSMBAPh%2BPDwrIsAHvgABeNMLCADATZvAMByH%2Fw%2FqQplcAYCEAcB0kThLCIAUAEB6jkKmAEBGAYCdmCZTAKAEAGDLY2LjAFAtAGAnf%2BbTAICd%2BJl7AQBblCEVAaCRACATZYhEAGg7AKzPVopFAFgwABRmS8Q5ANgtADBJV2ZIALC3AMDOEAuyAAgMADBRiIUpAAR7AGDIIyN4AISZABRG8lc88SuuEOcqAAB4mbI8uSQ5RYFbCC1xB1dXLh4ozkkXKxQ2YQJhmkAuwnmZGTKBNA%2Fg88wAAKCRFRHgg%2FP9eM4Ors7ONo62Dl8t6r8G%2FyJiYuP%2B5c%2BrcEAAAOF0ftH%2BLC%2BzGoA7BoBt%2FqIl7gRoXgugdfeLZrIPQLUAoOnaV%2FNw%2BH48PEWhkLnZ2eXk5NhKxEJbYcpXff5nwl%2FAV%2F1s%2BX48%2FPf14L7iJIEyXYFHBPjgwsz0TKUcz5IJhGLc5o9H%2FLcL%2F%2Fwd0yLESWK5WCoU41EScY5EmozzMqUiiUKSKcUl0v9k4t8s%2BwM%2B3zUAsGo%2BAXuRLahdYwP2SycQWHTA4vcAAPK7b8HUKAgDgGiD4c93%2F%2B8%2F%2FUegJQCAZkmScQAAXkQkLlTKsz%2FHCAAARKCBKrBBG%2FTBGCzABhzBBdzBC%2FxgNoRCJMTCQhBCCmSAHHJgKayCQiiGzbAdKmAv1EAdNMBRaIaTcA4uwlW4Dj1wD%2FphCJ7BKLyBCQRByAgTYSHaiAFiilgjjggXmYX4IcFIBBKLJCDJiBRRIkuRNUgxUopUIFVIHfI9cgI5h1xGupE7yAAygvyGvEcxlIGyUT3UDLVDuag3GoRGogvQZHQxmo8WoJvQcrQaPYw2oefQq2gP2o8%2BQ8cwwOgYBzPEbDAuxsNCsTgsCZNjy7EirAyrxhqwVqwDu4n1Y8%2BxdwQSgUXACTYEd0IgYR5BSFhMWE7YSKggHCQ0EdoJNwkDhFHCJyKTqEu0JroR%2BcQYYjIxh1hILCPWEo8TLxB7iEPENyQSiUMyJ7mQAkmxpFTSEtJG0m5SI%2BksqZs0SBojk8naZGuyBzmULCAryIXkneTD5DPkG%2BQh8lsKnWJAcaT4U%2BIoUspqShnlEOU05QZlmDJBVaOaUt2ooVQRNY9aQq2htlKvUYeoEzR1mjnNgxZJS6WtopXTGmgXaPdpr%2Bh0uhHdlR5Ol9BX0svpR%2BiX6AP0dwwNhhWDx4hnKBmbGAcYZxl3GK%2BYTKYZ04sZx1QwNzHrmOeZD5lvVVgqtip8FZHKCpVKlSaVGyovVKmqpqreqgtV81XLVI%2BpXlN9rkZVM1PjqQnUlqtVqp1Q61MbU2epO6iHqmeob1Q%2FpH5Z%2FYkGWcNMw09DpFGgsV%2FjvMYgC2MZs3gsIWsNq4Z1gTXEJrHN2Xx2KruY%2FR27iz2qqaE5QzNKM1ezUvOUZj8H45hx%2BJx0TgnnKKeX836K3hTvKeIpG6Y0TLkxZVxrqpaXllirSKtRq0frvTau7aedpr1Fu1n7gQ5Bx0onXCdHZ4%2FOBZ3nU9lT3acKpxZNPTr1ri6qa6UbobtEd79up%2B6Ynr5egJ5Mb6feeb3n%2Bhx9L%2F1U%2FW36p%2FVHDFgGswwkBtsMzhg8xTVxbzwdL8fb8VFDXcNAQ6VhlWGX4YSRudE8o9VGjUYPjGnGXOMk423GbcajJgYmISZLTepN7ppSTbmmKaY7TDtMx83MzaLN1pk1mz0x1zLnm%2Beb15vft2BaeFostqi2uGVJsuRaplnutrxuhVo5WaVYVVpds0atna0l1rutu6cRp7lOk06rntZnw7Dxtsm2qbcZsOXYBtuutm22fWFnYhdnt8Wuw%2B6TvZN9un2N%2FT0HDYfZDqsdWh1%2Bc7RyFDpWOt6azpzuP33F9JbpL2dYzxDP2DPjthPLKcRpnVOb00dnF2e5c4PziIuJS4LLLpc%2BLpsbxt3IveRKdPVxXeF60vWdm7Obwu2o26%2FuNu5p7ofcn8w0nymeWTNz0MPIQ%2BBR5dE%2FC5%2BVMGvfrH5PQ0%2BBZ7XnIy9jL5FXrdewt6V3qvdh7xc%2B9j5yn%2BM%2B4zw33jLeWV%2FMN8C3yLfLT8Nvnl%2BF30N%2FI%2F9k%2F3r%2F0QCngCUBZwOJgUGBWwL7%2BHp8Ib%2BOPzrbZfay2e1BjKC5QRVBj4KtguXBrSFoyOyQrSH355jOkc5pDoVQfujW0Adh5mGLw34MJ4WHhVeGP45wiFga0TGXNXfR3ENz30T6RJZE3ptnMU85ry1KNSo%2Bqi5qPNo3ujS6P8YuZlnM1VidWElsSxw5LiquNm5svt%2F87fOH4p3iC%2BN7F5gvyF1weaHOwvSFpxapLhIsOpZATIhOOJTwQRAqqBaMJfITdyWOCnnCHcJnIi%2FRNtGI2ENcKh5O8kgqTXqS7JG8NXkkxTOlLOW5hCepkLxMDUzdmzqeFpp2IG0yPTq9MYOSkZBxQqohTZO2Z%2Bpn5mZ2y6xlhbL%2BxW6Lty8elQfJa7OQrAVZLQq2QqboVFoo1yoHsmdlV2a%2FzYnKOZarnivN7cyzytuQN5zvn%2F%2FtEsIS4ZK2pYZLVy0dWOa9rGo5sjxxedsK4xUFK4ZWBqw8uIq2Km3VT6vtV5eufr0mek1rgV7ByoLBtQFr6wtVCuWFfevc1%2B1dT1gvWd%2B1YfqGnRs%2BFYmKrhTbF5cVf9go3HjlG4dvyr%2BZ3JS0qavEuWTPZtJm6ebeLZ5bDpaql%2BaXDm4N2dq0Dd9WtO319kXbL5fNKNu7g7ZDuaO%2FPLi8ZafJzs07P1SkVPRU%2BlQ27tLdtWHX%2BG7R7ht7vPY07NXbW7z3%2FT7JvttVAVVN1WbVZftJ%2B7P3P66Jqun4lvttXa1ObXHtxwPSA%2F0HIw6217nU1R3SPVRSj9Yr60cOxx%2B%2B%2Fp3vdy0NNg1VjZzG4iNwRHnk6fcJ3%2FceDTradox7rOEH0x92HWcdL2pCmvKaRptTmvtbYlu6T8w%2B0dbq3nr8R9sfD5w0PFl5SvNUyWna6YLTk2fyz4ydlZ19fi753GDborZ752PO32oPb%2B%2B6EHTh0kX%2Fi%2Bc7vDvOXPK4dPKy2%2BUTV7hXmq86X23qdOo8%2FpPTT8e7nLuarrlca7nuer21e2b36RueN87d9L158Rb%2F1tWeOT3dvfN6b%2FfF9%2FXfFt1%2Bcif9zsu72Xcn7q28T7xf9EDtQdlD3YfVP1v%2B3Njv3H9qwHeg89HcR%2FcGhYPP%2FpH1jw9DBY%2BZj8uGDYbrnjg%2BOTniP3L96fynQ89kzyaeF%2F6i%2FsuuFxYvfvjV69fO0ZjRoZfyl5O%2FbXyl%2FerA6xmv28bCxh6%2ByXgzMV70VvvtwXfcdx3vo98PT%2BR8IH8o%2F2j5sfVT0Kf7kxmTk%2F8EA5jz%2FGMzLdsAAAAEZ0FNQQAAsY58%2B1GTAAAAIGNIUk0AAHolAACAgwAA%2Bf8AAIDpAAB1MAAA6mAAADqYAAAXb5JfxUYAAAN8SURBVHjaVJFNTBxlAIafb2Z29gd2l4VdYCkokAUt1AJplQRTrVqjUWMPPWHSCzb21IOn9qIHY2xMahoTTb00NmkUm5qAjdpUI61VaCxCpCVYixt%2ByvKzCwu7LDs7zMw3HmhM%2Bt6fJ0%2FyCp69wiOzZBCPcqSmIXg0HPHuC4R8nkLWyOXyYiIzfuVHzMIA%2BZsLtH18EApntUdhpzUSD5577nDLi%2FGWKjx%2BHVfR8HpFwNwsxTMzza%2BOXJ1%2B58Ev2sVEV%2ByEawXqxf8FllNWEQ9ePXzsqQOecIDU8jampSAVD76Al2BIIx4Dv2Nz7%2FYq%2B5%2BP8sNXE6WdAhdQlOM9rzUdaGiN8M9UjnKvQjzuA0UjV3AxDIcHywqRoEbXoVrKgyBtKXYEUvprmiN9oaoyvr9wl62NHJbtJeDzOo17YmprVzWOppLO2RRNwf1FSOzSUAXsCIR4QdP13UPfjhUde2mjuBXUjcXNEabOnJmq7Y4Nd7z1fu%2BJ%2FR2Jpgrm0jauAI8GlnSlBi4I0bO6sLBWHc9esxRdmjOZf5n%2B5CLWzCzOvsbKupBZ1xgmElUoC%2BgoKtRGQfNomoaND8P8XS%2Bby1olO7O6GHTl1DejGDOrNB%2BvpO7I%2Ba31%2FDP9Z28YUmqoqhCKcG2EYD6ZMUTojZ8WHmsqD%2BI6wnWFajugCkuuZaV%2FZS47wp99R7E3LbxPV6rtr7dV1pmyuBWs3hr7dZ380LC2tzseffvUHm86C1JC2A%2FrGcn509cn%2BPvTk9ibc1R06qL91Ms1CadF000ll9rVS2VykLzVr0lHOgtpuJ9yUFyXxqhKZjbH2nJRI9IZwyw2kXjvXV%2FIOWgaBcc2a%2BtjdVXR1J3iBDx8QUpQUJAuJJclseogxz441H5vrPO72cm0VSyVPJq27ZaHm8ST3Y0M9d9Kkr19A1A1x4VIObTGBfNrsJ5XmE9b6KqgvrOGhr1Vns2sgeNIkXiigvHf1liZuHWZYjINSEXRVLewZjN6bYmYbvN4rcDvVzFKLnOpErMLBpvbklClznyyyPDA6DjTX3wJWICr%2Bnb3ffjXSGpl5Nxnn88uh2ORUCBaHfVQU%2BsjVuGhKqJT5lFYShr8fGH4j42bH53EnJ4EtgEEPQOTzHx9mqXLl9AT9TS82RvreOmVcMTXVh4JhIr5kp3LFu6u3Lk%2ByMylQazU3ENYAvw3AFUTimFqj5i7AAAAAElFTkSuQmCC)',
                        onclick: '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); \
                                  };'
                    };
                    for (var p in props)
                        toolbaritem.setAttribute(p, props[p]);
                    return toolbaritem;
                }
            });
    //        about:config öffnen
            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()',
                        onclick: 'if (event.button == 0) { \
                                            openTrustedLinkIn("about:config", "tab");\
                                     }; '
                    };
                    for (var p in props)
                        toolbaritem.setAttribute(p, props[p]);
                    return toolbaritem;
                }
            });
    //        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()',
                        onclick: 'if (event.button == 0) { \
                                      openTrustedLinkIn("about:newtab", "tabshifted");/*BrowserOpenTab(event);*/ \
                                     }; '
                    };
                    for (var p in props)
                        toolbaritem.setAttribute(p, props[p]);
                    return toolbaritem;
                }
            });
    //        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()',
                        onclick: 'if (event.button == 0) { \
                                      Services.dirsvc.get("ProfD", Ci.nsIFile).launch(); \
                                  }; '
                    };
                    for (var p in props)
                        toolbaritem.setAttribute(p, props[p]);
                    return toolbaritem;
                }
            });
    //        Cookies anzeigen
            CustomizableUI.createWidget({
                id: 'showCookies-ToolBarButton',
                type: 'custom',
                onBuild: function(aDocument) {            
                    let toolbaritem = aDocument.createXULElement('toolbarbutton');
                    let props = {
                        id: 'showCookies-ToolBarButton',
                        class: 'toolbarbutton-1 chromeclass-toolbar-additional',
                        label: 'Cookies',
                        tooltiptext: 'Cookies anzeigen',
                        style: 'list-style-image: url()',
                        onclick: 'if (event.button == 0) { \
                                         window.open("chrome://browser/content/preferences/cookies.xhtm","cookie","chrome,dialog,centerscreen,dependent"); \
                                      }; '
                    };
                    for (var p in props)
                        toolbaritem.setAttribute(p, props[p]);
                    return toolbaritem;
                }
            });    
    //        Lesezeichen-Seitenleiste Öffnen/Schließen
            CustomizableUI.createWidget({
                id: 'BookmarksSidebar-ToolBarButton',
                type: 'custom',
                defaultArea: CustomizableUI.AREAS,
                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()',
                        onclick: 'if (event.button == 0) { \
                                        SidebarUI.toggle("viewBookmarksSidebar"); \
                                     }; '
                    };
                    for (var p in props)
                        toolbaritem.setAttribute(p, props[p]);
                    return toolbaritem;
                }
            });
    //        Chronik-Seitenleiste Ö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()',
                        onclick: 'if (event.button == 0) { \
                                        SidebarUI.toggle("viewHistorySidebar"); \
                                     }; '
                    };
                    for (var p in props)
                        toolbaritem.setAttribute(p, props[p]);
                    return toolbaritem;
                }
            });
    //        Tabs-Seitenleiste Ö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: 'Tabs-Sidebar',
                        tooltiptext: 'Tabs-Sidebar öffnen/schließen',
                        style: 'list-style-image: url()',
                        onclick: 'if (event.button == 0) { \
                                        SidebarUI.toggle("viewTabsSidebar"); \
                                     }; '
                    };
                    for (var p in props)
                        toolbaritem.setAttribute(p, props[p]);
                    return toolbaritem;
                }
            });
    //      Weitere Schaltflächen
    //      DownloadsFenster öffnen
                 CustomizableUI.createWidget({
                 id: 'Download-button',
                 type: 'custom',
                 onBuild: function(aDocument) {         
                    let toolbaritem = aDocument.createXULElement('toolbarbutton');
                    let props = {
                       id: 'Download-button',
                       class: 'toolbarbutton-1 chromeclass-toolbar-additional',
                       removable: true,
                       label: 'Downloads',
                       accesskey: 'D',
                       tooltiptext: 'Download Fenster öffnen',
                       style: 'list-style-image: url()',
                       oncommand: "DownloadsPanel.showDownloadsHistory();"
                    };
                    for (var p in props)
                        toolbaritem.setAttribute(p, props[p]);
                    return toolbaritem;
                }
            });
    //      Lesezeichenmanager öffnen    
                 CustomizableUI.createWidget({
                 id: 'bookmarks-manager-button',
                 type: 'custom',
                 onBuild: function(aDocument) {         
                    let toolbaritem = aDocument.createXULElement('toolbarbutton');
                    let props = {
                       id: 'bookmarks-manager-button',
                       class: 'toolbarbutton-1 chromeclass-toolbar-additional',
                       label: 'Lesezeichen Manager',
                       tooltiptext: 'Lesezeichen Manager öffnen',
                       style: 'list-style-image: url()',
                       oncommand: "PlacesCommandHook.showPlacesOrganizer('AllBookmarks');"
                    };            
                    for (var p in props)
                       toolbaritem.setAttribute(p, props[p]);            
                    return toolbaritem;
                 }      
            });        
            
    //      Tabs neuladen ohne Cache
                 CustomizableUI.createWidget({
                 id: 'reload-skip-cache-button',
                 type: 'custom',
                 onBuild: function(aDocument) {         
                    let toolbaritem = aDocument.createXULElement('toolbarbutton');
                    let props = {
                       id: 'reload-skip-cache-button',
                       class: 'toolbarbutton-1 chromeclass-toolbar-additional',
                       removable: true,
                       label: 'Tab neu laden',
                       tooltiptext: 'Tab neu laden, ohne den Browsercache zu benutzen',
                       style: 'list-style-image: url()',
                       oncommand: "BrowserReloadSkipCache();"
                    };
                    for (var p in props)
                        toolbaritem.setAttribute(p, props[p]);
                    return toolbaritem;
                }
            });
    //      Einstellungen öffnen
                 CustomizableUI.createWidget({
                 id: 'Einstellungen-button',
                 type: 'custom',
                 onBuild: function(aDocument) {         
                    let toolbaritem = aDocument.createXULElement('toolbarbutton');
                    let props = {
                       id: 'Einstellungen-button',
                       class: 'toolbarbutton-1 chromeclass-toolbar-additional',
                       removable: true,
                       label: 'Einstellungen',
                       tooltiptext: 'Einstellungen-Button',
                       style: 'list-style-image: url()',
                       oncommand: "openPreferences();"
                    };
                    for (var p in props)
                        toolbaritem.setAttribute(p, props[p]);
                    return toolbaritem;
                }
            });
    //      about:plugins öffnen
                CustomizableUI.createWidget({
                id: 'aboutplugins-ToolBarButton',
                type: 'custom',
                onBuild: function(aDocument) {            
                    let toolbaritem = aDocument.createXULElement('toolbarbutton');
                    let props = {
                        id: 'aboutplugins-ToolBarButton',
                        class: 'toolbarbutton-1 chromeclass-toolbar-additional',
                        label: 'About:Plugins',
                        tooltiptext: 'About:Plugins öffnen',
                        style: 'list-style-image: url()',
                        onclick: 'if (event.button == 0) { \
                                            openTrustedLinkIn("about:plugins", "tab");\
                                     }; '
                    };
                    for (var p in props)
                        toolbaritem.setAttribute(p, props[p]);
                    return toolbaritem;
                }
            });        
    //      Chrome Ordner öffnen
                 CustomizableUI.createWidget({
                 id: 'Open-Chrome-Folderbutton',
                 type: 'custom',
                 onBuild: function(aDocument) {         
                    let toolbaritem = aDocument.createXULElement('toolbarbutton');
                    let props = {
                       id: 'Open-Chrome-Folderbutton',
                       class: 'toolbarbutton-1 chromeclass-toolbar-additional',
                       removable: true,
                       label: 'Chrome Ordner',
                       tooltiptext: 'Chrome Ordner öffnen',
                       style: 'list-style-image: url()',
                       oncommand: 'Services.dirsvc.get("UChrm", Ci.nsIFile).launch();'
                    };            
                    for (var p in props)
                       toolbaritem.setAttribute(p, props[p]);            
                    return toolbaritem;
                 }      
              });
    //        Seiteninformationen anzeigen
                 CustomizableUI.createWidget({
                 id: 'context-viewinfo',
                 type: 'custom',
                 onBuild: function(aDocument) {         
                    let toolbaritem = aDocument.createXULElement('toolbarbutton');
                    let props = {
                       id: 'context-viewinfo',
                       class: 'toolbarbutton-1 chromeclass-toolbar-additional',
                       removable: true,
                       label: 'Seiteninformationen',
                       accesskey: 'i',
                       tooltiptext: 'Seiteninformationen anzeigen',
                       style: 'list-style-image: url()',
                       command: "View:PageInfo"
                    };            
                    for (var p in props)
                       toolbaritem.setAttribute(p, props[p]);            
                    return toolbaritem;
                 }      
              });
    //        Zertifikate Anzeigen
                 CustomizableUI.createWidget({
                 id: 'context-viewcert',
                 type: 'custom',
                 onBuild: function(aDocument) {         
                    let toolbaritem = aDocument.createXULElement('toolbarbutton');
                    let props = {
                       id: 'context-viewcert',
                       class: 'toolbarbutton-1 chromeclass-toolbar-additional',
                       removable: true,
                       label: 'Zertifikate',
                       tooltiptext: 'Zertifikate anzeigen',
                       style: 'list-style-image: url()',
                       oncommand: "window.open('chrome://pippki/content/certManager.xhtml', 'mozilla:certmanager', 'chrome,resizable=yes,all,width=830,height=400');"
                    };            
                    for (var p in props)
                       toolbaritem.setAttribute(p, props[p]);            
                    return toolbaritem;
                 }      
              });
    //      Passwörter anzeigen          
                 CustomizableUI.createWidget({
                 id: 'context-viewpassword',
                 type: 'custom',
                 onBuild: function(aDocument) {         
                    let toolbaritem = aDocument.createXULElement('toolbarbutton');
                    let props = {
                       id: 'context-viewpassword',
                       class: 'toolbarbutton-1 chromeclass-toolbar-additional',
                       removable: true,
                       label: 'Passwörter',
                       tooltiptext: 'Passwörter anzeigen',
                       style: 'list-style-image: url()',
                       onclick: 'if (event.button == 0) { \
                                        window.open("chrome://passwordmgr/content/passwordManager.xhtml","PasswordManager","chrome,dialog,centerscreen,dependent,resizable"); \
                                     }; '
                    };            
                    for (var p in props)
                       toolbaritem.setAttribute(p, props[p]);            
                    return toolbaritem;
                 }      
              });
    //       Chronik löschen öffnen
                 CustomizableUI.createWidget({
                 id: 'context-deletehistory',
                 type: 'custom',
                 onBuild: function(aDocument) {         
                    let toolbaritem = aDocument.createXULElement('toolbarbutton');
                    let props = {
                       id: 'context-deletehistory',
                       class: 'toolbarbutton-1 chromeclass-toolbar-additional',
                       removable: true,
                       label: 'Chronik löschen',
                       tooltiptext: 'Chronik löschen',
                       style: 'list-style-image: url()',
                       oncommand: "window.open('chrome://browser/content/sanitize.xhtml', 'Toolkit:SanitizeDialog', 'chrome,resizable=yes');"
                    };            
                    for (var p in props)
                       toolbaritem.setAttribute(p, props[p]);            
                    return toolbaritem;
                 }      
              });    
    //      Zoom 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()',
                        oncommand: "FullZoom.enlarge()"
                    };
                    for (let p in props)
                        toolbaritem.setAttribute(p, props[p]);
                    return toolbaritem;
                }
            });
    //      Zoom 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()',
                        oncommand: "FullZoom.reduce()"
                    };
                    for (let p in props)
                        toolbaritem.setAttribute(p, props[p]);
                    return toolbaritem;
                }
            });
    //      Aktiven Tab verschieben
            CustomizableUI.createWidget({
                id: 'moveTab-ToolBarButton',
                type: 'custom',
                onBuild: function(aDocument) {
                    let toolbaritem = aDocument.createXULElement('toolbarbutton');
                    let props = {
                        id: 'moveTab-ToolBarButton',
                        class: 'toolbarbutton-1 chromeclass-toolbar-additional',
                        oncontextmenu: 'return(false);',
                        label: 'Tab verschieben',
                        tooltiptext: 'Tabs verschieben linke Maustaste: nach links, Rechte Maustaste: nach rechts bewegen Rad: aufwärts Tab nach Links, Rab abwärts Tab nach rechts',
                        style: 'list-style-image: url()',
                        onclick: 'if (event.button == 0) { \
                                      gBrowser.moveTabBackward(); \
                                  }; \
                                  if (event.button == 2) { \
                                      gBrowser.moveTabForward(); \
                                  };',
                        onwheel: 'if (event.deltaY < 0) { \
                                      gBrowser.tabContainer.advanceSelectedTab(-1, true); \
                                  } else { \
                                      gBrowser.tabContainer.advanceSelectedTab(1, true); \
                                  };'
                    };
                    for (let p in props)
                        toolbaritem.setAttribute(p, props[p]);
                    return toolbaritem;
                }
            });
    //      Zoom Steuerung
            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: 'Zoomsteuerung',
                        tooltiptext: 'Linksklick oder Rad ↑: Vergrößern | Mitte: 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;
                }
            });
    //      Cookies und Websitedaten verwalten (Cookies und Websitedaten werden anscheinend nur angezeigt, wenn Sie die Firefox-Option einmal öffnen.)
            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 Websitedaten verwalten',
                        tooltiptext: 'Cookie- und Site-Datenverwaltung anzeigen (Firefox-Option muss anscheinend aber zuerst einmal geöffnet werden)',
                        style: 'list-style-image: url()',
                        onclick: 'if (event.button == 0) { \
                                      window.open("chrome://browser/content/preferences/siteDataSettings.xhtml","cookie","chrome,dialog,centerscreen,dependent,resizable,width=700,height=560"); \
                                  }; '
                    };
                    for (let p in props)
                        toolbaritem.setAttribute(p, props[p]);
                    return toolbaritem;
                }
            });
    //      Entwicklerwerkzeuge
            CustomizableUI.createWidget({
                id: 'toggleToolbox-ToolBarButton',
                type: 'custom',
                onBuild: function(aDocument) {
                    let toolbaritem = aDocument.createXULElement('toolbarbutton');
                    let props = {
                        id: 'toggleToolbox-ToolBarButton',
                        class: 'toolbarbutton-1 chromeclass-toolbar-additional',
                        label: 'Entwicklerwerkzeuge',
                        tooltiptext: 'Entwicklerwerkzeuge öffnen',
                        style: 'list-style-image: url()',
                        onclick: 'if (event.button == 0) { \
                                      let ev = new KeyboardEvent("keypress", {bubbles : true, cancelable : true, keyCode:  KeyboardEvent.DOM_VK_F9, shiftKey : true }); document.getElementById("main-window").dispatchEvent(ev); \
                                  }; '
                    };
                    for (let p in props)
                        toolbaritem.setAttribute(p, props[p]);
                    return toolbaritem;
                }
            });
    //      Benutzerdefinierte Schaltfläche
            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',
                        oncontextmenu: 'return(false);',
                        label: 'Benutzerdefinierte Schaltfläche',
                        tooltiptext: 'Links oder Rad ↑ ↓: Neuer Tab | Mitte: about: config | Rechts: Chrome-Ordner',
                        style: 'list-style-image: url()',
                        onclick: '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(); \
                                  };',
                        onwheel: 'if (event.deltaY < 0) { \
                                      openTrustedLinkIn("about:newtab", "tabshifted"); /* ホイールスクロール↑ */ \
                                  } else { \
                                      openTrustedLinkIn("about:newtab", "tabshifted"); /* ホイールスクロール↓ */ \
                                  };'
                    };
                    for (let p in props)
                        toolbaritem.setAttribute(p, props[p]);
                    return toolbaritem;
                }
            });          
              
              
              
        } catch(e) { };
    
    })();
    Alles anzeigen
    JavaScript
    // Restart button script for Firefox 60+ by Aris */
    //
    // left-click on restart button: normal restart
    // middle-click on restart button: restart + clear caches
    // right-click on restart button: restart + clear caches
    // Edit by 2002Andreas
    // based on 'Quit' button code by 2002Andreas
    // restart code from Classic Theme Restorer add-on
    // invalidate caches from Session Saver add-on
    
    (function() {
    
    try {
      Components.utils.import("resource:///modules/CustomizableUI.jsm");
      var {Services} = Components.utils.import("resource://gre/modules/Services.jsm", {});
      var sss = Components.classes["@mozilla.org/content/style-sheet-service;1"].getService(Components.interfaces.nsIStyleSheetService);
      
      var button_label = "Restart";
        
        try {
          switch (document.getElementById("nav-bar").getAttribute("aria-label")) {
            case "Navigations-Symbolleiste": button_label = "Neustarten"; break;
          }
        } catch(e) {}
      
      CustomizableUI.createWidget({
        id: "uc-restart", // button id
        defaultArea: CustomizableUI.AREA_NAVBAR,
        removable: true,
        label: button_label, // button title
        tooltiptext: button_label, // tooltip title
        onClick: function(event) {
          
          var cancelQuit   = Components.classes["@mozilla.org/supports-PRBool;1"].createInstance(Components.interfaces.nsISupportsPRBool);
          var observerSvc  = Components.classes["@mozilla.org/observer-service;1"].getService(Components.interfaces.nsIObserverService);
                
          if(event.button=='1') { // middle-click - clear caches
            Components.classes["@mozilla.org/xre/app-info;1"].getService(Components.interfaces.nsIXULRuntime).invalidateCachesOnRestart();
          }
          
          if(event.button=='0' || event.button=='2') { // left-click - restart/right-click - clear caches
            observerSvc.notifyObservers(cancelQuit, "quit-application-requested", "restart");
                
            if(cancelQuit.data) return false;
                    
            Services.startup.quit(Services.startup.eRestart | Services.startup.eAttemptQuit);
          }
        },
        onCreated: function(button) {
          return button;
        }
            
      });
      
      // style button icon
      var uri = Services.io.newURI("data:text/css;charset=utf-8," + encodeURIComponent('\
        \
          #uc-restart .toolbarbutton-icon {\
            list-style-image: url("%2F9hAAAACXBIWXMAAAsTAAALEwEAmpwYAAAKT2lDQ1BQaG90b3Nob3AgSUNDIHByb2ZpbGUAAHjanVNnVFPpFj333vRCS4iAlEtvUhUIIFJCi4AUkSYqIQkQSoghodkVUcERRUUEG8igiAOOjoCMFVEsDIoK2AfkIaKOg6OIisr74Xuja9a89%2BbN%2FrXXPues852zzwfACAyWSDNRNYAMqUIeEeCDx8TG4eQuQIEKJHAAEAizZCFz%2FSMBAPh%2BPDwrIsAHvgABeNMLCADATZvAMByH%2Fw%2FqQplcAYCEAcB0kThLCIAUAEB6jkKmAEBGAYCdmCZTAKAEAGDLY2LjAFAtAGAnf%2BbTAICd%2BJl7AQBblCEVAaCRACATZYhEAGg7AKzPVopFAFgwABRmS8Q5ANgtADBJV2ZIALC3AMDOEAuyAAgMADBRiIUpAAR7AGDIIyN4AISZABRG8lc88SuuEOcqAAB4mbI8uSQ5RYFbCC1xB1dXLh4ozkkXKxQ2YQJhmkAuwnmZGTKBNA%2Fg88wAAKCRFRHgg%2FP9eM4Ors7ONo62Dl8t6r8G%2FyJiYuP%2B5c%2BrcEAAAOF0ftH%2BLC%2BzGoA7BoBt%2FqIl7gRoXgugdfeLZrIPQLUAoOnaV%2FNw%2BH48PEWhkLnZ2eXk5NhKxEJbYcpXff5nwl%2FAV%2F1s%2BX48%2FPf14L7iJIEyXYFHBPjgwsz0TKUcz5IJhGLc5o9H%2FLcL%2F%2Fwd0yLESWK5WCoU41EScY5EmozzMqUiiUKSKcUl0v9k4t8s%2BwM%2B3zUAsGo%2BAXuRLahdYwP2SycQWHTA4vcAAPK7b8HUKAgDgGiD4c93%2F%2B8%2F%2FUegJQCAZkmScQAAXkQkLlTKsz%2FHCAAARKCBKrBBG%2FTBGCzABhzBBdzBC%2FxgNoRCJMTCQhBCCmSAHHJgKayCQiiGzbAdKmAv1EAdNMBRaIaTcA4uwlW4Dj1wD%2FphCJ7BKLyBCQRByAgTYSHaiAFiilgjjggXmYX4IcFIBBKLJCDJiBRRIkuRNUgxUopUIFVIHfI9cgI5h1xGupE7yAAygvyGvEcxlIGyUT3UDLVDuag3GoRGogvQZHQxmo8WoJvQcrQaPYw2oefQq2gP2o8%2BQ8cwwOgYBzPEbDAuxsNCsTgsCZNjy7EirAyrxhqwVqwDu4n1Y8%2BxdwQSgUXACTYEd0IgYR5BSFhMWE7YSKggHCQ0EdoJNwkDhFHCJyKTqEu0JroR%2BcQYYjIxh1hILCPWEo8TLxB7iEPENyQSiUMyJ7mQAkmxpFTSEtJG0m5SI%2BksqZs0SBojk8naZGuyBzmULCAryIXkneTD5DPkG%2BQh8lsKnWJAcaT4U%2BIoUspqShnlEOU05QZlmDJBVaOaUt2ooVQRNY9aQq2htlKvUYeoEzR1mjnNgxZJS6WtopXTGmgXaPdpr%2Bh0uhHdlR5Ol9BX0svpR%2BiX6AP0dwwNhhWDx4hnKBmbGAcYZxl3GK%2BYTKYZ04sZx1QwNzHrmOeZD5lvVVgqtip8FZHKCpVKlSaVGyovVKmqpqreqgtV81XLVI%2BpXlN9rkZVM1PjqQnUlqtVqp1Q61MbU2epO6iHqmeob1Q%2FpH5Z%2FYkGWcNMw09DpFGgsV%2FjvMYgC2MZs3gsIWsNq4Z1gTXEJrHN2Xx2KruY%2FR27iz2qqaE5QzNKM1ezUvOUZj8H45hx%2BJx0TgnnKKeX836K3hTvKeIpG6Y0TLkxZVxrqpaXllirSKtRq0frvTau7aedpr1Fu1n7gQ5Bx0onXCdHZ4%2FOBZ3nU9lT3acKpxZNPTr1ri6qa6UbobtEd79up%2B6Ynr5egJ5Mb6feeb3n%2Bhx9L%2F1U%2FW36p%2FVHDFgGswwkBtsMzhg8xTVxbzwdL8fb8VFDXcNAQ6VhlWGX4YSRudE8o9VGjUYPjGnGXOMk423GbcajJgYmISZLTepN7ppSTbmmKaY7TDtMx83MzaLN1pk1mz0x1zLnm%2Beb15vft2BaeFostqi2uGVJsuRaplnutrxuhVo5WaVYVVpds0atna0l1rutu6cRp7lOk06rntZnw7Dxtsm2qbcZsOXYBtuutm22fWFnYhdnt8Wuw%2B6TvZN9un2N%2FT0HDYfZDqsdWh1%2Bc7RyFDpWOt6azpzuP33F9JbpL2dYzxDP2DPjthPLKcRpnVOb00dnF2e5c4PziIuJS4LLLpc%2BLpsbxt3IveRKdPVxXeF60vWdm7Obwu2o26%2FuNu5p7ofcn8w0nymeWTNz0MPIQ%2BBR5dE%2FC5%2BVMGvfrH5PQ0%2BBZ7XnIy9jL5FXrdewt6V3qvdh7xc%2B9j5yn%2BM%2B4zw33jLeWV%2FMN8C3yLfLT8Nvnl%2BF30N%2FI%2F9k%2F3r%2F0QCngCUBZwOJgUGBWwL7%2BHp8Ib%2BOPzrbZfay2e1BjKC5QRVBj4KtguXBrSFoyOyQrSH355jOkc5pDoVQfujW0Adh5mGLw34MJ4WHhVeGP45wiFga0TGXNXfR3ENz30T6RJZE3ptnMU85ry1KNSo%2Bqi5qPNo3ujS6P8YuZlnM1VidWElsSxw5LiquNm5svt%2F87fOH4p3iC%2BN7F5gvyF1weaHOwvSFpxapLhIsOpZATIhOOJTwQRAqqBaMJfITdyWOCnnCHcJnIi%2FRNtGI2ENcKh5O8kgqTXqS7JG8NXkkxTOlLOW5hCepkLxMDUzdmzqeFpp2IG0yPTq9MYOSkZBxQqohTZO2Z%2Bpn5mZ2y6xlhbL%2BxW6Lty8elQfJa7OQrAVZLQq2QqboVFoo1yoHsmdlV2a%2FzYnKOZarnivN7cyzytuQN5zvn%2F%2FtEsIS4ZK2pYZLVy0dWOa9rGo5sjxxedsK4xUFK4ZWBqw8uIq2Km3VT6vtV5eufr0mek1rgV7ByoLBtQFr6wtVCuWFfevc1%2B1dT1gvWd%2B1YfqGnRs%2BFYmKrhTbF5cVf9go3HjlG4dvyr%2BZ3JS0qavEuWTPZtJm6ebeLZ5bDpaql%2BaXDm4N2dq0Dd9WtO319kXbL5fNKNu7g7ZDuaO%2FPLi8ZafJzs07P1SkVPRU%2BlQ27tLdtWHX%2BG7R7ht7vPY07NXbW7z3%2FT7JvttVAVVN1WbVZftJ%2B7P3P66Jqun4lvttXa1ObXHtxwPSA%2F0HIw6217nU1R3SPVRSj9Yr60cOxx%2B%2B%2Fp3vdy0NNg1VjZzG4iNwRHnk6fcJ3%2FceDTradox7rOEH0x92HWcdL2pCmvKaRptTmvtbYlu6T8w%2B0dbq3nr8R9sfD5w0PFl5SvNUyWna6YLTk2fyz4ydlZ19fi753GDborZ752PO32oPb%2B%2B6EHTh0kX%2Fi%2Bc7vDvOXPK4dPKy2%2BUTV7hXmq86X23qdOo8%2FpPTT8e7nLuarrlca7nuer21e2b36RueN87d9L158Rb%2F1tWeOT3dvfN6b%2FfF9%2FXfFt1%2Bcif9zsu72Xcn7q28T7xf9EDtQdlD3YfVP1v%2B3Njv3H9qwHeg89HcR%2FcGhYPP%2FpH1jw9DBY%2BZj8uGDYbrnjg%2BOTniP3L96fynQ89kzyaeF%2F6i%2FsuuFxYvfvjV69fO0ZjRoZfyl5O%2FbXyl%2FerA6xmv28bCxh6%2ByXgzMV70VvvtwXfcdx3vo98PT%2BR8IH8o%2F2j5sfVT0Kf7kxmTk%2F8EA5jz%2FGMzLdsAAAAEZ0FNQQAAsY58%2B1GTAAAAIGNIUk0AAHolAACAgwAA%2Bf8AAIDpAAB1MAAA6mAAADqYAAAXb5JfxUYAAAN8SURBVHjaVJFNTBxlAIafb2Z29gd2l4VdYCkokAUt1AJplQRTrVqjUWMPPWHSCzb21IOn9qIHY2xMahoTTb00NmkUm5qAjdpUI61VaCxCpCVYixt%2ByvKzCwu7LDs7zMw3HmhM%2Bt6fJ0%2FyCp69wiOzZBCPcqSmIXg0HPHuC4R8nkLWyOXyYiIzfuVHzMIA%2BZsLtH18EApntUdhpzUSD5577nDLi%2FGWKjx%2BHVfR8HpFwNwsxTMzza%2BOXJ1%2B58Ev2sVEV%2ByEawXqxf8FllNWEQ9ePXzsqQOecIDU8jampSAVD76Al2BIIx4Dv2Nz7%2FYq%2B5%2BP8sNXE6WdAhdQlOM9rzUdaGiN8M9UjnKvQjzuA0UjV3AxDIcHywqRoEbXoVrKgyBtKXYEUvprmiN9oaoyvr9wl62NHJbtJeDzOo17YmprVzWOppLO2RRNwf1FSOzSUAXsCIR4QdP13UPfjhUde2mjuBXUjcXNEabOnJmq7Y4Nd7z1fu%2BJ%2FR2Jpgrm0jauAI8GlnSlBi4I0bO6sLBWHc9esxRdmjOZf5n%2B5CLWzCzOvsbKupBZ1xgmElUoC%2BgoKtRGQfNomoaND8P8XS%2Bby1olO7O6GHTl1DejGDOrNB%2BvpO7I%2Ba31%2FDP9Z28YUmqoqhCKcG2EYD6ZMUTojZ8WHmsqD%2BI6wnWFajugCkuuZaV%2FZS47wp99R7E3LbxPV6rtr7dV1pmyuBWs3hr7dZ380LC2tzseffvUHm86C1JC2A%2FrGcn509cn%2BPvTk9ibc1R06qL91Ms1CadF000ll9rVS2VykLzVr0lHOgtpuJ9yUFyXxqhKZjbH2nJRI9IZwyw2kXjvXV%2FIOWgaBcc2a%2BtjdVXR1J3iBDx8QUpQUJAuJJclseogxz441H5vrPO72cm0VSyVPJq27ZaHm8ST3Y0M9d9Kkr19A1A1x4VIObTGBfNrsJ5XmE9b6KqgvrOGhr1Vns2sgeNIkXiigvHf1liZuHWZYjINSEXRVLewZjN6bYmYbvN4rcDvVzFKLnOpErMLBpvbklClznyyyPDA6DjTX3wJWICr%2Bnb3ffjXSGpl5Nxnn88uh2ORUCBaHfVQU%2BsjVuGhKqJT5lFYShr8fGH4j42bH53EnJ4EtgEEPQOTzHx9mqXLl9AT9TS82RvreOmVcMTXVh4JhIr5kp3LFu6u3Lk%2ByMylQazU3ENYAvw3AFUTimFqj5i7AAAAAElFTkSuQmCC");  \
            \
          }\
        \
      '), null, null);
      
      sss.loadAndRegisterSheet(uri, sss.AGENT_SHEET);
      
    } catch (e) {
        Components.utils.reportError(e);
    };
    
    })();
    Alles anzeigen

    Falls auch für andere interessant

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