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

  • browser.warnOnQuit Skript funktioniert im aktuellem Nightly nicht mehr

    • Endor
    • 2. Januar 2023 um 16:01

    Ja habe ich auch bemerkt.

    Ich mache da was falsch. Mal sehen.

    Mfg.
    Endor

  • browser.warnOnQuit Skript funktioniert im aktuellem Nightly nicht mehr

    • Endor
    • 2. Januar 2023 um 15:50

    Habe ich schon befürchtet.

    Denn in meinem Quellscript von alice sieht es noch etwas anders aus:

    Code
    ChromeUtils.import("resource://gre/modules/Services.jsm");
      ChromeUtils.importESModule(
        "resource://gre/modules/DownloadIntegration.sys.mjs"
       );

    Es geht da um eine andere Datei, aber das Prinzip müsste ähnlich sein.

    Quelle:

    userChrome.js/ucjsDownloadsManager.uc.js at 2d218dbf85c92d7a943014c235b829913bec8535 · alice0775/userChrome.js
    Contribute to alice0775/userChrome.js development by creating an account on GitHub.
    github.com

    Zeile 233 - 236


    Teste mal, keine Ahnung ob das funktioniert:

    Edit: Script da nicht funktioniert wieder entfernt.

  • browser.warnOnQuit Skript funktioniert im aktuellem Nightly nicht mehr

    • Endor
    • 2. Januar 2023 um 15:43

    Hallo 2002Andreas

    Teste mal:

    resource://gre/modules/BrowserGlue.sys.mjs

    Mfg.
    Endor

  • In memoriam

    • Endor
    • 29. Dezember 2022 um 20:14

    Edson Arantes do Nascimento, genannt Pelé, ist tot.

    Brasilianische Fußball-Legende Pelé gestorben
    Der frühere brasilianische Fußball-Star Pelé ist tot. Das bestätigte sein Agent. Seine Familie hatte sich an Weihnachten bereits im Krankenhaus versammelt. Der…
    www.tagesschau.de

    R.I.P.

    Mfg.
    Endor

  • Frohe Weihnachten und einen guten Rutsch

    • Endor
    • 25. Dezember 2022 um 19:01

    Auch von mir allen Frohe Weihnachten und einen guten Rutsch ins neue Jahr.
    Habe zwar keinen so edlen Tropfen wie .DeJaVu zur Hand, hoffe 1995er,
    aber ein Blauburgunder hier aus der Gegend tut es auch.

    Viele Grüße und bleib gesund.

    Mfg.
    Endor

  • Browser-Werkzeuge-Modus > Leiste ausblenden

    • Endor
    • 22. Dezember 2022 um 20:11

    Hallo 2002Andreas .

    Vielen Dank auch von meiner Seite.

    Habe ich gleich mal übernommen.
    :thumbup: :thumbup:
    Mfg.
    Endor

  • Quicklink-Button

    • Endor
    • 30. November 2022 um 17:25

    BrokenHeart

    Auch von meiner Seite vielen vielen Dank für das Script.
    Klasse Arbeit :thumbup: :thumbup:

    Funktioniert hier auch einwandfrei. Das im neuen Fenster zuerst
    ganz kurz die Seite Neuer Tab angezeigt wird, stört mich überhaupt nicht.

    Nochmals vielen Dank!

    Mfg.
    Endor

  • In memoriam

    • Endor
    • 30. November 2022 um 17:20

    Christiane Hörbiger ist tot.

    Schauspielerin Christiane Hörbiger ist tot
    Die 84-Jährige ist am Mittwoch in Wien gestorben, wie ein Freund der Familie bestätigt.
    www.sueddeutsche.de

    R.I.P.

    Mfg.
    Endor

  • Quicklink-Button

    • Endor
    • 24. November 2022 um 20:38

    Wenn mich nicht alles täuscht, verhindert der Browser aus Sicherheitsgründen, dass

    sich bei einem klick gleich mehrere neue Tabs mit Links öffnen. Da das nach einem Virus aussieht.
    Habe ich mal irgendwo gelesen. Finde die Seite im Moment leider nicht mehr.

    Hätte eine Älternative:

    Dieses Script hier öffnet je nach klick, also linksklick, rechtsklick, Mittelklick, usw.
    bis zu 9 verschiedene Adressen. Jeweils in einem neuen Tab.

    JavaScript
    // Customhomebutton.uc.js
    // Firefox 107 kompatibel
    // https://www.reddit.com/r/FirefoxCSS/comments/9klrpp/bookmark_buttons/
    // Linksklick: Camp-Firefox Forum, Mittelklick: Bild.de, Rechtsklick: Google News, Umschalt + Linksklick: Computerbase Forum, 
    // Strg + Linksklick: Thunderbird Mail Forum, Umschalttaste + Mitteklick: Stern.de, Strg + Mitteklick: Spiegel.de, 
    // Strg + Rechtsklick: ZDF.de, Umschalttaste + Rechtsklick: ARD.de
    // In Zeile 31 kann der Tooltip-Text den eigenen Wünschen entsprechend geändert werden. (\n fügt einen Zeilenumbruch an der entsprechenden Stelle ein.)
    // Text muss nur geändert werden, wenn man andere Internetadressen, URls, als die vorgegebenen, verwenden will.
    (function() 
        {
        if(location != 'chrome://browser/content/browser.xhtml') 
            return;
        
        try 
            {
            CustomizableUI.createWidget
                (
                {
                id: 'click-button',
                type: 'custom',
                defaultArea: CustomizableUI.AREA_NAVBAR,
                onBuild: function(aDocument) 
                    {            
                    var toolbaritem = aDocument.createElementNS('http://www.mozilla.org/keymaster/gatekeeper/there.is.only.xul', 'toolbarbutton');
                    toolbaritem.onclick = event => onClick(event);
                    var props = 
                        {
                        id: 'click-button',
                        class: 'toolbarbutton-1 chromeclass-toolbar-additional',
                        label: 'Benutzerdefinierte Home-Schaltfläche',
                        tooltiptext: 'Linksklick:    camp-firefox.de/Forum\nMittelklick:   Bild.de\nRechtsklick:  Google News\nStrg + Linksklick:    Thunderbird Forum\nStrg + Mittelklick:   Spiegel.de\nStrg + Rechtsklick:  ZDF.de\nUmschalttaste + Linksklick:    Computerbase Forum\nUmschalttaste + Mittelklick:   Stern.de\nUmschalttaste + Rechtsklick:  ARD.de',
                        style: 'list-style-image: url()'
                        };        
                    for(var p in props)
                        toolbaritem.setAttribute(p, props[p]);                
                    return toolbaritem;
                    }        
                }
                );
            } 
        catch(e) {};        
        
    function onClick(event) 
        {
        window.oncontextmenu = function () /*context menu = right-click*/
            {
            if (event.shiftKey)
                return true;
            else
                {
                openTrustedLinkIn('https://www.camp-firefox.de/forum/',"tab");
                return false;
                }
            }
        if(event.button == 0) /*left click*/
            {
            if (event.shiftKey)
                openTrustedLinkIn('https://www.computerbase.de/forum/',"tab");
            else if (event.ctrlKey)
                openTrustedLinkIn('https://www.camp-firefox.de/forum',"tab");
            else
                openTrustedLinkIn('https://www.thunderbird-mail.de/forum/',"tab");
            }
            
        else if(event.button == 1) /*middle click*/
               {
               if (event.shiftKey)
                openTrustedLinkIn('https://www.stern.de/',"tab");
            else if (event.ctrlKey)
                openTrustedLinkIn('https://www.spiegel.de/',"tab");
            else
                   openTrustedLinkIn('https://www.bild.de/',"tab");
               }    
        else if(event.button == 2) /*right click*/
               {
               if (event.shiftKey)
                openTrustedLinkIn('https://www.ard.de/',"tab");
            else if (event.ctrlKey)
                openTrustedLinkIn('https://www.zdf.de/',"tab");
            else
                   openTrustedLinkIn('https://news.google.com/',"tab");
                   return false;
            }    
            /*alert("Right mouse button")*/
    
        }
        }
    )
    ();
    Alles anzeigen

    Vielleicht hilft Dir das weiter.

    Mfg.

    Endor

  • Skript für Add-ons Update

    • Endor
    • 17. November 2022 um 11:35

    Hallo zusammen.

    Ich kann das: Skript für Add-ons Update hier auch bestätigen.

    Vielleicht kann aborix sich das mal anschauen.
    Wenn dann kann nur er es wieder richtig zum Laufen bringen.
    Mfg.
    Endor

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

    • Endor
    • 7. November 2022 um 17:56

    Hallo zusammen.

    Nur als Info für Leute die das Script expandsidebar.uc.js verwenden.

    Der Autor hat neue Versionen dafür veröffentlicht:

    Für Firefox 106

    JavaScript
    // ==UserScript==
    // @name           expandsidebar_fx58.uc.js
    // @description    Seitenleiste automatisches Öffnen und Schließen
    // @namespace      http://forums.mozillazine.org/viewtopic.php?p=2592073#2592073
    // @include        main
    // @compatibility  Firefox 106
    // @author         Alice0775
    // @Note           Seitenleistenposition bei _SIDEBARPOSITION wählbar (links oder rechts)
    // @Note           Keyconfig und Mousegesten usw. SidebarUI.toggle (entsprechender Code);
    // @Note
    // @version        2022/09/14 11:00 box width:auto
    // @version        2022/08/26 Bug 1695435 - Remove @@hasInstance for IDL interfaces in chrome context
    // @version        2021/11/14 21:00 css
    // @version        2021/11/14 13:00 no longer close when print preview
    // @version        2021/09/30 22:00 change splitter color
    // @version        2020/12/14 00:00 vtb
    // @version        2020/07/14 00:00 style
    // @version        2019/12/09 18:00 fix 72 Bug 1582530
    // @version        2019/12/05 18:00 fix 72 Bug 1492582 - browser.xhtml: Migrate root xul:window element to an html:html element
    // @version        2019/12/05 17:00 fix 71 Bug 1582530 - Turn on `layout.css.xul-box-display-values.survive-blockification.enabled` by default
    // @version        2019/12/05 10:00 fix 70 Bug 1558914 - Disable Array generics in Nightly
    // @version        2019/09/04 Fx69
    // @version        2018/07/03 Fx61 fix regression from remove loadoverlay
    // @version        2018/07/03 Fx61 remove loadoverlay
    // @version        2018/06/25 Fx61 wip
    // @version        2018/01/25 Fx58 wip
    // @version        2017/11/18 Fx57
    // @version        2017/11/18 nsIPrefBranch2 to nsIPrefBranch
    // @version        2017/02/01 00:00 enable floating(overlay) sidebar
    // @version        2017/01/19 00:00 change event phase,target
    // @version        2015/08/29 00:00 fix lastused command
    // @version        2015/05/13 19:00 fix lastused command
    // @version        2015/02/20 22:00 fix due to Bug 1123517
    // @version        2014/10/31 22:00 fix due to Bug 714675
    // @version        2014/05/22 12:00 fix var
    // @version        2013/03/03 00:00 fix It close too soon when it opened from a button or menu
    // @version        2013/02/26 00:00 fix close delay 
    // @version        2012/12/08 22:30 Bug 788290 Bug 788293 Remove E4X 
    // ==/UserScript==
    // @version        2012/08/04 09:00 private browsingを考慮
    // @version        2012/08/04 09:00 hiddenではなくcollapsedを使うように
    // @version        2012/02/08 14:00 splitter width in full screen
    // @version        2011/05/26 12:00 5.0a2でマウスが要素上通過する時, 移動速度が速すぎるとmouseoverイベントが発火しない? 感度が落ちた?
    // @version        2011/03/24 12:00 ドラッグオーバー遅延を別設定とした
    // @version        2010/10/30 18:00 http://hg.mozilla.org/mozilla-central/pushloghtml?fromchange=84baf90b040c&tochange=16eac4b8b8e0
    // @version        2010/10/09 18:00 Windows7 Aero
    // @version        2009/06/06 20:00 ドラッグオーバーで閉じてしまうので
    // @version        2009/05/24 18:00 chromeのチェック変更
    // @version        2009/04/30 18:00 サイドバーを開閉したときは必ずタイマーをクリアするようにした。
    // @version        2009/04/28 00:00 負荷軽減
    // @version        2009/04/23 00:00 _KEEP_SIZESが動かなくなっていたので
    // @version        2009/04/22 12:00 ドラッグオーバーで開かなくなっていたので
    // @version        2009/04/15 21:00 マウスが通過したときは開かないが動かなくなっていたので
    // @version        2009/04/15 19:00 細々bug修正
    // @version        2009/04/15 02:00 _CLOSEWHENGOOUTが動かなくなっていたので
    // @version        2009/04/14 22:00 fx2削除
    var ucjs_expand_sidebar = {
    // --- config ---
      //Anfang Konfiguration
      _OPEN_DELAY: 300,             //Zeitverzögerung zum Öffnen bei Mouseover
      _OPEN_DELAY_DRAGOVER: 400,    //Zeitverzögerung zum Öffnen per Dragover
      _CLOSE_DELAY: 800,            //Zeitverzögerung beim Schließen
      _SCROLLBAR_DELAY: 1000,       //Zeitverzögerung der Bildlaufleiste beim Öffnen / Schließen
      _DEFAULTCOMMAND: "viewBookmarksSidebar", // Standardseitenleiste
     _TOLERANCE: 0,                //Bereich, der als linke Kante des Fensters erkannt wird (0 kann bei Verwendung von TreeStyleTab usw. verwendet werden)
      _DONOTCLOSE_XULELEMENT: true, //Wenn sich die Maus auf einem XUL-Element befindet, nicht schließen 
                                    //(Wird nicht geschlossen, selbst wenn XUL im Inhalt angezeigt wird)
      _CLOSEWHENGOOUT:  false,  //Wenn sich die Maus aus dem Fenster bewegt: true: schließen, [false]: nicht schließen
      _FLOATING_SIDEBAR: true,  //Schwebende Seitenleiste (Überlagerung des Seiteninhalts) aktivieren, 
                                //(bekanntes Problem: Seitenleiste kann nicht skaliert werden = mit Maus breiter oder schmaler ziehen)
      _SIDEBARPOSITION: "L",    //Seitenleistenposition Linke Seite: L Rechte Seite: R
                                //VerticalToolbar.uc.js von Gomita - vertikale Symbolleiste 0.1 
                                //(http://www.xuldev.org/blog/?p=113) muss zuerst ausgeführt werden!
      _KEEP_SIZES:true,         //Breite für jeden Seitenleisten-Typ speichern
      _defaultWidth: 234,       //Standardbreite der Seitenleiste
      _inFullscreen: true,      //Bei Vollbild, Verhalten von Firefox 31 verwenden
      //Ende Konfiguration
    // --- config ---
    
      _MOUSEMOVEINTERVAL: 10,    //Intervall zum Überprüfen der Mausposition
      _CHECKBOX_AT_STARUP:false, //Kontrollkästchen beim Start anzeigen
      _CLOSE_AT_STARTUP:true,    //Seitenleiste beim Start geschlossen
      _lastcommand: null,
      _backup_lastcommand:null,
      _open_Timeout: null,
      _close_Timeout: null,
      _sidebar_box:null,
      _sidebar:null,
      _sidebar_splitter:null,
      _checkbox:null,
      _content:null,
      _opend:false,
      _mousedown:false,
      _mouse_Timeout: null,
      _resizeTimer: null,
      _mtimer: false,
      _startup:true,
    
      sizes:[],
      prefKeepItSizes: "userChrome.expandSidebar.keepItSizes",
    
      jsonToDOM: function(jsonTemplate, doc, nodes) {
        jsonToDOM.namespaces = {
        html: "http://www.w3.org/1999/xhtml",
        xul: "http://www.mozilla.org/keymaster/gatekeeper/there.is.only.xul"
        };
        jsonToDOM.defaultNamespace = jsonToDOM.namespaces.xul;
        function jsonToDOM(jsonTemplate, doc, nodes) {
          function namespace(name) {
              var reElemNameParts = /^(?:(.*):)?(.*)$/.exec(name);
              return { namespace: jsonToDOM.namespaces[reElemNameParts[1]], shortName: reElemNameParts[2] };
          }
    
          // Note that 'elemNameOrArray' is: either the full element name (eg. [html:]div) or an array of elements in JSON notation
          function tag(elemNameOrArray, elemAttr) {
            // Array of elements?  Parse each one...
            if (Array.isArray(elemNameOrArray)) {
              var frag = doc.createDocumentFragment();
              Array.prototype.forEach.call(arguments, function(thisElem) {
                frag.appendChild(tag.apply(null, thisElem));
              });
              return frag;
            }
    
            // Single element? Parse element namespace prefix (if none exists, default to defaultNamespace), and create element
            var elemNs = namespace(elemNameOrArray);
            var elem = doc.createElementNS(elemNs.namespace || jsonToDOM.defaultNamespace, elemNs.shortName);
    
            // Set element's attributes and/or callback functions (eg. onclick)
            for (var key in elemAttr) {
              var val = elemAttr[key];
              if (nodes && key == "keyvalue") {
                  nodes[val] = elem;
                  continue;
              }
    
              var attrNs = namespace(key);
              if (typeof val == "function") {
                // Special case for function attributes; don't just add them as 'on...' attributes, but as events, using addEventListener
                elem.addEventListener(key.replace(/^on/, ""), val, false);
              } else {
                // Note that the default namespace for XML attributes is, and should be, blank (ie. they're not in any namespace)
                elem.setAttributeNS(attrNs.namespace || "", attrNs.shortName, val);
              }
            }
    
            // Create and append this element's children
            var childElems = Array.prototype.slice.call(arguments, 2);
            childElems.forEach(function(childElem) {
              if (childElem != null) {
                elem.appendChild(
                    doc.defaultView.Node.isInstance(childElem)
                    /*childElem instanceof doc.defaultView.Node*/ ? childElem :
                        Array.isArray(childElem) ? tag.apply(null, childElem) :
                            doc.createTextNode(childElem));
              }
            });
            return elem;
          }
          return tag.apply(null, jsonTemplate);
        }
    
        return jsonToDOM(jsonTemplate, doc, nodes);
      },
    
      init: function(){
        if ("EzSidebarService" in window)
          return;
        this._sidebar_box = document.getElementById('sidebar-box');
    
        var style = ` 
        @namespace url(http://www.mozilla.org/keymaster/gatekeeper/there.is.only.xul);     
        #sidebar-checkbox {
          border: 1px solid currentColor !important;
          width: 16px !important;
          height: 16px !important;
          overflow-x: hidden !important;
        }
        
        #sidebar-splitter 
        { 
          -moz-box-align: center; 
          -moz-box-pack: center; 
          cursor: ew-resize; 
          border-width: 0 2px; 
          border-style: solid; 
          width: 2px; 
          max-width: 2px; 
          min-width: 0px; 
          background-color: var(--toolbar-bgcolor);
          border-inline-start-color: var(--toolbar-bgcolor);
          border-inline-end-color: var(--toolbar-bgcolor);
          margin-left: 0px; 
          margin-inline-start: 0px; 
        } 
        #navigator-toolbox[inFullscreen="true"] #sidebar-box[hidden="true"] + #sidebar-splitter, 
        :root[inFullscreen="true"] #sidebar-box[hidden="true"] + #sidebar-splitter 
        { 
          width: 0px; 
          max-width: 1px; 
          min-width: 0px; 
          border-left-width: 0px; 
          border-right-width: 1px; 
          background-color: ThreeDFace; 
        }  
        `;
        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);
        };
    
        if (this._FLOATING_SIDEBAR) {
          // floating css
          var floatingStyle = `
            @namespace url("http://www.mozilla.org/keymaster/gatekeeper/there.is.only.xul"); 
     
            #sidebar-box { 
            position: fixed ; 
            display: block; 
            z-index: 55555; 
                                           
            left: 4px; 
            }
            :root:not([lwtheme-image]) #sidebar-box { 
            background-color: var(--toolbar-bgcolor); 
            } 
            :root[lwtheme-image] #sidebar-box { 
            background-color: var(--tabpanel-background-color); 
            } 
    
            #sidebar-box #sidebar-header 
            { 
            width :100%; 
            } 
            #sidebar-box #sidebar 
            { 
                              
                            
            height: calc(100vh - 230px); 
            border-left:3px solid var(--toolbar-bgcolor); 
            border-right:3px solid var(--toolbar-bgcolor); 
            border-bottom:3px solid var(--toolbar-bgcolor); 
            } 
            #sidebar-box #sidebar:-moz-lwtheme
            { 
            border-left:3px solid var(--sidebar-background-color);
            border-right:3px solid var(--sidebar-background-color);
            border-bottom:3px solid var(--sidebar-background-color);
            } 
     
            #sidebar-box { 
              border-right: 1px solid var(--sidebar-border-color);
              border-bottom: 1px solid var(--sidebar-border-color); 
              
            } 
            #sidebar-box:-moz-locale-dir(rtl) { 
              border-left: 1px solid var(--sidebar-border-color); 
            } 
            #sidebar-box:-moz-lwtheme { 
              background-color: var(--sidebar-background-color);
            } 
            #sidebar-box sidebarheader:-moz-lwtheme { 
              color: -moz-dialogtext; 
              text-shadow: none; 
              background-color: var(--sidebar-background-color);
              -moz-appearance: toolbox; 
              border-bottom: 1px solid var(--sidebar-border-color); 
              border-top: 1px solid var(--sidebar-border-color); 
            } 
            #sidebar-box #sidebarpopuppanel-bottom { 
            background-color: var(--toolbar-bgcolor); 
            width:100%; 
            }
            #sidebar-box #sidebarpopuppanel-bottom:-moz-lwtheme { 
            background-color: var(--sidebar-background-color);
            }`;
    
          if (this._SIDEBARPOSITION="L") {
            floatingStyle += ' #sidebar-box .PopupResizerGripper { \
            list-style-image: url(""); \
            cursor: se-resize; \
            }';
          } else {
            floatingStyle += ' #sidebar-box:-moz-locale-dir(rtl) .PopupResizerGripper { \
            list-style-image: url(""); \
            cursor: sw-resize; \
            }';
          }
    
           sspi = document.createProcessingInstruction(
            'xml-stylesheet',
            'type="text/css" href="data:text/css,' + encodeURIComponent(floatingStyle) + '"'
          );
          document.insertBefore(sspi, document.documentElement);
          sspi.getAttribute = function(name) {
          return document.documentElement.getAttribute(name);
          };
          let template = 
            ["hbox", {id: "sidebarpopuppanel-bottom"},
              ["spacer", {flex: "1"}],
              ["image", {class: "PopupResizerGripper",
                 onmousedown: "if (event.target == this) sidebarpopuppanelResize.start(event);"}]
            ];
          document.getElementById('sidebar-box')
                  .appendChild(this.jsonToDOM(template, document, {}));
        }
    
        if (this._sidebar_box.hasAttribute('hidden') ||
            this._CLOSE_AT_STARTUP) {
          this._sidebar_box.collapsed = true;
        }
        this._sidebar_box.hidden = false;
    
        this._sidebar = document.getElementById('sidebar');
    
        this._sidebar_splitter = document.getElementById('sidebar-splitter');
        if (this._sidebar_splitter.hasAttribute('hidden')) {
          this._sidebar_splitter.removeAttribute('hidden');
        }
        this._sidebar_splitter.removeAttribute('state');
        this._sidebar_splitter.removeAttribute('collapsed');
    
        var checkbox = document.createXULElement('checkbox');
        var item = document.getElementById('sidebar-throbber');
        this._checkbox = item.parentNode.insertBefore(checkbox, item);
        checkbox.setAttribute("id", "sidebar-checkbox");
        checkbox.setAttribute("type", "checkbox");
        checkbox.setAttribute("label", "");
        checkbox.setAttribute('persist','checked');
    
        
        checkbox.checked = this._CHECKBOX_AT_STARUP;
        
        if(this._SIDEBARPOSITION == "R"){
          (function(self){ //this code from http://pc11.2ch.net/test/read.cgi/software/1185343069/128
            self._sidebar_splitter = self._sidebar_box.parentNode.appendChild(self._sidebar_splitter);
            self._sidebar_box = self._sidebar_box.parentNode.appendChild(self._sidebar_box);
          })(this);
        }
    
        window.PrintUtils.printPreview_org = PrintUtils.printPreview;
        PrintUtils.printPreview = function(arg) {
          if(document.getElementById("sidebar-box") && 
             !!document.getElementById("sidebar-box").getAttribute("sidebarcommand")) { 
            if (window.ucjs_expand_sidebar._FLOATING_SIDEBAR)
              SidebarUI.hide();
          }
          window.PrintUtils.printPreview_org(arg);
        };
    
        /**
         * helper functions
         */
            function accessorDescriptor(field, fun) {
              var desc = { enumerable: true, configurable: true };
              desc[field] = fun;
              return desc;
            }
    
            function defineGetter(obj, prop, get) {
              if (Object.defineProperty)
                return Object.defineProperty(obj, prop, accessorDescriptor("get", get));
              if (Object.prototype.__defineGetter__)
                return obj.__defineGetter__(prop, get);
    
              throw new Error("browser does not support getters");
            }
    
            function defineSetter(obj, prop, set) {
              if (Object.defineProperty)
                return Object.defineProperty(obj, prop, accessorDescriptor("set", set));
              if (Object.prototype.__defineSetter__)
                return obj.__defineSetter__(prop, set);
    
              throw new Error("browser does not support setters");
            }
    
    
        /**
         * hack
         */
            defineGetter(SidebarUI, "isOpen", function isOpen(){return this._box && !this._box.collapsed;})
    
    
            SidebarUI.show_org = SidebarUI.show;
            SidebarUI.show = function show(commandID, triggerNode) {
              //this._box.hidden = false;
              this._box.collapsed = false;
              this._splitter.hidden = false;
            ucjs_expand_sidebar._loadKeepItSizes(commandID);
            ucjs_expand_sidebar._lastcommand = commandID;
            ucjs_expand_sidebar._opend = true;
            if (ucjs_expand_sidebar._FLOATING_SIDEBAR) {
              let x = document.getElementById("appcontent").getBoundingClientRect().x;
              ucjs_expand_sidebar._sidebar_box.style.setProperty("left", x + "px", "");
            }
          SidebarUI.show_org(commandID, triggerNode);
          }
    
            SidebarUI.hide_org = SidebarUI.hide;
            SidebarUI.hide =
            function hide(triggerNode) {
            if (!this.isOpen) {
              return;
            }
    
          ucjs_expand_sidebar._saveKeepItSizes(ucjs_expand_sidebar._lastcommand);
            this._box.collapsed = true;
            if ("treeStyleTab" in gBrowser)
              gBrowser.treeStyleTab.updateFloatingTabbar(gBrowser.treeStyleTab.kTABBAR_UPDATE_BY_WINDOW_RESIZE);
            gBrowser.selectedBrowser.focus();
    
            //SidebarUI.hide(triggerNode);
          }
    
        //Fokussierte Aktion der Seitenleisten ausführen
        //
        if (typeof fireSidebarFocusedEvent == "function") {
          window.fireSidebarFocusedEvent_org = fireSidebarFocusedEvent;
          fireSidebarFocusedEvent = function () {
            fireSidebarFocusedEvent_org();
            ucjs_expand_sidebar._focused();
          }
        }
    
        if (typeof SidebarUI._fireFocusedEvent == "function") {
          SidebarUI._fireFocusedEvent_org = SidebarUI._fireFocusedEvent;
          SidebarUI._fireFocusedEvent = function () {
            SidebarUI._fireFocusedEvent_org();
            ucjs_expand_sidebar._focused();
          }
        }
    
        //Beim Start Seitenleiste geschlossen halten?
    
        setTimeout(function(self) {
          var command = self._sidebar_box.getAttribute("sidebarcommand");
          if (command)
            self._lastcommand = command;
          var broadcasters = document.getElementsByAttribute("group", "sidebar");
          if (self._CLOSE_AT_STARTUP) {
            SidebarUI.hide();
            //self._sidebar_box.setAttribute('collapsed',true);
            for (var i = 0; i < broadcasters.length; ++i) {
              if (broadcasters[i].localName != "broadcaster") {
                  continue;
              }
              broadcasters[i].removeAttribute("checked");
            }
          } else {
            for (var i = 0; i < broadcasters.length; ++i) {
              if (broadcasters[i].localName != "broadcaster") {
                continue;
              }
              if (broadcasters[i].hasAttribute("checked")) {
                self._loadKeepItSizes();
                break;;
              }
            }
          }
    
        }, 500, this);
    
        this._sidebar.style.removeProperty('max-width');
        this._sidebar.style.removeProperty('min-width');
    
        this._content = document.getElementById("content");
    
        if (this._CLOSEWHENGOOUT)
          window.addEventListener("mouseout", ucjs_expand_sidebar._mouseout, true);
        else
          this._sidebar_splitter.addEventListener("mouseout", ucjs_expand_sidebar._mouseout, true);
    
        if (this._KEEP_SIZES)
          window.addEventListener("resize", this, false);
    
        if (this._SIDEBARPOSITION == "R"){
          gBrowser.tabpanels.addEventListener("mouseup", this, true);
          gBrowser.tabpanels.addEventListener("mousedown", this, true);
        }
    
        //this._content.addEventListener("mouseover", ucjs_expand_sidebar._mousemove, true);
        document.getElementById("browser").addEventListener("mousemove", ucjs_expand_sidebar._mousemove, true);
        this._sidebar_box.addEventListener("mouseover", ucjs_expand_sidebar._mouseover, true);
        window.addEventListener("dblclick", this, true);
        //window.addEventListener("click", this, true);
        this._sidebar_splitter.addEventListener("dragover", this, true);
    
        Services.obs.addObserver(this, "private-browsing", false);
      },
    
      uninit: function(){
        if (this._CLOSEWHENGOOUT)
          window.removeEventListener("mouseout", ucjs_expand_sidebar._mouseout, true);
        else
          this._sidebar_splitter.removeEventListener("mouseout", ucjs_expand_sidebar._mouseout, true);
    
        if (this._KEEP_SIZES)
          window.removeEventListener("resize", this, false);
    
        if (this._SIDEBARPOSITION == "R"){
          gBrowser.tabpanels.removeEventListener("mouseup", this, true);
          gBrowser.tabpanels.removeEventListener("mousedown", this, true);
        }
    
        //this._content.removeEventListener("mouseover", ucjs_expand_sidebar._mousemove, true);
        document.getElementById("browser").removeEventListener("mousemove", ucjs_expand_sidebar._mousemove, true);
        this._sidebar_box.removeEventListener("mouseover", ucjs_expand_sidebar._mouseover, true);
        window.removeEventListener("dblclick", this, true);
        //window.removeEventListener("click", this, true);
        this._sidebar_splitter.removeEventListener("dragover", this, true);
    
         Services.obs.removeObserver(this, "private-browsing");
      },
    
      _back_url: null,
      _back_cachedurl: null,
      observe: function(aSubject, aTopic, aData) {
        var self = ucjs_expand_sidebar;
        if (aData == "enter") {
          self._back_url = self._sidebar_box.getAttribute("src");
          if (self._back_url == "chrome://browser/content/web-panels.xul") {
            var b = self._sidebar.contentDocument.getElementById("web-panels-browser");
            self._back_cachedurl = b.getAttribute("cachedurl");
          }
          self._sidebar_box.setAttribute("src", "about:blank");
          self._sidebar.setAttribute("src", "about:blank");
          self._backup_lastcommand = self._lastcommand;
        } else if (aData == "exit") {
          self._lastcommand = self._backup_lastcommand;
          self._backup_lastcommand = null;
          self._sidebar.setAttribute("src", "about:blank");
          if (self._back_url == "chrome://browser/content/web-panels.xul") {
            if (!!self._back_cachedurl) {
              b = self._sidebar.contentDocument.getElementById("web-panels-browser");
              b.setAttribute("cachedurl", self._back_cachedurl);
              document.persist("web-panels-browser", "cachedurl");
              self._back_cachedurl = null;
            }
          }
          self._sidebar_box.setAttribute("src", self._back_url);
          self._back_url = null;
        }
      },
    
      handleEvent: function(event){
        event = new XPCNativeWrapper(event);
        switch (event.type){
          case "mouseup":
              if (this._mouse_Timeout)
                clearTimeout(this._mouse_Timeout);
              this._mouse_Timeout = setTimeout(function(self) {
                self._mousedown = false;
                self._checkWindowSideOrNot(event);
              },this._SCROLLBAR_DELAY,this);
              break;
          case "mousedown":
              if (event.screenX < this._sidebar_splitter.screenX - this._TOLERANCE)
                break;
              this._mousedown = true;
              if (this._mouse_Timeout)
                clearTimeout(this._mouse_Timeout);
              this._mouse_Timeout = null;
              this._clearOpenCloseTimer();
              break;
          case "click":
            if (event.button != 2) {
              //return;
            }
            event.preventDefault();
          case "dblclick":
              if(event.originalTarget != this._sidebar_splitter)
                return;
              event.preventDefault();
              event.stopPropagation();
              if (this._mouse_Timeout)
                clearTimeout(this._mouse_Timeout);
              this._mouse_Timeout = null;
              SidebarUI.toggle(this._getDefaultCommandID());
              this._openSidebar(this._getDefaultCommandID());
              this._mousedown = false;
              break;
          case "dragover":
              if (this._mouse_Timeout)
                clearTimeout(this._mouse_Timeout);
              this._mouse_Timeout = null;
              this._mousedown = false;
                if (this._close_Timeout)
                  clearTimeout(this._close_Timeout);
                this._close_Timeout = null;
                if(!this._open_Timeout){
                  this._open_Timeout = setTimeout(function(self){
                     var hidden = (self._sidebar_box.hasAttribute('hidden')?true:false) ||
                                   self._sidebar_box.getAttribute('collapsed') == "true";
                     if (hidden) {
                       SidebarUI.toggle(self._getDefaultCommandID(), true);
                       self._openSidebar(self._getDefaultCommandID(), true);
                     }
                  }, this._OPEN_DELAY_DRAGOVER, this);
                }
              break;
          case "resize":
            if (this._FLOATING_SIDEBAR) {
    /*          this._loadKeepItSizes();
              if (this._resizeTimer)
                clearTimeout(this._resizeTimer);
              this._resizeTimer = setTimeout(() => {this._loadKeepItSizes();},250)
    */
              return;
            }
            if (this._resizeTimer)
              clearTimeout(this._resizeTimer);
            if (this._startup) {
              this._startup = false;
              return;
            }
            this._resizeTimer = setTimeout(function(self) {
              //Wenn die Seitenleiste geöffnet ist, Größe speichern
              var hidden = self._sidebar_box.hasAttribute('hidden') ? true : false;
              if (!hidden && self._sidebar_box.getAttribute('collapsed') != "true" ) {
                var size = self._sidebar_box.getBoundingClientRect().width;
                //Aktuellen Befehl ermitteln.(get)
                var _command =  self.getCommandId();
                if (!!_command){
                  self._saveKeepItSizes(_command, size);
                }
              }
            }, 500, this);
            break;
        }
      },
    
      //Getrennt, um die Last zu reduzieren
      _mouseover: function(event){
        ucjs_expand_sidebar._checkWindowSideOrNot(event);
      },
    
      _mousemove: function(event){ 
        var self = ucjs_expand_sidebar;
    //self.debug(event);
        if (self._mtimer)
          return;
        self._mtimer = true;
        setTimeout(function(self){
          self._mtimer = false;
        }, self._MOUSEMOVEINTERVAL, self);
        
        //self..debug("_mousemove " +event.originalTarget);
    
        if (event.originalTarget == self._sidebar_splitter) {
          self._checkWindowSideOrNot(event);
          return;
        }
        //self.debug("_mousemove self._mousedown=" +self._mousedown);
    
        if (self._mousedown) {
          return;
        }
        self._checkWindowSideOrNot(event);
      },
    
      _mouseout: function(event){
        var self = ucjs_expand_sidebar;
        if (self._mouse_Timeout)
          clearTimeout(self._mouse_Timeout);
        self._mouse_Timeout = null;
        //keine Aktion direkt nach dem öffnen
        if (self._opend) return;
        //Beim Überfahren des Fensterrandes Seitenleiste nicht öffnen
        if(!self._CLOSEWHENGOOUT){
          if (self._sidebar_splitter == event.originalTarget){
            if (self._open_Timeout)
              clearTimeout(self._open_Timeout);
            self._open_Timeout = null;
          }
          return;
        }
        //Wenn diese Option aktiviert ist, Seitenleiste nicht schließen
        if (self._checkbox.checked) return;
        if (/^menu|browser|tooltip/.test(event.originalTarget.localName)) return;
        if (self._sidebar.contentWindow.location.href == "chrome://browser/content/web-panels.xul") return;
        if (!self._close_Timeout) {
          //self.debug(event.type + "  " + event.originalTarget.localName + "  " + event.target.localName );
          if (self._open_Timeout)
            clearTimeout(self._open_Timeout);
          self._open_Timeout = null;
          self._close_Timeout = setTimeout(function(self){
            self._mousedown = false;
            self.toggleSidebar();
          }, self._CLOSE_DELAY, self);
        }
      },
    
      //Aktuellen Befehl ermitteln.(get)
      getCommandId: function(){
        return SidebarUI._box.getAttribute("sidebarcommand");                
      },
    
        toggleSidebar: function expandsidebartoggleSidebar(commandID, forceOpen = false) {
        if (this._FLOATING_SIDEBAR) {
          let x = document.getElementById("appcontent").getBoundingClientRect().x;
          this._sidebar_box.style.setProperty("left", x + "px", "");
          this._sidebar.style.setProperty("left", x - 1  + "px", "");
        }
        if (forceOpen) {
          SidebarUI.show(commandID);
        } else {
          SidebarUI.toggle(commandID);
        }
      },
    
      _loadKeepItSizes: function(_command){
          if (this._KEEP_SIZES) {
            if (!_command)
              _command = this.getCommandId();
            if(!!_command) {
              this.sizes = this.getPref(this.prefKeepItSizes, 'str', 'viewBookmarksSidebar|178|viewHistorySidebar|286|viewGrepSidebar|157|viewUpdateScanSidebar|230|viewWebPanelsSidebar|371|viewWebPageSidebar|371|viewScrapBookSidebar|182|viewAdd-onsSidebar|371|viewStylishSidebar|379|viewMozgestSidebar|234|viewConsole2Sidebar|234|viewGoogleTransitSidebar|371|viewGoogleDocSidebar|371|viewIGoogleSidebar|371|viewPasswordManagerSidebar|371').split('|');
              var index = this.sizes.indexOf(_command);
              if (index < 0 ){
                this.sizes.push(_command);
                index = this.sizes.length - 1;
                this.sizes.push(this._defaultWidth);
              }
              if (this.sizes[index + 1] <= 0)
                this.sizes[index + 1] = this._defaultWidth
    
              if (this._FLOATING_SIDEBAR) {
                this._sidebar_box.style.setProperty('width', this.sizes[index + 1] + "px", "");
                this._sidebar.style.setProperty('width', this.sizes[index + 1] - 1  + "px", "");
              } else
                this._sidebar_box.style.setProperty('width', this.sizes[index + 1] + "px", "");
              return;
            }
          }
    
          if (this._sidebar_box.getBoundingClientRect().width == 0) {
            if (this._FLOATING_SIDEBAR) {
              this._sidebar_box.style.setProperty('width', this._defaultWidth + "px", "");
              this._sidebar.style.setProperty('width', this._defaultWidth - 1  + "px", "");
            } else {
              this._sidebar_box.style.setProperty('width', this._defaultWidth + "px", "");
            }
          }
      },
    
      _saveKeepItSizes: function(_command, size){
        if (!this._KEEP_SIZES)
          return;
        if (!!_command && size) {
          //this.debug(_command + "  "+ size);
          var index = this.sizes.indexOf(_command);
          if (index < 0 ){
            this.sizes.push(_command);
            this.sizes.push(size);
          } else {
            this.sizes[index + 1] = size;
          }
          var str = this.sizes.join('|');
          this.setPref(this.prefKeepItSizes, 'str', str);
        }
      },
    
      _openSidebar: function(_command, _forceOpen){
        this._clearOpenCloseTimer();
        //this.toggleSidebar(_command, _forceOpen);
        //Flag, ob mouseout sofort nach dem Öffnen als true verarbeitet werden soll oder nicht
        this._opend = true;
        if(this._mouseoutTimer)
          clearTimeout(this._mouseoutTimer);
        //Auf „false“ setzen, damit mouseout nach 200 ms nach dem Öffnen verarbeitet werden kann
        this._mouseoutTimer = setTimeout(function(that){that._opend = false;},300,this);
      },
    
      _focused: function(){
        //Suchfeld fokussieren wenn vorhanden
        var doc = this._sidebar.contentWindow.document;
        if (doc) {
          var elem = doc.getElementById("search-box");
          if (elem) {
            try {
              setTimeout(function(doc, elem){
                doc.defaultView.focus();
                elem.focus();
              }, 0, doc, elem)
            } catch(e) {}
          }
        }
      },
    
      _getDefaultCommandID: function(_command){
        if(!_command) _command = this._lastcommand;
        if(!_command) _command = this._DEFAULTCOMMAND;
        return _command;
      },
    
      _clearOpenCloseTimer: function() {
        if (this._close_Timeout)
          clearTimeout(this._close_Timeout);
        this._close_Timeout = null;
        if (this._open_Timeout)
          clearTimeout(this._open_Timeout);
        this._open_Timeout = null;
      },
    
      _checkMouseIsWindowEdge: function(x) {
        var sw = this._sidebar_splitter.getBoundingClientRect().width;
        if (this._SIDEBARPOSITION == "L") {
          //Linker Rand des Fensters x Koordinaten
          if ( 0 <= x && x <= sw + this._TOLERANCE)
            return true;
        }else if(this._SIDEBARPOSITION == "R") {
          //Rechter Rand des Fensters x Koordinaten
          if (-this._TOLERANCE <= x && x <= sw)
            return true;
        }
        return false;
      },
    
      _checkMouseIsSidebarEdge: function(x){
        var sw = this._sidebar_splitter.getBoundingClientRect().width;
    
        //this.debug("_checkMouseIsSidebarEdge " +(sw + this._TOLERANCE+"px ") + (x+"px "));
    
        if (this._SIDEBARPOSITION == "L") {
          //Linker Rand des Fensters x Koordinaten
          if(sw + this._TOLERANCE < x)
            return true;
        } else if(this._SIDEBARPOSITION == "R") {
          //Rechter Rand des Fensters x Koordinaten
          if (x <  -this._TOLERANCE)
            return true;
        }
        return false;
      },
    
      _checkWindowSideOrNot: function(event){ 
        var sidebar_box = this._sidebar_box;
        if (sidebar_box.getBoundingClientRect().width == 0) {
          sidebar_box.style.setProperty('width', this._defaultWidth + "px", "");//Seitenleiste Standardbreite
          this._sidebar.style.setProperty('width', this._defaultWidth - 1 + "px", "");//Seitenleiste Standardbreite
        }
    //this.debug(event.target.localName);
    /*
        if(/tabbrowser/.test(event.target.localName)){
          return
        }
    */
        //Ob es außerhalb des oberen und unteren Bereichs des Inhaltsbereichs liegt
        var y = event.screenY - gBrowser.tabpanels.screenY;
        if(y < 0 || y > gBrowser.tabpanels.getBoundingClientRect().height){
          this._clearOpenCloseTimer();
          return
        }
    
    //this.debug(event.type+"\n"+event.screenX+"\n"+this._sidebar_splitter.boxObject.screenX+"\n"+(event.target instanceof HTMLElement || /browser/.test(event.target.localName) ))
        var hidden = (sidebar_box.hasAttribute('hidden')?true:false) ||
                      sidebar_box.getAttribute('collapsed') == "true";
        var x = event.screenX - this._sidebar_splitter.screenX;
        //Fensterrand ermitteln
        if (hidden) {
          if (event.originalTarget == this._sidebar_splitter ||
              this._checkMouseIsWindowEdge(x)) {
            if (this._close_Timeout)
              clearTimeout(this._close_Timeout);
            this._close_Timeout = null;
            if (!this._open_Timeout) {
              this._open_Timeout = setTimeout(function(self){
                SidebarUI.toggle(self._getDefaultCommandID());
                self._openSidebar(self._getDefaultCommandID());
              }, this._OPEN_DELAY, this);
            }
          } else {
            if (this._open_Timeout)
              clearTimeout(this._open_Timeout);
            this._open_Timeout = null;
          }
          return;
        }
        //X-Koordinate der Inhaltsseite der Seitenleiste
        if (!this._checkbox.checked && !hidden) {
    //this.debug("this.isChrome(event) "+ this.isChrome(event));
          if (event.originalTarget != this._sidebar_splitter &&
              this._checkMouseIsSidebarEdge(x) &&
              !(this._DONOTCLOSE_XULELEMENT && this.isChrome(event)) /*||
              (event.type == "mouseover" &&
               (event.target instanceof HTMLElement || /browser/.test(event.target.localName)) )*/ ) {
            if (this._open_Timeout)
              clearTimeout(this._open_Timeout);
            this._open_Timeout = null;
    
            if (this._close_Timeout || this._opend)
              return;
            this._close_Timeout = setTimeout(function(self){
              self.toggleSidebar();
            }, this._CLOSE_DELAY, this);
          } else {
            if (this._close_Timeout)
              clearTimeout(this._close_Timeout);
            this._close_Timeout = null;
            this._opend = false;
          }
        }
      },
    
      isChrome: function(aEvent) {
        var x = aEvent.screenX;
        var y = aEvent.screenY;
        var sidebarBox = this._sidebar_box.getBoundingClientRect();
    //userChrome_js.debug( this._sidebar_box.screenX <= x)
    //userChrome_js.debug( x <= this._sidebar_box.screenX + sidebarBox.width )
        if (this._sidebar_box.screenX <= x && x <= this._sidebar_box.screenX + sidebarBox.width &&
            this._sidebar_box.screenY <= y && y <= this._sidebar_box.screenY + sidebarBox.height)
          return true;
        //if (aEvent.target instanceof HTMLElement)
        //  return false;
        if (/^(splitter|grippy|menu|panel|notification)/.test(aEvent.target.localName))
          return true;
        var box = gBrowser.tabpanels.getBoundingClientRect();
        var bx = gBrowser.tabpanels.screenX;
        var by = gBrowser.tabpanels.screenY;
        if (bx <= x && x <= bx + box.width &&
            by <= y && y <= by + box.height)
          return false;
        else
          return true;
      },
    
      //Einstellungen lesen
      getPref: function(aPrefString, aPrefType, aDefault){
        var xpPref = Components.classes['@mozilla.org/preferences-service;1']
                      .getService(Components.interfaces.nsIPrefBranch);
        try{
          switch (aPrefType){
            case 'complex':
              return xpPref.getComplexValue(aPrefString, Components.interfaces.nsILocalFile); break;
            case 'str':
              return xpPref.getCharPref(aPrefString).toString(); break;
            case 'int':
              return xpPref.getIntPref(aPrefString); break;
            case 'bool':
            default:
              return xpPref.getBoolPref(aPrefString); break;
          }
        }catch(e){
        }
        return aDefault;
      },
      //Einstellungen speichern
      setPref: function(aPrefString, aPrefType, aValue){
        var xpPref = Components.classes['@mozilla.org/preferences-service;1']
                      .getService(Components.interfaces.nsIPrefBranch);
        try{
          switch (aPrefType){
            case 'complex':
              return xpPref.setComplexValue(aPrefString, Components.interfaces.nsIFile, aValue); break;
            case 'str':
              return xpPref.setCharPref(aPrefString, aValue); break;
            case 'int':
              aValue = parseInt(aValue);
              return xpPref.setIntPref(aPrefString, aValue);  break;
            case 'bool':
            default:
              return xpPref.setBoolPref(aPrefString, aValue); break;
          }
        }catch(e){
        }
        return null;
      },
    
      debug: function(aMsg){
       // return;
        const Cc = Components.classes;
        const Ci = Components.interfaces;
        Cc["@mozilla.org/consoleservice;1"]
          .getService(Ci.nsIConsoleService)
          .logStringMessage(aMsg);
      }
    };
    
    // Einstiegspunkt
    ucjs_expand_sidebar.init();
    window.addEventListener("unload", function(){ ucjs_expand_sidebar.uninit(); }, false);
    
    var sidebarpopuppanelResize = {
      drag   : false,
      size   : null,
      offset : null,
    
      PREF_SIZE : "extensions.sidebarpopuppanelResize.size.",
    
      get isRTL() {
        return document.defaultView
                    .getComputedStyle(document.getElementById("nav-bar"), "")
                    .direction == "rtl";
      },
    
      get sidebar() {
        return document.getElementById("sidebar");;
      },
      
      get sidebarbox() {
        return document.getElementById("sidebar-box");;
      },
    
      get sidebarcommand() {
        return this.sidebarbox.getAttribute('sidebarcommand');
      },
    
      init: function(){
        window.addEventListener("unload", this, false);
          this.SM_Observer = new MutationObserver(function(mutations) {
          mutations.forEach(function(mutation) {
            switch (mutation.attributeName) {
              case "style":
                let style = this.sidebarbox.getAttribute("style");
                if (style.includes("width: 0px")) {
                  ucjs_expand_sidebar._loadKeepItSizes();
                }
                break;
            }
          }.bind(this));
        }.bind(this));
        // pass in the target node, as well as the observer options
        this.SM_Observer.observe(document.getElementById("sidebar-box"),
                                 {attribute: true, attributeFilter: ["style"]});
      },
    
      uninit: function(){
        window.removeEventListener("unload", this, false);
        window.removeEventListener("mouseup", this, true);
        window.removeEventListener("mousemove", this, true);
      },
    
      handleEvent: function (event) {
        switch (event.type) {
          case "load":
            this.init();
            break;
          case "unload":
            this.uninit();
            break;
          case "mouseup":
            this.mouseup(event);
            break;
          case "mousemove":
            if (this.timer) {
                clearTimeout(this.timer);
            }
            this.timer = setTimeout(function (event, self) {
              self.mousemove(event);
            }, 10, event, this);
            break;
          default:;
        }
      },
    
      start: function(event){
        this.drag = true;
        this.size = {height:parseInt(this.sidebarbox.getBoundingClientRect().height),
                     width:parseInt(this.sidebarbox.getBoundingClientRect().width)};
        this.offset = {x: event.screenX, y: event.screenY};
        window.addEventListener("mouseup", this, true);
        window.addEventListener("mousemove", this, true);
      },
    
      mouseup: function(event) {
        this.drag = false;
        window.removeEventListener("mousemove", this, true);
        window.removeEventListener("mouseup", this, true);
        ucjs_expand_sidebar._saveKeepItSizes(this.sidebarcommand, this.sidebarbox.getBoundingClientRect().width);
      },
    
      mousemove: function(event) {
        if (this.drag) {
          var newValue;
          var h = this.sidebarbox.getBoundingClientRect().height;
          newValue = this.size.height + event.screenY - this.offset.y;
          if (newValue <= screen.height - 50 && newValue >= 10) {
            h = newValue;
          }
    
          var w = this.sidebarbox.getBoundingClientRect().width;
          if (this.isRTL)
            newValue = this.size.width - (event.screenX - this.offset.x);
          else
            newValue = this.size.width + event.screenX - this.offset.x;
          if (newValue <= screen.width && newValue >= 100) {
            w = newValue;
          }
          this.setSize(h, w);
        }
      },
    
      setSize: function(h, w){
        if (h && h + this.sidebarbox.screenY <= screen.height - 50 && h >= 10) {
    //      this.sidebar.style.setProperty('height', h + "px", "");
        }                         
        if (w && 0<=w ) {
          this.sidebar.style.setProperty('width', w - 1 + "px", "");
          this.sidebarbox.style.setProperty('width', w + "px", "");
        }
      }
    };
    sidebarpopuppanelResize.init();
    Alles anzeigen

    Für Firefox 107+

    JavaScript
    // ==UserScript==
    // @name           expandsidebar_fx58.uc.js
    // @description    Seitenleiste automatisches Öffnen und Schließen
    // @namespace      http://forums.mozillazine.org/viewtopic.php?p=2592073#2592073
    // @include        main
    // @compatibility  Firefox 107
    // @author         Alice0775
    // @Note           Seitenleistenposition bei _SIDEBARPOSITION wählbar (links oder rechts)
    // @Note           Keyconfig und Mousegesten usw. SidebarUI.toggle (entsprechender Code);
    // @Note
    // @version        2022/10/14 20:00 sidebar width:100%
    // @version        2022/09/30 20:00 Bug 1792748
    // @version        2022/09/14 11:00 box width:auto
    // @version        2022/08/26 Bug 1695435 - Remove @@hasInstance for IDL interfaces in chrome context
    // @version        2021/11/14 21:00 css
    // @version        2021/11/14 13:00 no longer close when print preview
    // @version        2021/09/30 22:00 change splitter color
    // @version        2020/12/14 00:00 vtb
    // @version        2020/07/14 00:00 style
    // @version        2019/12/09 18:00 fix 72 Bug 1582530
    // @version        2019/12/05 18:00 fix 72 Bug 1492582 - browser.xhtml: Migrate root xul:window element to an html:html element
    // @version        2019/12/05 17:00 fix 71 Bug 1582530 - Turn on `layout.css.xul-box-display-values.survive-blockification.enabled` by default
    // @version        2019/12/05 10:00 fix 70 Bug 1558914 - Disable Array generics in Nightly
    // @version        2019/09/04 Fx69
    // @version        2018/07/03 Fx61 fix regression from remove loadoverlay
    // @version        2018/07/03 Fx61 remove loadoverlay
    // @version        2018/06/25 Fx61 wip
    // @version        2018/01/25 Fx58 wip
    // @version        2017/11/18 Fx57
    // @version        2017/11/18 nsIPrefBranch2 to nsIPrefBranch
    // @version        2017/02/01 00:00 enable floating(overlay) sidebar
    // @version        2017/01/19 00:00 change event phase,target
    // @version        2015/08/29 00:00 fix lastused command
    // @version        2015/05/13 19:00 fix lastused command
    // @version        2015/02/20 22:00 fix due to Bug 1123517
    // @version        2014/10/31 22:00 fix due to Bug 714675
    // @version        2014/05/22 12:00 fix var
    // @version        2013/03/03 00:00 fix It close too soon when it opened from a button or menu
    // @version        2013/02/26 00:00 fix close delay 
    // @version        2012/12/08 22:30 Bug 788290 Bug 788293 Remove E4X 
    // ==/UserScript==
    // @version        2012/08/04 09:00 private browsingを考慮
    // @version        2012/08/04 09:00 hiddenではなくcollapsedを使うように
    // @version        2012/02/08 14:00 splitter width in full screen
    // @version        2011/05/26 12:00 5.0a2でマウスが要素上通過する時, 移動速度が速すぎるとmouseoverイベントが発火しない? 感度が落ちた?
    // @version        2011/03/24 12:00 ドラッグオーバー遅延を別設定とした
    // @version        2010/10/30 18:00 http://hg.mozilla.org/mozilla-central/pushloghtml?fromchange=84baf90b040c&tochange=16eac4b8b8e0
    // @version        2010/10/09 18:00 Windows7 Aero
    // @version        2009/06/06 20:00 ドラッグオーバーで閉じてしまうので
    // @version        2009/05/24 18:00 chromeのチェック変更
    // @version        2009/04/30 18:00 サイドバーを開閉したときは必ずタイマーをクリアするようにした。
    // @version        2009/04/28 00:00 負荷軽減
    // @version        2009/04/23 00:00 _KEEP_SIZESが動かなくなっていたので
    // @version        2009/04/22 12:00 ドラッグオーバーで開かなくなっていたので
    // @version        2009/04/15 21:00 マウスが通過したときは開かないが動かなくなっていたので
    // @version        2009/04/15 19:00 細々bug修正
    // @version        2009/04/15 02:00 _CLOSEWHENGOOUTが動かなくなっていたので
    // @version        2009/04/14 22:00 fx2削除
    var ucjs_expand_sidebar = {
    // --- config ---
      //Anfang Konfiguration
      _OPEN_DELAY: 300,             //Zeitverzögerung zum Öffnen bei Mouseover
      _OPEN_DELAY_DRAGOVER: 400,    //Zeitverzögerung zum Öffnen per Dragover
      _CLOSE_DELAY: 800,            //Zeitverzögerung beim Schließen
      _SCROLLBAR_DELAY: 1000, //Zeitverzögerung der Bildlaufleiste beim Öffnen / Schließen
      _DEFAULTCOMMAND: "viewBookmarksSidebar", //  Standardseitenleiste
      _TOLERANCE: 0,          // Bereich, der als linke Kante des Fensters erkannt wird (0 kann bei Verwendung von TreeStyleTab usw. verwendet werden)
      _DONOTCLOSE_XULELEMENT: true, //Wenn sich die Maus auf einem XUL-Element befindet, nicht schließen 
                                    //(Wird nicht geschlossen, selbst wenn XUL im Inhalt angezeigt wird)
      _CLOSEWHENGOOUT:  false, //Wenn sich die Maus aus dem Fenster bewegt: true: schließen, [false]: nicht schließen
      _FLOATING_SIDEBAR: true, //Schwebende Seitenleiste (Überlagerung des Seiteninhalts) aktivieren,
                               //(bekanntes Problem: Seitenleiste kann nicht skaliert werden = mit Maus breiter oder schmaler ziehen)  
      _SIDEBARPOSITION: "L",   //Seitenleistenposition Linke Seite: L Rechte Seite: R
                               //VerticalToolbar.uc.js von Gomita - vertikale Symbolleiste 0.1 
                               //(http://www.xuldev.org/blog/?p=113) muss zuerst ausgeführt werden!
      _KEEP_SIZES:true,        //Breite für jeden Seitenleisten-Typ speichern
      _defaultWidth: 234,      //Standardbreite der Seitenleiste
      _inFullscreen: true,     //Bei Vollbild, Verhalten von Firefox 31 verwenden
      //Ende Konfiguration
    // --- config ---
    
      _MOUSEMOVEINTERVAL: 10,    //Intervall zum Überprüfen der Mausposition
      _CHECKBOX_AT_STARUP:false, //Kontrollkästchen beim Start anzeigen
      _CLOSE_AT_STARTUP:true,    //Seitenleiste beim Start geschlossen
      _lastcommand: null,
      _backup_lastcommand:null,
      _open_Timeout: null,
      _close_Timeout: null,
      _sidebar_box:null,
      _sidebar:null,
      _sidebar_splitter:null,
      _checkbox:null,
      _content:null,
      _opend:false,
      _mousedown:false,
      _mouse_Timeout: null,
      _resizeTimer: null,
      _mtimer: false,
      _startup:true,
    
      sizes:[],
      prefKeepItSizes: "userChrome.expandSidebar.keepItSizes",
    
      jsonToDOM: function(jsonTemplate, doc, nodes) {
        jsonToDOM.namespaces = {
        html: "http://www.w3.org/1999/xhtml",
        xul: "http://www.mozilla.org/keymaster/gatekeeper/there.is.only.xul"
        };
        jsonToDOM.defaultNamespace = jsonToDOM.namespaces.xul;
        function jsonToDOM(jsonTemplate, doc, nodes) {
          function namespace(name) {
              var reElemNameParts = /^(?:(.*):)?(.*)$/.exec(name);
              return { namespace: jsonToDOM.namespaces[reElemNameParts[1]], shortName: reElemNameParts[2] };
          }
    
          // Note that 'elemNameOrArray' is: either the full element name (eg. [html:]div) or an array of elements in JSON notation
          function tag(elemNameOrArray, elemAttr) {
            // Array of elements?  Parse each one...
            if (Array.isArray(elemNameOrArray)) {
              var frag = doc.createDocumentFragment();
              Array.prototype.forEach.call(arguments, function(thisElem) {
                frag.appendChild(tag.apply(null, thisElem));
              });
              return frag;
            }
    
            // Single element? Parse element namespace prefix (if none exists, default to defaultNamespace), and create element
            var elemNs = namespace(elemNameOrArray);
            var elem = doc.createElementNS(elemNs.namespace || jsonToDOM.defaultNamespace, elemNs.shortName);
    
            // Set element's attributes and/or callback functions (eg. onclick)
            for (var key in elemAttr) {
              var val = elemAttr[key];
              if (nodes && key == "keyvalue") {
                  nodes[val] = elem;
                  continue;
              }
    
              var attrNs = namespace(key);
              if (typeof val == "function") {
                // Special case for function attributes; don't just add them as 'on...' attributes, but as events, using addEventListener
                elem.addEventListener(key.replace(/^on/, ""), val, false);
              } else {
                // Note that the default namespace for XML attributes is, and should be, blank (ie. they're not in any namespace)
                elem.setAttributeNS(attrNs.namespace || "", attrNs.shortName, val);
              }
            }
    
            // Create and append this element's children
            var childElems = Array.prototype.slice.call(arguments, 2);
            childElems.forEach(function(childElem) {
              if (childElem != null) {
                elem.appendChild(
                    doc.defaultView.Node.isInstance(childElem)
                    /*childElem instanceof doc.defaultView.Node*/ ? childElem :
                        Array.isArray(childElem) ? tag.apply(null, childElem) :
                            doc.createTextNode(childElem));
              }
            });
            return elem;
          }
          return tag.apply(null, jsonTemplate);
        }
    
        return jsonToDOM(jsonTemplate, doc, nodes);
      },
    
      init: function(){
        if ("EzSidebarService" in window)
          return;
        this._sidebar_box = document.getElementById('sidebar-box');
    
        var style = ` 
        @namespace url(http://www.mozilla.org/keymaster/gatekeeper/there.is.only.xul);     
        #sidebar-checkbox {
          border: 1px solid currentColor !important;
          width: 16px !important;
          height: 16px !important;
          overflow-x: hidden !important;
        }
        
        #sidebar-splitter 
        { 
          -moz-box-align: center; 
          -moz-box-pack: center; 
          cursor: ew-resize; 
          border-width: 0;
          border-style: solid; 
          width: 2px; 
          max-width: 2px; 
          min-width: 0px; 
          background-color: transparent;
          border-inline-start-color: var(--toolbar-bgcolor);
          border-inline-end-color: var(--toolbar-bgcolor);
          margin-left: 0px; 
          margin-inline-start: 0px; 
        } 
        #navigator-toolbox[inFullscreen="true"] #sidebar-box[hidden="true"] + #sidebar-splitter, 
        :root[inFullscreen="true"] #sidebar-box[hidden="true"] + #sidebar-splitter 
        { 
          width: 0px; 
          max-width: 1px; 
          min-width: 0px; 
          border-left-width: 0px; 
          border-right-width: 1px; 
          background-color: ThreeDFace; 
        }  
        `;
        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);
        };
    
        if (this._FLOATING_SIDEBAR) {
          // floating css
          var floatingStyle = `
            @namespace url("http://www.mozilla.org/keymaster/gatekeeper/there.is.only.xul"); 
     
            #sidebar-box { 
            position: fixed ; 
            display: block; 
            z-index: 55555; 
            left: 4px; 
            min-width: unset;
            max-width: unset;
            }
            :root:not([lwtheme-image]) #sidebar-box { 
            background-color: var(--toolbar-bgcolor); 
            } 
            :root[lwtheme-image] #sidebar-box { 
            background-color: var(--tabpanel-background-color); 
            } 
    
            #sidebar-box #sidebar-header 
            { 
            width :100%; 
            } 
            #sidebar-box #sidebar 
            { 
            height: calc(100vh - 230px); 
            border-left:3px solid var(--toolbar-bgcolor); 
            border-right:3px solid var(--toolbar-bgcolor); 
            border-bottom:3px solid var(--toolbar-bgcolor); 
            } 
            #sidebar-box #sidebar:-moz-lwtheme
            { 
            border-left:3px solid var(--sidebar-background-color);
            border-right:3px solid var(--sidebar-background-color);
            border-bottom:3px solid var(--sidebar-background-color);
            } 
     
            #sidebar-box { 
              border-right: 1px solid var(--sidebar-border-color);
              border-bottom: 1px solid var(--sidebar-border-color); 
              
            } 
            #sidebar-box:-moz-locale-dir(rtl) { 
              border-left: 1px solid var(--sidebar-border-color); 
            } 
            #sidebar-box:-moz-lwtheme { 
              background-color: var(--sidebar-background-color);
            } 
            #sidebar-box sidebarheader:-moz-lwtheme { 
              color: -moz-dialogtext; 
              text-shadow: none; 
              background-color: var(--sidebar-background-color);
              -moz-appearance: toolbox; 
              border-bottom: 1px solid var(--sidebar-border-color); 
              border-top: 1px solid var(--sidebar-border-color); 
            } 
            #sidebar-box #sidebarpopuppanel-bottom { 
            background-color: var(--toolbar-bgcolor); 
            width:100%; 
            }
            #sidebar-box #sidebarpopuppanel-bottom:-moz-lwtheme { 
            background-color: var(--sidebar-background-color);
            }`;
    
          if (this._SIDEBARPOSITION="L") {
            floatingStyle += ' #sidebar-box .PopupResizerGripper { \
            list-style-image: url(""); \
            cursor: se-resize; \
            }';
          } else {
            floatingStyle += ' #sidebar-box:-moz-locale-dir(rtl) .PopupResizerGripper { \
            list-style-image: url(""); \
            cursor: sw-resize; \
            }';
          }
    
           sspi = document.createProcessingInstruction(
            'xml-stylesheet',
            'type="text/css" href="data:text/css,' + encodeURIComponent(floatingStyle) + '"'
          );
          document.insertBefore(sspi, document.documentElement);
          sspi.getAttribute = function(name) {
          return document.documentElement.getAttribute(name);
          };
          let template = 
            ["hbox", {id: "sidebarpopuppanel-bottom"},
              ["spacer", {flex: "1"}],
              ["image", {class: "PopupResizerGripper",
                 onmousedown: "if (event.target == this) sidebarpopuppanelResize.start(event);"}]
            ];
          document.getElementById('sidebar-box')
                  .appendChild(this.jsonToDOM(template, document, {}));
        }
    
        if (this._sidebar_box.hasAttribute('hidden') ||
            this._CLOSE_AT_STARTUP) {
          this._sidebar_box.collapsed = true;
        }
        this._sidebar_box.hidden = false;
    
        this._sidebar = document.getElementById('sidebar');
    
        this._sidebar_splitter = document.getElementById('sidebar-splitter');
        if (this._sidebar_splitter.hasAttribute('hidden')) {
          this._sidebar_splitter.removeAttribute('hidden');
        }
        this._sidebar_splitter.removeAttribute('state');
        this._sidebar_splitter.removeAttribute('collapsed');
    
        var checkbox = document.createXULElement('checkbox');
        var item = document.getElementById('sidebar-throbber');
        this._checkbox = item.parentNode.insertBefore(checkbox, item);
        checkbox.setAttribute("id", "sidebar-checkbox");
        checkbox.setAttribute("type", "checkbox");
        checkbox.setAttribute("label", "");
        checkbox.setAttribute('persist','checked');
    
        
        checkbox.checked = this._CHECKBOX_AT_STARUP;
        
        if(this._SIDEBARPOSITION == "R"){
          (function(self){ //this code from http://pc11.2ch.net/test/read.cgi/software/1185343069/128
            self._sidebar_splitter = self._sidebar_box.parentNode.appendChild(self._sidebar_splitter);
            self._sidebar_box = self._sidebar_box.parentNode.appendChild(self._sidebar_box);
          })(this);
        }
    
        window.PrintUtils.printPreview_org = PrintUtils.printPreview;
        PrintUtils.printPreview = function(arg) {
          if(document.getElementById("sidebar-box") && 
             !!document.getElementById("sidebar-box").getAttribute("sidebarcommand")) { 
            if (window.ucjs_expand_sidebar._FLOATING_SIDEBAR)
              SidebarUI.hide();
          }
          window.PrintUtils.printPreview_org(arg);
        };
    
        /**
         * helper functions
         */
            function accessorDescriptor(field, fun) {
              var desc = { enumerable: true, configurable: true };
              desc[field] = fun;
              return desc;
            }
    
            function defineGetter(obj, prop, get) {
              if (Object.defineProperty)
                return Object.defineProperty(obj, prop, accessorDescriptor("get", get));
              if (Object.prototype.__defineGetter__)
                return obj.__defineGetter__(prop, get);
    
              throw new Error("browser does not support getters");
            }
    
            function defineSetter(obj, prop, set) {
              if (Object.defineProperty)
                return Object.defineProperty(obj, prop, accessorDescriptor("set", set));
              if (Object.prototype.__defineSetter__)
                return obj.__defineSetter__(prop, set);
    
              throw new Error("browser does not support setters");
            }
    
    
        /**
         * hack
         */
            defineGetter(SidebarUI, "isOpen", function isOpen(){return this._box && !this._box.collapsed;})
    
    
            SidebarUI.show_org = SidebarUI.show;
            SidebarUI.show = function show(commandID, triggerNode) {
              //this._box.hidden = false;
              this._box.collapsed = false;
              this._splitter.hidden = false;
            ucjs_expand_sidebar._loadKeepItSizes(commandID);
            ucjs_expand_sidebar._lastcommand = commandID;
            ucjs_expand_sidebar._opend = true;
            if (ucjs_expand_sidebar._FLOATING_SIDEBAR) {
              let x = document.getElementById("appcontent").getBoundingClientRect().x;
              ucjs_expand_sidebar._sidebar_box.style.setProperty("left", x + "px", "");
            }
          SidebarUI.show_org(commandID, triggerNode);
          }
    
            SidebarUI.hide_org = SidebarUI.hide;
            SidebarUI.hide =
            function hide(triggerNode) {
            if (!this.isOpen) {
              return;
            }
    
          ucjs_expand_sidebar._saveKeepItSizes(ucjs_expand_sidebar._lastcommand);
            this._box.collapsed = true;
            if ("treeStyleTab" in gBrowser)
              gBrowser.treeStyleTab.updateFloatingTabbar(gBrowser.treeStyleTab.kTABBAR_UPDATE_BY_WINDOW_RESIZE);
            gBrowser.selectedBrowser.focus();
    
            //SidebarUI.hide(triggerNode);
          }
    
        //Fokussierte Aktion der Seitenleisten ausführen
        //
        if (typeof fireSidebarFocusedEvent == "function") {
          window.fireSidebarFocusedEvent_org = fireSidebarFocusedEvent;
          fireSidebarFocusedEvent = function () {
            fireSidebarFocusedEvent_org();
            ucjs_expand_sidebar._focused();
          }
        }
    
        if (typeof SidebarUI._fireFocusedEvent == "function") {
          SidebarUI._fireFocusedEvent_org = SidebarUI._fireFocusedEvent;
          SidebarUI._fireFocusedEvent = function () {
            SidebarUI._fireFocusedEvent_org();
            ucjs_expand_sidebar._focused();
          }
        }
    
        //Beim Start Seitenleiste geschlossen halten?
    
        setTimeout(function(self) {
          var command = self._sidebar_box.getAttribute("sidebarcommand");
          if (command)
            self._lastcommand = command;
          var broadcasters = document.getElementsByAttribute("group", "sidebar");
          if (self._CLOSE_AT_STARTUP) {
            SidebarUI.hide();
            //self._sidebar_box.setAttribute('collapsed',true);
            for (var i = 0; i < broadcasters.length; ++i) {
              if (broadcasters[i].localName != "broadcaster") {
                  continue;
              }
              broadcasters[i].removeAttribute("checked");
            }
          } else {
            for (var i = 0; i < broadcasters.length; ++i) {
              if (broadcasters[i].localName != "broadcaster") {
                continue;
              }
              if (broadcasters[i].hasAttribute("checked")) {
                self._loadKeepItSizes();
                break;;
              }
            }
          }
    
        }, 500, this);
    
        this._sidebar.style.removeProperty('max-width');
        this._sidebar.style.removeProperty('min-width');
        this._sidebar.style.setProperty('width', '100%', '');
    
        this._content = document.getElementById("content");
    
        if (this._CLOSEWHENGOOUT)
          window.addEventListener("mouseout", ucjs_expand_sidebar._mouseout, true);
        else
          this._sidebar_splitter.addEventListener("mouseout", ucjs_expand_sidebar._mouseout, true);
    
        if (this._KEEP_SIZES)
          window.addEventListener("resize", this, false);
    
        if (this._SIDEBARPOSITION == "R"){
          gBrowser.tabpanels.addEventListener("mouseup", this, true);
          gBrowser.tabpanels.addEventListener("mousedown", this, true);
        }
    
        //this._content.addEventListener("mouseover", ucjs_expand_sidebar._mousemove, true);
        document.getElementById("browser").addEventListener("mousemove", ucjs_expand_sidebar._mousemove, true);
        this._sidebar_box.addEventListener("mouseover", ucjs_expand_sidebar._mouseover, true);
        window.addEventListener("dblclick", this, true);
        //window.addEventListener("click", this, true);
        this._sidebar_splitter.addEventListener("dragover", this, true);
    
        Services.obs.addObserver(this, "private-browsing", false);
      },
    
      uninit: function(){
        if (this._CLOSEWHENGOOUT)
          window.removeEventListener("mouseout", ucjs_expand_sidebar._mouseout, true);
        else
          this._sidebar_splitter.removeEventListener("mouseout", ucjs_expand_sidebar._mouseout, true);
    
        if (this._KEEP_SIZES)
          window.removeEventListener("resize", this, false);
    
        if (this._SIDEBARPOSITION == "R"){
          gBrowser.tabpanels.removeEventListener("mouseup", this, true);
          gBrowser.tabpanels.removeEventListener("mousedown", this, true);
        }
    
        //this._content.removeEventListener("mouseover", ucjs_expand_sidebar._mousemove, true);
        document.getElementById("browser").removeEventListener("mousemove", ucjs_expand_sidebar._mousemove, true);
        this._sidebar_box.removeEventListener("mouseover", ucjs_expand_sidebar._mouseover, true);
        window.removeEventListener("dblclick", this, true);
        //window.removeEventListener("click", this, true);
        this._sidebar_splitter.removeEventListener("dragover", this, true);
    
         Services.obs.removeObserver(this, "private-browsing");
      },
    
      _back_url: null,
      _back_cachedurl: null,
      observe: function(aSubject, aTopic, aData) {
        var self = ucjs_expand_sidebar;
        if (aData == "enter") {
          self._back_url = self._sidebar_box.getAttribute("src");
          if (self._back_url == "chrome://browser/content/web-panels.xul") {
            var b = self._sidebar.contentDocument.getElementById("web-panels-browser");
            self._back_cachedurl = b.getAttribute("cachedurl");
          }
          self._sidebar_box.setAttribute("src", "about:blank");
          self._sidebar.setAttribute("src", "about:blank");
          self._backup_lastcommand = self._lastcommand;
        } else if (aData == "exit") {
          self._lastcommand = self._backup_lastcommand;
          self._backup_lastcommand = null;
          self._sidebar.setAttribute("src", "about:blank");
          if (self._back_url == "chrome://browser/content/web-panels.xul") {
            if (!!self._back_cachedurl) {
              b = self._sidebar.contentDocument.getElementById("web-panels-browser");
              b.setAttribute("cachedurl", self._back_cachedurl);
              document.persist("web-panels-browser", "cachedurl");
              self._back_cachedurl = null;
            }
          }
          self._sidebar_box.setAttribute("src", self._back_url);
          self._back_url = null;
        }
      },
    
      handleEvent: function(event){
        event = new XPCNativeWrapper(event);
        switch (event.type){
          case "mouseup":
              if (this._mouse_Timeout)
                clearTimeout(this._mouse_Timeout);
              this._mouse_Timeout = setTimeout(function(self) {
                self._mousedown = false;
                self._checkWindowSideOrNot(event);
              },this._SCROLLBAR_DELAY,this);
              break;
          case "mousedown":
              if (event.screenX < this._sidebar_splitter.screenX - this._TOLERANCE)
                break;
              this._mousedown = true;
              if (this._mouse_Timeout)
                clearTimeout(this._mouse_Timeout);
              this._mouse_Timeout = null;
              this._clearOpenCloseTimer();
              break;
          case "click":
            if (event.button != 2) {
              //return;
            }
            event.preventDefault();
          case "dblclick":
              if(event.originalTarget != this._sidebar_splitter)
                return;
              event.preventDefault();
              event.stopPropagation();
              if (this._mouse_Timeout)
                clearTimeout(this._mouse_Timeout);
              this._mouse_Timeout = null;
              SidebarUI.toggle(this._getDefaultCommandID());
              this._openSidebar(this._getDefaultCommandID());
              this._mousedown = false;
              break;
          case "dragover":
              if (this._mouse_Timeout)
                clearTimeout(this._mouse_Timeout);
              this._mouse_Timeout = null;
              this._mousedown = false;
                if (this._close_Timeout)
                  clearTimeout(this._close_Timeout);
                this._close_Timeout = null;
                if(!this._open_Timeout){
                  this._open_Timeout = setTimeout(function(self){
                     var hidden = (self._sidebar_box.hasAttribute('hidden')?true:false) ||
                                   self._sidebar_box.getAttribute('collapsed') == "true";
                     if (hidden) {
                       SidebarUI.toggle(self._getDefaultCommandID(), true);
                       self._openSidebar(self._getDefaultCommandID(), true);
                     }
                  }, this._OPEN_DELAY_DRAGOVER, this);
                }
              break;
          case "resize":
            if (this._FLOATING_SIDEBAR) {
    /*          this._loadKeepItSizes();
              if (this._resizeTimer)
                clearTimeout(this._resizeTimer);
              this._resizeTimer = setTimeout(() => {this._loadKeepItSizes();},250)
    */
              return;
            }
            if (this._resizeTimer)
              clearTimeout(this._resizeTimer);
            if (this._startup) {
              this._startup = false;
              return;
            }
            this._resizeTimer = setTimeout(function(self) {
              //Wenn die Seitenleiste geöffnet ist, Größe speichern
              var hidden = self._sidebar_box.hasAttribute('hidden') ? true : false;
              if (!hidden && self._sidebar_box.getAttribute('collapsed') != "true" ) {
                var size = self._sidebar_box.getBoundingClientRect().width;
                //Aktuellen Befehl ermitteln.(get)
                var _command =  self.getCommandId();
                if (!!_command){
                  self._saveKeepItSizes(_command, size);
                }
              }
            }, 500, this);
            break;
        }
      },
    
      //Getrennt, um die Last zu reduzieren
      _mouseover: function(event){
        ucjs_expand_sidebar._checkWindowSideOrNot(event);
      },
    
      _mousemove: function(event){ 
        var self = ucjs_expand_sidebar;
    //self.debug(event);
        if (self._mtimer)
          return;
        self._mtimer = true;
        setTimeout(function(self){
          self._mtimer = false;
        }, self._MOUSEMOVEINTERVAL, self);
        
        //self..debug("_mousemove " +event.originalTarget);
    
        if (event.originalTarget == self._sidebar_splitter) {
          self._checkWindowSideOrNot(event);
          return;
        }
        //self.debug("_mousemove self._mousedown=" +self._mousedown);
    
        if (self._mousedown) {
          return;
        }
        self._checkWindowSideOrNot(event);
      },
    
      _mouseout: function(event){
        var self = ucjs_expand_sidebar;
        if (self._mouse_Timeout)
          clearTimeout(self._mouse_Timeout);
        self._mouse_Timeout = null;
        //keine Aktion direkt nach dem öffnen
        if (self._opend) return;
        //Beim Überfahren des Fensterrandes Seitenleiste nicht öffnen
        if(!self._CLOSEWHENGOOUT){
          if (self._sidebar_splitter == event.originalTarget){
            if (self._open_Timeout)
              clearTimeout(self._open_Timeout);
            self._open_Timeout = null;
          }
          return;
        }
        //Wenn diese Option aktiviert ist, Seitenleiste nicht schließen
        if (self._checkbox.checked) return;
        if (/^menu|browser|tooltip/.test(event.originalTarget.localName)) return;
        if (self._sidebar.contentWindow.location.href == "chrome://browser/content/web-panels.xul") return;
        if (!self._close_Timeout) {
          //self.debug(event.type + "  " + event.originalTarget.localName + "  " + event.target.localName );
          if (self._open_Timeout)
            clearTimeout(self._open_Timeout);
          self._open_Timeout = null;
          self._close_Timeout = setTimeout(function(self){
            self._mousedown = false;
            self.toggleSidebar();
          }, self._CLOSE_DELAY, self);
        }
      },
    
      //Aktuellen Befehl ermitteln.(get)
      getCommandId: function(){
        return SidebarUI._box.getAttribute("sidebarcommand");
      },
    
        toggleSidebar: function expandsidebartoggleSidebar(commandID, forceOpen = false) {
        if (this._FLOATING_SIDEBAR) {
          let x = document.getElementById("appcontent").getBoundingClientRect().x;
          this._sidebar_box.style.setProperty("left", x + "px", "");
          this._sidebar.style.setProperty("left", x - 1  + "px", "");
        }
        if (forceOpen) {
          SidebarUI.show(commandID);
        } else {
          SidebarUI.toggle(commandID);
        }
      },
    
      _loadKeepItSizes: function(_command){
          if (this._KEEP_SIZES) {
            if (!_command)
              _command = this.getCommandId();
            if(!!_command) {
              this.sizes = this.getPref(this.prefKeepItSizes, 'str', 'viewBookmarksSidebar|178|viewHistorySidebar|286|viewGrepSidebar|157|viewUpdateScanSidebar|230|viewWebPanelsSidebar|371|viewWebPageSidebar|371|viewScrapBookSidebar|182|viewAdd-onsSidebar|371|viewStylishSidebar|379|viewMozgestSidebar|234|viewConsole2Sidebar|234|viewGoogleTransitSidebar|371|viewGoogleDocSidebar|371|viewIGoogleSidebar|371|viewPasswordManagerSidebar|371').split('|');
              var index = this.sizes.indexOf(_command);
              if (index < 0 ){
                this.sizes.push(_command);
                index = this.sizes.length - 1;
                this.sizes.push(this._defaultWidth);
              }
              if (this.sizes[index + 1] <= 0)
                this.sizes[index + 1] = this._defaultWidth
    
              if (this._FLOATING_SIDEBAR) {
                this._sidebar_box.style.setProperty('width', this.sizes[index + 1] + "px", "");
                //this._sidebar.style.setProperty('width', this.sizes[index + 1] - 1  + "px", "");
              } else
                this._sidebar_box.style.setProperty('width', this.sizes[index + 1] + "px", "");
              return;
            }
          }
    
          if (this._sidebar_box.getBoundingClientRect().width == 0) {
            if (this._FLOATING_SIDEBAR) {
              this._sidebar_box.style.setProperty('width', this._defaultWidth + "px", "");
              //this._sidebar.style.setProperty('width', this._defaultWidth - 1  + "px", "");
            } else {
              this._sidebar_box.style.setProperty('width', this._defaultWidth + "px", "");
            }
          }
      },
    
      _saveKeepItSizes: function(_command, size){
        if (!this._KEEP_SIZES)
          return;
        if (!!_command && size) {
          //this.debug(_command + "  "+ size);
          var index = this.sizes.indexOf(_command);
          if (index < 0 ){
            this.sizes.push(_command);
            this.sizes.push(size);
          } else {
            this.sizes[index + 1] = size;
          }
          var str = this.sizes.join('|');
          this.setPref(this.prefKeepItSizes, 'str', str);
        }
      },
    
      _openSidebar: function(_command, _forceOpen){
        this._clearOpenCloseTimer();
        //this.toggleSidebar(_command, _forceOpen);
        //Flag, ob mouseout sofort nach dem Öffnen als true verarbeitet werden soll oder nicht
        this._opend = true;
        if(this._mouseoutTimer)
          clearTimeout(this._mouseoutTimer);
        //Auf „false“ setzen, damit mouseout nach 200 ms nach dem Öffnen verarbeitet werden kann
        this._mouseoutTimer = setTimeout(function(that){that._opend = false;},300,this);
      },
    
      _focused: function(){
        //Suchfeld fokussieren wenn vorhanden
        var doc = this._sidebar.contentWindow.document;
        if (doc) {
          var elem = doc.getElementById("search-box");
          if (elem) {
            try {
              setTimeout(function(doc, elem){
                doc.defaultView.focus();
                elem.focus();
              }, 0, doc, elem)
            } catch(e) {}
          }
        }
      },
    
      _getDefaultCommandID: function(_command){
        if(!_command) _command = this._lastcommand;
        if(!_command) _command = this._DEFAULTCOMMAND;
        return _command;
      },
    
      _clearOpenCloseTimer: function() {
        if (this._close_Timeout)
          clearTimeout(this._close_Timeout);
        this._close_Timeout = null;
        if (this._open_Timeout)
          clearTimeout(this._open_Timeout);
        this._open_Timeout = null;
      },
    
      _checkMouseIsWindowEdge: function(x) {
        var sw = this._sidebar_splitter.getBoundingClientRect().width;
        if (this._SIDEBARPOSITION == "L") {
          //Linker Rand des Fensters x Koordinaten
          if ( 0 <= x && x <= sw + this._TOLERANCE)
            return true;
        }else if(this._SIDEBARPOSITION == "R") {
          //Rechter Rand des Fensters x Koordinaten
          if (-this._TOLERANCE <= x && x <= sw)
            return true;
        }
        return false;
      },
    
      _checkMouseIsSidebarEdge: function(x){
        var sw = this._sidebar_splitter.getBoundingClientRect().width;
    
        //this.debug("_checkMouseIsSidebarEdge " +(sw + this._TOLERANCE+"px ") + (x+"px "));
    
        if (this._SIDEBARPOSITION == "L") {
          //Linker Rand des Fensters x Koordinaten
          if(sw + this._TOLERANCE < x)
            return true;
        } else if(this._SIDEBARPOSITION == "R") {
          //Rechter Rand des Fensters x Koordinaten
          if (x <  -this._TOLERANCE)
            return true;
        }
        return false;
      },
    
      _checkWindowSideOrNot: function(event){ 
        var sidebar_box = this._sidebar_box;
        if (sidebar_box.getBoundingClientRect().width == 0) {
          sidebar_box.style.setProperty('width', this._defaultWidth + "px", "");//Seitenleiste Standardbreite
          //this._sidebar.style.setProperty('width', this._defaultWidth - 1 + "px", "");//Seitenleiste Standardbreite
        }
    //this.debug(event.target.localName);
    /*
        if(/tabbrowser/.test(event.target.localName)){
          return
        }
    */
        //Ob es außerhalb des oberen und unteren Bereichs des Inhaltsbereichs liegt
        var y = event.screenY - gBrowser.tabpanels.screenY;
        if(y < 0 || y > gBrowser.tabpanels.getBoundingClientRect().height){
          this._clearOpenCloseTimer();
          return
        }
    
    //this.debug(event.type+"\n"+event.screenX+"\n"+this._sidebar_splitter.boxObject.screenX+"\n"+(event.target instanceof HTMLElement || /browser/.test(event.target.localName) ))
        var hidden = (sidebar_box.hasAttribute('hidden')?true:false) ||
                      sidebar_box.getAttribute('collapsed') == "true";
        var x = event.screenX - this._sidebar_splitter.screenX;
        //Fensterrand ermitteln
        if (hidden) {
          if (event.originalTarget == this._sidebar_splitter ||
              this._checkMouseIsWindowEdge(x)) {
            if (this._close_Timeout)
              clearTimeout(this._close_Timeout);
            this._close_Timeout = null;
            if (!this._open_Timeout) {
              this._open_Timeout = setTimeout(function(self){
                SidebarUI.toggle(self._getDefaultCommandID());
                self._openSidebar(self._getDefaultCommandID());
              }, this._OPEN_DELAY, this);
            }
          } else {
            if (this._open_Timeout)
              clearTimeout(this._open_Timeout);
            this._open_Timeout = null;
          }
          return;
        }
        //X-Koordinaten der Inhaltsseite der Seitenleiste
        if (!this._checkbox.checked && !hidden) {
    //this.debug("this.isChrome(event) "+ this.isChrome(event));
          if (event.originalTarget != this._sidebar_splitter &&
              this._checkMouseIsSidebarEdge(x) &&
              !(this._DONOTCLOSE_XULELEMENT && this.isChrome(event)) /*||
              (event.type == "mouseover" &&
               (event.target instanceof HTMLElement || /browser/.test(event.target.localName)) )*/ ) {
            if (this._open_Timeout)
              clearTimeout(this._open_Timeout);
            this._open_Timeout = null;
    
            if (this._close_Timeout || this._opend)
              return;
            this._close_Timeout = setTimeout(function(self){
              self.toggleSidebar();
            }, this._CLOSE_DELAY, this);
          } else {
            if (this._close_Timeout)
              clearTimeout(this._close_Timeout);
            this._close_Timeout = null;
            this._opend = false;
          }
        }
      },
    
      isChrome: function(aEvent) {
        var x = aEvent.screenX;
        var y = aEvent.screenY;
        var sidebarBox = this._sidebar_box.getBoundingClientRect();
    //userChrome_js.debug( this._sidebar_box.screenX <= x)
    //userChrome_js.debug( x <= this._sidebar_box.screenX + sidebarBox.width )
        if (this._sidebar_box.screenX <= x && x <= this._sidebar_box.screenX + sidebarBox.width &&
            this._sidebar_box.screenY <= y && y <= this._sidebar_box.screenY + sidebarBox.height)
          return true;
        //if (aEvent.target instanceof HTMLElement)
        //  return false;
        if (/^(splitter|grippy|menu|panel|notification)/.test(aEvent.target.localName))
          return true;
        var box = gBrowser.tabpanels.getBoundingClientRect();
        var bx = gBrowser.tabpanels.screenX;
        var by = gBrowser.tabpanels.screenY;
        if (bx <= x && x <= bx + box.width &&
            by <= y && y <= by + box.height)
          return false;
        else
          return true;
      },
    
      //Einstellungen lesen
      getPref: function(aPrefString, aPrefType, aDefault){
        var xpPref = Components.classes['@mozilla.org/preferences-service;1']
                      .getService(Components.interfaces.nsIPrefBranch);
        try{
          switch (aPrefType){
            case 'complex':
              return xpPref.getComplexValue(aPrefString, Components.interfaces.nsILocalFile); break;
            case 'str':
              return xpPref.getCharPref(aPrefString).toString(); break;
            case 'int':
              return xpPref.getIntPref(aPrefString); break;
            case 'bool':
            default:
              return xpPref.getBoolPref(aPrefString); break;
          }
        }catch(e){
        }
        return aDefault;
      },
      //Einstellungen speichern
      setPref: function(aPrefString, aPrefType, aValue){
        var xpPref = Components.classes['@mozilla.org/preferences-service;1']
                      .getService(Components.interfaces.nsIPrefBranch);
        try{
          switch (aPrefType){
            case 'complex':
              return xpPref.setComplexValue(aPrefString, Components.interfaces.nsIFile, aValue); break;
            case 'str':
              return xpPref.setCharPref(aPrefString, aValue); break;
            case 'int':
              aValue = parseInt(aValue);
              return xpPref.setIntPref(aPrefString, aValue);  break;
            case 'bool':
            default:
              return xpPref.setBoolPref(aPrefString, aValue); break;
          }
        }catch(e){
        }
        return null;
      },
    
      debug: function(aMsg){
       // return;
        const Cc = Components.classes;
        const Ci = Components.interfaces;
        Cc["@mozilla.org/consoleservice;1"]
          .getService(Ci.nsIConsoleService)
          .logStringMessage(aMsg);
      }
    };
    
    // Einstiegspunkt
    ucjs_expand_sidebar.init();
    window.addEventListener("unload", function(){ ucjs_expand_sidebar.uninit(); }, false);
    
    var sidebarpopuppanelResize = {
      drag   : false,
      size   : null,
      offset : null,
    
      PREF_SIZE : "extensions.sidebarpopuppanelResize.size.",
    
      get isRTL() {
        return document.defaultView
                    .getComputedStyle(document.getElementById("nav-bar"), "")
                    .direction == "rtl";
      },
    
      get sidebar() {
        return document.getElementById("sidebar");;
      },
      
      get sidebarbox() {
        return document.getElementById("sidebar-box");;
      },
    
      get sidebarcommand() {
        return this.sidebarbox.getAttribute('sidebarcommand');
      },
    
      init: function(){
        window.addEventListener("unload", this, false);
          this.SM_Observer = new MutationObserver(function(mutations) {
          mutations.forEach(function(mutation) {
            switch (mutation.attributeName) {
              case "style":
                let style = this.sidebarbox.getAttribute("style");
                if (style.includes("width: 0px")) {
                  ucjs_expand_sidebar._loadKeepItSizes();
                }
                break;
            }
          }.bind(this));
        }.bind(this));
        // pass in the target node, as well as the observer options
        this.SM_Observer.observe(document.getElementById("sidebar-box"),
                                 {attribute: true, attributeFilter: ["style"]});
      },
    
      uninit: function(){
        window.removeEventListener("unload", this, false);
        window.removeEventListener("mouseup", this, true);
        window.removeEventListener("mousemove", this, true);
      },
    
      handleEvent: function (event) {
        switch (event.type) {
          case "load":
            this.init();
            break;
          case "unload":
            this.uninit();
            break;
          case "mouseup":
            this.mouseup(event);
            break;
          case "mousemove":
            if (this.timer) {
                clearTimeout(this.timer);
            }
            this.timer = setTimeout(function (event, self) {
              self.mousemove(event);
            }, 10, event, this);
            break;
          default:;
        }
      },
    
      start: function(event){
        this.checked = ucjs_expand_sidebar._checkbox.checked;
        ucjs_expand_sidebar._checkbox.checked = true;
        this.drag = true;
        this.size = {height:parseInt(this.sidebarbox.getBoundingClientRect().height),
                     width:parseInt(this.sidebarbox.getBoundingClientRect().width)};
        this.offset = {x: event.screenX, y: event.screenY};
        window.addEventListener("mouseup", this, true);
        window.addEventListener("mousemove", this, true);
      },
    
      mouseup: function(event) {
        ucjs_expand_sidebar._checkbox.checked = this.checked;
        this.drag = false;
        window.removeEventListener("mousemove", this, true);
        window.removeEventListener("mouseup", this, true);
        ucjs_expand_sidebar._saveKeepItSizes(this.sidebarcommand, this.sidebarbox.getBoundingClientRect().width);
      },
    
      mousemove: function(event) {
        if (this.drag) {
          var newValue;
          var h = this.size.height;
          newValue = h + event.screenY - this.offset.y;
          if (newValue <= h - 50) {
            h = newValue;
          }
    
          var w = this.size.width;
          if (this.isRTL)
            newValue = w - (event.screenX - this.offset.x);
          else
            newValue = w + event.screenX - this.offset.x;
          if (newValue <= screen.width) {
            w = newValue;
          }
          this.setSize(h, w);
        }
      },
    
      setSize: function(h, w){
        if (h && h + this.sidebarbox.screenY <= screen.height - 50 && h >= 10) {
    //      this.sidebar.style.setProperty('height', h + "px", "");
        }
        if (w && 0<=w ) {
          this.sidebar.style.setProperty('width', w - 1 + "px", "");
          this.sidebarbox.style.setProperty('width', w + "px", "");
        }
      }
    };
    sidebarpopuppanelResize.init();
    Alles anzeigen

    Mfg.
    Endor

  • Probleme mit dem Tab-CSS

    • Endor
    • 24. Oktober 2022 um 20:21

    Boersenfeger

    Wenn ich mich nicht irre, hast Du gesagt beim hovern wird der ausgewählte Tab

    breiter.

    Das liegt daran:

    CSS
         /* Aktiver Tab breiter */
        
        .tabbrowser-tab:not([pinned]):not([selected]) {
        min-width: 200px !important;
        max-width: 200px !important;
        }
        .tabbrowser-tab:not([pinned])[selected] {
        min-width: 256px !important;
        max-width: 256px !important;
        }


    Du hast im unteren Absatz diesbezüglich eine größere Breite
    vergeben als sonst. Oben 200px unten 256px. Daher wird er breiter.
    Wenn das nicht erwünscht sein sollte, dann bei allen den gleichen Wert verwenden.

    Mfg.
    Endor

  • Probleme mit dem Tab-CSS

    • Endor
    • 24. Oktober 2022 um 19:34

    Hallo Boersenfeger.

    Für Tabs mittig teste bitte mal:

    ersetzte in deinem CSS Code

    CSS
        /* Tabs in Tableiste mittig */
        
        scrollbox:not(#PlacesToolbarItems) {
        -moz-box-pack: center !important;
        }

    durch:

    CSS
        /* Tabs in Tableiste mittig */
        
        .scrollbox-clip > scrollbox:not(#PlacesToolbarItems){
        -moz-box-pack: center !important;
        }

    Dann schauen wir mal weiter.

    Mfg.
    Endor

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

    • Endor
    • 24. Oktober 2022 um 17:35

    Umbenennung in Multirowtabs erledigt.

    Vorhandene Links auf diese Dateien hier im Forum

    müssen nun aber angepasst werden.

    Links von hier: RE: userChrome.js Scripte für den Fuchs (Diskussion)

    geht jetzt nicht mehr, muss jetzt so sein:

    userChrome.js/Multirowtabs/Firefox-106 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

    Mfg.
    Endor

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

    • Endor
    • 23. Oktober 2022 um 17:12

    Hallo BrokenHeart .
    Sehe ich auch so.

    Danke.

    Edit: Erledigt

    Mfg.
    Endor

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

    • Endor
    • 23. Oktober 2022 um 17:00

    BrokenHeart

    Soll ich die Änderung in Zeile 37

    .tabbrowser-tab,#tabs-newtab-button

    übernehmen? Was meinst Du?

    Mfg.
    Endor

  • Vertikale Lesezeichenleiste, Script und CSS

    • Endor
    • 21. Oktober 2022 um 14:16

    Also etwas hätte ich da noch.
    Ist noch nicht die ganze Lösung, aber ein Anfang.
    Dieses Script fügt eine Vertikale Symbolleiste ein, die mit Schaltfläche ein

    und ausgeblendet werden kann. Inhalt, also Schaltflächen usw.

    müssen über den Symbolleiste anpassen Dialog eingefügt werden.
    Ich habe versucht den Inhalt der Lesezeichenleiste auch rein zu schieben,

    das geht, wird aber nicht untereinander dargestellt. Da müsste man dann
    mit CSS arbeiten.

    Hier das Script ist glaube ich auch von Aborix:

    JavaScript
    (function() {
    /*******************************************************************************/
    
    
        if (location != 'chrome://browser/content/browser.xhtml') {
            return;
        }
    
    
    /*******************************************************************************/
    
        // Background Color
        var vb_bg_color = '#f6f6f6';
        // Border Color
        var vb_border_color = 'rgb(0,128,0)';
        // Number of columns
        var vb_cols = 1;
        // Visibility on Start
        var vb_visibilityOnStart = 1;
    
        // Button Icon, if Toolbar is visible
        vb_isVisibleImage = 'url("")';
        // Button Icon, if Toolbar is hidden
        vb_isHiddenImage = 'url("")';
    
    
    /*******************************************************************************/
    
    
        var vb_h = window.outerHeight;
        var vb_minH = vb_h/20;
        var vb_maxH = vb_h/2;
        var vb_width = 40;
        var vb_totalwidth = vb_cols * vb_width;
    
    
        var vb_style = '\
        box-sizing: content-box !important; \
        background-color: ' + vb_bg_color + ' !important; \
        min-width: ' + vb_totalwidth + 'px !important; \
        max-width: ' + vb_totalwidth + 'px !important; \
        min-height: ' + vb_minH + 'px !important; \
        max-height: ' + vb_maxH + 'px !important; \
        position: absolute !important; \
        right: 17px !important; \
        padding: 5px 0 !important; \
        border: 2px ridge ' + vb_border_color + '; \
        border-radius: 10px !important; \
        z-index: 1 !important; \
        ';
    
        var vb_element = document.getElementById('navigator-toolbox');
        var vb_toolbar = document.createElement('toolbar');
        vb_toolbar.id = 'fp-toolbar';
        vb_toolbar.setAttribute('customizable', true);
        vb_toolbar.setAttribute('mode', 'icons');
        vb_toolbar.setAttribute('style', vb_style);    
        vb_element.appendChild( vb_toolbar );
        vb_toolbar.setAttribute('collapsed', false);        
    
    
        CustomizableUI.registerArea( 'fp-toolbar' , { legacy: true } );
        CustomizableUI.registerToolbarNode(vb_toolbar);
    
    
        setTimeout(function(){ 
            var tmp_positionInfo = vb_toolbar.getBoundingClientRect();
            var tmp_height = tmp_positionInfo.height;
            var vb_ptop = ( vb_h - tmp_height ) / 2; 
            vb_toolbar.style.top = vb_ptop + 'px';
    
            if( vb_visibilityOnStart == 0 ) {
                vb_toolbar.setAttribute('collapsed', true);
            }
        }, 500);    
    
    
    /*******************************************************************************/
    
    
        try {
            Components.utils.import("resource:///modules/CustomizableUI.jsm");
            CustomizableUI.createWidget({
                id: "fp-toggle-toolbar",
                defaultArea: CustomizableUI.AREA_NAVBAR,
                removable: true,
                label: "Vertical Toolbar",
                tooltiptext: "Vertical Toolbar",
                            onClick: function() {
                    var node = document.getElementById('fp-toolbar');
                    var isCollapsed = node.getAttribute('collapsed');
                    if( isCollapsed == 'false' ) {
                        node.setAttribute( 'collapsed' , 'true' );
                        node.style.visibility = 'collapse';
                        document.getElementById(this.id).style.listStyleImage = vb_isHiddenImage;
                    } else {
                        node.setAttribute( 'collapsed' , 'false' );
                        node.style.visibility = 'visible';
                        document.getElementById(this.id).style.listStyleImage = vb_isVisibleImage;
                    }
                },
                onCreated: function(aNode) {
                    if( vb_visibilityOnStart == 1 ) {
                        aNode.style.listStyleImage = vb_isVisibleImage;
                    } else {
                        aNode.style.listStyleImage = vb_isHiddenImage;
                    }
                    return aNode;
                }
            });
        } catch (e) {
            Components.utils.reportError(e);
        };
    
    
    /*******************************************************************************/
    })();
    Alles anzeigen

    Hoffe das hilft weiter.

    Mfg.
    Endor

  • Vertikale Lesezeichenleiste, Script und CSS

    • Endor
    • 20. Oktober 2022 um 17:33

    Ja das Teil ist komplexer.
    Ich muss es die Tage mal in Ruhe testen.

    Mfg.
    Endor

  • Vertikale Lesezeichenleiste, Script und CSS

    • Endor
    • 20. Oktober 2022 um 15:48

    Hallo zusammen.
    expandsidebar.uc.js funktioniert hier gut.

    Wenn Ihr lust habe es gäbe da noch eine Alternative vom selben Autor
    und etwas aktueller:

    SidebarModoki.uc.js

    JavaScript
    // ==UserScript==
    // @name           SidebarModoki
    // @namespace      http://space.geocities.yahoo.co.jp/gl/alice0775
    // @description    TST
    // @include        main
    // @compatibility  Firefox 106
    // @author         Alice0775
    // @note           Tree Style Tab がある場合にブックマークと履歴等を別途"サイドバーもどき"で表示
    // @note           SidebarModoki.uc.js.css をuserChrome.cssに読み込ませる必要あり
    // @version        2022/09/29 fix Bug 1689816 
    // @version        2022/09/28 ordinal position
    // @version        2022/09/14 fix Bug 1790299
    // @version        2022/09/14 use toolbarspring instead of spacer
    // @version        2022/08/26 Bug 1695435 - Remove @@hasInstance for IDL interfaces in chrome context
    // @version        2022/04/01 23:00 Convert Components.utils.import to ChromeUtils.import
    // @version        2022/03/26 23:00 Bug 1760342 - Remove :-moz-lwtheme-{brighttext,darktext}
    // @version        2021/11/21 18:00 Bug 1742111 - Rename internal accentcolor and textcolor properties to be more consistent with the webext theme API
    // @version        2021/11/14 13:00 wip change css(Bug 1740230 - moz-lwtheme* pseudo-classes don't get invalidated correctly)
    // @version        2021/09/30 22:00 change splitter color
    // @version        2021/05/18 20:00 fix margin of tabpanels
    // @version        2021/02/09 20:00 Rewrite `X.setAttribute("hidden", Y)` to `X.hidden = Y`
    // @version       2020/06/18 fix SidebarModoki position(Bug 1603830 - Remove support for XULElement.ordinal)
    // @version       2019/12/11 fix for 73 Bug 1601094 - Rename remaining .xul files to .xhtml in browser
    // @version        2019/11/14 03:00 workarround Ctrl+tab/Ctrl+pageUP/Down
    // @version        2019/10/20 22:00 fix surplus loading
    // @version        2019/10/20 12:30 workaround Bug 1497200: Apply Meta CSP to about:downloads, Bug 1513325 - Remove textbox binding
    // @version        2019/09/05 13:00 fix listitem
    // @version        2019/08/07 15:00 fix adding key(renamde from key to keyvalue in jsonToDOM)
    // @version        2019/07/13 13:00 fix wrong commit
    // @version        2019/07/10 10:00 fix 70 Bug 1558914 - Disable Array generics in Nightly
    // @version        2019/05/29 16:00 Bug 1519514 - Convert tab bindings
    // @version        2018/12/23 14:00 Adjust margin
    // @version        2018/12/23 00:00 Add option of SidebarModoki posiotion SM_RIGHT
    // @version        2018/05/10 00:00 for 61 wip Bug 1448810 - Rename the Places sidebar files
    // @version        2018/05/08 21:00 use jsonToDOM(https://developer.mozilla.org/en-US/docs/Archive/Add-ons/Overlay_Extensions/XUL_School/DOM_Building_and_HTML_Insertion)
    // @version        2018/05/08 19:00 get rid loadoverlay
    // @version        2017/11/24 19:50 do nothing if window is popup(window.open)
    // @version        2017/11/24 19:20 change close button icon style to 57
    // @version        2017/11/24 19:10 add key(accel(ctrl)+alt+s) and close button
    // @version        2017/11/24 19:00 hack for DL manager
    // @version        2017/11/24 15:00 remove unused variable
    // @version        2017/11/23 13:10 restore initial tab index/width and more unique id
    // @version        2017/11/23 12:30 try catch.  download manager
    // @version        2017/11/23 00:30 Make button icon
    // @version        2017/11/23 00:00 Make button customizable
    // @version        2017/11/22 23:00 fullscreen
    // @version        2017/11/22 23:00 DOM fullscreen
    // @version        2017/11/22 22:00 F11 fullscreen
    // @version        2017/11/15 09:00
    // ==/UserScript==
    
    
    var SidebarModoki = {
      // -- config --
      SM_RIGHT: false,  // SidebarModoki position
      SM_WIDTH : 130,
      SM_AUTOHIDE : false,  //F11 Fullscreen
      TAB_SRC : ["chrome://browser/content/places/bookmarksSidebar.xhtml",
                 "chrome://browser/content/places/historySidebar.xhtml",
                 "chrome://browser/content/downloads/contentAreaDownloadsView.xhtml?SM"],
      TAB_LABEL : ["Bookmarks", "History", "DL"],
      // -- config --
    
      kSM_Open : "userChrome.SidebarModoki.Open",
      kSM_lastSelectedTabIndex : "userChrome.SidebarModoki.lastSelectedTabIndex",
      kSM_lastSelectedTabWidth : "userChrome.SidebarModoki.lastSelectedTabWidth",
      ToolBox: null,
      Button: null,
    
      get prefs(){
        delete this.prefs;
        return this.prefs = Services.prefs;
      },
    
      jsonToDOM: function(jsonTemplate, doc, nodes) {
        jsonToDOM.namespaces = {
        html: "http://www.w3.org/1999/xhtml",
        xul: "http://www.mozilla.org/keymaster/gatekeeper/there.is.only.xul"
        };
        jsonToDOM.defaultNamespace = jsonToDOM.namespaces.xul;
        function jsonToDOM(jsonTemplate, doc, nodes) {
          function namespace(name) {
              var reElemNameParts = /^(?:(.*):)?(.*)$/.exec(name);
              return { namespace: jsonToDOM.namespaces[reElemNameParts[1]], shortName: reElemNameParts[2] };
          }
    
          // Note that 'elemNameOrArray' is: either the full element name (eg. [html:]div) or an array of elements in JSON notation
          function tag(elemNameOrArray, elemAttr) {
            // Array of elements?  Parse each one...
            if (Array.isArray(elemNameOrArray)) {
              var frag = doc.createDocumentFragment();
              Array.prototype.forEach.call(arguments, function(thisElem) {
                frag.appendChild(tag.apply(null, thisElem));
              });
              return frag;
            }
    
            // Single element? Parse element namespace prefix (if none exists, default to defaultNamespace), and create element
            var elemNs = namespace(elemNameOrArray);
            var elem = doc.createElementNS(elemNs.namespace || jsonToDOM.defaultNamespace, elemNs.shortName);
    
            // Set element's attributes and/or callback functions (eg. onclick)
            for (var key in elemAttr) {
              var val = elemAttr[key];
              if (nodes && key == "keyvalue") {  //for later convenient JavaScript access) by giving them a 'keyvalue' attribute; |nodes|.|keyvalue|
                  nodes[val] = elem;
                  continue;
              }
    
              var attrNs = namespace(key);
              if (typeof val == "function") {
                // Special case for function attributes; don't just add them as 'on...' attributes, but as events, using addEventListener
                elem.addEventListener(key.replace(/^on/, ""), val, false);
              } else {
                // Note that the default namespace for XML attributes is, and should be, blank (ie. they're not in any namespace)
                elem.setAttributeNS(attrNs.namespace || "", attrNs.shortName, val);
              }
            }
    
            // Create and append this element's children
            var childElems = Array.prototype.slice.call(arguments, 2);
            childElems.forEach(function(childElem) {
              if (childElem != null) {
                elem.appendChild(
                    doc.defaultView.Node.isInstance(childElem)
                    /*childElem instanceof doc.defaultView.Node*/ ? childElem :
                        Array.isArray(childElem) ? tag.apply(null, childElem) :
                            doc.createTextNode(childElem));
              }
            });
            return elem;
          }
          return tag.apply(null, jsonTemplate);
        }
    
        return jsonToDOM(jsonTemplate, doc, nodes);
      },
    
      init: function() {
        let chromehidden = document.getElementById("main-window").hasAttribute("chromehidden");
        if (chromehidden &&
            document.getElementById("main-window").getAttribute("chromehidden").includes("extrachrome")) {
          return; // do nothing
        }
    
        let MARGINHACK = this.SM_RIGHT ? "0 0 0 0" : "0 -2px 0 0";
        let style = `
          @namespace url(http://www.mozilla.org/keymaster/gatekeeper/there.is.only.xul);
          
          #SM_toolbox
          {
            width: {SM_WIDTH}px;
            background-color: var(--toolbar-bgcolor);
            color: -moz-dialogtext;
            text-shadow: none;
          }
          #SM_toolbox:-moz-lwtheme {
            /*background-color: var(--lwt-accent-color);*/
            background-color: var(--toolbar-bgcolor);
            color: var(--lwt-text-color);
          }
          .SM_toolbarspring {
              max-width: unset !important;
          }
          
          /*visibility*/
          #SM_toolbox[collapsed],
          #SM_splitter[collapsed],
          /*フルスクリーン*/
          #SM_toolbox[moz-collapsed="true"],
          #SM_splitter[moz-collapsed="true"]
          {
            visibility:collapse;
          }
          #SM_splitter {
            background-color: var(--toolbar-bgcolor) !important;
            border-inline-start-color: var(--toolbar-bgcolor) !important;
            border-inline-end-color: var(--toolbar-bgcolor) !important;
          }
    
          /*ポップアップの時*/
          #main-window[chromehidden~="extrachrome"] #SM_toolbox,
          #main-window[chromehidden~="extrachrome"] #SM_splitter
          {
            visibility: collapse;
          }
    
          #SM_tabpanels
          { 
            appearance: none !important;
            padding: 0 !important;
            margin: {MARGINHACK}; /*hack*/
            appearance: unset;
            color-scheme: unset !important;
          }
    
          toolbar[brighttext]:-moz-lwtheme #SM_tabbox {
            background-color: var(--toolbar-bgcolor);
          }
          #SM_tabs {
            overflow-x: hidden;
          }
          #SM_tabs tab {
            appearance: none !important;
          }
          #SM_tabs tab:not([selected]) {
            opacity: 0.6 !important;
          }
          #SM_tabs tab {
            color: unset !important;
          }
          
          #SM_Button
          {
            list-style-image: url('');
          }
          toolbar[brighttext]:-moz-lwtheme #SM_Button
          {
            list-style-image: url('');
          }
         `;
      var sss = Cc['@mozilla.org/content/style-sheet-service;1'].getService(Ci.nsIStyleSheetService);
      var uri = makeURI('data:text/css;charset=UTF=8,' + encodeURIComponent(style.replace(/\s+/g, " ").replace(/\{SM_WIDTH\}/g, this.SM_WIDTH).replace(/\{MARGINHACK\}/g, MARGINHACK)));
      if(!sss.sheetRegistered(uri, sss.AGENT_SHEET))
        sss.loadAndRegisterSheet(uri, sss.AGENT_SHEET);
    /*
        style = style.replace(/\s+/g, " ").replace(/\{SM_WIDTH\}/g, this.SM_WIDTH).replace(/\{MARGINHACK\}/g, MARGINHACK);
        let 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);
        };
    */
        ChromeUtils.import("resource:///modules/CustomizableUI.jsm");
        // xxxx try-catch may need for 2nd window
        try {
          CustomizableUI.createWidget({ //must run createWidget before windowListener.register because the register function needs the button added first
            id: 'SM_Button',
            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 props = {
                id: "SM_Button",
                class: "toolbarbutton-1 chromeclass-toolbar-additional",
                tooltiptext: "Sidebar Modoki",
                oncommand: "SidebarModoki.toggle();",
                type: "button",
                label: "Sidebar Modoki",
                removable: "true"
              };
              for (var p in props) {
                toolbaritem.setAttribute(p, props[p]);
              }
              
              return toolbaritem;
            }
          });
        }catch(e){}
    
        // to do, replace with MozXULElement.parseXULToFragment();
        let template = ["command", {id: "cmd_SidebarModoki", oncommand: "SidebarModoki.toggle()"}];
        document.getElementById("mainCommandSet").appendChild(this.jsonToDOM(template, document, {}));
    
        template = ["key", {id: "key_SidebarModoki", key: "B", modifiers: "accel,alt", command: "cmd_SidebarModoki",}];
        document.getElementById("mainKeyset").appendChild(this.jsonToDOM(template, document, {}));
    //to do xxx ordinal=xx shoud be replaced with style="-moz-box-ordinal-group: xx;"
        template =
          ["vbox", {id: "SM_toolbox", style: this.SM_RIGHT ? "-moz-box-ordinal-group:10" : "-moz-box-ordinal-group:0"},
            ["hbox", {id: "SM_header", align: "center"},
              ["label", {}, "SidebarModoki"],
              ["toolbarspring", {class: "SM_toolbarspring", flex: "1000"}],
              ["toolbarbutton", {id: "SM_closeButton", class: "close-icon tabbable", tooltiptext: "Close SidebarModoki", oncommand: "SidebarModoki.close();"}]
            ],
            ["tabbox", {id:"SM_tabbox", flex: "1", handleCtrlPageUpDown: false, handleCtrlTab: false},
              ["tabs", {id: "SM_tabs"},
                ["tab", {id: "SM_tab0", label: this.TAB_LABEL[0]}],
                ["tab", {id: "SM_tab1", label: this.TAB_LABEL[1]}],
                ["tab", {id: "SM_tab2", label: this.TAB_LABEL[2]}]
              ],
              ["tabpanels", {id: "SM_tabpanels", flex: "1", style: "border: none;"},
                ["tabpanel", {id: "SM_tab0-container", orient: "vertical", flex: "1"},
                  ["browser", {id: "SM_tab0-browser", flex: "1", autoscroll: "false", src: ""}]
                ],
                ["tabpanel", {id: "SM_tab1-container", orient: "vertical", flex: "1"},
                  ["browser", {id: "SM_tab1-browser", flex: "1", autoscroll: "false", src: ""}]
                ],
                ["tabpanel", {id: "SM_tab2-container", orient: "vertical", flex: "1"},
                  ["browser", {id: "SM_tab2-browser", flex: "1", autoscroll: "false", src: ""}]
                ]
              ]
            ]
          ];
        let sidebar = document.getElementById("sidebar-box");
        sidebar.parentNode.insertBefore(this.jsonToDOM(template, document, {}), sidebar);
    
        template =
          ["splitter", {id: "SM_splitter", style: this.SM_RIGHT ? "-moz-box-ordinal-group:9" : "-moz-box-ordinal-group:0", state: "open", collapse: this.SM_RIGHT ? "after" :"before", resizebefore: "closest", resizeafter: "farthest"},
            ["grippy", {}]
          ];
        sidebar.parentNode.insertBefore(this.jsonToDOM(template, document, {}), sidebar);
    
        //xxx 69 hack
        let tabbox = document.getElementById("SM_tabbox");
        tabbox.handleEvent = function handleEvent(event) {
          if (!event.isTrusted) {
            // Don't let untrusted events mess with tabs.
            return;
          }
    
          // Skip this only if something has explicitly cancelled it.
          if (event.defaultCancelled) {
            return;
          }
    
          // Don't check if the event was already consumed because tab
          // navigation should always work for better user experience.
          let imports = {};
          ChromeUtils.defineModuleGetter(
            imports,
            "ShortcutUtils",
            "resource://gre/modules/ShortcutUtils.jsm"
          );
          const { ShortcutUtils } = imports;
    
          switch (ShortcutUtils.getSystemActionForEvent(event)) {
            case ShortcutUtils.CYCLE_TABS:
              if (this.tabs && this.handleCtrlTab) {
                this.tabs.advanceSelectedTab(event.shiftKey ? -1 : 1, true);
                event.preventDefault();
              }
              break;
            case ShortcutUtils.PREVIOUS_TAB:
              if (this.tabs && this.handleCtrlPageUpDown) {
                this.tabs.advanceSelectedTab(-1, true);
                event.preventDefault();
              }
              break;
            case ShortcutUtils.NEXT_TAB:
              if (this.tabs && this.handleCtrlPageUpDown) {
                this.tabs.advanceSelectedTab(1, true);
                event.preventDefault();
              }
              break;
          }
        };
    
        let index = document.getElementById("SM_tabpanels").selectedIndex;
        let tb0 = document.getElementById("SM_tab0");
        let tb1 = document.getElementById("SM_tab1");
        let tb2 = document.getElementById("SM_tab2");
        tb0.parentNode.insertBefore(tb0, tb1);
        tb0.parentNode.insertBefore(tb1, tb2);
        document.getElementById("SM_tabs").selectedIndex = index;
    
        setTimeout(function(){this.observe();}.bind(this), 0);
    
        //F11 fullscreen
        FullScreen.showNavToolbox_org = FullScreen.showNavToolbox;
        FullScreen.showNavToolbox = function(trackMouse = true) {
          FullScreen.showNavToolbox_org(trackMouse);
          if (!!SidebarModoki.ToolBox) {
            SidebarModoki.ToolBox.removeAttribute("moz-collapsed"); 
            SidebarModoki.Splitter.removeAttribute("moz-collapsed");
          }
        }
        FullScreen.hideNavToolbox_org = FullScreen.hideNavToolbox;
        FullScreen.hideNavToolbox = function(aAnimate = false) {
          FullScreen.hideNavToolbox_org(aAnimate);
          if (SidebarModoki.SM_AUTOHIDE && !!SidebarModoki.ToolBox) {
            SidebarModoki.ToolBox.setAttribute("moz-collapsed", "true");
            SidebarModoki.Splitter.setAttribute("moz-collapsed", "true");
          }
        }
    
        //DOM fullscreen
        window.addEventListener("MozDOMFullscreen:Entered", this,
                                /* useCapture */ true,
                                /* wantsUntrusted */ false);
        window.addEventListener("MozDOMFullscreen:Exited", this,
                                /* useCapture */ true,
                                /* wantsUntrusted */ false);
    /*
        SidebarUI.setPosition_org = SidebarUI.setPosition;
        SidebarUI.setPosition = function() {
          SidebarUI.setPosition_org();
          if (SidebarModoki && SidebarModoki.ToolBox) 
          SidebarModoki.ToolBox.style.setProperty("-moz-box-ordinal-group", SidebarModoki.SM_RIGHT ? "10" : "0", "");
          if (SidebarModoki && SidebarModoki.Splitter) 
          SidebarModoki.Splitter.style.setProperty("-moz-box-ordinal-group", SidebarModoki.SM_RIGHT ? "9" : "0", "");
        };
    */
      },
    
    
      observe: function() {
        this.ToolBox = document.getElementById("SM_toolbox");
        this.Splitter = document.getElementById("SM_splitter");
        this.ToolBox.style.setProperty("-moz-box-ordinal-group", this.SM_RIGHT ? "10" : "0", "");
        this.Splitter.style.setProperty("-moz-box-ordinal-group", this.SM_RIGHT ? "9" : "0", "");
    
        if (this.getPref(this.kSM_Open, "bool", true)) {
          this.toggle(true);
        } else {
          this.close();
        }
        document.getElementById("SM_tabs").addEventListener("focus", this, true);
        window.addEventListener("aftercustomization", this, false);
    
        // xxxx native sidebar changes ordinal when change position of the native sidebar and open/close
        this.SM_Observer = new MutationObserver(function(mutations) {
          mutations.forEach(function(mutation) {
            switch (mutation.attributeName) {
              case "collapsed":
              case "hidden":
              case "positionend":
                setTimeout(() => {
                  this.ToolBox.style.setProperty("-moz-box-ordinal-group", this.SM_RIGHT ? "10" : "0", "");
                  this.Splitter.style.setProperty("-moz-box-ordinal-group", this.SM_RIGHT ? "9" : "0", "");
                }, 0);
                break;
            }
          }.bind(this));
        }.bind(this));
        // pass in the target node, as well as the observer options
        this.SM_Observer.observe(document.getElementById("sidebar-box"),
                                 {attribute: true, attributeFilter: ["collapsed", "hidden", "positionend"]});
      },
    
      onSelect: function(event) {
        let aIndex = document.getElementById("SM_tabpanels").selectedIndex;
        this.prefs.setIntPref(this.kSM_lastSelectedTabIndex, aIndex);
        width = this.getPref(this.kSM_lastSelectedTabWidth + aIndex, "int", this.SM_WIDTH);
        if (document.getElementById("SM_tab" + aIndex +"-browser").src == "" ) {
          document.getElementById("SM_tab" + aIndex +"-browser").src = this.TAB_SRC[aIndex];
        }
        document.getElementById("SM_toolbox").style.setProperty("width", width + "px", "");
      },
      
      toggle: function(forceopen) {
        this.Button = document.getElementById("SM_Button");
        if (!this.Button.hasAttribute("checked") || forceopen) {
          this.Button.setAttribute("checked", true);
          this.ToolBox.collapsed= false;
          this.Splitter.collapsed= false;
          let index = this.getPref(this.kSM_lastSelectedTabIndex, "int", 0);
          document.getElementById("SM_tabs").selectedIndex = index;
          width = this.getPref(this.kSM_lastSelectedTabWidth + index, "int", this.SM_WIDTH);
          document.getElementById("SM_toolbox").style.setProperty("width", width + "px", "");
          this.prefs.setBoolPref(this.kSM_Open, true)
          this.onSelect({});
          addEventListener("resize", this, false);
        } else {
          this.close();
        }
      },
    
      close: function() {
        removeEventListener("resize", this, false);
        this.Button = document.getElementById("SM_Button");
        this.Button.removeAttribute("checked");
        this.ToolBox.collapsed = true;
        this.Splitter.collapsed = true;
        this.prefs.setBoolPref(this.kSM_Open, false)
      },
    
    
      //ここからは, 大きさの調整
      onResize: function(event) {
         let width = this.ToolBox.getBoundingClientRect().width;
         let aIndex = document.getElementById("SM_tabs").selectedIndex;
         this.prefs.setIntPref(this.kSM_lastSelectedTabWidth + aIndex, width);
      },
    
      handleEvent: function(event) {
        switch(event.type) {
          case 'focus':
            this.onSelect(event);
            break;
          case 'resize':
            this.onResize(event);
            break;
          case 'MozDOMFullscreen:Entered':
            if (!!this.ToolBox) {
              this.ToolBox.setAttribute("moz-collapsed", "true");
              this.Splitter.setAttribute("moz-collapsed", "true");
            }
            break;
          case 'MozDOMFullscreen:Exited':
            if (!!this.ToolBox) {
              this.ToolBox.removeAttribute("moz-collapsed"); 
              this.Splitter.removeAttribute("moz-collapsed");
            }
            break;
          case 'aftercustomization':
            if (this.getPref(this.kSM_Open, "bool", true)) {
              this.Button.setAttribute("checked", true);
            }
            break;
         }
      },
    
      //pref読み込み
      getPref: function(aPrefString, aPrefType, aDefault) {
        try{
          switch (aPrefType){
            case "str":
              return this.prefs.getCharPref(aPrefString).toString(); break;
            case "int":
              return this.prefs.getIntPref(aPrefString); break;
            case "bool":
            default:
              return this.prefs.getBoolPref(aPrefString); break;
          }
        }catch(e){
        }
        return aDefault;
      }
    
    }
    
    SidebarModoki.init();
    Alles anzeigen

    Dieser CSS Code muss dazu verwendet werden, bzw. über userchrome.css geladen werden:

    SidebarModoki.uc.js.css

    CSS
    @charset "utf-8";
    @namespace url("http://www.mozilla.org/keymaster/gatekeeper/there.is.only.xul");
    
    /*@version        2020/03/13 17:00 use xhtml instead xul*/
    /*@version        2019/10/20 12:30*/
    
    @-moz-document url("chrome://browser/content/downloads/contentAreaDownloadsView.xhtml?SM") {
          *|*:root
          {
            --downloads-item-height: 3.5em;
          }
                richlistitem { 
                  height: 3.5em !important;
                }       
          #contentAreaDownloadsView
          {
            padding: 0 !important;
          }
          .downloadTypeIcon,
          .downloadBlockedBadge
          {
            margin-left:0 !important;
            margin-right:1px !important;
          }
          .downloadButton {
            padding-left:0 !important;
            padding-right:0 !important;
          }
    }
    Alles anzeigen

    Verwende ich hier nicht.
    Vielleicht passt das ja auch.
    Mfg.
    Endor

  • Fenster unter Firefox-Suchfeld mit einer anderen Rahmenfarbe versehen und nicht mit so stark abgerundeten Ecken

    • Endor
    • 19. Oktober 2022 um 19:32

    Hallo 2002Andreas.

    Vielen Dank. :thumbup:

    Wieder etwas dazu gelernt.

    :)

    Mfg.
    Endor

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