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

Beiträge von GermanFreme82

  • Mehrzeilige Tableiste für aktuelle Firefox-Versionen

    • GermanFreme82
    • 30. April 2025 um 23:04
    Zitat von grisu2099
    Zitat von GermanFreme82

    Bitte bitte ich brauch dringen die neuen Anpassung "in" meinem Script,

    Das alte Skript kann nicht mehr angepaßt werden - wie oft muß man dir das noch sagen... :sleeping:

    Ich hab keine Ahnung ich habe einen Link bekommen zu dem Beitrag hier und hier soll es soweit ich verstehe darum gehen eine neue Version zu bekommen für dieses "MultiRowTab_Firefox107.js"

    Ich sehe hier nur keine neue Version, darum Frage ich weil ich mich nicht auskenne.

    Bitte sagt mir was ich machen muß damit "MultiRowTab_Firefox107.js" in der Upgrade Version oder was das ist in meinen Firefox reinkommt und das ich es mit FF138 nutzen kann.

  • Mehrzeilige Tableiste für aktuelle Firefox-Versionen

    • GermanFreme82
    • 30. April 2025 um 22:48

    Hallo liebe Grüße an alle hier !

    Könnte mir bitte jemand mit meinem Script helfen es auf FF138 zu bekommen ?

    In dem Script sind div. Anpassungen optisch und technisch soweit ich das noch weiß.
    "BrokenHeart" hat mir in der Vergangenheit sehr damit geholfen, weil ich mich nicht auskenne mit sowas.

    Ich weiß nicht wie man Code postet tut mir leid, kann mir das nicht merken, daher poste ich es als Datei.
    bitte ignoriert den komischen Namen der ist nur für mich wichtig.

    MultiRowTab_Firefox107.js.txt

    Bitte bitte ich brauch dringen die neuen Anpassung "in" meinem Script, da ich nicht mehr weiß was damals alles geändert wurde.


    Code Versuch post keien Ahnung geht nicht

    Spoiler anzeigen

    CODE Versuch post

    // 'MultiRowTabs.uc.js' V02 by BrokenHeart
    // based on 'MultiRowTab_LiteforFx48.uc.js' from 'http://space.geocities.yahoo.co.jp/gl/alice0775' (Alice0775)
    // Thanks to aborix...

    /* ///////////////////////////////////////////////////////////////////////////////////
    [13.07.2021 22:45Uhr]
    - 'Nur-JavaScript-Version' (CSS wird nicht mehr benötigt)
    - Sehr viele funktionale und optische Anpassungen hinzugefügt
    [20.02.2020 18:45Uhr]
    Fehler in allen CSS-Dateien beseitigt (:thumbup:Dank an diwa fürs melden )
    [18.02.2020 13:30Uhr]
    - Anpassen des User-JavaSkripts aus (3).
    - Skript 'Tabsrunter.uc.js' wurde entfernt, da jetzt bereits in (3) integriert.
    [11.12.2019 13:15Uhr]
    - Optische Anpassungen an Code (1) und (2).
    - Neuen Code hinzugefügt für 'Tabs mit abgerundeten Ecken' (2a).
    - Anpassen des User-JavaSkripts zum Verschieben der Tabs (3).
    [08.12.2019 17:45Uhr]
    - Anpassungen am Code (1) und (2) vorgenommen, um 'Tableiste unten' zu berücksichtigen.
    - JavaSkript hinzugefügt, welches die Tableiste nach unten befördert.
    [19.08.2022 21:28Uhr]
    - Fehler Menüleiste behoben
    [23.09.2022 01:58Uhr]
    - "Wheel-Event" Problem behoben
    [18.10.2022 15:20Uhr]
    -Fix: FF106+ -> 'Drag&Drop'
    [19.11.2022 09:28Uhr]
    -Fix: FF107+ -> 'contain' entfernt
    [15.12.2022 07:52Uhr]
    -Fix: FF108+ -> Toggle-menubar angepasst
    [15.12.2022 15:50Uhr]
    -Fix: FF108+ -> Position der vertikalen Tableiste korrigiert
    [19.12.2022 19:58Uhr]
    - Seite für neuen Tab wird aus Voreinstellungen gelesen
    - kleinere optische Anpassungen
    [21.12.2022 18:32Uhr]
    - Fix: Menüleiste per 'alt'/'F10'-Key einblenden
    [10.05.2023 00:08]
    - Fix: Anpassungen Flex-Container
    [10.05.2023 19:32]
    - Fix: Anpassungen "Vertikale Tableiste"
    [07.06.2023 18:35]
    - Fix: Siehe: RE: Entwicklung Firefox
    [07.06.2023 18:35]
    - Fix: Siehe: RE: Entwicklung Firefox
    [02.09.2023 09:30]
    -Fix: Visualisierung ausgewählter Tabs (>=FF119)
    [24.10.2023 18:44]
    - Tabbar-Position [6] (FF119+)
    - angeheftete Tabs
    - kleinere Fehler
    [04.03.2024 19:48]
    - angeheftete Tabs -> Fehlerbehebungen
    [23.08.2024 13:00]
    - Tab-Tooltip ausblenden -> funktioniert wieder
    [01.10.2024 19:00]
    - Fix: Anpassung der Tableiste FF 131
    [16.10.2024 23:45]
    - Fix: Probleme mit Lesezeichenleiste behoben (Vielen Dank an 2002Andreas für den Code!)
    [26.11.2034 19:00]
    - Unterschiedliche Anpassungen für FF133
    /////////////////////////////////////////////////////////////////////////////////////*/


    "use strict";

    MultiRowTabs();
    function MultiRowTabs() {
       
    if (!window.gBrowser){
    return;
    }

    // ----------------------------
    // --- User-Settings: Start ---
    // ----------------------------

    // Position der Tab-Leiste:
    //
    var nTabbarPosition = 2; // [1] Tab-Leiste ist oberhalb aller Symbolleisten
    // [2] Tab-Leiste ist unterhalb aller Symbolleisten, aber über dem Inhaltsbereich
    // [3] Tab-Leiste ist vertikal auf der linken Seite
    // [4] Tab-Leiste ist vertikal auf der linken Seite - Tableiste wird erst angezeigt bei Mausbewegung an den linken Rand (Autohide/Autopopup)
    // [5] Tab-Leiste ist vertikal auf der rechten Seite
    // [6] Tab-Leiste ist unterhalb des Inhaltsbereichs


    // Tab-Größenangaben
    //
    var nTabWidth = 170; // Breite der einzelnen Tabs in Pixeln
    var nTabHeight = 35; // Höhe der einzelnen Tabs in Pixeln
    var nTabMargin = 1; // Abstand zwischen den Tab-Zeilen in Pixeln


    // sonstige Einstellungen
    //
    var nTabLines = 7; // Anzahl der sichtbaren Tab-Zeilen, darüber hinaus wird gescrollt <nur bei horizontaler Ausrichtung (Position:[1],[2],[6]) - sonst keine Funktion>
    var bTabScrollbar = true; // [true] Scrollbar für Tab-Leiste anzeigen, [false] Keine Scrollbar für Tab-Leiste anzeigen (Achtung: [false] = kein Scrollen mehr bei 'drag&drop' von Tabs!)
    var bTabTooltips = true; // [true] Tab-Tooltips werden angezeigt, [false] Tab-Tooltips werden nicht angezeigt


    // Tab-Schließen-Button
    //
    var bTabCloseButton = true; // [true] Tab-Schließen-Button anzeigen, [false] Tab-Schließen-Button verbergen
    var bTabCloseButRounded = false; // [false] quadratische Darstellung, [true] abgerundete Darstellung
    var nTabCloseButTransparency= 0.85; // Transparenzwert des Tab-Schließen-Button in Prozent. Wertebereich: [0]=vollständig durchscheinend bis [1]=vollständig deckend (z.B [0.75])
    var nTabCloseIconNr = 0; // [0] Standard-Icon wird angezeigt
    // [1] rotes Icon mit weißem Kreuz wird angezeigt
    // [2] schwarzes Icon mit weißem Kreuz wird angezeigt
    var nTabCloseButSize = 18; // Höhe und Breite des Tab-Schließen-Buttons in Pixeln


    // FavIcon
    //
    var nFavIconSize = 16; // Höhe und Breite des 'FavIcons' und der Ladeanimation,[16] = Standard


    // 'Throbber'-Animation
    //
    var bNewThroberAnimation = true; // [true] Alternative 'Throbber'-Animation auswählen, [false] Standard 'Throbber'-Animation beibehalten


    // Hintergrundfarbe der Tabs (für einfarbige Darstellung müssen die RGB-Farbwerte 1 und 2 jeweils identisch sein)
    //
    var strTabSelColor1 = "240,152,0"; // RGB-Farbwert1 selektierter Tab
    var strTabSelColor2 = "240,152,0"; // RGB-Farbwert2 selektierter Tab
    var strTabNotSelColor1 = "195,157,116";// RGB-Farbwert1 nicht selektierter Tab
    var strTabNotSelColor2 = "195,157,116";// RGB-Farbwert2 nicht selektierter Tab
    var nTabTransparency = 1; // Transparenzwert des unselektierten Tab Hintergrundes. Wertebereich: [0]=vollständig durchscheinend bis [1]=vollständig deckend (z.B [0.75])


    // Schriftart und Textdarstellung der Tabs
    //
    var strTabFontName = "Segoe UI"; // Name der Schriftart
    var strTabFontColorSel = "255,255,255";// RGB-Farbwert der Schrift des selektierten Tabs
    var strTabFontColorNotSel = "255,255,255";// RGB-Farbwert der Schrift des nicht selektierten Tabs
    var nTabFontWeight = 600; // Stärke der Schrift: Wertebereich: [100] = sehr dünn bis [900] = sehr dick(bold). [500] = normal
    var nTabFontSize = 12; // Größe/Höhe der Schrift in Pixeln
    var bTabFontTextShadow = true; // [true] Text wird mit Schatteneffekt ausgegeben, [false] Text wird ohne Schatteneffekt ausgegeben. (Effekt nur bei selektierten Tabs!)
    var bMarkUnreadTab = false; // [true] Kursive Schrift für ungelesene Tabs, [false] ungelesene Tabs werden nicht hervorgehoben


    // Rahmen um einzelne Tabs
    //
    var nTabBorderWidth = 0; // Breite des Tab-Rahmen ([0] = kein sichtbarer Rahmen)
    var nTabBorderRadius = 30; // Radius für abgerundete Ecken des Tabs ([0] = rechteckig, [80] = ideal abgerundet ).
    var strTabBorderColor = "128,128,128";// RGB-Farbwert des Rahmens


    // Neuer-Tab-Button
    //
    var strNewTabButtonColor = "255,255,255";// RGB-Farbwert des '+'-Zeichens


    // Hintergrund der Tab-Leiste (für einfarbige Darstellung müssen die RGB-Farbwerte 1 und 2 jeweils identisch sein)
    //
    var strTabBarBgColor1 = "21,21,12"; // RGB-Farbwert1 für Hintergrund der Tab-Leiste
    var strTabBarBgColor2 = "62,75,84"; // RGB-Farbwert2 für Hintergrund der Tab-Leiste



    var nTabBarTransparency = 0; // Transparenzwert des Tab-Leisten Hintergrundes. Wertebereich: [0]=vollständig durchscheinend bis [1]=vollständig deckend
    var strTabBarBgImagePath = ""; // Absoluter Dateipfad zu einem gepeicherten Bild (z.B.: "D://Bilder//Firefox//Hintergrund.jpg" )
    // "D://Programme%20(Portable)//Firefox%20Portable//FireFox%20ESR%2091//Profilordner//chrome//image//NavToolbarBackground02.png"
    var bTabBarBgImageRepeat = false; // [true] Bild wird für den gesamten Bereich mehrfach nebeneinander angezeigt, [false] Bild wird nur einmal angezeigt (Position: linke/obere Ecke)


    // Einstellungen für vertikale Tab-Leiste
    //
    var nVerticalTabbarWidth = 215; // Breite der Vertikalen Tab-Leiste in Pixeln <nur bei vertikaler Ausrichtung (Position:[3],[4],[5]) - sonst keine Funktion>
    var nVerticalAutoPopupHover = 2; // Abstand zum linken Fensterrand in Pixeln, ab der die vertikale Tab-Leiste sichtbar gemacht wird <Position[4] - sonst keine Funktion>
    var nVerticalAutoPopupAnim = 0.5; // Dauer der Animation beim 'Herausschieben' des vertikalen Tab-Leiste in Sekunden ([0] = keine Animation) <Position[4] - sonst keine Funktion>


    // Einstellungen für Maus-Bedienung
    //
    var bTabWheel = false; // [true]: Tab-Wheel-Selection(=Selektieren des nächsten/vorherigen Tabs mit dem Mausrad) einschalten, [false]: Tab-Wheel-Selection ausschalten
    var bPageScroll = true; // [true]: seitenweises Scrollen, [false]: zeilenweises Scrollen
    var bDblclickOnTabbarNewTab = true; // [true] Doppel-Klick über Tabbar öffnet neuen Tab, [false] Funktion wird nicht ausgeführt
    var bDblclickOnTabReloadTab = true; // [true] Doppel-Klick über Tab lädt diesen neu, [false] Funktion wird nicht ausgeführt

    // ----------------------------
    // --- User-Settings: Ende ---
    // ----------------------------


           
    let strHomepageURL;
    try {
    strHomepageURL = Services.prefs.getCharPref('browser.startup.homepage');
    console.log("homepage: " + strHomepageURL);
    } catch(e) {
    console.log("Error Homepage-String loading...");
    }
           
            
    if( nTabbarPosition < 1 || nTabbarPosition > 6 ) {
    nTabbarPosition = 1;
    }
       
    // Tab-Leiste ganz unten
    if( nTabbarPosition == 6 )
    {
    let tabbarBoxBottom = document.createXULElement('vbox');
    tabbarBoxBottom.id = 'tabbarboxbottom';
    tabbarBoxBottom.style.background = '#000000';
           
    document.getElementById("navigator-toolbox").parentNode.insertBefore( tabbarBoxBottom, null);
    //document.getElementById("navigator-toolbox").parentNode.parentNode.insertBefore( tabbarBoxBottom, document.getElementById("browser-bottombox"));
    let tabbar = document.getElementById("TabsToolbar");
    tabbarBoxBottom.appendChild(tabbar);
    }
       
    //Tableiste vertikal
    if(nTabbarPosition == 3 || nTabbarPosition == 5 )
    {
    let nTabbarWidth = nVerticalTabbarWidth;
               
    let tabbarBox = document.createXULElement('vbox');
    tabbarBox.id = 'tabbar-box';
    tabbarBox.style.width = nVerticalTabbarWidth + 'px';
    tabbarBox.style.background = '#000000';
           
    // Platz für Tab-Leiste auf der linken Seite
    if(nTabbarPosition == 3) {
    let sidebarBox = document.getElementById('sidebar-box');
    sidebarBox.parentNode.insertBefore(tabbarBox, sidebarBox);
    }
    // Platz für Tab-Leiste auf der rechten Seite
    else if( nTabbarPosition == 5) {
    document.getElementById("browser").insertBefore(tabbarBox,document.getElementById("browser").lastChild.nextSibling);
    tabbarBox.style.width = '0px';
    }
           
    }

    tabsetting: {
    let css =`
    tabs tab {
    border-left: solid 1px hsla(0,0%,0%,0) !important;
    border-right: solid 1px hsla(0,0%,0%,0) !important;
    z-index: 2 !important;
    }
    tabs tab:after,tabs tab:before
    {
    display: none !important;
    }
               
       
    `;

    let sss = Cc['@mozilla.org/content/style-sheet-service;1'].getService(Ci.nsIStyleSheetService);
    let uri = makeURI('data:text/css;charset=UTF=8,' + encodeURIComponent(css));
    sss.loadAndRegisterSheet(uri, sss.AUTHOR_SHEET);
    }


    //var nTabLineHeight = nTabHeight+2*nTabMargin;
    nTabMargin *= 2;
    var nTabLineHeight = nTabHeight+nTabMargin;
       
    //console.log("Margin: " + nTabMargin );
       
    multiLineTabSetup: {
           
    let service,uri,cssIn,cssOut;
           
    // ---
    // CSS-Icon-Settings
    // ---
    cssIn =`
               
        
    /* Tab-Schließen-Button auf allen Tabs anzeigen oder verbergen */
    .tabbrowser-tab:not([pinned]) .tab-close-button,
    .tabbrowser-tab:not([pinned]) .tab-close-button:not([selected="true"]) {
    display: __strTabCloseVisible__ !important;
    }
           
    /* Icon für Tab-Schließen-Button anzeigen */
    .tabbrowser-tab:not([pinned]) .close-icon {
    __CloseIcon1DisableStart__ list-style-image: url("") !important; __CloseIcon1DisableEnd__
    __CloseIcon2DisableStart__ list-style-image: url("") !important; __CloseIcon2DisableEnd__


    border-radius: __nBorderRadius__px !important;
    padding: 3px !important;
    width: __nTabCloseButSize__px !important;
    height: __nTabCloseButSize__px !important;
    filter: opacity(__nTabCloseButTransparency__%) drop-shadow(-1px -1px 1px rgba(0,0,0,0.15)) drop-shadow(0px -1px 1px rgba(255,255,255,0.15)) !important;
    }
               
    /* Neuer Tab Button */
    #TabsToolbar #tabs-newtab-button > image {
    min-height: __nNewTabButtonSize__px !important;
    max-height: __nNewTabButtonSize__px !important;
    min-width: __nNewTabButtonSize__px !important;
    max-width: __nNewTabButtonSize__px !important;
    margin-top: -1px !important;
    margin-left: -3px !important;
    padding: 2px !important;
    fill: rgba(__strNewTabButtonColor__,1) !important;
    }
               
               
    /* Throbber Icon ändern */
    __NewThrowberDisableStart__
    .tab-throbber[busy]::before,
    .tab-throbber[progress]::before {
    width: 16px !important;
    height: 16px !important;
    animation: unset !important;
    -moz-context-properties: unset !important;
    fill: unset !important;
    opacity: unset !important;
    }
    .tab-throbber[busy]::before {
    background-image: url("") !important;
    }/*
    .tab-throbber-fallback[busy] {
    list-style-image: url("") !important;
    }*/
    .tab-throbber[progress]::before{
    background-image: url("") !important;
    }/*
    .tab-throbber-fallback[progress] {
    list-style-image: url("") !important;
    }*/
    __NewThrowberDisableEnd__
           
    `;
           
    cssOut = cssIn;
           
    if(bTabCloseButton) {
    cssOut = cssOut.replace("__strTabCloseVisible__", "initial");
    }
    else {
    cssOut = cssOut.replace("__strTabCloseVisible__", "none");
    nTabCloseIconNr = 0;
    }
           
    if( nTabCloseIconNr == 1 ) {
    cssOut = cssOut.replace(/__CloseIcon1DisableStart__/g, ' ');
    cssOut = cssOut.replace(/__CloseIcon1DisableEnd__/g, ' ');
    cssOut = cssOut.replace(/__CloseIcon2DisableStart__/g, '/*');
    cssOut = cssOut.replace(/__CloseIcon2DisableEnd__/g, '*/');
    }
    else if( nTabCloseIconNr == 2 ) {
    cssOut = cssOut.replace(/__CloseIcon1DisableStart__/g, '/*');
    cssOut = cssOut.replace(/__CloseIcon1DisableEnd__/g, '*/');
    cssOut = cssOut.replace(/__CloseIcon2DisableStart__/g, ' ');
    cssOut = cssOut.replace(/__CloseIcon2DisableEnd__/g, ' ');
    }
    else
    {
    cssOut = cssOut.replace(/__CloseIcon1DisableStart__/g, '/*');
    cssOut = cssOut.replace(/__CloseIcon1DisableEnd__/g, '*/');
    cssOut = cssOut.replace(/__CloseIcon2DisableStart__/g, '/*');
    cssOut = cssOut.replace(/__CloseIcon2DisableEnd__/g, '*/');
               
    }
           
    if(bTabCloseButRounded)
    cssOut = cssOut.replace(/__nBorderRadius__/g, 20);
    else
    cssOut = cssOut.replace(/__nBorderRadius__/g, 0);
           
    cssOut = cssOut.replace(/__nTabCloseButTransparency__/g, nTabCloseButTransparency*100);
    cssOut = cssOut.replace(/__nTabCloseButSize__/g, nTabCloseButSize);
           
           
    cssOut = cssOut.replace(/__nNewTabButtonSize__/g, nTabHeight);
    cssOut = cssOut.replace(/__strNewTabButtonColor__/g, strNewTabButtonColor);
           
    if(bNewThroberAnimation)
    {
    cssOut = cssOut.replace(/__NewThrowberDisableStart__/g, ' ');
    cssOut = cssOut.replace(/__NewThrowberDisableEnd__/g, ' ');
    }
    else
    {
    cssOut = cssOut.replace(/__NewThrowberDisableStart__/g, '/*');
    cssOut = cssOut.replace(/__NewThrowberDisableEnd__/g, '*/');
    }

    //console.log("cssOut1: " + cssOut );
           
    service = Cc['@mozilla.org/content/style-sheet-service;1'].getService(Ci.nsIStyleSheetService);
    uri = makeURI('data:text/css;charset=UTF=8,' + encodeURIComponent(cssOut));
    service.loadAndRegisterSheet(uri, service.AUTHOR_SHEET);
          
            
    cssIn =`
    /* Scrollbars -> "no-drag"*/
    scrollbar, scrollcorner, scrollbar thumb, scrollbar scrollbarbutton {
    -moz-window-dragging: no-drag !important;
    }
            
    /* Tabs */
                        
    scrollbox[smoothscroll="true"] > slot {
    display: contents !important;
    }
            
    `;
           
    service = Cc['@mozilla.org/content/style-sheet-service;1'].getService(Ci.nsIStyleSheetService);
    uri = makeURI('data:text/css;charset=UTF=8,' + encodeURIComponent(cssIn));
    service.loadAndRegisterSheet(uri, service.AGENT_SHEET);


    cssIn =`

    :root[tabsintitlebar][sizemode="maximized"] #titlebar,
    :root[tabsintitlebar][sizemode="normal"] #titlebar {
    appearance: none !important;
    }

    .tabbrowser-tab {
    --tab-label-mask-size: 1em;
    }
           
    #tabbrowser-tabs[haspinnedtabs]:not([positionpinnedtabs]) > #tabbrowser-arrowscrollbox >
    .tabbrowser-tab:nth-child(1 of :not([pinned], [hidden])) {
    margin-inline-start: -1px !important;
    }
           
    #tab-preview-panel {
    strTabTooltips !important;
    }
                    
    #TabsToolbar > .titlebar-buttonbox-container,
    #main-window[sizemode="fullscreen"] #window-controls {
    display: none !important;
    }
               
    #TabsToolbar {
    /* Hintergrund der Tab-Leiste setzen */
    __strTabBarBackground__
    }
           
                   
                           
    /* Tab-Höhe */
    .tabbrowser-tab, .tab-stack, .tab-background {
    min-height: nTabHeightpx !important;
    max-height: nTabHeightpx !important;
               
    margin-top: 0px !important;
    margin-bottom: nTabMarginpx !important;
               
    margin-left: -1px !important;
    margin-right: 0px !important;
    }


    #tabbrowser-tabs .tab-label:not([fokus]){
    opacity: 1!important;
    }

    tabs > arrowscrollbox::part(scrollbox) {
    overflow-x: hidden !important;
    overflow-y: strScrollbar !important;
    }


    .tabbrowser-tab:not([pinned]) {
    flex-grow: 0 !important;
    min-width: nTabWidthpx !important;
    }
           
       
    /* Schriftart/Schriftgröße ändern */
    .tabbrowser-tab .tab-label {
    text-shadow: none !important;
    color: rgb(strTabFontColorNotSel) !important;
    font-weight: nTabFontWeight !important;
    font-size: nTabFontSizepx !important;
    font-family: "strTabFontName" !important;
    font-style: normal;
    }

    .tabbrowser-tab[selected] .tab-label,
    .tabbrowser-tab[multiselected] .tab-label {
    text-shadow: __strTextShadow__ !important; ;
    color: rgb(strTabFontColorSel) !important;
    font-weight: nTabFontWeight !important;
    font-size: nTabFontSizepx !important;
    font-family: "strTabFontName" !important;
    font-style: normal;
    }
           
    /*Ungelesene Tabs werden markiert */
    .tabbrowser-tab[pending] .tab-label, .tabbrowser-tab[notselectedsinceload="true"] {
    font-style: __strMarkUnreadTab__ !important;
    }

    #TabsToolbar .tabbrowser-tab .tab-background
    {
    border-radius: nTabBorderRadiuspx !important;
    border: nTabBorderWidthpx solid rgba(strTabBorderColor,0.66) !important;
    }


    /* Tab-Hintergrund */
    /*--- selektiert ---*/
    .tab-background[selected]{
    background-image: linear-gradient( rgba(strTabSelColor1,1), rgba(strTabSelColor2,1) ), none !important;
    filter: drop-shadow(2px 2px 2px rgba(0,0,0,0.5)) drop-shadow(-2px 2px 2px rgba(0,0,0,0.5)) !important;
    border-radius: nTabBorderRadiuspx !important;
    }
    /*--- hover: nicht selektiert ---*/
    .tabbrowser-tab:hover > .tab-stack > .tab-background:not([selected]) {
    filter: brightness(130%) contrast(110%) drop-shadow(1px 1px 1px rgba(0,0,0,0.5)) drop-shadow(-1px 1px 1px rgba(0,0,0,0.5)) !important;
    border-radius: nTabBorderRadiuspx !important;
    }
    .tabbrowser-tab:hover:not([selected]) :is(.tab-label,.tab-icon-stack) {
    filter: drop-shadow( 0px 0px 2px #AAAAAA) brightness(115%) !important;
    }
    /*--- hover: Multi selektiert ---*/
    .tabbrowser-tab:hover > .tab-stack > .tab-background[multiselected]:not([selected]) {
    filter: brightness(120%) contrast(100%) drop-shadow(1px 1px 1px rgba(0,0,0,0.5)) drop-shadow(-1px 1px 1px rgba(0,0,0,0.5)) !important;
    border-radius: nTabBorderRadiuspx !important;
    }
    /*--- nicht selektiert ---*/
    .tab-background:not([selected]) {
    background-image: linear-gradient( rgba(strTabNotSelColor1,nTabTransparency), rgba(strTabNotSelColor2,nTabTransparency) ), none !important;
    filter: brightness(115%) contrast(90%) drop-shadow(1px 1px 1px rgba(0,0,0,0.5)) drop-shadow(-1px 1px 1px rgba(0,0,0,0.5)) !important;
    border-radius: nTabBorderRadiuspx !important;
    }
    /*--- Multi selektiert ---*/
    .tab-background[multiselected]:not([selected]) {
    background-image: linear-gradient( rgba(strTabSelColor1,1), rgba(strTabSelColor2,1) ), none !important;
    filter: brightness(130%) saturate(50%) drop-shadow(1px 1px 1px rgba(0,0,0,0.5)) drop-shadow(-1px 1px 1px rgba(0,0,0,0.5)) !important;
    border-radius: nTabBorderRadiuspx !important;
    }
       
    .tab-sharing-icon-overlay, .tab-icon-overlay:not([pinned]), .tab-icon-overlay[soundplaying] {
    transform: scale(1.5) !important;
    }
           
    .tabbrowser-tab .tab-label
    {
    margin-top: -2px !important;
    }
               
           
    .tab-close-button
    {
    margin-top: -2px !important;
    }
           
    .tab-throbber, .tab-throbber-tabslist, .tab-icon-pending, .tab-icon-image, .tab-sharing-icon-overlay {
    height: nFavIconSizepx !important;
    width: nFavIconSizepx !important;
    fill: rgba(255,255,255,0.8) !important;
    margin-top: -2px !important;
    }
           
    #tabbrowser-tabs, #tabbrowser-arrowscrollbox, #tabbrowser-tabs[positionpinnedtabs] > #tabbrowser-arrowscrollbox > .tabbrowser-tab[pinned] {
    min-height: 0 !important;
    }

    #tabbrowser-tabs {
    appearance: none !important;
    }
           
    .tabbrowser-tab:is([visuallyselected], [multiselected]) > .tab-stack > .tab-background:-moz-lwtheme {
    box-shadow: none !important;
    }
            
    `;


    // --- CSS-Parameter ersetzen ---
    cssOut = cssIn.replace(/nTabHeight/g, nTabHeight);
    cssOut = cssOut.replace(/nTabMargin/g, nTabMargin);
    cssOut = cssOut.replace(/nTabWidth/g, nTabWidth);
           
                   
    if(bTabScrollbar) {
    cssOut = cssOut.replace("strScrollbar", "auto");
    }
    else {
    cssOut = cssOut.replace("strScrollbar", "hidden");
    }


    if(!bTabTooltips) {
    cssOut = cssOut.replace("strTabTooltips", "display: none");
    }


    cssOut = cssOut.replace(/strTabSelColor1/g, strTabSelColor1);
    cssOut = cssOut.replace(/strTabSelColor2/g, strTabSelColor2);
    cssOut = cssOut.replace(/strTabNotSelColor1/g, strTabNotSelColor1);
    cssOut = cssOut.replace(/strTabNotSelColor2/g, strTabNotSelColor2);
    cssOut = cssOut.replace(/nTabBorderRadius/g, nTabBorderRadius);
    cssOut = cssOut.replace(/nTabBorderWidth/g, nTabBorderWidth);
    cssOut = cssOut.replace(/strTabBorderColor/g, strTabBorderColor);
    cssOut = cssOut.replace(/nTabTransparency/g, nTabTransparency);
           
    cssOut = cssOut.replace(/strTabFontName/g, strTabFontName);
    cssOut = cssOut.replace(/strTabFontColorSel/g, strTabFontColorSel);
    cssOut = cssOut.replace(/strTabFontColorNotSel/g, strTabFontColorNotSel);
    cssOut = cssOut.replace(/nTabFontSize/g, nTabFontSize);
    cssOut = cssOut.replace(/nTabFontWeight/g, nTabFontWeight);
           
    if (bTabFontTextShadow)
    cssOut = cssOut.replace(/__strTextShadow__/g, "1px 1px 0px #000000");
    else
    cssOut = cssOut.replace(/__strTextShadow__/g, "none");
           
           
    if( bMarkUnreadTab )
    cssOut = cssOut.replace(/__strMarkUnreadTab__/g, "italic");
    else
    cssOut = cssOut.replace(/__strMarkUnreadTab__/g, "normal");
           
                        
    let strTabBarBackgroundOut = "";
    if( strTabBarBgImagePath ) {
    if( bTabBarBgImageRepeat ) {
    strTabBarBackgroundOut = "background: #000000 url(\"file:" + strTabBarBgImagePath + "\") repeat !important;";
    }
    else {
    strTabBarBackgroundOut = "background: #000000 url(\"file:" + strTabBarBgImagePath + "\") no-repeat !important;";
    }
    }
    else {
    strTabBarBackgroundOut = "background-image: linear-gradient( rgba(" + strTabBarBgColor1 + "," + nTabBarTransparency +"), rgba(" + strTabBarBgColor2 + "," + nTabBarTransparency + ") ) !important;";
    }
                           
    cssOut = cssOut.replace(/__strTabBarBackground__/g, strTabBarBackgroundOut);
           
    cssOut = cssOut.replace(/nFavIconSize/g, nFavIconSize);
                           
    //console.log("CSSOut: " + cssOut );


    service = Cc['@mozilla.org/content/style-sheet-service;1'].getService(Ci.nsIStyleSheetService);
    uri = makeURI('data:text/css;charset=UTF=8,' + encodeURIComponent(cssOut));
    service.loadAndRegisterSheet(uri, service.AUTHOR_SHEET);
                   
    let tabsScrollbox = document.getElementById('tabbrowser-arrowscrollbox').scrollbox;
           
    tabsScrollbox.style.minHeight = nTabLineHeight +'px';
    tabsScrollbox.style.maxHeight = nTabLineHeight*nTabLines +'px';
    /*
    console.log("tabsScrollbox: " + tabsScrollbox );
    console.log("tabsScrollbox.style.minHeight: " + tabsScrollbox.style.minHeight );
    console.log("tabsScrollbox.style.maxHeight: " + tabsScrollbox.style.maxHeight );
    */
           
    }


    if( nTabbarPosition >= 2 && nTabbarPosition <= 5 ) {
    let tabbar = document.getElementById("TabsToolbar");
    tabbar.parentNode.appendChild(tabbar);
    }


    if( nTabbarPosition >= 3 && nTabbarPosition <= 5 )
    {
    let cssIn =`
           
    .StyleShowingTabsToolbar {
    transition: margin-left nVerticalAutoPopupAnims !important;
    display: flex !important;
    position: absolute !important;
    opacity: 1;
    margin-left: 0px;
    z-index: 100 !important;
    min-width: nVerticalTabbarWidthpx !important;
    filter: drop-shadow(4px 3px 2px rgba(0,0,0,0.33)) !important;
    }
           
                   
    .StyleHidingTabsToolbar {
    display: flex !important;
    position: absolute !important;
    opacity: 0;
    margin-left: calc( (nVerticalTabbarWidthpx - nVerticalAutoPopupHoverpx) * -1 );
    z-index: 100 !important;
    min-width: nVerticalTabbarWidthpx !important;
    }

    .toolbar-items[align="end"] {
    display:initial !important;
    }

    tabs > arrowscrollbox {
    display: flex !important;
    position: absolute !important;
    min-width: nVerticalTabbarWidthpx !important;
    }
       
    `;
       
    let cssOut;
           
    if ( nTabbarPosition != 4 ) {
    nVerticalAutoPopupAnim = 0;
    }
           
                           
    cssOut = cssIn.replace(/nVerticalTabbarWidth/g, nVerticalTabbarWidth);
    cssOut = cssOut.replace(/nVerticalAutoPopupHover/g, nVerticalAutoPopupHover);
    cssOut = cssOut.replace(/nVerticalAutoPopupAnim/g, nVerticalAutoPopupAnim);
           
                           
    let sss = Cc['@mozilla.org/content/style-sheet-service;1'].getService(Ci.nsIStyleSheetService);
    let uri = makeURI('data:text/css;charset=UTF=8,' + encodeURIComponent(cssOut));
    sss.loadAndRegisterSheet(uri, sss.AUTHOR_SHEET);


    let tabsToolbar = document.getElementById('TabsToolbar');
           
    if ( nTabbarPosition == 4 )
    {
    tabsToolbar.classList.add('StyleHidingTabsToolbar');
    }
    else
    {
    tabsToolbar.classList.add('StyleShowingTabsToolbar');
    }
           
    }

    //------------------------------------------------------------------------------------------
       
    var tabsToolbar = document.getElementById('TabsToolbar');
    var tabbrowsertabs = document.getElementById('tabbrowser-tabs');
    var tabsscrollbox = document.getElementById('tabbrowser-arrowscrollbox');
    var ScrollBox = tabsscrollbox.scrollbox;

    var bMouseEnter = false;
    var bToolbarLocked = false;

    // ----------------------------------
    // Load-Event:
    // ----------------------------------
    function onReady()
    {
    console.log("OnReady");


    let cssElements =`
           
    #tabbrowser-tabs {
    --tab-overflow-pinned-tabs-width: 0px !important;
    }
               
    #alltabs-button,
    hbox.titlebar-spacer,
    #tabbrowser-arrowscrollbox::part(scrollbutton-up),
    #tabbrowser-arrowscrollbox::part(scrollbutton-down),
    #tabbrowser-arrowscrollbox::part(overflow-start-indicator),
    #tabbrowser-arrowscrollbox::part(overflow-end-indicator) {
    display: none !important;
    }
               
    tabs > arrowscrollbox::part(scrollbox) {
    flex-wrap: wrap !important;
    }
    `;
           
    let service = Cc['@mozilla.org/content/style-sheet-service;1'].getService(Ci.nsIStyleSheetService);
    let ur = makeURI('data:text/css;charset=UTF=8,' + encodeURIComponent(cssElements));
    service.loadAndRegisterSheet(ur, service.AUTHOR_SHEET);

    gBrowser.selectedTab.scrollIntoView();
    }
       
       
    if (window.readyState !== "loading") {
    setTimeout(onReady,500);
    }
    else
    {
    window.addEventListener("DOMContentLoaded", onReady );
    }
       
    // ----------------------------------
    // ResizeObserver / Client
    // ----------------------------------
    var resizeClientObserver=null;
       
    let navigatorToolbox = document.getElementById('navigator-toolbox');
    let mainWindow = document.getElementById('main-window');
       
    if( nTabbarPosition >= 3 && nTabbarPosition <= 5 )
    {
    resizeClientObserver = new ResizeObserver(function(entries) {
    for (let entry of entries) {
                   
    tabsToolbar.style.minHeight = tabsToolbar.style.maxHeight = entry.contentRect.height + 'px';
    ScrollBox.style.maxHeight = entry.contentRect.height + 'px';
                   
    tabsToolbar.style.top = navigatorToolbox.clientHeight + 'px';
                                   
    if(mainWindow.getAttribute('inFullscreen') == 'true' ) {
    if (navigatorToolbox.style.marginTop != "") {
    tabsToolbar.style.top = '0px';
    }
    }
                   
    if( nTabbarPosition == 5 ) {
    tabsToolbar.style.marginLeft = (entry.contentRect.width - nVerticalTabbarWidth) + 'px';
    }
    }
    });
                   
    resizeClientObserver.observe(document.getElementById("browser"));
    }


    // ----------------------------------
    // ToggleMenuObserver
    // ----------------------------------
    if( nTabbarPosition == 2 || nTabbarPosition == 6) {
    let observerToggleMenu=null;
    let configObserver=null;
           
    let bTabsintitlebar = document.querySelector('html#main-window').getAttribute('tabsintitlebar');
    let titlebar = document.querySelector('#navigator-toolbox>vbox#titlebar');
    let targetMenubar = document.getElementById('toolbar-menubar');

    const callback = (mutationList, observer) => {
    for (const mutation of mutationList) {
    if (mutation.type === 'attributes') {
    let bAutohide = targetMenubar.getAttribute('autohide');
    let bInacive = targetMenubar.getAttribute('inactive');
    if(bInactive == 'true') {
    titlebar.style.display = "none";
    console.log("titlebar.style.display = none");
    }
    else {
    titlebar.style.display = "initial";
    console.log("titlebar.style.display = initial");
                           
    }
    }
    }
    }
       
    observerToggleMenu = new MutationObserver(callback);
    configObserver = { attributes: true, attributeFilter: ['autohide','inactive'] };
           
    observerToggleMenu.observe(targetMenubar, configObserver);
    }

    // ----------------------------------
    // 'Middleclick' on Tab -> Close Tab
    // ----------------------------------
    gBrowser.tabContainer.addEventListener('click', function(event)
    {
    if (event.button == 1)
    {
    let element = event.target.parentNode;
    while(element)
    {
    if (element.localName == 'tab')
    {
    gBrowser.removeTab(element, {animate: false});
    event.preventDefault();
    event.stopPropagation();
    return;
    }
                   
    element = element.parentNode;
    }
               
    };
       
    }, true);

    // ----------------------------------
    // 'Middleclick' on TabsToolbar -> Add Tab
    // ----------------------------------
    tabsToolbar.addEventListener('click', function(event)
    {
    if (event.button == 1)
    {
    if(event.target.parentNode.id == "TabsToolbar")
    {
    event.target.ownerGlobal.openTrustedLinkIn(strHomepageURL,"tab");
    return;
    }
    };
    }, true);


    // ----------------------------------
    // 'Doubleclick' on TabsToolbar -> Add Tab
    // ----------------------------------
    tabsToolbar.addEventListener('dblclick', function(event)
    {
    if(!bDblclickOnTabbarNewTab)
    return;
           
    if (event.button == 0)
    {
                   
    if(event.target.parentNode.id == "TabsToolbar")
    {
    event.target.ownerGlobal.openTrustedLinkIn(strHomepageURL,"tab");
                  
    event.preventDefault();
    event.stopPropagation();
    return;
    }
    };
    }, true);
           
           
           
    // ----------------------------------
    // 'Doubleclick' on TabsContainer -> Add Tab
    // ----------------------------------
    gBrowser.tabContainer.addEventListener('dblclick', function(event)
    {
    if(!bDblclickOnTabbarNewTab)
    return;
           
    if (event.button == 0)
    {
    let element = event.target.parentNode;
    if (element == gBrowser.tabContainer )
    {
    event.target.ownerGlobal.openTrustedLinkIn(strHomepageURL,"tab");
       
    event.preventDefault();
    event.stopPropagation();
    return;
    }
    };
    }, true);
       
       
    // ----------------------------------
    // 'Doubleclick' on Tab -> Reload Tab
    // ----------------------------------
    gBrowser.tabContainer.addEventListener('dblclick', function(event)
    {
    if(!bDblclickOnTabReloadTab)
    return;
           
    if (event.button == 0)
    {
    let element = event.target.parentNode;
    while (element)
    {
    if (element.localName == 'tab')
    {
    element.linkedBrowser.reload();
                       
    return;
    }
                    
    element = element.parentNode;
    }
    }
    }, true);
       
    // ----------------------------------
    // 'mouseenter'
    // ----------------------------------
    tabsToolbar.addEventListener('mouseenter', event => {
    if( nTabbarPosition == 4 )
    {
    if(!bMouseEnter)
    {
    bMouseEnter = true;
                   
    tabsToolbar.classList.add('StyleShowingTabsToolbar');
    tabsToolbar.classList.remove('StyleHidingTabsToolbar');
                   
    }
    }
    }, true);
       
    // ----------------------------------
    // 'mouseleave'
    // ----------------------------------
    tabsToolbar.addEventListener('mouseleave', event => {
    if( nTabbarPosition == 4 )
    {
    if(bMouseEnter)
    {
                               
    if( event.clientX >= 0 &&
    event.offsetY > tabsToolbar.clientTop &&
    event.offsetX < tabsToolbar.clientWidth &&
    event.offsetY < tabsToolbar.clientHeight )
    {
    return;
    }
           
    event.preventDefault();
    event.stopPropagation();
                   
                   
    tabsToolbar.classList.add('StyleHidingTabsToolbar');
    tabsToolbar.classList.remove('StyleShowingTabsToolbar');

    bMouseEnter = false;
    }
    }
    }, false);


       
    // ...
    // TabSelect-Event:
    // ...
    gBrowser.tabContainer.addEventListener("TabSelect", function(event) {
                   
    let bScroll = false;
    let bScrollTop = true;
                   
    let scrollBoxY1 = event.target.parentElement.scrollbox.screenY;
    let scrollBoxHeight = event.target.parentElement.scrollbox.clientHeight;
    let scrollBoxY2 = scrollBoxY1+scrollBoxHeight;
           
    let TabSelY1 = event.target.screenY;
    let TabSelHeight = event.target.clientHeight;
    let TabSelY2 = TabSelY1+TabSelHeight;
           
           
           
    if( TabSelY2 > scrollBoxY2 )
    {
    bScroll = true;
    bScrollTop = false;
    }
    if( TabSelY1 < scrollBoxY1 )
    {
    bScroll = true;
    bScrollTop = true;
    }
           
    if( bScroll )
    {
    setTimeout(function()
    {
    event.target.scrollIntoView(bScrollTop);
    //gBrowser.selectedTab.scrollIntoView();
    //console.log("TabSelect_IntoView:" + bScrollTop );
    }, 0);
    }
           
    //console.log("TabSelect:" + bScroll );
           
    }, true);
         
       
         
         
    // ...
    // Drag-Event: Start
    // ...
    gBrowser.tabContainer.addEventListener("dragstart", function(event) {
    //console.log("dragstart..." );
    if(nTabLines==1 && ( nTabbarPosition == 1 || nTabbarPosition == 2 || nTabbarPosition == 6 )) {
    let tabsScrollbox = document.getElementById('tabbrowser-arrowscrollbox').scrollbox;
    tabsScrollbox.style.maxHeight = nTabLineHeight*3 +'px';
    event.target.scrollIntoView(false);
    }
    }, false);

    // ...
    // Drag-Event: Ende
    // ...
    gBrowser.tabContainer.addEventListener("dragend", function(event) {
    //console.log("dragend..." );
    if(nTabLines==1 && ( nTabbarPosition == 1 || nTabbarPosition == 2 || nTabbarPosition == 6 )) {
    let tabsScrollbox = document.getElementById('tabbrowser-arrowscrollbox').scrollbox;
    tabsScrollbox.style.maxHeight = nTabLineHeight +'px';
    event.target.scrollIntoView(false);
    }
    }, false);
       
       
    // ...
    // Wheel-Event:
    // ...
    let tabsScrollbox = document.getElementById('tabbrowser-arrowscrollbox').scrollbox;
    tabsScrollbox.addEventListener("wheel", function(event)
    {
    event.preventDefault();
    event.stopPropagation();
           
               
    let scrollUp = true;
    let wrap = false;
    let scrollBoxY1 = gBrowser.tabContainer._animateElement.scrollbox.scrollTop;
    let scrollHeight;
           
    if(bPageScroll)
    {scrollHeight = gBrowser.tabContainer._animateElement.scrollbox.clientHeight;}
    else
    {scrollHeight = nTabLineHeight;}
           
    let dir = (scrollUp ? 1 : -1) * Math.sign(event.deltaY);
           
    let bLastScrollLine = false;
           
    if( gBrowser.tabContainer._animateElement.scrollbox.scrollTopMax == gBrowser.tabContainer._animateElement.scrollbox.scrollTop)
    {
    bLastScrollLine = true;
    }

    if( !bTabWheel || event.ctrlKey || event.originalTarget.localName == "thumb" || event.originalTarget.localName == "slider" || event.originalTarget.localName == "scrollbarbutton" )
    {
    setTimeout(function()
    {
    let scrollBoxMod = scrollBoxY1%scrollHeight;
                   
    if( scrollBoxMod > 0 )
    {
    if( dir == -1 )
    {
    scrollBoxY1 -= scrollBoxMod;
    if(scrollBoxMod < nTabLineHeight && !bLastScrollLine) { scrollBoxY1 -= scrollHeight; }
                   
    }
    else
    {
    scrollBoxY1 += (scrollHeight-(scrollBoxMod));
    if(scrollHeight-(scrollBoxMod) < nTabLineHeight) { scrollBoxY1 += scrollHeight; }
                           
    }
    }
    else
    {
    if( dir == -1 )
    {
    scrollBoxY1 -= scrollHeight;
    }
    else
    {
    scrollBoxY1 += scrollHeight;
    }
    }
                   
    gBrowser.tabContainer._animateElement.scrollbox.scrollTo({ top: scrollBoxY1, left: 0, behavior: 'auto'});
    }, 20);
    }

    if( bTabWheel && !event.ctrlKey )
    {
    setTimeout(function()
    {
    if( event.originalTarget.localName != "slider" &&
    event.originalTarget.localName != "thumb" &&
    event.originalTarget.localName != "scrollbarbutton" )
    {
    gBrowser.tabContainer.advanceSelectedTab(dir, wrap);
    if( (gBrowser.tabContainer._firstTab == gBrowser.selectedTab) ||
    (gBrowser.tabContainer._lastTab == gBrowser.selectedTab) )
    {
    gBrowser.selectedTab.scrollIntoView();
    }
           
    }
    }, 50);
    }


    }, false);

    //-------------------------------------------------------------------------------------------

    gBrowser.tabContainer.clearDropIndicator = function() {
    var tabs = this.allTabs;
    for (let i = 0, len = tabs.length; i < len; i++) {
    tabs[i].style.removeProperty("border-left-color");
    tabs[i].style.removeProperty("border-right-color");
    }
    }
    gBrowser.tabContainer.addEventListener("dragleave", function(event) { this.clearDropIndicator(event); }, true);


    gBrowser.tabContainer.on_dragover = function(event) {
    this.clearDropIndicator();
    var effects = this.getDropEffectForTabDrag(event);
    var ind = this._tabDropIndicator;
    if (effects == "" || effects == "none") {
    ind.hidden = true;
    return;
    }
    event.preventDefault();
    event.stopPropagation();
    if (effects == "link") {
    let tab = this._getDragTargetTab(event, true);
    if (tab) {
    if (!this._dragTime) {
    this._dragTime = Date.now();
    }
    if (Date.now() >= this._dragTime + this._dragOverDelay) {
    this.selectedItem = tab;
    }
    ind.hidden = true;
    return;
    }
    }
    let newIndex = this._getDropIndex(event, effects == "link");
    let children = this.allTabs;
    if (newIndex == children.length) {
    children[newIndex - 1].style.setProperty("border-right-color","red","important");
    } else {
    children[newIndex].style.setProperty("border-left-color","red","important");
    }
    }

    gBrowser.tabContainer.on_drop = function(event) {
    this.clearDropIndicator();
    var dt = event.dataTransfer;
    var dropEffect = dt.dropEffect;
    var draggedTab;
    let movingTabs;
    if (dt.mozTypesAt(0)[0] == TAB_DROP_TYPE) {
    // tab copy or move
    draggedTab = dt.mozGetDataAt(TAB_DROP_TYPE, 0);
    // not our drop then
    if (!draggedTab) {
    return;
    }
    movingTabs = draggedTab._dragData.movingTabs;
    draggedTab.container._finishMoveTogetherSelectedTabs(draggedTab);
    }
    this._tabDropIndicator.hidden = true;
    event.stopPropagation();
    if (draggedTab && dropEffect == "copy") {
    // copy the dropped tab (wherever it's from)
    let newIndex = this._getDropIndex(event, false);
    let draggedTabCopy;
    for (let tab of movingTabs) {
    let newTab = gBrowser.duplicateTab(tab);
    gBrowser.moveTabTo(newTab, newIndex++);
    if (tab == draggedTab) {
    draggedTabCopy = newTab;
    }
    }
    if (draggedTab.container != this || event.shiftKey) {
    this.selectedItem = draggedTabCopy;
    }
    } else if (draggedTab && draggedTab.container == this) {
    let oldTranslateX = Math.round(draggedTab._dragData.translateX);
    let tabWidth = Math.round(draggedTab._dragData.tabWidth);
    let translateOffset = oldTranslateX % tabWidth;
    let newTranslateX = oldTranslateX - translateOffset;
    if (oldTranslateX > 0 && translateOffset > tabWidth / 2) {
    newTranslateX += tabWidth;
    } else if (oldTranslateX < 0 && -translateOffset > tabWidth / 2) {
    newTranslateX -= tabWidth;
    }
    let dropIndex = this._getDropIndex(event, false);
    // "animDropIndex" in draggedTab._dragData &&
    // draggedTab._dragData.animDropIndex;
    let incrementDropIndex = true;
    if (dropIndex && dropIndex > movingTabs[0]._tPos) {
    dropIndex--;
    incrementDropIndex = false;
    }
    let animate = gBrowser.animationsEnabled;
    if (oldTranslateX && oldTranslateX != newTranslateX && animate) {
    for (let tab of movingTabs) {
    tab.setAttribute("tabdrop-samewindow", "true");
    tab.style.transform = "translateX(" + newTranslateX + "px)";
    let onTransitionEnd = transitionendEvent => {
    if (
    transitionendEvent.propertyName != "transform" ||
    transitionendEvent.originalTarget != tab
    ) {
    return;
    }
    tab.removeEventListener("transitionend", onTransitionEnd);
    tab.removeAttribute("tabdrop-samewindow");
    this._finishAnimateTabMove();
    if (dropIndex !== false) {
    gBrowser.moveTabTo(tab, dropIndex);
    if (incrementDropIndex) {
    dropIndex++;
    }
    }
    gBrowser.syncThrobberAnimations(tab);
    };
    tab.addEventListener("transitionend", onTransitionEnd);
    }
    } else {
    this._finishAnimateTabMove();
    if (dropIndex !== false) {
    for (let tab of movingTabs) {
    gBrowser.moveTabTo(tab, dropIndex);
    if (incrementDropIndex) {
    dropIndex++;
    }
    }
    }
    }
    } else if (draggedTab) {
    let newIndex = this._getDropIndex(event, false);
    let newTabs = [];
    for (let tab of movingTabs) {
    let newTab = gBrowser.adoptTab(tab, newIndex++, tab == draggedTab);
    newTabs.push(newTab);
    }
    // Restore tab selection
    gBrowser.addRangeToMultiSelectedTabs(
    newTabs[0],
    newTabs[newTabs.length - 1]
    );
    } else {
    // Pass true to disallow dropping javascript: or data: urls
    let links;
    try {
    links = browserDragAndDrop.dropLinks(event, true);
    } catch (ex) {}
    if (!links || links.length === 0) {
    return;
    }
    let inBackground = Services.prefs.getBoolPref(
    "browser.tabs.loadInBackground"
    );
    if (event.shiftKey) {
    inBackground = !inBackground;
    }
    let targetTab = this._getDragTargetTab(event, true);
    let userContextId = this.selectedItem.getAttribute("usercontextid");
    let replace = !!targetTab;
    let newIndex = this._getDropIndex(event, true);
    let urls = links.map(link => link.url);
    let csp = browserDragAndDrop.getCSP(event);
    let triggeringPrincipal = browserDragAndDrop.getTriggeringPrincipal(
    event
    );
    (async () => {
    if (
    urls.length >=
    Services.prefs.getIntPref("browser.tabs.maxOpenBeforeWarn")
    ) {
    // Sync dialog cannot be used inside drop event handler.
    let answer = await OpenInTabsUtils.promiseConfirmOpenInTabs(
    urls.length,
    window
    );
    if (!answer) {
    return;
    }
    }
    gBrowser.loadTabs(urls, {
    inBackground,
    replace,
    allowThirdPartyFixup: true,
    targetTab,
    newIndex,
    userContextId,
    triggeringPrincipal,
    csp,
    });
    })();
    }
    if (draggedTab) {
    delete draggedTab._dragData;
    }
    }

    gBrowser.tabContainer._getDropIndex = function(event, isLink) {
    var tabs = this.allTabs;
    var tab = this._getDragTargetTab(event, isLink);
    if (!RTL_UI) {
    for (let i = tab ? tab._tPos : 0; i < tabs.length; i++) {
    if (
    event.screenY <
    tabs[i].screenY + tabs[i].getBoundingClientRect().height
    ) {
    if (
    event.screenX <
    tabs[i].screenX + tabs[i].getBoundingClientRect().width / 2
    ) {
    return i;
    }
    if (
    event.screenX >
    tabs[i].screenX + tabs[i].getBoundingClientRect().width / 2 &&
    event.screenX <
    tabs[i].screenX + tabs[i].getBoundingClientRect().width
    ) {
    return i + 1;
    }
    }
    }
    } else {
    for (let i = tab ? tab._tPos : 0; i < tabs.length; i++) {
    if (
    event.screenY <
    tabs[i].screenY + tabs[i].getBoundingClientRect().height
    ) {
    if (
    event.screenX <
    tabs[i].screenX + tabs[i].getBoundingClientRect().width &&
    event.screenX >
    tabs[i].screenX + tabs[i].getBoundingClientRect().width / 2
    ) {
    return i;
    }
    if (
    event.screenX <
    tabs[i].screenX + tabs[i].getBoundingClientRect().width / 2
    ) {
    return i + 1;
    }
    }
    }
    }
    return tabs.length;
    }
    }

  • Firefox 138 - TAB verschieben geht nicht mehr

    • GermanFreme82
    • 30. April 2025 um 22:43
    Zitat von BrokenHeart

    Ich glaube, du hast den Punkt, um den es eigentlich geht, leider überhaupt nicht verstanden! Ich hatte in der Vergangenheit bisher immer die für dich angepassten Skripte geliefert, aber jetzt hat sich die Situation grundlegend geändert. Nochmal:

    Das Skript 'MultiRowTabs.uc.js", welches du verwendest, wird von meiner Seite nicht mehr weiterentwickelt. Fehlerfrei funktioniert es nur bis FF 137. Ab FF 138 funktioniert das Verschieben nicht mehr und daran wird sich auch nichts mehr ändern!

    Das steht aber alles in dem Link, den ich gepostet habe. Du musst also zwangsläufig auf ein anderes Skript umsteigen. Deine für dich wichtigen optischen Anpassungen der Tabs sind schon in der 'userChrome.css', da muss also nichts neu in einem anderen Skript angepasst werden. Vielleicht können dir Endor , FuchsFan oder 2002Andreas alternative Skriptversionen empfehlen? :/

    Achso ich dachte du hast nur den Namen gesehen XXXX107 und hast gleich gesagt "Nein veraltet" jetzt verstehe ich dich.
    Ich werde mir den Link mal anschauen und hoffentlich sind da alle Farben, Verhalten und so gleich


    Zitat von Mira_Belle

    GermanFreme82 Nein, das Skript ist nicht UpToDate!
    Es wurde zwar für Dich modifiziert, was bedeutet, dass nur das CSS, also das Layout geändert wurde.
    Der JavaScript-Code wurde aber gar nicht angefasst!
    Und wie immer, Mozilla hat im Firefox was geändert und Funktionen in JavaScript funktionieren nicht mehr.

    Das Script ist von BrokenHeart und hier noch einmal seine Antwort:

    :!:Wichtig: Dieses Skript wird nicht mehr weiterentwickelt. Die letzte Firefox-Version, die noch unterstützt wird ist 137.:!:

    Das hab ich jetzt auch verstanden hehehehehe ich dachte er hat nur gesehen XXX107 und gleich "NEIN veraltet" gesagt,

  • Firefox 138 - TAB verschieben geht nicht mehr

    • GermanFreme82
    • 30. April 2025 um 22:18
    Zitat von BrokenHeart
    Zitat von GermanFreme82

    moemnt ich sende dir was ich habe

    ...

    MultiRowTab_Firefox107.js.txt

    ...

    bitte bitte ich habe gerade nicht die nerven für sowas Firefox macht nicht was es soll. bitte bitte hilf mir

    (Hervorhebung von mir)

    Da liegt der Hund begraben...und wird auch leider nicht wieder auferstehen.:(

    Du musst also zwangsläufig auf ein anderes Skript umsteigen. In diesem Thread:

    Beitrag

    Mehrzeilige Tableiste für aktuelle Firefox-Versionen

    Neues Update (26.11.2024):

    (Versteckter Text)



    :!:Wichtig: Dieses Skript wird nicht mehr weiterentwickelt. Die letzte Firefox-Version, die noch unterstützt wird ist 137.:!:



    Für aktuelle Versionen ab FF133+:

    Das Script richtet sich in erster Linie an Nutzer, die sich nicht mit CSS beschäftigen wollen, aber trotzdem eine mehrzeilige und optisch angepasste Tableiste nutzen möchten.

    Diese neue Version besteht ausschließlich aus einem User-JavaScript. Es sind keine zusätzlichen CSS-Eintragungen mehr nötig!

    In…
    BrokenHeart
    8. Dezember 2019 um 01:19

    findest du in den letzten Beiträgen auch eine Erklärung dazu und u.U. auch eine Lösung für dein Anliegen. Vielleicht können dir andere User insoweit weiterhelfen, dass du deinen alten Stand wiederherstellen kannst, zumal sich sämtliche optischen Anpassungen der Tabs ja schon in der userChrome,css befinden.

    Ich bin da leider wirklich raus, Sorry :(

    Alles anzeigen

    Nein das ist Up2Date

    Ich weiß nicht wie man hier Code einfügt, darum copy&paste bitte schau einmal das wurde bereits geändert dein Script

    [13.07.2021 22:45Uhr]
    - 'Nur-JavaScript-Version' (CSS wird nicht mehr benötigt)
    - Sehr viele funktionale und optische Anpassungen hinzugefügt
    [20.02.2020 18:45Uhr]
    Fehler in allen CSS-Dateien beseitigt (:thumbup:Dank an diwa fürs melden )
    [18.02.2020 13:30Uhr]
    - Anpassen des User-JavaSkripts aus (3).
    - Skript 'Tabsrunter.uc.js' wurde entfernt, da jetzt bereits in (3) integriert.
    [11.12.2019 13:15Uhr]
    - Optische Anpassungen an Code (1) und (2).
    - Neuen Code hinzugefügt für 'Tabs mit abgerundeten Ecken' (2a).
    - Anpassen des User-JavaSkripts zum Verschieben der Tabs (3).
    [08.12.2019 17:45Uhr]
    - Anpassungen am Code (1) und (2) vorgenommen, um 'Tableiste unten' zu berücksichtigen.
    - JavaSkript hinzugefügt, welches die Tableiste nach unten befördert.
    [19.08.2022 21:28Uhr]
    - Fehler Menüleiste behoben
    [23.09.2022 01:58Uhr]
    - "Wheel-Event" Problem behoben
    [18.10.2022 15:20Uhr]
    -Fix: FF106+ -> 'Drag&Drop'
    [19.11.2022 09:28Uhr]
    -Fix: FF107+ -> 'contain' entfernt
    [15.12.2022 07:52Uhr]
    -Fix: FF108+ -> Toggle-menubar angepasst
    [15.12.2022 15:50Uhr]
    -Fix: FF108+ -> Position der vertikalen Tableiste korrigiert
    [19.12.2022 19:58Uhr]
    - Seite für neuen Tab wird aus Voreinstellungen gelesen
    - kleinere optische Anpassungen
    [21.12.2022 18:32Uhr]
    - Fix: Menüleiste per 'alt'/'F10'-Key einblenden
    [10.05.2023 00:08]
    - Fix: Anpassungen Flex-Container
    [10.05.2023 19:32]
    - Fix: Anpassungen "Vertikale Tableiste"
    [07.06.2023 18:35]
    - Fix: Siehe: RE: Entwicklung Firefox
    [07.06.2023 18:35]
    - Fix: Siehe: RE: Entwicklung Firefox
    [02.09.2023 09:30]
    -Fix: Visualisierung ausgewählter Tabs (>=FF119)
    [24.10.2023 18:44]
    - Tabbar-Position [6] (FF119+)
    - angeheftete Tabs
    - kleinere Fehler
    [04.03.2024 19:48]
    - angeheftete Tabs -> Fehlerbehebungen
    [23.08.2024 13:00]
    - Tab-Tooltip ausblenden -> funktioniert wieder
    [01.10.2024 19:00]
    - Fix: Anpassung der Tableiste FF 131
    [16.10.2024 23:45]
    - Fix: Probleme mit Lesezeichenleiste behoben (Vielen Dank an 2002Andreas für den Code!)
    [26.11.2034 19:00]
    - Unterschiedliche Anpassungen für FF133


    Ich kann das Script nicht anpassen, oder copypaste machen das geht nicht, dann sind alle Einstellungen weg das war schon immer so.

    merken Ich brauche also nur eine Änderung in meinem Script weil dort das Design drinnen ist und mehr und dann geht wieder alles. ich kann mir nicht alles merken, daher ist halt Design drinnen von mir und Dinge.

    schon Es gibt schon einige Beiträge hier im Forum dafür von mir, wenn wieder ein Update kam und das Script zicken gemacht hat ich weiß aber nicht wo ich die finde hier im Forum. Dinge sind hier im Forum dazu magisch versteckt irgendwo.

    Bitte bitte ich hab keine Ahnung ich verstehe nur bahnhof zu fährt ab.

    kann man das script bitte mal öffnen udn reinschauen das geht zu ändern da fehlt wieder in irgendeinen komischen Zeile was und alles wird gut.

    ich kann nicht jedes mal das ganze Haus abreißen, nur weil 1 Zeile Code falsch ist.

    Einfach bitte bitte einfach anpassen bitte der Name ist so weil es sonst nicht geht, einfahc lassen das muss so heißen weil keien Ahnung Name ignorieren bitte der Code darin ist aktuell

    völlig Wurst das es XXXX107 heißt einfach ausblenden und bitte reinschauen

    MultiRowTab_Firefox107.js.txt

  • Firefox 138 - TAB verschieben geht nicht mehr

    • GermanFreme82
    • 30. April 2025 um 14:55

    moemnt ich sende dir was ich habe


    userChrome.css.txt
    MultiRowTab_Firefox107.js.txt
    HideTabbarWithOneTab.uc.js.txt
    AddonLeisteUnten.uc.js.txt

    bitte bitte ich habe gerade nicht die nerven für sowas Firefox macht nicht was es soll. bitte bitte hilf mir

  • Firefox 138 - TAB verschieben geht nicht mehr

    • GermanFreme82
    • 30. April 2025 um 14:50

    Nein habe ich nicht wenn ich das Update lösche dann geht es, also ist der Fehler Firefox 138.
    Habe es an 3 PC getestet der Fehler ist in Firefox 138 Update beides kaputt.

    ich kann die scripte posten vielleicht findet man da den fehler der FF 138 unbrauchbar macht.

    Welche Scripte braucht man um das zu sehen ?


    einfachIch gehe jetzt zurück auf FF 137 ich kann nicht so leben. ich mach das in der sandbox später oder woanders mit FF 138 ich habe keien geduld jetzt für probleme die Firefox in die leben gebährt es nervt mich einfahc nur und behindert mich

  • Firefox 138 - TAB verschieben geht nicht mehr

    • GermanFreme82
    • 30. April 2025 um 14:43

    Hallo liebe Fuchsfreunde !

    Ich habe soeben auf FF 138 ein Update gemacht und nun lassen sich meine TABS in der Leiste oben nicht mehr verschieben.

    Könnt ihr mir bitte helfen und zeigen wie man das korrigiert das es wieder geht ?

  • 4 TAB in 1 Fenster nebeneinander

    • GermanFreme82
    • 5. März 2025 um 14:16
    Zitat von Sören Hentzschel

    Hallo,

    wenn es dir nur um Videos geht, benötigst du keine Erweiterung. Nutze die Bild-im-Bild-Funktion. Das ist auch für mehrere Videos gleichzeitig möglich.

    Naja das ist schwer zu erklären für mich, aber ich versuche es einmal.
    Es ist nicht einfach nur Bild-in-Bild ,sondern das alle 4 Videos als eigenständiges DING so existieren in einer 4er Kachel und zwar so, als würde ich als Beispiel das Youtube Video 4x aufrufen mit allen Funktionen die 1 TAB hat, nur das er nun 4x da ist.

    Demnach sollten alle 4 TABs in dieser 4er Kachel (2 oben, 2 drunter) alle Funktionen haben wenn ich mit der Maus draufklicke um zum Beispiel laut, leise, Stopp und so weiter bedienen möchte.

    Ich weiß nicht ob ich das richtig erklärt habe 😅. Ich könnte auch den Namen des Browsers nennen, der das kann, also wo ich das gesehen habe, aber ich bin mir nicht sicher, ob ich diesen XXX Browser hier erwähnen darf 😇.

  • Firefox 136 - Restart Button Script geht nicht mehr

    • GermanFreme82
    • 5. März 2025 um 13:55

    Ich nutze nun das unten erwähnte Script und da sind blaue Pfeile drin und ich bin vollkommen glücklich damit.

    Habt vielen DANK ... großes dickes DANKE an alle Beteiligten. Der adipöse Hamster ist nun wieder glücklich. 😅

    JavaScript
    // Restart button script for Firefox 60+ by Aris
    //
    // left-click on restart button: normal restart
    // right-click on restart button: restart + clear caches
    // Edit by 2002Andreas
    // based on 'Quit' button code by 2002Andreas
    // 24.01.2025 BrokenHeart - Änderung an der ScriptCache Funktionalität. Fehlermeldung beseitigt.
    (function() {
    if (!window.gBrowser){
           return;
       }
    try {
       var sss = Components.classes["@mozilla.org/content/style-sheet-service;1"].getService(Components.interfaces.nsIStyleSheetService);
       var button_label = "Linke Maustaste:\tNeustart\nRechte Maustaste:\tNeustart + SkriptCache Löschen";
       CustomizableUI.createWidget({
       id: "restart-button-ucjs", // button id
       defaultArea: CustomizableUI.AREA_NAVBAR,
       removable: true,
       label: button_label, // button title
       tooltiptext: button_label, // tooltip title
       onClick: function(event) {
         
         var cancelQuit   = Components.classes["@mozilla.org/supports-PRBool;1"].createInstance(Components.interfaces.nsISupportsPRBool);
         var observerSvc  = Components.classes["@mozilla.org/observer-service;1"].getService(Components.interfaces.nsIObserverService);
               
         
         if(event.button=='0' || event.button=='2') { // left-click - restart/right-click - clear caches
            if(event.button == '2') {       
                event.preventDefault();    
                Components.classes["@mozilla.org/xre/app-info;1"].getService(Components.interfaces.nsIXULRuntime).invalidateCachesOnRestart();
            }
            
            observerSvc.notifyObservers(cancelQuit, "quit-application-requested", "restart");
                        
           if(cancelQuit.data) return false;
                   
           Services.startup.quit(Services.startup.eRestart | Services.startup.eAttemptQuit);
         }
       },
       onCreated: function(button) {
         return button;
       }
           
     });
     
     // style button icon
     var uri = Services.io.newURI("data:text/css;charset=utf-8," + encodeURIComponent('\
       \
         #restart-button-ucjs .toolbarbutton-icon {\
           list-style-image: url("");  \
              }\
       \
     '), null, null);
     
     sss.loadAndRegisterSheet(uri, sss.AGENT_SHEET);
     
    } catch (e) {
       Components.utils.reportError(e);
    };
    })();
    Alles anzeigen
  • Firefox 136 - Restart Button Script geht nicht mehr

    • GermanFreme82
    • 5. März 2025 um 13:38
    Zitat von 2002Andreas
    Zitat von GermanFreme82

    Oh oh ja ja bitte bitte die blauen Pfeile wieder bittttte

    JavaScript
    // Restart button script for Firefox 60+ by Aris
    //
    // left-click on restart button: normal restart
    // right-click on restart button: restart + clear caches
    // Edit by 2002Andreas
    // based on 'Quit' button code by 2002Andreas
    // 24.01.2025 BrokenHeart - Änderung an der ScriptCache Funktionalität. Fehlermeldung beseitigt.
    
    (function() {
    
     if (!window.gBrowser){
            return;
        }
    
    try {
        var sss = Components.classes["@mozilla.org/content/style-sheet-service;1"].getService(Components.interfaces.nsIStyleSheetService);
    
        var button_label = "Linke Maustaste:\tNeustart\nRechte Maustaste:\tNeustart + SkriptCache Löschen";
    
        CustomizableUI.createWidget({
        id: "restart-button-ucjs", // button id
        defaultArea: CustomizableUI.AREA_NAVBAR,
        removable: true,
        label: button_label, // button title
        tooltiptext: button_label, // tooltip title
        onClick: function(event) {
          
          var cancelQuit   = Components.classes["@mozilla.org/supports-PRBool;1"].createInstance(Components.interfaces.nsISupportsPRBool);
          var observerSvc  = Components.classes["@mozilla.org/observer-service;1"].getService(Components.interfaces.nsIObserverService);
                
          
          if(event.button=='0' || event.button=='2') { // left-click - restart/right-click - clear caches
    
    		if(event.button == '2') {       
    			event.preventDefault();	
    			Components.classes["@mozilla.org/xre/app-info;1"].getService(Components.interfaces.nsIXULRuntime).invalidateCachesOnRestart();
    		}
    		
    		observerSvc.notifyObservers(cancelQuit, "quit-application-requested", "restart");
    					
            if(cancelQuit.data) return false;
                    
            Services.startup.quit(Services.startup.eRestart | Services.startup.eAttemptQuit);
          }
        },
        onCreated: function(button) {
          return button;
        }
            
      });
      
      // style button icon
      var uri = Services.io.newURI("data:text/css;charset=utf-8," + encodeURIComponent('\
        \
          #restart-button-ucjs .toolbarbutton-icon {\
            list-style-image: url("");  \
    		  }\
        \
      '), null, null);
      
      sss.loadAndRegisterSheet(uri, sss.AGENT_SHEET);
      
    } catch (e) {
        Components.utils.reportError(e);
    };
    
    })();
    Alles anzeigen

    Ja genau das sind die 2 blauen Pfeile °
    Super endlich sind die wieder da.
    Cool jetzt habe ich sogar 2 Versionen... 1x mit weißem Pfeil und 1x mit blauen Pfeilen.

  • Firefox 136 - Restart Button Script geht nicht mehr

    • GermanFreme82
    • 5. März 2025 um 13:34
    Zitat von milupo
    Zitat von GermanFreme82

    Ist das normal, das der Button kein Symbol mehr hat und könnte man das Symbol wieder hinzufügen irgendwie ?

    Das Skript hat ein Symbol, diese zwei blauen Pfeile. FuchsFan verwendet einen absoluten Pfad zur Grafikdatei mit dem Symbol. Diesen musst du in Zeile 17 deinem anpassen.

    Oh oh ja ja bitte bitte die blauen Pfeile wieder bittttte !

  • Firefox 136 - Restart Button Script geht nicht mehr

    • GermanFreme82
    • 5. März 2025 um 13:17
    Zitat von FuchsFan

    Ich kann dir damit aushelfen.

    JavaScript
    // Restart.uc.js
    // linke Maus Neustart  
    // rechte Maus Neustart mit Löschüng des Start-Caches
    // Mittelklick öffnet about:config
    
    (function() {
    	if (!window.gBrowser)
    		return;
    
    	CustomizableUI.createWidget({
    		id: 'buttonNeustart',
    		defaultArea: CustomizableUI.AREA_NAVBAR,
    		label: 'Restart Firefox',
    		tooltiptext: 'Startet Firefox neu',
    
    		onCreated: (button) => {
    			button.style.listStyleImage = 'url("file:///C:/FoxIcons2/neustarten.png")';
    
    			button.addEventListener('click', () => {
    				if (event.button == 0) {
    			        Services.startup.quit(Ci.nsIAppStartup.eRestart | Ci.nsIAppStartup.eAttemptQuit); 	
    				}
    				if (event.button == 2) {
    			        Services.appinfo.invalidateCachesOnRestart();
    		            Services.startup.quit(Ci.nsIAppStartup.eRestart | Ci.nsIAppStartup.eAttemptQuit); 	
    				}
    				if (event.button == 1) {
    			        openTrustedLinkIn("about:config", "tab");
    				}
    			})
    		}
    	});
    })();
    Alles anzeigen

    Oh das ist wunderbar !
    Vielen herzlichen Dank für das Script es geht einwandfrei hier.
    Ist das normal, das der Button kein Symbol mehr hat und könnte man das Symbol wieder hinzufügen irgendwie ?


    Zitat von 2002Andreas
    Zitat von GermanFreme82

    ich finde den Button dazu nicht mehr

    Der ist damit gemeint:

    Okay einen Moment bitte ...

    Code
    Test 123 Test
  • Firefox 136 - Restart Button Script geht nicht mehr

    • GermanFreme82
    • 5. März 2025 um 00:15

    Hallo liebe Fuchsfreunde !

    Ich habe eben auf FF 136 geupdated und jetzt geht der Restart Button nicht mehr, den ich per Script reingemacht habe.

    Hier ist das Script und kann bitte jemand mal schauen, wieso es nicht mehr geht und es reparieren, damit es wieder geht ?

    RestartFirefoxButtonNEU.uc.js.txt

    Ich habe leider keine Ahnung wie man hier Code einfügt, denn ich finde den Button dazu nicht mehr daher der Dateianhang.

  • 4 TAB in 1 Fenster nebeneinander

    • GermanFreme82
    • 5. März 2025 um 00:00

    Hallo liebe Fuchsfreunde !

    Ich wollte einmal nachfragen, ob es eine Erweiterung gibt, mit der ich 4 TABs in 1 Fenster abbilden kann. Damit meine ich zum Beispiel 4 Youtube Videos nebeneinander anzuschauen (2 oben, 2 unten), wie in einer Art 4er Kachel.

    ich habe dazu von einem anderen Web-Browser mal ein Foto gemacht, der das kann, aber ich möchte das gleiche im Firefox machen.

    ^ Wäre sowas möglich und wenn ja, mit welcher Erweiterung kann man das hinbekommen ?

  • Mehrzeilige Tableiste für aktuelle Firefox-Versionen

    • GermanFreme82
    • 28. November 2024 um 23:13

    Ich danke euch beiden ganz herzlich nochmals für die Hilfe und den ganzen Aufwand 2002Andreas und BrokenHeart

  • Mehrzeilige Tableiste für aktuelle Firefox-Versionen

    • GermanFreme82
    • 28. November 2024 um 13:36
    Zitat von 2002Andreas
    Zitat von GermanFreme82

    Ich habe Script eben übernommen und ausprobiert

    Das aus Beitrag Nr. 852?

    Wenn nicht, dann bitte das nehmen und testen.

    Ich habe das Script aus "Nr. 852" nun eingefügt und jetzt scheint es zu funktionieren. Ich weiß nicht aus welche Beitrag darüber ich das Script genommen hatte.

    Bis jetzt sieht alles super aus vielen, vielen DANK !

  • Mehrzeilige Tableiste für aktuelle Firefox-Versionen

    • GermanFreme82
    • 28. November 2024 um 12:35

    adipösen Hamster 🤣

    Vielen herzlichen Dank an eich beide, für eure Mühe 2002Andreas und BrokenHeart . Ich habe Script eben übernommen und ausprobiert. Auf den ersten Blick sah noch alles gut aus, aber leider ist darin ein Fehler, der verhindert das ich bei mehreren geöffnetes Tabs die Tabs nicht mehr mit Drag&Drop verschieben kann.

    Könntet ihr bitte da nochmal drüberschauen, wieso das so ist und bitte, bitte versuchen das zu korrigieren ?


    CSS
    Ich meine dieses Scripte hier 
    
    // 'MultiRowTabs.uc.js' V02 by BrokenHeart
    // based on 'MultiRowTab_LiteforFx48.uc.js' from 'http://space.geocities.yahoo.co.jp/gl/alice0775' (Alice0775)
    // Thanks to aborix...
    /* ///////////////////////////////////////////////////////////////////////////////////
    [13.07.2021 22:45Uhr]
    - 'Nur-JavaScript-Version' (CSS wird nicht mehr benötigt)
    - Sehr viele funktionale und optische Anpassungen hinzugefügt
    [20.02.2020 18:45Uhr]
    Fehler in allen CSS-Dateien beseitigt (:thumbup:Dank an diwa fürs melden )
    [18.02.2020 13:30Uhr]
    - Anpassen des User-JavaSkripts aus (3).
    - Skript 'Tabsrunter.uc.js' wurde entfernt, da jetzt bereits in (3) integriert.
    [11.12.2019 13:15Uhr]
    - Optische Anpassungen an Code (1) und (2).
    - Neuen Code hinzugefügt für 'Tabs mit abgerundeten Ecken' (2a).
    - Anpassen des User-JavaSkripts zum Verschieben der Tabs (3).
    [08.12.2019 17:45Uhr]
    - Anpassungen am Code (1) und (2) vorgenommen, um 'Tableiste unten' zu berücksichtigen.
    - JavaSkript hinzugefügt, welches die Tableiste nach unten befördert.
    [19.08.2022 21:28Uhr]
    - Fehler Menüleiste behoben
    [23.09.2022 01:58Uhr]
    - "Wheel-Event" Problem behoben
    [18.10.2022 15:20Uhr]
    -Fix: FF106+ -> 'Drag&Drop'
    [19.11.2022 09:28Uhr]
    -Fix: FF107+ -> 'contain' entfernt
    [15.12.2022 07:52Uhr]
    -Fix: FF108+ -> Toggle-menubar angepasst
    [15.12.2022 15:50Uhr]
    -Fix: FF108+ -> Position der vertikalen Tableiste korrigiert
    [19.12.2022 19:58Uhr]
    - Seite für neuen Tab wird aus Voreinstellungen gelesen
    - kleinere optische Anpassungen
    [21.12.2022 18:32Uhr]
    - Fix: Menüleiste per 'alt'/'F10'-Key einblenden
    [10.05.2023 00:08]
    - Fix: Anpassungen Flex-Container
    [10.05.2023 19:32]
    - Fix: Anpassungen "Vertikale Tableiste"
    [07.06.2023 18:35]
    - Fix: Siehe:  https://www.camp-firefox.de/forum/thema/74296-entwicklung-firefox/?postID=1227494#post1227494
    [07.06.2023 18:35]
    - Fix: Siehe:  https://www.camp-firefox.de/forum/thema/74296-entwicklung-firefox/?postID=1227494#post1227494
    [02.09.2023 09:30]
    -Fix: Visualisierung ausgewählter Tabs (>=FF119)
    [24.10.2023 18:44] 
    - Tabbar-Position [6] (FF119+) 
    - angeheftete Tabs 
    - kleinere Fehler
    [04.03.2024 19:48]
    - angeheftete Tabs -> Fehlerbehebungen  
    [23.08.2024 13:00]
    - Tab-Tooltip ausblenden -> funktioniert wieder
    [01.10.2024 19:00]
    - Fix: Anpassung der Tableiste FF 131
    [16.10.2024 23:45]
    - Fix: Probleme mit Lesezeichenleiste behoben (Vielen Dank an 2002Andreas für den Code!)
    [26.11.2034 19:00]
    - Unterschiedliche Anpassungen für FF133
    /////////////////////////////////////////////////////////////////////////////////////*/
    
    "use strict";
    MultiRowTabs();
    function MultiRowTabs() {
       
       if (!window.gBrowser){
           return;
       }
           // ----------------------------
    // --- User-Settings: Start ---
    // ----------------------------
    // Position der Tab-Leiste:
    //
    var nTabbarPosition = 2; // [1] Tab-Leiste ist oberhalb aller Symbolleisten
    // [2] Tab-Leiste ist unterhalb aller Symbolleisten, aber über dem Inhaltsbereich
    // [3] Tab-Leiste ist vertikal auf der linken Seite
    // [4] Tab-Leiste ist vertikal auf der linken Seite - Tableiste wird erst angezeigt bei Mausbewegung an den linken Rand (Autohide/Autopopup)
    // [5] Tab-Leiste ist vertikal auf der rechten Seite
    // [6] Tab-Leiste ist unterhalb des Inhaltsbereichs
    
    // Tab-Größenangaben
    //
    var nTabWidth = 170; // Breite der einzelnen Tabs in Pixeln
    var nTabHeight = 35; // Höhe der einzelnen Tabs in Pixeln
    var nTabMargin = 1; // Abstand zwischen den Tab-Zeilen in Pixeln
    
    // sonstige Einstellungen
    //
    var nTabLines = 7; // Anzahl der sichtbaren Tab-Zeilen, darüber hinaus wird gescrollt <nur bei horizontaler Ausrichtung (Position:[1],[2],[6]) - sonst keine Funktion>
    var bTabScrollbar = true; // [true] Scrollbar für Tab-Leiste anzeigen, [false] Keine Scrollbar für Tab-Leiste anzeigen (Achtung: [false] = kein Scrollen mehr bei 'drag&drop' von Tabs!)
    var bTabTooltips = true; // [true] Tab-Tooltips werden angezeigt, [false] Tab-Tooltips werden nicht angezeigt
    
    // Tab-Schließen-Button
    //
    var bTabCloseButton = true; // [true] Tab-Schließen-Button anzeigen, [false] Tab-Schließen-Button verbergen
    var bTabCloseButRounded = false; // [false] quadratische Darstellung, [true] abgerundete Darstellung
    var nTabCloseButTransparency= 0.85; // Transparenzwert des Tab-Schließen-Button in Prozent. Wertebereich: [0]=vollständig durchscheinend bis [1]=vollständig deckend (z.B [0.75])
    var nTabCloseIconNr = 0; // [0] Standard-Icon wird angezeigt
    // [1] rotes Icon mit weißem Kreuz wird angezeigt
    // [2] schwarzes Icon mit weißem Kreuz wird angezeigt
    var nTabCloseButSize = 18; // Höhe und Breite des Tab-Schließen-Buttons in Pixeln
    
    // FavIcon
    //
    var nFavIconSize = 16; // Höhe und Breite des 'FavIcons' und der Ladeanimation,[16] = Standard
    
    // 'Throbber'-Animation
    //
    var bNewThroberAnimation = true; // [true] Alternative 'Throbber'-Animation auswählen, [false] Standard 'Throbber'-Animation beibehalten
    
    // Hintergrundfarbe der Tabs (für einfarbige Darstellung müssen die RGB-Farbwerte 1 und 2 jeweils identisch sein)
    //
    var strTabSelColor1 = "240,152,0"; // RGB-Farbwert1 selektierter Tab
    var strTabSelColor2 = "240,152,0"; // RGB-Farbwert2 selektierter Tab
    var strTabNotSelColor1 = "195,157,116";// RGB-Farbwert1 nicht selektierter Tab
    var strTabNotSelColor2 = "195,157,116";// RGB-Farbwert2 nicht selektierter Tab
    var nTabTransparency = 1; // Transparenzwert des unselektierten Tab Hintergrundes. Wertebereich: [0]=vollständig durchscheinend bis [1]=vollständig deckend (z.B [0.75])
    
    // Schriftart und Textdarstellung der Tabs
    //
    var strTabFontName = "Segoe UI"; // Name der Schriftart
    var strTabFontColorSel = "255,255,255";// RGB-Farbwert der Schrift des selektierten Tabs
    var strTabFontColorNotSel = "255,255,255";// RGB-Farbwert der Schrift des nicht selektierten Tabs
    var nTabFontWeight = 600; // Stärke der Schrift: Wertebereich: [100] = sehr dünn bis [900] = sehr dick(bold). [500] = normal
    var nTabFontSize = 12; // Größe/Höhe der Schrift in Pixeln
    var bTabFontTextShadow = true; // [true] Text wird mit Schatteneffekt ausgegeben, [false] Text wird ohne Schatteneffekt ausgegeben. (Effekt nur bei selektierten Tabs!)
    var bMarkUnreadTab = false; // [true] Kursive Schrift für ungelesene Tabs, [false] ungelesene Tabs werden nicht hervorgehoben
    
    // Rahmen um einzelne Tabs
    //
    var nTabBorderWidth = 0; // Breite des Tab-Rahmen ([0] = kein sichtbarer Rahmen)
    var nTabBorderRadius = 30; // Radius für abgerundete Ecken des Tabs ([0] = rechteckig, [80] = ideal abgerundet ).
    var strTabBorderColor = "128,128,128";// RGB-Farbwert des Rahmens
    
    // Neuer-Tab-Button
    //
    var strNewTabButtonColor = "255,255,255";// RGB-Farbwert des '+'-Zeichens
    
    // Hintergrund der Tab-Leiste (für einfarbige Darstellung müssen die RGB-Farbwerte 1 und 2 jeweils identisch sein)
    //
    var strTabBarBgColor1 = "21,21,12"; // RGB-Farbwert1 für Hintergrund der Tab-Leiste
    var strTabBarBgColor2 = "62,75,84"; // RGB-Farbwert2 für Hintergrund der Tab-Leiste
    
    
    var nTabBarTransparency = 0; // Transparenzwert des Tab-Leisten Hintergrundes. Wertebereich: [0]=vollständig durchscheinend bis [1]=vollständig deckend
    var strTabBarBgImagePath = ""; // Absoluter Dateipfad zu einem gepeicherten Bild (z.B.: "D://Bilder//Firefox//Hintergrund.jpg" )
    // "D://Programme%20(Portable)//Firefox%20Portable//FireFox%20ESR%2091//Profilordner//chrome//image//NavToolbarBackground02.png"
    var bTabBarBgImageRepeat = false; // [true] Bild wird für den gesamten Bereich mehrfach nebeneinander angezeigt, [false] Bild wird nur einmal angezeigt (Position: linke/obere Ecke)
    
    // Einstellungen für vertikale Tab-Leiste
    //
    var nVerticalTabbarWidth = 215; // Breite der Vertikalen Tab-Leiste in Pixeln <nur bei vertikaler Ausrichtung (Position:[3],[4],[5]) - sonst keine Funktion>
    var nVerticalAutoPopupHover = 2; // Abstand zum linken Fensterrand in Pixeln, ab der die vertikale Tab-Leiste sichtbar gemacht wird <Position[4] - sonst keine Funktion>
    var nVerticalAutoPopupAnim = 0.5; // Dauer der Animation beim 'Herausschieben' des vertikalen Tab-Leiste in Sekunden ([0] = keine Animation) <Position[4] - sonst keine Funktion>
    
    // Einstellungen für Maus-Bedienung
    //
    var bTabWheel = false; // [true]: Tab-Wheel-Selection(=Selektieren des nächsten/vorherigen Tabs mit dem Mausrad) einschalten, [false]: Tab-Wheel-Selection ausschalten
    var bPageScroll = true; // [true]: seitenweises Scrollen, [false]: zeilenweises Scrollen
    var bDblclickOnTabbarNewTab = true; // [true] Doppel-Klick über Tabbar öffnet neuen Tab, [false] Funktion wird nicht ausgeführt
    var bDblclickOnTabReloadTab = true; // [true] Doppel-Klick über Tab lädt diesen neu, [false] Funktion wird nicht ausgeführt
    // ----------------------------
    // --- User-Settings: Ende ---
    // ----------------------------
           
           
       let strHomepageURL;
       try {
         strHomepageURL = Services.prefs.getCharPref('browser.startup.homepage');
         console.log("homepage: " + strHomepageURL);
       } catch(e) {
           console.log("Error Homepage-String loading...");
       }
           
            
       if( nTabbarPosition < 1 || nTabbarPosition > 6 ) {
           nTabbarPosition = 1;
       }
       
       // Tab-Leiste ganz unten 
       if( nTabbarPosition == 6 )
       {
               let tabbarBoxBottom = document.createXULElement('vbox');
               tabbarBoxBottom.id = 'tabbarboxbottom';
               tabbarBoxBottom.style.background = '#000000';
           
               document.getElementById("navigator-toolbox").parentNode.insertBefore( tabbarBoxBottom, null);
               //document.getElementById("navigator-toolbox").parentNode.parentNode.insertBefore( tabbarBoxBottom, document.getElementById("browser-bottombox"));
               let tabbar = document.getElementById("TabsToolbar");
               tabbarBoxBottom.appendChild(tabbar);
       }
       
       //Tableiste vertikal
       if(nTabbarPosition == 3 || nTabbarPosition == 5 )
       {
               let nTabbarWidth = nVerticalTabbarWidth;
               
               let tabbarBox = document.createXULElement('vbox');
               tabbarBox.id = 'tabbar-box';
               tabbarBox.style.width = nVerticalTabbarWidth + 'px';
               tabbarBox.style.background = '#000000';
           
               // Platz für Tab-Leiste auf der linken Seite 
               if(nTabbarPosition == 3) {
                   let sidebarBox = document.getElementById('sidebar-box');
                   sidebarBox.parentNode.insertBefore(tabbarBox, sidebarBox);
               }
               // Platz für Tab-Leiste auf der rechten Seite 
               else if( nTabbarPosition == 5) {
                   document.getElementById("browser").insertBefore(tabbarBox,document.getElementById("browser").lastChild.nextSibling);
                    tabbarBox.style.width = '0px';
               }
           
       }
       tabsetting: { 
           let css =` 
               tabs tab {
                   border-left: solid 1px hsla(0,0%,0%,0) !important;
                   border-right: solid 1px hsla(0,0%,0%,0) !important;
                   z-index: 2 !important;
               }
               tabs tab:after,tabs tab:before
               { 
                   display: none !important; 
               }
               
       
           `;
           let sss = Cc['@mozilla.org/content/style-sheet-service;1'].getService(Ci.nsIStyleSheetService);
           let uri = makeURI('data:text/css;charset=UTF=8,' + encodeURIComponent(css));
           sss.loadAndRegisterSheet(uri, sss.AUTHOR_SHEET);
       }
           
       //var nTabLineHeight = nTabHeight+2*nTabMargin;
       nTabMargin *= 2;
       var nTabLineHeight = nTabHeight+nTabMargin;
       
       //console.log("Margin: " + nTabMargin );
       
       multiLineTabSetup: {
           
           let service,uri,cssIn,cssOut;
           
           // ---
           // CSS-Icon-Settings 
           // ---
           cssIn =`
               
        
               /* Tab-Schließen-Button auf allen Tabs anzeigen oder verbergen */
               .tabbrowser-tab:not([pinned]) .tab-close-button, 
               .tabbrowser-tab:not([pinned]) .tab-close-button:not([selected="true"]) {
                   display: __strTabCloseVisible__ !important;
               }
           
               /* Icon für Tab-Schließen-Button anzeigen */
               .tabbrowser-tab:not([pinned]) .close-icon {
                   __CloseIcon1DisableStart__ list-style-image: url("") !important; __CloseIcon1DisableEnd__
                   __CloseIcon2DisableStart__ list-style-image: url("") !important; __CloseIcon2DisableEnd__
                   
                   border-radius: __nBorderRadius__px !important;
                   padding: 3px !important;
                   width: __nTabCloseButSize__px !important;
                   height: __nTabCloseButSize__px !important;
                   filter: opacity(__nTabCloseButTransparency__%) drop-shadow(-1px -1px 1px rgba(0,0,0,0.15)) drop-shadow(0px -1px 1px rgba(255,255,255,0.15)) !important; 
               }
               
               /* Neuer Tab Button */
               #TabsToolbar #tabs-newtab-button > image {
                   min-height: __nNewTabButtonSize__px !important;
                   max-height: __nNewTabButtonSize__px !important;
                   min-width: __nNewTabButtonSize__px !important;
                   max-width: __nNewTabButtonSize__px !important;
                   margin-top: -1px !important;
                   margin-left: -3px !important;
                   padding: 2px !important;
                   fill: rgba(__strNewTabButtonColor__,1) !important;
               }
               
               
               /* Throbber Icon ändern */
               __NewThrowberDisableStart__
               .tab-throbber[busy]::before,
               .tab-throbber[progress]::before {
                 width: 16px !important;
                 height: 16px !important;
                 animation: unset !important;
                 -moz-context-properties: unset !important;
                 fill: unset !important;
                 opacity: unset !important;
               }
               .tab-throbber[busy]::before {
                 background-image: url("") !important;
               }/*
               .tab-throbber-fallback[busy] {
                 list-style-image: url("") !important;
               }*/
               .tab-throbber[progress]::before{
                 background-image: url("") !important;
               }/*
               .tab-throbber-fallback[progress] {
                 list-style-image: url("") !important;
               }*/
               __NewThrowberDisableEnd__
           
           `;
           
           cssOut = cssIn;
           
           if(bTabCloseButton) {
               cssOut = cssOut.replace("__strTabCloseVisible__", "initial");
           }    
           else {
               cssOut = cssOut.replace("__strTabCloseVisible__", "none");
               nTabCloseIconNr = 0;
           }
           
           if( nTabCloseIconNr == 1 ) {
               cssOut = cssOut.replace(/__CloseIcon1DisableStart__/g, ' ');
               cssOut = cssOut.replace(/__CloseIcon1DisableEnd__/g, ' ');
               cssOut = cssOut.replace(/__CloseIcon2DisableStart__/g, '/*');
               cssOut = cssOut.replace(/__CloseIcon2DisableEnd__/g, '*/');
           }        
           else if( nTabCloseIconNr == 2 ) {
               cssOut = cssOut.replace(/__CloseIcon1DisableStart__/g, '/*');
               cssOut = cssOut.replace(/__CloseIcon1DisableEnd__/g, '*/');
               cssOut = cssOut.replace(/__CloseIcon2DisableStart__/g, ' ');
               cssOut = cssOut.replace(/__CloseIcon2DisableEnd__/g, ' ');
           }
           else
           {
               cssOut = cssOut.replace(/__CloseIcon1DisableStart__/g, '/*');
               cssOut = cssOut.replace(/__CloseIcon1DisableEnd__/g, '*/');
               cssOut = cssOut.replace(/__CloseIcon2DisableStart__/g, '/*');
               cssOut = cssOut.replace(/__CloseIcon2DisableEnd__/g, '*/');
               
           }
           
           if(bTabCloseButRounded)
               cssOut = cssOut.replace(/__nBorderRadius__/g, 20);
           else
               cssOut = cssOut.replace(/__nBorderRadius__/g, 0);
           
           cssOut = cssOut.replace(/__nTabCloseButTransparency__/g, nTabCloseButTransparency*100);
           cssOut = cssOut.replace(/__nTabCloseButSize__/g, nTabCloseButSize);
           
           
           cssOut = cssOut.replace(/__nNewTabButtonSize__/g, nTabHeight);
           cssOut = cssOut.replace(/__strNewTabButtonColor__/g, strNewTabButtonColor);
           
           if(bNewThroberAnimation)
           {
               cssOut = cssOut.replace(/__NewThrowberDisableStart__/g, ' ');
               cssOut = cssOut.replace(/__NewThrowberDisableEnd__/g, ' ');
           }
           else
           {
               cssOut = cssOut.replace(/__NewThrowberDisableStart__/g, '/*');
               cssOut = cssOut.replace(/__NewThrowberDisableEnd__/g, '*/');
           }
    
           //console.log("cssOut1: " + cssOut );
           
           service = Cc['@mozilla.org/content/style-sheet-service;1'].getService(Ci.nsIStyleSheetService);
           uri = makeURI('data:text/css;charset=UTF=8,' + encodeURIComponent(cssOut));
           service.loadAndRegisterSheet(uri, service.AUTHOR_SHEET);
          
            
           cssIn =`
              /* Scrollbars -> "no-drag"*/
             scrollbar, scrollcorner, scrollbar thumb, scrollbar scrollbarbutton {
               -moz-window-dragging: no-drag !important;
           }
            
            /* Tabs */
                        
            scrollbox[smoothscroll="true"] > slot  {
                display: contents !important;
            }
            
           `;
           
           service = Cc['@mozilla.org/content/style-sheet-service;1'].getService(Ci.nsIStyleSheetService);
           uri = makeURI('data:text/css;charset=UTF=8,' + encodeURIComponent(cssIn));
           service.loadAndRegisterSheet(uri, service.AGENT_SHEET);
           
    
           cssIn =`
           :root[tabsintitlebar][sizemode="maximized"]  #titlebar,
           :root[tabsintitlebar][sizemode="normal"]  #titlebar {
               appearance: none !important;
           }
           .tabbrowser-tab {
               --tab-label-mask-size: 1em;
           }
           
           #tabbrowser-tabs[haspinnedtabs]:not([positionpinnedtabs]) > #tabbrowser-arrowscrollbox >
           .tabbrowser-tab:nth-child(1 of :not([pinned], [hidden])) {
               margin-inline-start: -1px !important; 
           }
           
            #tab-preview-panel { 
               strTabTooltips !important;
           }
                    
           #TabsToolbar > .titlebar-buttonbox-container,
           #main-window[sizemode="fullscreen"]  #window-controls {
               display: none !important;
           }    
               
           #TabsToolbar { 
               /* Hintergrund der Tab-Leiste setzen */
               __strTabBarBackground__
           }
           
                   
                           
           /* Tab-Höhe */
           .tabbrowser-tab, .tab-stack, .tab-background {
               min-height: nTabHeightpx !important;
               max-height: nTabHeightpx !important;
               
               margin-top: 0px !important;
               margin-bottom: nTabMarginpx !important;
               
               margin-left: -1px !important;
               margin-right: 0px !important;
           }
    
           #tabbrowser-tabs .tab-label:not([fokus]){
               opacity: 1!important;
           }
            
            tabs > arrowscrollbox::part(scrollbox)    {
               overflow-x: hidden !important;
               overflow-y: strScrollbar !important;
           }
    
           .tabbrowser-tab:not([pinned]) {
               flex-grow: 0 !important;
               min-width: nTabWidthpx !important;             
           }
           
       
           /* Schriftart/Schriftgröße ändern */
           .tabbrowser-tab .tab-label {
               text-shadow: none !important; 
               color: rgb(strTabFontColorNotSel) !important; 
               font-weight: nTabFontWeight !important;
               font-size:   nTabFontSizepx !important;
               font-family: "strTabFontName" !important;
               font-style: normal; 
           }
           .tabbrowser-tab[selected] .tab-label,
           .tabbrowser-tab[multiselected] .tab-label {
               text-shadow: __strTextShadow__ !important; ;
               color: rgb(strTabFontColorSel) !important; 
               font-weight: nTabFontWeight !important;
               font-size:   nTabFontSizepx !important; 
               font-family: "strTabFontName" !important; 
               font-style: normal; 
           }
           
           /*Ungelesene Tabs werden markiert */
           .tabbrowser-tab[pending] .tab-label, .tabbrowser-tab[notselectedsinceload="true"] {
               font-style: __strMarkUnreadTab__ !important;
           }
           
           #TabsToolbar .tabbrowser-tab .tab-background
           {
               border-radius: nTabBorderRadiuspx !important; 
               border: nTabBorderWidthpx solid rgba(strTabBorderColor,0.66) !important;
           }
           
           /* Tab-Hintergrund  */
           /*--- selektiert ---*/
           .tab-background[selected]{
               background-image:  linear-gradient( rgba(strTabSelColor1,1), rgba(strTabSelColor2,1) ), none !important;
               filter: drop-shadow(2px 2px 2px rgba(0,0,0,0.5)) drop-shadow(-2px 2px 2px rgba(0,0,0,0.5)) !important; 
               border-radius: nTabBorderRadiuspx !important; 
           }
           /*--- hover: nicht selektiert ---*/
           .tabbrowser-tab:hover > .tab-stack > .tab-background:not([selected]) {
               filter: brightness(130%) contrast(110%) drop-shadow(1px 1px 1px rgba(0,0,0,0.5)) drop-shadow(-1px 1px 1px rgba(0,0,0,0.5)) !important; 
               border-radius: nTabBorderRadiuspx !important;    
           }
           .tabbrowser-tab:hover:not([selected]) :is(.tab-label,.tab-icon-stack) {
               filter: drop-shadow( 0px 0px 2px #AAAAAA) brightness(115%) !important; 
           }
           /*--- hover: Multi selektiert ---*/
           .tabbrowser-tab:hover > .tab-stack > .tab-background[multiselected]:not([selected]) {
               filter: brightness(120%) contrast(100%) drop-shadow(1px 1px 1px rgba(0,0,0,0.5)) drop-shadow(-1px 1px 1px rgba(0,0,0,0.5)) !important; 
               border-radius: nTabBorderRadiuspx !important;    
           }
           /*--- nicht selektiert ---*/
           .tab-background:not([selected]) {
               background-image:  linear-gradient( rgba(strTabNotSelColor1,nTabTransparency), rgba(strTabNotSelColor2,nTabTransparency) ),  none !important; 
               filter: brightness(115%) contrast(90%) drop-shadow(1px 1px 1px rgba(0,0,0,0.5)) drop-shadow(-1px 1px 1px rgba(0,0,0,0.5)) !important; 
               border-radius: nTabBorderRadiuspx !important; 
           }
           /*--- Multi selektiert ---*/
           .tab-background[multiselected]:not([selected]) {
               background-image:  linear-gradient( rgba(strTabSelColor1,1), rgba(strTabSelColor2,1) ), none !important;
               filter: brightness(130%) saturate(50%) drop-shadow(1px 1px 1px rgba(0,0,0,0.5)) drop-shadow(-1px 1px 1px rgba(0,0,0,0.5)) !important; 
               border-radius: nTabBorderRadiuspx !important; 
           }
       
           .tab-sharing-icon-overlay, .tab-icon-overlay:not([pinned]), .tab-icon-overlay[soundplaying] {
               transform:  scale(1.5) !important;  
           }
           
           .tabbrowser-tab .tab-label 
           {
               margin-top: -2px !important;
           }
               
           
           .tab-close-button
           {
               margin-top: -2px !important;
           }
           
           .tab-throbber, .tab-throbber-tabslist, .tab-icon-pending, .tab-icon-image, .tab-sharing-icon-overlay {
               height:     nFavIconSizepx !important;
               width:         nFavIconSizepx !important;
               fill: rgba(255,255,255,0.8) !important;
               margin-top: -2px !important;
           }    
           
           #tabbrowser-tabs, #tabbrowser-arrowscrollbox, #tabbrowser-tabs[positionpinnedtabs] > #tabbrowser-arrowscrollbox > .tabbrowser-tab[pinned] {
               min-height: 0 !important; 
           }        
           #tabbrowser-tabs {
               appearance: none !important;
           }
           
           .tabbrowser-tab:is([visuallyselected], [multiselected]) > .tab-stack > .tab-background:-moz-lwtheme {
               box-shadow: none !important; 
           }
            
           `;
                   
           // --- CSS-Parameter ersetzen ---
           cssOut = cssIn.replace(/nTabHeight/g, nTabHeight);
           cssOut = cssOut.replace(/nTabMargin/g, nTabMargin);
           cssOut = cssOut.replace(/nTabWidth/g, nTabWidth);
           
                   
           if(bTabScrollbar) {
               cssOut = cssOut.replace("strScrollbar", "auto");
           }
           else {
               cssOut = cssOut.replace("strScrollbar", "hidden");
           }
    
            if(!bTabTooltips) {
               cssOut = cssOut.replace("strTabTooltips", "display: none");
            }
             
           cssOut = cssOut.replace(/strTabSelColor1/g, strTabSelColor1);
           cssOut = cssOut.replace(/strTabSelColor2/g, strTabSelColor2);
           cssOut = cssOut.replace(/strTabNotSelColor1/g, strTabNotSelColor1);
           cssOut = cssOut.replace(/strTabNotSelColor2/g, strTabNotSelColor2);
           cssOut = cssOut.replace(/nTabBorderRadius/g, nTabBorderRadius);
           cssOut = cssOut.replace(/nTabBorderWidth/g, nTabBorderWidth);
           cssOut = cssOut.replace(/strTabBorderColor/g, strTabBorderColor);
           cssOut = cssOut.replace(/nTabTransparency/g, nTabTransparency);
           
           cssOut = cssOut.replace(/strTabFontName/g, strTabFontName);
           cssOut = cssOut.replace(/strTabFontColorSel/g, strTabFontColorSel);
           cssOut = cssOut.replace(/strTabFontColorNotSel/g, strTabFontColorNotSel);
           cssOut = cssOut.replace(/nTabFontSize/g, nTabFontSize);
           cssOut = cssOut.replace(/nTabFontWeight/g, nTabFontWeight);
           
           if (bTabFontTextShadow)
               cssOut = cssOut.replace(/__strTextShadow__/g, "1px 1px 0px #000000");
           else
               cssOut = cssOut.replace(/__strTextShadow__/g, "none");
           
           
           if( bMarkUnreadTab )
             cssOut = cssOut.replace(/__strMarkUnreadTab__/g, "italic");
           else
             cssOut = cssOut.replace(/__strMarkUnreadTab__/g, "normal");
           
                        
           let strTabBarBackgroundOut = "";
           if( strTabBarBgImagePath ) {
               if( bTabBarBgImageRepeat ) {
                   strTabBarBackgroundOut = "background: #000000 url(\"file:" + strTabBarBgImagePath + "\") repeat !important;";
               }
               else {
                   strTabBarBackgroundOut = "background: #000000 url(\"file:" + strTabBarBgImagePath + "\") no-repeat !important;";
               }
           }
           else {
                strTabBarBackgroundOut = "background-image: linear-gradient( rgba(" + strTabBarBgColor1 + "," + nTabBarTransparency +"), rgba(" + strTabBarBgColor2 + "," + nTabBarTransparency + ") ) !important;";
           }
                           
           cssOut = cssOut.replace(/__strTabBarBackground__/g, strTabBarBackgroundOut);
           
           cssOut = cssOut.replace(/nFavIconSize/g, nFavIconSize);
                           
           //console.log("CSSOut: " + cssOut );
        
           service = Cc['@mozilla.org/content/style-sheet-service;1'].getService(Ci.nsIStyleSheetService);
           uri = makeURI('data:text/css;charset=UTF=8,' + encodeURIComponent(cssOut));
           service.loadAndRegisterSheet(uri, service.AUTHOR_SHEET);
                   
           let tabsScrollbox     = document.getElementById('tabbrowser-arrowscrollbox').scrollbox;
           
           tabsScrollbox.style.minHeight      =  nTabLineHeight +'px';
           tabsScrollbox.style.maxHeight      =  nTabLineHeight*nTabLines +'px';
           /*
           console.log("tabsScrollbox: " + tabsScrollbox );
            console.log("tabsScrollbox.style.minHeight: " + tabsScrollbox.style.minHeight ); 
            console.log("tabsScrollbox.style.maxHeight: " + tabsScrollbox.style.maxHeight );
            */
           
       }
       
       if( nTabbarPosition >= 2 && nTabbarPosition <= 5 ) {
           let tabbar = document.getElementById("TabsToolbar");
           tabbar.parentNode.appendChild(tabbar);
       }
       
       if( nTabbarPosition >= 3 && nTabbarPosition <= 5 )
       {
           let cssIn =`
           
           .StyleShowingTabsToolbar {
               transition:                margin-left nVerticalAutoPopupAnims !important; 
               display:                   flex !important;
               position:                  absolute !important;
               opacity:                   1;
               margin-left:               0px;
               z-index:                   100 !important;
               min-width:                 nVerticalTabbarWidthpx !important;
               filter:                    drop-shadow(4px 3px 2px rgba(0,0,0,0.33)) !important; 
           }
           
                   
           .StyleHidingTabsToolbar {
               display:                   flex !important;
               position:                  absolute !important;
               opacity:                   0;
               margin-left:               calc( (nVerticalTabbarWidthpx - nVerticalAutoPopupHoverpx) * -1 ); 
               z-index:                   100 !important;
               min-width:                 nVerticalTabbarWidthpx !important;
           }
     
           .toolbar-items[align="end"] {
               display:initial !important;
           }
     
           tabs > arrowscrollbox { 
               display:  flex !important;
               position: absolute !important;
               min-width: nVerticalTabbarWidthpx !important;
           }
       
           `;
       
           let cssOut;
           
           if ( nTabbarPosition != 4 ) {
               nVerticalAutoPopupAnim = 0;
           }        
           
                           
           cssOut = cssIn.replace(/nVerticalTabbarWidth/g, nVerticalTabbarWidth);
           cssOut = cssOut.replace(/nVerticalAutoPopupHover/g, nVerticalAutoPopupHover);
           cssOut = cssOut.replace(/nVerticalAutoPopupAnim/g, nVerticalAutoPopupAnim);
           
                           
           let sss = Cc['@mozilla.org/content/style-sheet-service;1'].getService(Ci.nsIStyleSheetService);
           let uri = makeURI('data:text/css;charset=UTF=8,' + encodeURIComponent(cssOut));
           sss.loadAndRegisterSheet(uri, sss.AUTHOR_SHEET);
       
           
           let tabsToolbar =  document.getElementById('TabsToolbar');
           
           if ( nTabbarPosition == 4 )
           {
               tabsToolbar.classList.add('StyleHidingTabsToolbar');
           }
           else
           {
               tabsToolbar.classList.add('StyleShowingTabsToolbar');
           }
           
       }
    //------------------------------------------------------------------------------------------
       
       var tabsToolbar     = document.getElementById('TabsToolbar');
       var tabbrowsertabs     = document.getElementById('tabbrowser-tabs');
       var tabsscrollbox    = document.getElementById('tabbrowser-arrowscrollbox');
       var ScrollBox = tabsscrollbox.scrollbox;    
       var bMouseEnter = false;
       var bToolbarLocked = false;
       // ----------------------------------
       // Load-Event:  
       // ----------------------------------
       function onReady() 
       {    
           console.log("OnReady");
           
           let cssElements =`
           
               #tabbrowser-tabs {
                   --tab-overflow-pinned-tabs-width: 0px !important;
               }
               
               #alltabs-button,
               hbox.titlebar-spacer,
               #tabbrowser-arrowscrollbox::part(scrollbutton-up), 
               #tabbrowser-arrowscrollbox::part(scrollbutton-down),
               #tabbrowser-arrowscrollbox::part(overflow-start-indicator), 
               #tabbrowser-arrowscrollbox::part(overflow-end-indicator) {
                   display: none !important;
               }
               
               tabs > arrowscrollbox::part(scrollbox)    {
                   flex-wrap: wrap !important; 
               }
           `;
           
           let service = Cc['@mozilla.org/content/style-sheet-service;1'].getService(Ci.nsIStyleSheetService);
           let ur         = makeURI('data:text/css;charset=UTF=8,' + encodeURIComponent(cssElements));
           service.loadAndRegisterSheet(ur, service.AUTHOR_SHEET);
           
           gBrowser.selectedTab.scrollIntoView(); 
       }    
       
       
       if (window.readyState !== "loading") {
           setTimeout(onReady,500); 
       }
       else 
       {
           window.addEventListener("DOMContentLoaded", onReady );
       }
       
       // ----------------------------------
       // ResizeObserver / Client
       // ----------------------------------
       var resizeClientObserver=null;
       
       let navigatorToolbox = document.getElementById('navigator-toolbox');
       let mainWindow = document.getElementById('main-window');
       
       if( nTabbarPosition >= 3 && nTabbarPosition <= 5 )
       {
           resizeClientObserver = new ResizeObserver(function(entries) {
               for (let entry of entries) {
                   
                   tabsToolbar.style.minHeight = tabsToolbar.style.maxHeight = entry.contentRect.height + 'px';
                   ScrollBox.style.maxHeight = entry.contentRect.height + 'px';
                   
                   tabsToolbar.style.top = navigatorToolbox.clientHeight + 'px';
                                   
                   if(mainWindow.getAttribute('inFullscreen') == 'true' ) {
                       if (navigatorToolbox.style.marginTop != "") {
                           tabsToolbar.style.top = '0px';
                       }
                   }
                   
                   if( nTabbarPosition == 5 )    {
                       tabsToolbar.style.marginLeft = (entry.contentRect.width - nVerticalTabbarWidth) + 'px';
                   }
               }
           });
                   
           resizeClientObserver.observe(document.getElementById("browser"));            
       }  
    
       // ----------------------------------
       // ToggleMenuObserver
       // ----------------------------------
       if( nTabbarPosition == 2 || nTabbarPosition == 6) {
           let observerToggleMenu=null;
           let configObserver=null;
           
           let bTabsintitlebar = document.querySelector('html#main-window').getAttribute('tabsintitlebar');
           let titlebar = document.querySelector('#navigator-toolbox>vbox#titlebar');
           let targetMenubar = document.getElementById('toolbar-menubar');
           const callback = (mutationList, observer) => {
               for (const mutation of mutationList) {
                   if (mutation.type === 'attributes') {
                       let bAutohide = targetMenubar.getAttribute('autohide');
                       let bInacive = targetMenubar.getAttribute('inactive');
                       if(bInactive == 'true')    {
                           titlebar.style.display = "none";
                           console.log("titlebar.style.display = none");
                       }
                       else {
                           titlebar.style.display = "initial";
                           console.log("titlebar.style.display = initial");
                           
                       }
                   }
               }
           }
       
           observerToggleMenu = new MutationObserver(callback);
           configObserver = { attributes: true, attributeFilter: ['autohide','inactive'] };
           
           observerToggleMenu.observe(targetMenubar, configObserver);    
       }
       // ----------------------------------
       // 'Middleclick' on Tab -> Close Tab
       // ----------------------------------
       gBrowser.tabContainer.addEventListener('click', function(event) 
       {
           if (event.button == 1)
           {
               let element = event.target.parentNode;
               while(element)
               {
                   if (element.localName == 'tab') 
                   {
                       gBrowser.removeTab(element, {animate: false});
                       event.preventDefault();
                       event.stopPropagation();    
                       return;
                   }
                   
                   element = element.parentNode;
               }
               
           };
       
       }, true);
       // ----------------------------------
       // 'Middleclick' on TabsToolbar -> Add Tab
       // ----------------------------------
       tabsToolbar.addEventListener('click', function(event)
       {
           if (event.button == 1)
           {
               if(event.target.parentNode.id == "TabsToolbar") 
               { 
                  event.target.ownerGlobal.openTrustedLinkIn(strHomepageURL,"tab");
                  return;
               }
           };
       }, true);
       
       // ----------------------------------
       // 'Doubleclick' on TabsToolbar -> Add Tab
       // ----------------------------------
       tabsToolbar.addEventListener('dblclick', function(event)
       {
           if(!bDblclickOnTabbarNewTab)
               return;
           
           if (event.button == 0)
           {  
                   
               if(event.target.parentNode.id == "TabsToolbar") 
               {
                  event.target.ownerGlobal.openTrustedLinkIn(strHomepageURL,"tab");
                  
                  event.preventDefault();
                  event.stopPropagation();    
                  return;
               }
           };
       }, true);
           
           
           
       // ----------------------------------
       // 'Doubleclick' on TabsContainer -> Add Tab
       // ----------------------------------
       gBrowser.tabContainer.addEventListener('dblclick', function(event)
       {
           if(!bDblclickOnTabbarNewTab)
               return;
           
           if (event.button == 0)
           {  
                  let element = event.target.parentNode;
               if (element == gBrowser.tabContainer ) 
               {
                  event.target.ownerGlobal.openTrustedLinkIn(strHomepageURL,"tab");
       
                  event.preventDefault();
                  event.stopPropagation();    
                  return;
               }
           };
       }, true);
       
       
       // ----------------------------------
       // 'Doubleclick' on Tab -> Reload Tab
       // ----------------------------------
       gBrowser.tabContainer.addEventListener('dblclick', function(event) 
       {
           if(!bDblclickOnTabReloadTab)
               return;
           
           if (event.button == 0)
           {
               let element = event.target.parentNode;
               while (element) 
               {
                   if (element.localName == 'tab') 
                   {
                       element.linkedBrowser.reload();
                       
                       return;
                   }
                    
                   element = element.parentNode;
               }
           }
       }, true);
       
       // ----------------------------------
       // 'mouseenter'
       // ----------------------------------
       tabsToolbar.addEventListener('mouseenter', event => {
           if( nTabbarPosition == 4  ) 
           {
               if(!bMouseEnter)
               {
                   bMouseEnter = true;
                   
                   tabsToolbar.classList.add('StyleShowingTabsToolbar');    
                   tabsToolbar.classList.remove('StyleHidingTabsToolbar');
                   
               }
           }
       }, true);
       
       // ----------------------------------
       // 'mouseleave'
       // ----------------------------------
       tabsToolbar.addEventListener('mouseleave', event => {
           if( nTabbarPosition == 4 ) 
           {    
               if(bMouseEnter)
               {      
                               
                   if( event.clientX >= 0 &&
                       event.offsetY > tabsToolbar.clientTop  &&
                       event.offsetX < tabsToolbar.clientWidth &&
                       event.offsetY < tabsToolbar.clientHeight )
                   {
                       return;
                   }
           
                   event.preventDefault();
                   event.stopPropagation();
                   
                   
                   tabsToolbar.classList.add('StyleHidingTabsToolbar');
                   tabsToolbar.classList.remove('StyleShowingTabsToolbar');
                   
                   bMouseEnter = false;
               }
           }                
       }, false);
    
       
       // ...  
       // TabSelect-Event:  
       // ...
       gBrowser.tabContainer.addEventListener("TabSelect", function(event) {
                   
           let bScroll    = false;
           let bScrollTop = true;
                   
           let scrollBoxY1     = event.target.parentElement.scrollbox.screenY;
           let scrollBoxHeight = event.target.parentElement.scrollbox.clientHeight;
           let scrollBoxY2     = scrollBoxY1+scrollBoxHeight;
           
           let TabSelY1     = event.target.screenY;
           let TabSelHeight = event.target.clientHeight;
           let TabSelY2     = TabSelY1+TabSelHeight;
           
           
           
           if( TabSelY2 > scrollBoxY2 )
           {
               bScroll = true;
               bScrollTop = false;
           }
           if( TabSelY1 < scrollBoxY1 ) 
           {
               bScroll = true;
               bScrollTop = true;
           }
           
           if( bScroll )
           {
               setTimeout(function() 
               {
                   event.target.scrollIntoView(bScrollTop);
                   //gBrowser.selectedTab.scrollIntoView(); 
                   //console.log("TabSelect_IntoView:" + bScrollTop );    
               }, 0);
           }
           
          //console.log("TabSelect:" + bScroll );    
           
       }, true);
         
       
         
         
       // ...  
       // Drag-Event: Start  
       // ...
       gBrowser.tabContainer.addEventListener("dragstart",  function(event) {
           //console.log("dragstart..." );    
           if(nTabLines==1 && ( nTabbarPosition == 1 || nTabbarPosition == 2 || nTabbarPosition == 6 )) {
               let tabsScrollbox  = document.getElementById('tabbrowser-arrowscrollbox').scrollbox;
               tabsScrollbox.style.maxHeight      =  nTabLineHeight*3 +'px';
               event.target.scrollIntoView(false);
           }
       }, false);
       // ...  
       // Drag-Event: Ende  
       // ...
       gBrowser.tabContainer.addEventListener("dragend",  function(event) {
           //console.log("dragend..." );    
           if(nTabLines==1 && ( nTabbarPosition == 1 || nTabbarPosition == 2 || nTabbarPosition == 6 )) {
               let tabsScrollbox  = document.getElementById('tabbrowser-arrowscrollbox').scrollbox;
               tabsScrollbox.style.maxHeight      =  nTabLineHeight +'px';
               event.target.scrollIntoView(false);
           }
       }, false);
       
       
       // ...  
       // Wheel-Event:  
       // ...
       let tabsScrollbox  = document.getElementById('tabbrowser-arrowscrollbox').scrollbox;
       tabsScrollbox.addEventListener("wheel", function(event) 
       {
           event.preventDefault();
           event.stopPropagation();
           
               
           let scrollUp        = true;
           let wrap            = false;
           let scrollBoxY1     = gBrowser.tabContainer._animateElement.scrollbox.scrollTop; 
           let scrollHeight;
           
           if(bPageScroll)
               {scrollHeight  = gBrowser.tabContainer._animateElement.scrollbox.clientHeight;}
           else            
               {scrollHeight  = nTabLineHeight;}
           
           let dir = (scrollUp ? 1 : -1) * Math.sign(event.deltaY);
           
           let bLastScrollLine = false; 
           
           if( gBrowser.tabContainer._animateElement.scrollbox.scrollTopMax == gBrowser.tabContainer._animateElement.scrollbox.scrollTop)
               {
                   bLastScrollLine = true;
               }        
           
           if( !bTabWheel || event.ctrlKey || event.originalTarget.localName == "thumb"  || event.originalTarget.localName == "slider" || event.originalTarget.localName == "scrollbarbutton" ) 
           {
                 setTimeout(function()
               {
                   let scrollBoxMod = scrollBoxY1%scrollHeight;
                   
                   if( scrollBoxMod > 0 )
                   {
                       if( dir == -1 )
                       {
                           scrollBoxY1 -= scrollBoxMod;
                           if(scrollBoxMod < nTabLineHeight && !bLastScrollLine) { scrollBoxY1 -= scrollHeight; }
                   
                       }
                       else
                       {
                           scrollBoxY1 += (scrollHeight-(scrollBoxMod));
                           if(scrollHeight-(scrollBoxMod) < nTabLineHeight) { scrollBoxY1 += scrollHeight; }
                           
                       }
                   }
                   else
                   {
                       if( dir == -1 )
                       {
                           scrollBoxY1 -= scrollHeight;
                       }
                       else
                       {
                           scrollBoxY1 += scrollHeight;
                       }
                   }
                   
                   gBrowser.tabContainer._animateElement.scrollbox.scrollTo({ top: scrollBoxY1, left: 0, behavior: 'auto'}); 
               }, 20);
           }
           
           if( bTabWheel && !event.ctrlKey )
           {    
               setTimeout(function()
               {
                   if( event.originalTarget.localName != "slider" && 
                       event.originalTarget.localName != "thumb"  &&
                       event.originalTarget.localName != "scrollbarbutton" )
                   {
                       gBrowser.tabContainer.advanceSelectedTab(dir, wrap);
                       if( (gBrowser.tabContainer._firstTab == gBrowser.selectedTab) || 
                           (gBrowser.tabContainer._lastTab  == gBrowser.selectedTab)     )
                           {
                               gBrowser.selectedTab.scrollIntoView(); 
                           }
           
                   }    
               }, 50);
           }
    
       }, false);
           
    //-------------------------------------------------------------------------------------------
    
       gBrowser.tabContainer.clearDropIndicator = function() {
           var tabs = this.allTabs;
           for (let i = 0, len = tabs.length; i < len; i++) {
               tabs[i].style.removeProperty("border-left-color");
               tabs[i].style.removeProperty("border-right-color");
           }
       }
       gBrowser.tabContainer.addEventListener("dragleave", function(event) {  this.clearDropIndicator(event); }, true);
    
       gBrowser.tabContainer.on_dragover = function(event) {
           this.clearDropIndicator();
           var effects = this.getDropEffectForTabDrag(event);
           var ind = this._tabDropIndicator;
           if (effects == "" || effects == "none") {
               ind.hidden = true;
               return;
           }
           event.preventDefault();
           event.stopPropagation();
           if (effects == "link") {
               let tab = this._getDragTargetTab(event, true);
               if (tab) {
                   if (!this._dragTime) {
                       this._dragTime = Date.now();
                   }
                   if (Date.now() >= this._dragTime + this._dragOverDelay) {
                       this.selectedItem = tab;
                   }
                   ind.hidden = true;
                   return;
               }
           }
           let newIndex = this._getDropIndex(event, effects == "link");
           let children = this.allTabs;
           if (newIndex == children.length) {
               children[newIndex - 1].style.setProperty("border-right-color","red","important");
           } else {
               children[newIndex].style.setProperty("border-left-color","red","important");
           }
       }
       gBrowser.tabContainer.on_drop = function(event) {
           this.clearDropIndicator();
           var dt = event.dataTransfer;
           var dropEffect = dt.dropEffect;
           var draggedTab;
           let movingTabs;
           if (dt.mozTypesAt(0)[0] == TAB_DROP_TYPE) {
               // tab copy or move
               draggedTab = dt.mozGetDataAt(TAB_DROP_TYPE, 0);
               // not our drop then
               if (!draggedTab) {
                   return;
               }
               movingTabs = draggedTab._dragData.movingTabs;
                draggedTab.container._finishMoveTogetherSelectedTabs(draggedTab);  
           }
           this._tabDropIndicator.hidden = true;
           event.stopPropagation();
           if (draggedTab && dropEffect == "copy") {
               // copy the dropped tab (wherever it's from)
               let newIndex = this._getDropIndex(event, false);
               let draggedTabCopy;
               for (let tab of movingTabs) {
                   let newTab = gBrowser.duplicateTab(tab);
                   gBrowser.moveTabTo(newTab, newIndex++);
                   if (tab == draggedTab) {
                       draggedTabCopy = newTab;
                   }
               }
               if (draggedTab.container != this || event.shiftKey) {
                   this.selectedItem = draggedTabCopy;
               }
           } else if (draggedTab && draggedTab.container == this) {
               let oldTranslateX = Math.round(draggedTab._dragData.translateX);
               let tabWidth = Math.round(draggedTab._dragData.tabWidth);
               let translateOffset = oldTranslateX % tabWidth;
               let newTranslateX = oldTranslateX - translateOffset;
               if (oldTranslateX > 0 && translateOffset > tabWidth / 2) {
                   newTranslateX += tabWidth;
               } else if (oldTranslateX < 0 && -translateOffset > tabWidth / 2) {
                   newTranslateX -= tabWidth;
               }
               let dropIndex = this._getDropIndex(event, false);
               //  "animDropIndex" in draggedTab._dragData &&
               //  draggedTab._dragData.animDropIndex;
               let incrementDropIndex = true;
               if (dropIndex && dropIndex > movingTabs[0]._tPos) {
                   dropIndex--;
                   incrementDropIndex = false;
               }
               let animate = gBrowser.animationsEnabled;
               if (oldTranslateX && oldTranslateX != newTranslateX && animate) {
                   for (let tab of movingTabs) {
                       tab.setAttribute("tabdrop-samewindow", "true");
                       tab.style.transform = "translateX(" + newTranslateX + "px)";
                       let onTransitionEnd = transitionendEvent => {
                           if (
                               transitionendEvent.propertyName != "transform" ||
                               transitionendEvent.originalTarget != tab
                           ) {
                               return;
                           }
                           tab.removeEventListener("transitionend", onTransitionEnd);
                           tab.removeAttribute("tabdrop-samewindow");
                           this._finishAnimateTabMove();
                           if (dropIndex !== false) {
                               gBrowser.moveTabTo(tab, dropIndex);
                               if (incrementDropIndex) {
                                   dropIndex++;
                               }
                           }
                           gBrowser.syncThrobberAnimations(tab);
                       };
                       tab.addEventListener("transitionend", onTransitionEnd);
                   }
               } else {
                   this._finishAnimateTabMove();
                   if (dropIndex !== false) {
                       for (let tab of movingTabs) {
                           gBrowser.moveTabTo(tab, dropIndex);
                           if (incrementDropIndex) {
                               dropIndex++;
                           }
                       }
                   }
               }
           } else if (draggedTab) {
               let newIndex = this._getDropIndex(event, false);
               let newTabs = [];
               for (let tab of movingTabs) {
                   let newTab = gBrowser.adoptTab(tab, newIndex++, tab == draggedTab);
                   newTabs.push(newTab);
               }
               // Restore tab selection
               gBrowser.addRangeToMultiSelectedTabs(
                   newTabs[0],
                   newTabs[newTabs.length - 1]
               );
           } else {
               // Pass true to disallow dropping javascript: or data: urls
               let links;
               try {
                   links = browserDragAndDrop.dropLinks(event, true);
               } catch (ex) {}
               if (!links || links.length === 0) {
                   return;
               }
               let inBackground = Services.prefs.getBoolPref(
                   "browser.tabs.loadInBackground"
               );
               if (event.shiftKey) {
                   inBackground = !inBackground;
               }
               let targetTab = this._getDragTargetTab(event, true);
               let userContextId = this.selectedItem.getAttribute("usercontextid");
               let replace = !!targetTab;
               let newIndex = this._getDropIndex(event, true);
               let urls = links.map(link => link.url);
               let csp = browserDragAndDrop.getCSP(event);
               let triggeringPrincipal = browserDragAndDrop.getTriggeringPrincipal(
                   event
               );
               (async () => {
                   if (
                       urls.length >=
                       Services.prefs.getIntPref("browser.tabs.maxOpenBeforeWarn")
                   ) {
                       // Sync dialog cannot be used inside drop event handler.
                       let answer = await OpenInTabsUtils.promiseConfirmOpenInTabs(
                           urls.length,
                           window
                       );
                       if (!answer) {
                           return;
                       }
                   }
                   gBrowser.loadTabs(urls, {
                       inBackground,
                       replace,
                       allowThirdPartyFixup: true,
                       targetTab,
                       newIndex,
                       userContextId,
                       triggeringPrincipal,
                       csp,
                   });
               })();
           }
           if (draggedTab) {
               delete draggedTab._dragData;
           }
       }
       gBrowser.tabContainer._getDropIndex = function(event, isLink) {
           var tabs = this.allTabs;
           var tab = this._getDragTargetTab(event, isLink);
           if (!RTL_UI) {
               for (let i = tab ? tab._tPos : 0; i < tabs.length; i++) {
                   if (
                       event.screenY <
                       tabs[i].screenY + tabs[i].getBoundingClientRect().height
                   ) {
                       if (
                           event.screenX <
                           tabs[i].screenX + tabs[i].getBoundingClientRect().width / 2
                       ) {
                           return i;
                       }
                       if (
                           event.screenX >
                           tabs[i].screenX + tabs[i].getBoundingClientRect().width / 2 &&
                           event.screenX <
                           tabs[i].screenX + tabs[i].getBoundingClientRect().width
                       ) {
                           return i + 1;
                       }
                   }
               }
           } else {
               for (let i = tab ? tab._tPos : 0; i < tabs.length; i++) {
                   if (
                       event.screenY <
                       tabs[i].screenY + tabs[i].getBoundingClientRect().height
                   ) {
                       if (
                           event.screenX <
                           tabs[i].screenX + tabs[i].getBoundingClientRect().width &&
                           event.screenX >
                           tabs[i].screenX + tabs[i].getBoundingClientRect().width / 2
                       ) {
                           return i;
                       }
                       if (
                           event.screenX <
                           tabs[i].screenX + tabs[i].getBoundingClientRect().width / 2
                       ) {
                           return i + 1;
                       }
                   }
               }
           }
           return tabs.length;
       }
    }
    Alles anzeigen
  • Tableiste unten per CSS-Code, oder per Skript.

    • GermanFreme82
    • 27. November 2024 um 13:05
    Zitat von 2002Andreas

    Ich habe den CSS Code und das Skript in Beitrag Nr. 1 angepasst für Firefox ab Version 133.

    Oh du meinst hier im Thread auf Seite 1 für Firefox 133 wirklich ?
    Bei mir sieht es aktuell so aus, OHNE Anpassung und nur updaten.



    Der Beitrag hier ? => Fx 133 > Tableiste unten per CSS-Code, oder per Skript.

    Sind das auch alle Einstellungen meines Design und mehrzeiligen TABs enthalten ?

  • Mehrzeilige Tableiste für aktuelle Firefox-Versionen

    • GermanFreme82
    • 27. November 2024 um 13:02



    Das ist ja wieder einmal ein wundervolles Chaos, das mit dem neuen Update auf 133er mitkommt.

    Könntest du bitte einmal nachschauen, was im CODE für mich geändert werden muss, damit es wieder "normal" aussieht BrokenHeart  2002Andreas AddonLeisteUnten.uc.js.txt // MultiRowTab_Firefox107.js.txt

    Ich verstehe nur Bahnhof und weiß nicht, wo ich dann das alte Design wieder einstellen soll, besonders die mehrzeiligen TABs. Es ist ein absoluter Wahnsinn.

  • Problem mit Darstellung Lesezeichen Symbolleiste

    • GermanFreme82
    • 17. Oktober 2024 um 20:47
    Zitat von 2002Andreas
    Zitat von GermanFreme82

    Vorher war alles in Butter und prima !

    Neuer Versuch:

    JavaScript
    // 'MultiRowTabs.uc.js' V02 by BrokenHeart
    // based on 'MultiRowTab_LiteforFx48.uc.js' from 'http://space.geocities.yahoo.co.jp/gl/alice0775' (Alice0775)
    // Thanks to aborix...
    
    /* ///////////////////////////////////////////////////////////////////////////////////
    [13.07.2021 22:45Uhr]
    - 'Nur-JavaScript-Version' (CSS wird nicht mehr benötigt)
    - Sehr viele funktionale und optische Anpassungen hinzugefügt
    [20.02.2020 18:45Uhr]
    Fehler in allen CSS-Dateien beseitigt (:thumbup:Dank an diwa fürs melden )
    [18.02.2020 13:30Uhr]
    - Anpassen des User-JavaSkripts aus (3).
    - Skript 'Tabsrunter.uc.js' wurde entfernt, da jetzt bereits in (3) integriert.
    [11.12.2019 13:15Uhr]
    - Optische Anpassungen an Code (1) und (2).
    - Neuen Code hinzugefügt für 'Tabs mit abgerundeten Ecken' (2a).
    - Anpassen des User-JavaSkripts zum Verschieben der Tabs (3).
    [08.12.2019 17:45Uhr]
    - Anpassungen am Code (1) und (2) vorgenommen, um 'Tableiste unten' zu berücksichtigen.
    - JavaSkript hinzugefügt, welches die Tableiste nach unten befördert.
    [19.08.2022 21:28Uhr]
    - Fehler Menüleiste behoben
    [23.09.2022 01:58Uhr]
    - "Wheel-Event" Problem behoben
    [18.10.2022 15:20Uhr]
    -Fix: FF106+ -> 'Drag&Drop'
    [19.11.2022 09:28Uhr]
    -Fix: FF107+ -> 'contain' entfernt
    [15.12.2022 07:52Uhr]
    -Fix: FF108+ -> Toggle-menubar angepasst
    [15.12.2022 15:50Uhr]
    -Fix: FF108+ -> Position der vertikalen Tableiste korrigiert
    [19.12.2022 19:58Uhr]
    - Seite für neuen Tab wird aus Voreinstellungen gelesen
    - kleinere optische Anpassungen
    [21.12.2022 18:32Uhr]
    - Fix: Menüleiste per 'alt'/'F10'-Key einblenden
    [10.05.2023 00:08]
    - Fix: Anpassungen Flex-Container
    [10.05.2023 19:32]
    - Fix: Anpassungen "Vertikale Tableiste"
    [07.06.2023 18:35]
    - Fix: Siehe:  https://www.camp-firefox.de/forum/thema/74296-entwicklung-firefox/?postID=1227494#post1227494
    [07.06.2023 18:35]
    - Fix: Siehe:  https://www.camp-firefox.de/forum/thema/74296-entwicklung-firefox/?postID=1227494#post1227494
    [02.09.2023 09:30]
    -Fix: Visualisierung ausgewählter Tabs (>=FF119)
    [24.10.2023 18:44] 
    - Tabbar-Position [6] (FF119+) 
    - angeheftete Tabs 
    - kleinere Fehler
    [04.03.2024 19:48]
    - angeheftete Tabs -> Fehlerbehebungen  
    [23.08.2024 13:00]
    - Tab-Tooltip ausblenden -> funktioniert wieder
    [01.10.2024 19:00]
    - Fix: Anpassung der Tableiste FF 131
    /////////////////////////////////////////////////////////////////////////////////////*/
    
    
    "use strict";
    
    MultiRowTabs();
    function MultiRowTabs() {
        
        if (!window.gBrowser){
            return;
        }
    
        // ----------------------------
    // --- User-Settings: Start ---
    // ----------------------------
    
    // Position der Tab-Leiste:
    //
    var nTabbarPosition = 2; // [1] Tab-Leiste ist oberhalb aller Symbolleisten
    // [2] Tab-Leiste ist unterhalb aller Symbolleisten, aber über dem Inhaltsbereich
    // [3] Tab-Leiste ist vertikal auf der linken Seite
    // [4] Tab-Leiste ist vertikal auf der linken Seite - Tableiste wird erst angezeigt bei Mausbewegung an den linken Rand (Autohide/Autopopup)
    // [5] Tab-Leiste ist vertikal auf der rechten Seite
    // [6] Tab-Leiste ist unterhalb des Inhaltsbereichs
    
    
    // Tab-Größenangaben
    //
    var nTabWidth = 170; // Breite der einzelnen Tabs in Pixeln
    var nTabHeight = 35; // Höhe der einzelnen Tabs in Pixeln
    var nTabMargin = 1; // Abstand zwischen den Tab-Zeilen in Pixeln
    
    
    // sonstige Einstellungen
    //
    var nTabLines = 7; // Anzahl der sichtbaren Tab-Zeilen, darüber hinaus wird gescrollt <nur bei horizontaler Ausrichtung (Position:[1],[2],[6]) - sonst keine Funktion>
    var bTabScrollbar = true; // [true] Scrollbar für Tab-Leiste anzeigen, [false] Keine Scrollbar für Tab-Leiste anzeigen (Achtung: [false] = kein Scrollen mehr bei 'drag&drop' von Tabs!)
    var bTabTooltips = true; // [true] Tab-Tooltips werden angezeigt, [false] Tab-Tooltips werden nicht angezeigt
    
    
    // Tab-Schließen-Button
    //
    var bTabCloseButton = true; // [true] Tab-Schließen-Button anzeigen, [false] Tab-Schließen-Button verbergen
    var bTabCloseButRounded = false; // [false] quadratische Darstellung, [true] abgerundete Darstellung
    var nTabCloseButTransparency= 0.85; // Transparenzwert des Tab-Schließen-Button in Prozent. Wertebereich: [0]=vollständig durchscheinend bis [1]=vollständig deckend (z.B [0.75])
    var nTabCloseIconNr = 0; // [0] Standard-Icon wird angezeigt
    // [1] rotes Icon mit weißem Kreuz wird angezeigt
    // [2] schwarzes Icon mit weißem Kreuz wird angezeigt
    var nTabCloseButSize = 18; // Höhe und Breite des Tab-Schließen-Buttons in Pixeln
    
    
    // FavIcon
    //
    var nFavIconSize = 16; // Höhe und Breite des 'FavIcons' und der Ladeanimation,[16] = Standard
    
    
    // 'Throbber'-Animation
    //
    var bNewThroberAnimation = true; // [true] Alternative 'Throbber'-Animation auswählen, [false] Standard 'Throbber'-Animation beibehalten
    
    
    // Hintergrundfarbe der Tabs (für einfarbige Darstellung müssen die RGB-Farbwerte 1 und 2 jeweils identisch sein)
    //
    var strTabSelColor1 = "240,152,0"; // RGB-Farbwert1 selektierter Tab
    var strTabSelColor2 = "240,152,0"; // RGB-Farbwert2 selektierter Tab
    var strTabNotSelColor1 = "195,157,116";// RGB-Farbwert1 nicht selektierter Tab
    var strTabNotSelColor2 = "195,157,116";// RGB-Farbwert2 nicht selektierter Tab
    var nTabTransparency = 1; // Transparenzwert des unselektierten Tab Hintergrundes. Wertebereich: [0]=vollständig durchscheinend bis [1]=vollständig deckend (z.B [0.75])
    
    
    // Schriftart und Textdarstellung der Tabs
    //
    var strTabFontName = "Segoe UI"; // Name der Schriftart
    var strTabFontColorSel = "255,255,255";// RGB-Farbwert der Schrift des selektierten Tabs
    var strTabFontColorNotSel = "255,255,255";// RGB-Farbwert der Schrift des nicht selektierten Tabs
    var nTabFontWeight = 600; // Stärke der Schrift: Wertebereich: [100] = sehr dünn bis [900] = sehr dick(bold). [500] = normal
    var nTabFontSize = 12; // Größe/Höhe der Schrift in Pixeln
    var bTabFontTextShadow = true; // [true] Text wird mit Schatteneffekt ausgegeben, [false] Text wird ohne Schatteneffekt ausgegeben. (Effekt nur bei selektierten Tabs!)
    var bMarkUnreadTab = false; // [true] Kursive Schrift für ungelesene Tabs, [false] ungelesene Tabs werden nicht hervorgehoben
    
    
    // Rahmen um einzelne Tabs
    //
    var nTabBorderWidth = 0; // Breite des Tab-Rahmen ([0] = kein sichtbarer Rahmen)
    var nTabBorderRadius = 30; // Radius für abgerundete Ecken des Tabs ([0] = rechteckig, [80] = ideal abgerundet ).
    var strTabBorderColor = "128,128,128";// RGB-Farbwert des Rahmens
    
    
    // Neuer-Tab-Button
    //
    var strNewTabButtonColor = "255,255,255";// RGB-Farbwert des '+'-Zeichens
    
    
    // Hintergrund der Tab-Leiste (für einfarbige Darstellung müssen die RGB-Farbwerte 1 und 2 jeweils identisch sein)
    //
    var strTabBarBgColor1 = "21,21,12"; // RGB-Farbwert1 für Hintergrund der Tab-Leiste
    var strTabBarBgColor2 = "62,75,84"; // RGB-Farbwert2 für Hintergrund der Tab-Leiste
    
    
    
    
    var nTabBarTransparency = 0; // Transparenzwert des Tab-Leisten Hintergrundes. Wertebereich: [0]=vollständig durchscheinend bis [1]=vollständig deckend
    var strTabBarBgImagePath = ""; // Absoluter Dateipfad zu einem gepeicherten Bild (z.B.: "D://Bilder//Firefox//Hintergrund.jpg" )
    // "D://Programme%20(Portable)//Firefox%20Portable//FireFox%20ESR%2091//Profilordner//chrome//image//NavToolbarBackground02.png"
    var bTabBarBgImageRepeat = false; // [true] Bild wird für den gesamten Bereich mehrfach nebeneinander angezeigt, [false] Bild wird nur einmal angezeigt (Position: linke/obere Ecke)
    
    
    // Einstellungen für vertikale Tab-Leiste
    //
    var nVerticalTabbarWidth = 215; // Breite der Vertikalen Tab-Leiste in Pixeln <nur bei vertikaler Ausrichtung (Position:[3],[4],[5]) - sonst keine Funktion>
    var nVerticalAutoPopupHover = 2; // Abstand zum linken Fensterrand in Pixeln, ab der die vertikale Tab-Leiste sichtbar gemacht wird <Position[4] - sonst keine Funktion>
    var nVerticalAutoPopupAnim = 0.5; // Dauer der Animation beim 'Herausschieben' des vertikalen Tab-Leiste in Sekunden ([0] = keine Animation) <Position[4] - sonst keine Funktion>
    
    
    // Einstellungen für Maus-Bedienung
    //
    var bTabWheel = false; // [true]: Tab-Wheel-Selection(=Selektieren des nächsten/vorherigen Tabs mit dem Mausrad) einschalten, [false]: Tab-Wheel-Selection ausschalten
    var bPageScroll = true; // [true]: seitenweises Scrollen, [false]: zeilenweises Scrollen
    var bDblclickOnTabbarNewTab = true; // [true] Doppel-Klick über Tabbar öffnet neuen Tab, [false] Funktion wird nicht ausgeführt
    var bDblclickOnTabReloadTab = true; // [true] Doppel-Klick über Tab lädt diesen neu, [false] Funktion wird nicht ausgeführt
    
    // ----------------------------
    // --- User-Settings: Ende ---
    // ----------------------------
    
            
            
        let strHomepageURL;
        try {
          strHomepageURL = Services.prefs.getCharPref('browser.startup.homepage');
          console.log("homepage: " + strHomepageURL);
        } catch(e) {
            console.log("Error Homepage-String loading...");
        }
            
             
        if( nTabbarPosition < 1 || nTabbarPosition > 6 ) {
            nTabbarPosition = 1;
        }
    	
    	
        // Tab-Leiste ganz unten 
        if( nTabbarPosition == 6 )
        {
                let tabbarBoxBottom = document.createXULElement('vbox');
                tabbarBoxBottom.id = 'tabbarboxbottom';
                tabbarBoxBottom.style.background = '#000000';
            
                document.getElementById("navigator-toolbox").parentNode.insertBefore( tabbarBoxBottom, null);
                //document.getElementById("navigator-toolbox").parentNode.parentNode.insertBefore( tabbarBoxBottom, document.getElementById("browser-bottombox"));
                let tabbar = document.getElementById("TabsToolbar");
                tabbarBoxBottom.appendChild(tabbar);
        }
        
        //Tableiste vertikal
        if(nTabbarPosition == 3 || nTabbarPosition == 5 )
        {
                let nTabbarWidth = nVerticalTabbarWidth;
                
                let tabbarBox = document.createXULElement('vbox');
                tabbarBox.id = 'tabbar-box';
                tabbarBox.style.width = nVerticalTabbarWidth + 'px';
                tabbarBox.style.background = '#000000';
            
                // Platz für Tab-Leiste auf der linken Seite 
                if(nTabbarPosition == 3) {
                    let sidebarBox = document.getElementById('sidebar-box');
                    sidebarBox.parentNode.insertBefore(tabbarBox, sidebarBox);
                }
                // Platz für Tab-Leiste auf der rechten Seite 
                else if( nTabbarPosition == 5) {
                    document.getElementById("browser").insertBefore(tabbarBox,document.getElementById("browser").lastChild.nextSibling);
    				tabbarBox.style.width = '0px';
                }
            
        }
    	
        tabsetting: { 
            let css =` 
                tabs tab {
                    border-left: solid 1px hsla(0,0%,0%,0) !important;
                    border-right: solid 1px hsla(0,0%,0%,0) !important;
                    z-index: 2 !important;
                }
                tabs tab:after,tabs tab:before
                { 
                    display: none !important; 
                }
                
        
            `;
    
            let sss = Cc['@mozilla.org/content/style-sheet-service;1'].getService(Ci.nsIStyleSheetService);
            let uri = makeURI('data:text/css;charset=UTF=8,' + encodeURIComponent(css));
            sss.loadAndRegisterSheet(uri, sss.AUTHOR_SHEET);
        }
    
            
        //var nTabLineHeight = nTabHeight+2*nTabMargin;
        nTabMargin *= 2;
        var nTabLineHeight = nTabHeight+nTabMargin;
        
        //console.log("Margin: " + nTabMargin );
        
        multiLineTabSetup: {
    		
            
    		let service,uri,cssIn,cssOut;
            
            // ---
            // CSS-Icon-Settings 
            // ---
            cssIn =`
                
         
                /* Tab-Schließen-Button auf allen Tabs anzeigen oder verbergen */
                .tabbrowser-tab:not([pinned]) .tab-close-button, 
                .tabbrowser-tab:not([pinned]) .tab-close-button:not([selected="true"]) {
                    display: __strTabCloseVisible__ !important;
                }
            
                /* Icon für Tab-Schließen-Button anzeigen */
                .tabbrowser-tab:not([pinned]) .close-icon {
                    __CloseIcon1DisableStart__ list-style-image: url("") !important; __CloseIcon1DisableEnd__
                    __CloseIcon2DisableStart__ list-style-image: url("") !important; __CloseIcon2DisableEnd__
    
                    
                    border-radius: __nBorderRadius__px !important;
                    padding: 3px !important;
                    width: __nTabCloseButSize__px !important;
                    height: __nTabCloseButSize__px !important;
                    filter: opacity(__nTabCloseButTransparency__%) drop-shadow(-1px -1px 1px rgba(0,0,0,0.15)) drop-shadow(0px -1px 1px rgba(255,255,255,0.15)) !important; 
                }
                
                /* Neuer Tab Button */
                #TabsToolbar #tabs-newtab-button > image {
                    min-height: __nNewTabButtonSize__px !important;
                    max-height: __nNewTabButtonSize__px !important;
                    min-width: __nNewTabButtonSize__px !important;
                    max-width: __nNewTabButtonSize__px !important;
                    margin-top: -1px !important;
                    margin-left: -3px !important;
                    padding: 2px !important;
                    fill: rgba(__strNewTabButtonColor__,1) !important;
                }
                
                
                /* Throbber Icon ändern */
                __NewThrowberDisableStart__
                .tab-throbber[busy]::before,
                .tab-throbber[progress]::before {
                  width: 16px !important;
                  height: 16px !important;
                  animation: unset !important;
                  -moz-context-properties: unset !important;
                  fill: unset !important;
                  opacity: unset !important;
                }
                .tab-throbber[busy]::before {
                  background-image: url("") !important;
                }/*
                .tab-throbber-fallback[busy] {
                  list-style-image: url("") !important;
                }*/
                .tab-throbber[progress]::before{
                  background-image: url("") !important;
                }/*
                .tab-throbber-fallback[progress] {
                  list-style-image: url("") !important;
                }*/
                __NewThrowberDisableEnd__
            
            `;
            
            cssOut = cssIn;
            
            if(bTabCloseButton) {
                cssOut = cssOut.replace("__strTabCloseVisible__", "initial");
            }    
            else {
                cssOut = cssOut.replace("__strTabCloseVisible__", "none");
                nTabCloseIconNr = 0;
            }
            
            if( nTabCloseIconNr == 1 ) {
                cssOut = cssOut.replace(/__CloseIcon1DisableStart__/g, ' ');
                cssOut = cssOut.replace(/__CloseIcon1DisableEnd__/g, ' ');
                cssOut = cssOut.replace(/__CloseIcon2DisableStart__/g, '/*');
                cssOut = cssOut.replace(/__CloseIcon2DisableEnd__/g, '*/');
            }        
            else if( nTabCloseIconNr == 2 ) {
                cssOut = cssOut.replace(/__CloseIcon1DisableStart__/g, '/*');
                cssOut = cssOut.replace(/__CloseIcon1DisableEnd__/g, '*/');
                cssOut = cssOut.replace(/__CloseIcon2DisableStart__/g, ' ');
                cssOut = cssOut.replace(/__CloseIcon2DisableEnd__/g, ' ');
            }
            else
            {
                cssOut = cssOut.replace(/__CloseIcon1DisableStart__/g, '/*');
                cssOut = cssOut.replace(/__CloseIcon1DisableEnd__/g, '*/');
                cssOut = cssOut.replace(/__CloseIcon2DisableStart__/g, '/*');
                cssOut = cssOut.replace(/__CloseIcon2DisableEnd__/g, '*/');
                
            }
            
            if(bTabCloseButRounded)
                cssOut = cssOut.replace(/__nBorderRadius__/g, 20);
            else
                cssOut = cssOut.replace(/__nBorderRadius__/g, 0);
            
            cssOut = cssOut.replace(/__nTabCloseButTransparency__/g, nTabCloseButTransparency*100);
            cssOut = cssOut.replace(/__nTabCloseButSize__/g, nTabCloseButSize);
            
            
            cssOut = cssOut.replace(/__nNewTabButtonSize__/g, nTabHeight);
            cssOut = cssOut.replace(/__strNewTabButtonColor__/g, strNewTabButtonColor);
            
            if(bNewThroberAnimation)
            {
                cssOut = cssOut.replace(/__NewThrowberDisableStart__/g, ' ');
                cssOut = cssOut.replace(/__NewThrowberDisableEnd__/g, ' ');
            }
            else
            {
                cssOut = cssOut.replace(/__NewThrowberDisableStart__/g, '/*');
                cssOut = cssOut.replace(/__NewThrowberDisableEnd__/g, '*/');
            }
     
            //console.log("cssOut1: " + cssOut );
            
            service = Cc['@mozilla.org/content/style-sheet-service;1'].getService(Ci.nsIStyleSheetService);
            uri = makeURI('data:text/css;charset=UTF=8,' + encodeURIComponent(cssOut));
            service.loadAndRegisterSheet(uri, service.AUTHOR_SHEET);
           
    		
            cssIn =`
    		  /* Scrollbars -> "no-drag"*/
              scrollbar, scrollcorner, scrollbar thumb, scrollbar scrollbarbutton {
                -moz-window-dragging: no-drag !important;
            }
    		
    		/* Tabs */
    		scrollbox[smoothscroll="true"] > slot {
    			display: contents !important;
    		}
    		
    		`;
            
            service = Cc['@mozilla.org/content/style-sheet-service;1'].getService(Ci.nsIStyleSheetService);
            uri = makeURI('data:text/css;charset=UTF=8,' + encodeURIComponent(cssIn));
            service.loadAndRegisterSheet(uri, service.AGENT_SHEET);
    
            
    
    
            cssIn =`
    
            :root[tabsintitlebar][sizemode="maximized"]  #titlebar,
            :root[tabsintitlebar][sizemode="normal"]  #titlebar {
                appearance: none !important;
            }
    
            .tabbrowser-tab {
                --tab-label-mask-size: 1em;
            }
            
            #tabbrowser-tabs[haspinnedtabs]:not([positionpinnedtabs]) > #tabbrowser-arrowscrollbox >
            .tabbrowser-tab:nth-child(1 of :not([pinned], [hidden])) {
                margin-inline-start: -1px !important; 
            }
            
    		#tab-preview-panel { 
                strTabTooltips !important;
            }
    				
            #TabsToolbar > .titlebar-buttonbox-container,
            #main-window[sizemode="fullscreen"]  #window-controls {
                display: none !important;
            }    
                
            #TabsToolbar { 
                /* Hintergrund der Tab-Leiste setzen */
                __strTabBarBackground__
            }
            
                    
                            
            /* Tab-Höhe */
            .tabbrowser-tab, .tab-stack, .tab-background {
                min-height: nTabHeightpx !important;
                max-height: nTabHeightpx !important;
                
                margin-top: 0px !important;
                margin-bottom: nTabMarginpx !important;
                
                margin-left: -1px !important;
                margin-right: 0px !important;
            }
    
    
            #tabbrowser-tabs .tab-label:not([fokus]){
                opacity: 1!important;
            }
    
    	
    		tabs > arrowscrollbox::part(scrollbox)    {
    			overflow-x: hidden !important;
    			overflow-y: strScrollbar !important;
    		}
    
    		.tabbrowser-tab:not([pinned]) {
    			flex-grow: 0 !important;
    			min-width: nTabWidthpx !important;             
    		}
    	    
        
            /* Schriftart/Schriftgröße ändern */
            .tabbrowser-tab .tab-label {
                text-shadow: none !important; 
                color: rgb(strTabFontColorNotSel) !important; 
                font-weight: nTabFontWeight !important;
                font-size:   nTabFontSizepx !important;
                font-family: "strTabFontName" !important;
                font-style: normal; 
            }
    
            .tabbrowser-tab[selected] .tab-label,
            .tabbrowser-tab[multiselected] .tab-label {
                text-shadow: __strTextShadow__ !important; ;
                color: rgb(strTabFontColorSel) !important; 
                font-weight: nTabFontWeight !important;
                font-size:   nTabFontSizepx !important; 
                font-family: "strTabFontName" !important; 
                font-style: normal; 
            }
            
            /*Ungelesene Tabs werden markiert */
            .tabbrowser-tab[pending] .tab-label, .tabbrowser-tab[notselectedsinceload="true"] {
                font-style: __strMarkUnreadTab__ !important;
            }
            
    
            #TabsToolbar .tabbrowser-tab .tab-background
            {
                border-radius: nTabBorderRadiuspx !important; 
                border: nTabBorderWidthpx solid rgba(strTabBorderColor,0.66) !important;
            }
    
            
            /* Tab-Hintergrund  */
            /*--- selektiert ---*/
            .tab-background[selected]{
                background-image:  linear-gradient( rgba(strTabSelColor1,1), rgba(strTabSelColor2,1) ), none !important;
                filter: drop-shadow(2px 2px 2px rgba(0,0,0,0.5)) drop-shadow(-2px 2px 2px rgba(0,0,0,0.5)) !important; 
                border-radius: nTabBorderRadiuspx !important; 
            }
            /*--- hover: nicht selektiert ---*/
            .tabbrowser-tab:hover > .tab-stack > .tab-background:not([selected]) {
                filter: brightness(130%) contrast(110%) drop-shadow(1px 1px 1px rgba(0,0,0,0.5)) drop-shadow(-1px 1px 1px rgba(0,0,0,0.5)) !important; 
                border-radius: nTabBorderRadiuspx !important;    
            }
            .tabbrowser-tab:hover:not([selected]) :is(.tab-label,.tab-icon-stack) {
                filter: drop-shadow( 0px 0px 2px #AAAAAA) brightness(115%) !important; 
            }
            /*--- hover: Multi selektiert ---*/
            .tabbrowser-tab:hover > .tab-stack > .tab-background[multiselected]:not([selected]) {
                filter: brightness(120%) contrast(100%) drop-shadow(1px 1px 1px rgba(0,0,0,0.5)) drop-shadow(-1px 1px 1px rgba(0,0,0,0.5)) !important; 
                border-radius: nTabBorderRadiuspx !important;    
            }
            /*--- nicht selektiert ---*/
            .tab-background:not([selected]) {
                background-image:  linear-gradient( rgba(strTabNotSelColor1,nTabTransparency), rgba(strTabNotSelColor2,nTabTransparency) ),  none !important; 
                filter: brightness(115%) contrast(90%) drop-shadow(1px 1px 1px rgba(0,0,0,0.5)) drop-shadow(-1px 1px 1px rgba(0,0,0,0.5)) !important; 
                border-radius: nTabBorderRadiuspx !important; 
            }
            /*--- Multi selektiert ---*/
            .tab-background[multiselected]:not([selected]) {
                background-image:  linear-gradient( rgba(strTabSelColor1,1), rgba(strTabSelColor2,1) ), none !important;
                filter: brightness(130%) saturate(50%) drop-shadow(1px 1px 1px rgba(0,0,0,0.5)) drop-shadow(-1px 1px 1px rgba(0,0,0,0.5)) !important; 
                border-radius: nTabBorderRadiuspx !important; 
            }
        
            .tab-sharing-icon-overlay, .tab-icon-overlay:not([pinned]), .tab-icon-overlay[soundplaying] {
                transform:  scale(1.5) !important;  
            }
            
            .tabbrowser-tab .tab-label 
            {
                margin-top: -2px !important;
            }
                
            
            .tab-close-button
            {
                margin-top: -2px !important;
            }
            
            .tab-throbber, .tab-throbber-tabslist, .tab-icon-pending, .tab-icon-image, .tab-sharing-icon-overlay {
                height:     nFavIconSizepx !important;
                width:         nFavIconSizepx !important;
                fill: rgba(255,255,255,0.8) !important;
                margin-top: -2px !important;
            }    
            
            #tabbrowser-tabs, #tabbrowser-arrowscrollbox, #tabbrowser-tabs[positionpinnedtabs] > #tabbrowser-arrowscrollbox > .tabbrowser-tab[pinned] {
                min-height: 0 !important; 
            }        
    
            #tabbrowser-tabs {
                appearance: none !important;
            }
            
            .tabbrowser-tab:is([visuallyselected], [multiselected]) > .tab-stack > .tab-background:-moz-lwtheme {
                box-shadow: none !important; 
            }
             
            `;
    
                    
            // --- CSS-Parameter ersetzen ---
            cssOut = cssIn.replace(/nTabHeight/g, nTabHeight);
            cssOut = cssOut.replace(/nTabMargin/g, nTabMargin);
            cssOut = cssOut.replace(/nTabWidth/g, nTabWidth);
            
                    
            if(bTabScrollbar) {
                cssOut = cssOut.replace("strScrollbar", "auto");
            }
            else {
                cssOut = cssOut.replace("strScrollbar", "hidden");
            }
    
    
    		if(!bTabTooltips) {
    		   cssOut = cssOut.replace("strTabTooltips", "display: none");
    		}
    
    		 
            cssOut = cssOut.replace(/strTabSelColor1/g, strTabSelColor1);
            cssOut = cssOut.replace(/strTabSelColor2/g, strTabSelColor2);
            cssOut = cssOut.replace(/strTabNotSelColor1/g, strTabNotSelColor1);
            cssOut = cssOut.replace(/strTabNotSelColor2/g, strTabNotSelColor2);
            cssOut = cssOut.replace(/nTabBorderRadius/g, nTabBorderRadius);
            cssOut = cssOut.replace(/nTabBorderWidth/g, nTabBorderWidth);
            cssOut = cssOut.replace(/strTabBorderColor/g, strTabBorderColor);
            cssOut = cssOut.replace(/nTabTransparency/g, nTabTransparency);
            
            cssOut = cssOut.replace(/strTabFontName/g, strTabFontName);
            cssOut = cssOut.replace(/strTabFontColorSel/g, strTabFontColorSel);
            cssOut = cssOut.replace(/strTabFontColorNotSel/g, strTabFontColorNotSel);
            cssOut = cssOut.replace(/nTabFontSize/g, nTabFontSize);
            cssOut = cssOut.replace(/nTabFontWeight/g, nTabFontWeight);
            
            if (bTabFontTextShadow)
                cssOut = cssOut.replace(/__strTextShadow__/g, "1px 1px 0px #000000");
            else
                cssOut = cssOut.replace(/__strTextShadow__/g, "none");
            
            
            if( bMarkUnreadTab )
              cssOut = cssOut.replace(/__strMarkUnreadTab__/g, "italic");
            else
              cssOut = cssOut.replace(/__strMarkUnreadTab__/g, "normal");
            
    		            
            let strTabBarBackgroundOut = "";
            if( strTabBarBgImagePath ) {
                if( bTabBarBgImageRepeat ) {
                    strTabBarBackgroundOut = "background: #000000 url(\"file:" + strTabBarBgImagePath + "\") repeat !important;";
                }
                else {
                    strTabBarBackgroundOut = "background: #000000 url(\"file:" + strTabBarBgImagePath + "\") no-repeat !important;";
                }
            }
            else {
                 strTabBarBackgroundOut = "background-image: linear-gradient( rgba(" + strTabBarBgColor1 + "," + nTabBarTransparency +"), rgba(" + strTabBarBgColor2 + "," + nTabBarTransparency + ") ) !important;";
            }
                            
            cssOut = cssOut.replace(/__strTabBarBackground__/g, strTabBarBackgroundOut);
            
            cssOut = cssOut.replace(/nFavIconSize/g, nFavIconSize);
                            
            //console.log("CSSOut: " + cssOut );
    
         
            service = Cc['@mozilla.org/content/style-sheet-service;1'].getService(Ci.nsIStyleSheetService);
            uri = makeURI('data:text/css;charset=UTF=8,' + encodeURIComponent(cssOut));
            service.loadAndRegisterSheet(uri, service.AUTHOR_SHEET);
                    
            let tabsScrollbox     = document.getElementById('tabbrowser-arrowscrollbox').scrollbox;
            
            tabsScrollbox.style.minHeight      =  nTabLineHeight +'px';
            tabsScrollbox.style.maxHeight      =  nTabLineHeight*nTabLines +'px';
            /*
            console.log("tabsScrollbox: " + tabsScrollbox );
    		console.log("tabsScrollbox.style.minHeight: " + tabsScrollbox.style.minHeight ); 
    		console.log("tabsScrollbox.style.maxHeight: " + tabsScrollbox.style.maxHeight );
    		*/
            
        }
    
     
        if( nTabbarPosition >= 2 && nTabbarPosition <= 5 ) {
            let tabbar = document.getElementById("TabsToolbar");
            tabbar.parentNode.parentNode.appendChild(tabbar);
        }
    
        
        if( nTabbarPosition >= 3 && nTabbarPosition <= 5 )
        {
            let cssIn =`
            
            .StyleShowingTabsToolbar {
                transition:                margin-left nVerticalAutoPopupAnims !important; 
                display:                   flex !important;
                position:                  absolute !important;
                opacity:                   1;
                margin-left:               0px;
                z-index:                   100 !important;
                min-width:                 nVerticalTabbarWidthpx !important;
                filter:                    drop-shadow(4px 3px 2px rgba(0,0,0,0.33)) !important; 
            }
            
                    
            .StyleHidingTabsToolbar {
                display:                   flex !important;
                position:                  absolute !important;
                opacity:                   0;
                margin-left:               calc( (nVerticalTabbarWidthpx - nVerticalAutoPopupHoverpx) * -1 ); 
                z-index:                   100 !important;
                min-width:                 nVerticalTabbarWidthpx !important;
            }
      
            .toolbar-items[align="end"] {
                display:initial !important;
            }
      
            tabs > arrowscrollbox { 
                display:  flex !important;
                position: absolute !important;
                min-width: nVerticalTabbarWidthpx !important;
            }
        
            `;
        
            let cssOut;
            
            if ( nTabbarPosition != 4 ) {
                nVerticalAutoPopupAnim = 0;
            }        
            
                            
            cssOut = cssIn.replace(/nVerticalTabbarWidth/g, nVerticalTabbarWidth);
            cssOut = cssOut.replace(/nVerticalAutoPopupHover/g, nVerticalAutoPopupHover);
            cssOut = cssOut.replace(/nVerticalAutoPopupAnim/g, nVerticalAutoPopupAnim);
            
                            
            let sss = Cc['@mozilla.org/content/style-sheet-service;1'].getService(Ci.nsIStyleSheetService);
            let uri = makeURI('data:text/css;charset=UTF=8,' + encodeURIComponent(cssOut));
            sss.loadAndRegisterSheet(uri, sss.AUTHOR_SHEET);
        
    
            
            let tabsToolbar =  document.getElementById('TabsToolbar');
            
            if ( nTabbarPosition == 4 )
            {
                tabsToolbar.classList.add('StyleHidingTabsToolbar');
            }
            else
            {
                tabsToolbar.classList.add('StyleShowingTabsToolbar');
            }
            
        }
    
    //------------------------------------------------------------------------------------------
        
        var tabsToolbar     = document.getElementById('TabsToolbar');
        var tabbrowsertabs     = document.getElementById('tabbrowser-tabs');
        var tabsscrollbox    = document.getElementById('tabbrowser-arrowscrollbox');
        var ScrollBox = tabsscrollbox.scrollbox;    
    
        var bMouseEnter = false;
        var bToolbarLocked = false;
    
        // ----------------------------------
        // Load-Event:  
        // ----------------------------------
        function onReady() 
        {    
            console.log("OnReady");
    
            
            let cssElements =`
            
                #tabbrowser-tabs {
                    --tab-overflow-pinned-tabs-width: 0px !important;
                }
                
                #alltabs-button,
                hbox.titlebar-spacer,
                #tabbrowser-arrowscrollbox::part(scrollbutton-up), 
                #tabbrowser-arrowscrollbox::part(scrollbutton-down),
                #tabbrowser-arrowscrollbox::part(overflow-start-indicator), 
                #tabbrowser-arrowscrollbox::part(overflow-end-indicator) {
                    display: none !important;
                }
                			
                tabs > arrowscrollbox::part(scrollbox)    {
                    flex-wrap: wrap !important; 
                }
            `;
            
            let service = Cc['@mozilla.org/content/style-sheet-service;1'].getService(Ci.nsIStyleSheetService);
            let ur         = makeURI('data:text/css;charset=UTF=8,' + encodeURIComponent(cssElements));
            service.loadAndRegisterSheet(ur, service.AUTHOR_SHEET);
            
    
            gBrowser.selectedTab.scrollIntoView(); 
        }    
        
        
        if (window.readyState !== "loading") {
            setTimeout(onReady,500); 
        }
        else 
        {
            window.addEventListener("DOMContentLoaded", onReady );
        }
        
        // ----------------------------------
        // ResizeObserver / Client
        // ----------------------------------
        var resizeClientObserver=null;
        
        let navigatorToolbox = document.getElementById('navigator-toolbox');
        let mainWindow = document.getElementById('main-window');
        
        if( nTabbarPosition >= 3 && nTabbarPosition <= 5 )
        {
            resizeClientObserver = new ResizeObserver(function(entries) {
                for (let entry of entries) {
                    
                    tabsToolbar.style.minHeight = tabsToolbar.style.maxHeight = entry.contentRect.height + 'px';
                    ScrollBox.style.maxHeight = entry.contentRect.height + 'px';
                    
                    tabsToolbar.style.top = navigatorToolbox.clientHeight + 'px';
                                    
                    if(mainWindow.getAttribute('inFullscreen') == 'true' ) {
                        if (navigatorToolbox.style.marginTop != "") {
                            tabsToolbar.style.top = '0px';
                        }
                    }
                    
                    if( nTabbarPosition == 5 )    {
                        tabsToolbar.style.marginLeft = (entry.contentRect.width - nVerticalTabbarWidth) + 'px';
                    }
                }
            });
                    
            resizeClientObserver.observe(document.getElementById("browser"));            
        }  
    
    
        // ----------------------------------
        // ToggleMenuObserver
        // ----------------------------------
        if( nTabbarPosition == 2 || nTabbarPosition == 6) {
            let observerToggleMenu=null;
            let configObserver=null;
            
            let bTabsintitlebar = document.querySelector('html#main-window').getAttribute('tabsintitlebar');
            let titlebar = document.querySelector('#navigator-toolbox>vbox#titlebar');
            let targetMenubar = document.getElementById('toolbar-menubar');
    
            const callback = (mutationList, observer) => {
                for (const mutation of mutationList) {
                    if (mutation.type === 'attributes') {
                        let bAutohide = targetMenubar.getAttribute('autohide');
                        let bInacive = targetMenubar.getAttribute('inactive');
                        if(bInactive == 'true')    {
                            titlebar.style.display = "none";
                            console.log("titlebar.style.display = none");
                        }
                        else {
                            titlebar.style.display = "initial";
                            console.log("titlebar.style.display = initial");
                            
                        }
                    }
                }
            }
        
            observerToggleMenu = new MutationObserver(callback);
            configObserver = { attributes: true, attributeFilter: ['autohide','inactive'] };
            
            observerToggleMenu.observe(targetMenubar, configObserver);    
        }
    
        // ----------------------------------
        // 'Middleclick' on Tab -> Close Tab
        // ----------------------------------
        gBrowser.tabContainer.addEventListener('click', function(event) 
        {
            if (event.button == 1)
            {
                let element = event.target.parentNode;
                while(element)
                {
                    if (element.localName == 'tab') 
                    {
                        gBrowser.removeTab(element, {animate: false});
                        event.preventDefault();
                        event.stopPropagation();    
                        return;
                    }
                    
                    element = element.parentNode;
                }
                
            };
        
        }, true);
    
        // ----------------------------------
        // 'Middleclick' on TabsToolbar -> Add Tab
        // ----------------------------------
        tabsToolbar.addEventListener('click', function(event)
        {
            if (event.button == 1)
            {
                if(event.target.parentNode.id == "TabsToolbar") 
                { 
                   event.target.ownerGlobal.openTrustedLinkIn(strHomepageURL,"tab");
                   return;
                }
            };
        }, true);
    
        
        // ----------------------------------
        // 'Doubleclick' on TabsToolbar -> Add Tab
        // ----------------------------------
        tabsToolbar.addEventListener('dblclick', function(event)
        {
            if(!bDblclickOnTabbarNewTab)
                return;
            
            if (event.button == 0)
            {  
                    
                if(event.target.parentNode.id == "TabsToolbar") 
                {
                   event.target.ownerGlobal.openTrustedLinkIn(strHomepageURL,"tab");
                   
                   event.preventDefault();
                   event.stopPropagation();    
                   return;
                }
            };
        }, true);
            
            
            
        // ----------------------------------
        // 'Doubleclick' on TabsContainer -> Add Tab
        // ----------------------------------
        gBrowser.tabContainer.addEventListener('dblclick', function(event)
        {
            if(!bDblclickOnTabbarNewTab)
                return;
            
            if (event.button == 0)
            {  
                   let element = event.target.parentNode;
                if (element == gBrowser.tabContainer ) 
                {
                   event.target.ownerGlobal.openTrustedLinkIn(strHomepageURL,"tab");
        
                   event.preventDefault();
                   event.stopPropagation();    
                   return;
                }
            };
        }, true);
        
        
        // ----------------------------------
        // 'Doubleclick' on Tab -> Reload Tab
        // ----------------------------------
        gBrowser.tabContainer.addEventListener('dblclick', function(event) 
        {
            if(!bDblclickOnTabReloadTab)
                return;
            
            if (event.button == 0)
            {
                let element = event.target.parentNode;
                while (element) 
                {
                    if (element.localName == 'tab') 
                    {
                        element.linkedBrowser.reload();
                        
                        return;
                    }
                     
                    element = element.parentNode;
                }
            }
        }, true);
        
        // ----------------------------------
        // 'mouseenter'
        // ----------------------------------
        tabsToolbar.addEventListener('mouseenter', event => {
            if( nTabbarPosition == 4  ) 
            {
                if(!bMouseEnter)
                {
                    bMouseEnter = true;
                    
                    tabsToolbar.classList.add('StyleShowingTabsToolbar');    
                    tabsToolbar.classList.remove('StyleHidingTabsToolbar');
                    
                }
            }
        }, true);
        
        // ----------------------------------
        // 'mouseleave'
        // ----------------------------------
        tabsToolbar.addEventListener('mouseleave', event => {
            if( nTabbarPosition == 4 ) 
            {    
                if(bMouseEnter)
                {      
                                
                    if( event.clientX >= 0 &&
                        event.offsetY > tabsToolbar.clientTop  &&
                        event.offsetX < tabsToolbar.clientWidth &&
                        event.offsetY < tabsToolbar.clientHeight )
                    {
                        return;
                    }
            
                    event.preventDefault();
                    event.stopPropagation();
                    
                    
                    tabsToolbar.classList.add('StyleHidingTabsToolbar');
                    tabsToolbar.classList.remove('StyleShowingTabsToolbar');
                    
    
                    bMouseEnter = false;
                }
            }                
        }, false);
    
    
        
        // ...  
        // TabSelect-Event:  
        // ...
        gBrowser.tabContainer.addEventListener("TabSelect", function(event) {
                    
            let bScroll    = false;
            let bScrollTop = true;
                    
            let scrollBoxY1     = event.target.parentElement.scrollbox.screenY;
            let scrollBoxHeight = event.target.parentElement.scrollbox.clientHeight;
            let scrollBoxY2     = scrollBoxY1+scrollBoxHeight;
            
            let TabSelY1     = event.target.screenY;
            let TabSelHeight = event.target.clientHeight;
            let TabSelY2     = TabSelY1+TabSelHeight;
            
            
            
            if( TabSelY2 > scrollBoxY2 )
            {
                bScroll = true;
                bScrollTop = false;
            }
            if( TabSelY1 < scrollBoxY1 ) 
            {
                bScroll = true;
                bScrollTop = true;
            }
            
            if( bScroll )
            {
                setTimeout(function() 
                {
                    event.target.scrollIntoView(bScrollTop);
                    //gBrowser.selectedTab.scrollIntoView(); 
                    //console.log("TabSelect_IntoView:" + bScrollTop );    
                }, 0);
            }
            
           //console.log("TabSelect:" + bScroll );    
            
        }, true);
          
        
          
          
        // ...  
        // Drag-Event: Start  
        // ...
        gBrowser.tabContainer.addEventListener("dragstart",  function(event) {
            //console.log("dragstart..." );    
            if(nTabLines==1 && ( nTabbarPosition == 1 || nTabbarPosition == 2 || nTabbarPosition == 6 )) {
                let tabsScrollbox  = document.getElementById('tabbrowser-arrowscrollbox').scrollbox;
                tabsScrollbox.style.maxHeight      =  nTabLineHeight*3 +'px';
                event.target.scrollIntoView(false);
            }
        }, false);
    
        // ...  
        // Drag-Event: Ende  
        // ...
        gBrowser.tabContainer.addEventListener("dragend",  function(event) {
            //console.log("dragend..." );    
            if(nTabLines==1 && ( nTabbarPosition == 1 || nTabbarPosition == 2 || nTabbarPosition == 6 )) {
                let tabsScrollbox  = document.getElementById('tabbrowser-arrowscrollbox').scrollbox;
                tabsScrollbox.style.maxHeight      =  nTabLineHeight +'px';
                event.target.scrollIntoView(false);
            }
        }, false);
        
        
        // ...  
        // Wheel-Event:  
        // ...
        let tabsScrollbox  = document.getElementById('tabbrowser-arrowscrollbox').scrollbox;
        tabsScrollbox.addEventListener("wheel", function(event) 
        {
            event.preventDefault();
            event.stopPropagation();
            
                
            let scrollUp        = true;
            let wrap            = false;
            let scrollBoxY1     = gBrowser.tabContainer._animateElement.scrollbox.scrollTop; 
            let scrollHeight;
            
            if(bPageScroll)
                {scrollHeight  = gBrowser.tabContainer._animateElement.scrollbox.clientHeight;}
            else            
                {scrollHeight  = nTabLineHeight;}
            
            let dir = (scrollUp ? 1 : -1) * Math.sign(event.deltaY);
            
            let bLastScrollLine = false; 
            
            if( gBrowser.tabContainer._animateElement.scrollbox.scrollTopMax == gBrowser.tabContainer._animateElement.scrollbox.scrollTop)
                {
                    bLastScrollLine = true;
                }        
            
    
            if( !bTabWheel || event.ctrlKey || event.originalTarget.localName == "thumb"  || event.originalTarget.localName == "slider" || event.originalTarget.localName == "scrollbarbutton" ) 
            {
                  setTimeout(function()
                {
                    let scrollBoxMod = scrollBoxY1%scrollHeight;
                    
                    if( scrollBoxMod > 0 )
                    {
                        if( dir == -1 )
                        {
                            scrollBoxY1 -= scrollBoxMod;
                            if(scrollBoxMod < nTabLineHeight && !bLastScrollLine) { scrollBoxY1 -= scrollHeight; }
                    
                        }
                        else
                        {
                            scrollBoxY1 += (scrollHeight-(scrollBoxMod));
                            if(scrollHeight-(scrollBoxMod) < nTabLineHeight) { scrollBoxY1 += scrollHeight; }
                            
                        }
                    }
                    else
                    {
                        if( dir == -1 )
                        {
                            scrollBoxY1 -= scrollHeight;
                        }
                        else
                        {
                            scrollBoxY1 += scrollHeight;
                        }
                    }
                    
                    gBrowser.tabContainer._animateElement.scrollbox.scrollTo({ top: scrollBoxY1, left: 0, behavior: 'auto'}); 
                }, 20);
            }
            
    
            if( bTabWheel && !event.ctrlKey )
            {    
                setTimeout(function()
                {
                    if( event.originalTarget.localName != "slider" && 
                        event.originalTarget.localName != "thumb"  &&
                        event.originalTarget.localName != "scrollbarbutton" )
                    {
                        gBrowser.tabContainer.advanceSelectedTab(dir, wrap);
                        if( (gBrowser.tabContainer._firstTab == gBrowser.selectedTab) || 
                            (gBrowser.tabContainer._lastTab  == gBrowser.selectedTab)     )
                            {
                                gBrowser.selectedTab.scrollIntoView(); 
                            }
            
                    }    
                }, 50);
            }
    
    
        }, false);
            
    
    //-------------------------------------------------------------------------------------------
     
        gBrowser.tabContainer.clearDropIndicator = function() {
            var tabs = this.allTabs;
            for (let i = 0, len = tabs.length; i < len; i++) {
                tabs[i].style.removeProperty("border-left-color");
                tabs[i].style.removeProperty("border-right-color");
            }
        }
        gBrowser.tabContainer.addEventListener("dragleave", function(event) {  this.clearDropIndicator(event); }, true);
    
    
    
        gBrowser.tabContainer.on_dragover = function(event) {
            this.clearDropIndicator();
            var effects = this.getDropEffectForTabDrag(event);
            var ind = this._tabDropIndicator;
            if (effects == "" || effects == "none") {
                ind.hidden = true;
                return;
            }
            event.preventDefault();
            event.stopPropagation();
            if (effects == "link") {
                let tab = this._getDragTargetTab(event, true);
                if (tab) {
                    if (!this._dragTime) {
                        this._dragTime = Date.now();
                    }
                    if (Date.now() >= this._dragTime + this._dragOverDelay) {
                        this.selectedItem = tab;
                    }
                    ind.hidden = true;
                    return;
                }
            }
            let newIndex = this._getDropIndex(event, effects == "link");
            let children = this.allTabs;
            if (newIndex == children.length) {
                children[newIndex - 1].style.setProperty("border-right-color","red","important");
            } else {
                children[newIndex].style.setProperty("border-left-color","red","important");
            }
        }
    
        gBrowser.tabContainer.on_drop = function(event) {
            this.clearDropIndicator();
            var dt = event.dataTransfer;
            var dropEffect = dt.dropEffect;
            var draggedTab;
            let movingTabs;
            if (dt.mozTypesAt(0)[0] == TAB_DROP_TYPE) {
                // tab copy or move
                draggedTab = dt.mozGetDataAt(TAB_DROP_TYPE, 0);
                // not our drop then
                if (!draggedTab) {
                    return;
                }
                movingTabs = draggedTab._dragData.movingTabs;
                draggedTab.container._finishGroupSelectedTabs(draggedTab);
            }
            this._tabDropIndicator.hidden = true;
            event.stopPropagation();
            if (draggedTab && dropEffect == "copy") {
                // copy the dropped tab (wherever it's from)
                let newIndex = this._getDropIndex(event, false);
                let draggedTabCopy;
                for (let tab of movingTabs) {
                    let newTab = gBrowser.duplicateTab(tab);
                    gBrowser.moveTabTo(newTab, newIndex++);
                    if (tab == draggedTab) {
                        draggedTabCopy = newTab;
                    }
                }
                if (draggedTab.container != this || event.shiftKey) {
                    this.selectedItem = draggedTabCopy;
                }
            } else if (draggedTab && draggedTab.container == this) {
                let oldTranslateX = Math.round(draggedTab._dragData.translateX);
                let tabWidth = Math.round(draggedTab._dragData.tabWidth);
                let translateOffset = oldTranslateX % tabWidth;
                let newTranslateX = oldTranslateX - translateOffset;
                if (oldTranslateX > 0 && translateOffset > tabWidth / 2) {
                    newTranslateX += tabWidth;
                } else if (oldTranslateX < 0 && -translateOffset > tabWidth / 2) {
                    newTranslateX -= tabWidth;
                }
                let dropIndex = this._getDropIndex(event, false);
                //  "animDropIndex" in draggedTab._dragData &&
                //  draggedTab._dragData.animDropIndex;
                let incrementDropIndex = true;
                if (dropIndex && dropIndex > movingTabs[0]._tPos) {
                    dropIndex--;
                    incrementDropIndex = false;
                }
                let animate = gBrowser.animationsEnabled;
                if (oldTranslateX && oldTranslateX != newTranslateX && animate) {
                    for (let tab of movingTabs) {
                        tab.setAttribute("tabdrop-samewindow", "true");
                        tab.style.transform = "translateX(" + newTranslateX + "px)";
                        let onTransitionEnd = transitionendEvent => {
                            if (
                                transitionendEvent.propertyName != "transform" ||
                                transitionendEvent.originalTarget != tab
                            ) {
                                return;
                            }
                            tab.removeEventListener("transitionend", onTransitionEnd);
                            tab.removeAttribute("tabdrop-samewindow");
                            this._finishAnimateTabMove();
                            if (dropIndex !== false) {
                                gBrowser.moveTabTo(tab, dropIndex);
                                if (incrementDropIndex) {
                                    dropIndex++;
                                }
                            }
                            gBrowser.syncThrobberAnimations(tab);
                        };
                        tab.addEventListener("transitionend", onTransitionEnd);
                    }
                } else {
                    this._finishAnimateTabMove();
                    if (dropIndex !== false) {
                        for (let tab of movingTabs) {
                            gBrowser.moveTabTo(tab, dropIndex);
                            if (incrementDropIndex) {
                                dropIndex++;
                            }
                        }
                    }
                }
            } else if (draggedTab) {
                let newIndex = this._getDropIndex(event, false);
                let newTabs = [];
                for (let tab of movingTabs) {
                    let newTab = gBrowser.adoptTab(tab, newIndex++, tab == draggedTab);
                    newTabs.push(newTab);
                }
                // Restore tab selection
                gBrowser.addRangeToMultiSelectedTabs(
                    newTabs[0],
                    newTabs[newTabs.length - 1]
                );
            } else {
                // Pass true to disallow dropping javascript: or data: urls
                let links;
                try {
                    links = browserDragAndDrop.dropLinks(event, true);
                } catch (ex) {}
                if (!links || links.length === 0) {
                    return;
                }
                let inBackground = Services.prefs.getBoolPref(
                    "browser.tabs.loadInBackground"
                );
                if (event.shiftKey) {
                    inBackground = !inBackground;
                }
                let targetTab = this._getDragTargetTab(event, true);
                let userContextId = this.selectedItem.getAttribute("usercontextid");
                let replace = !!targetTab;
                let newIndex = this._getDropIndex(event, true);
                let urls = links.map(link => link.url);
                let csp = browserDragAndDrop.getCSP(event);
                let triggeringPrincipal = browserDragAndDrop.getTriggeringPrincipal(
                    event
                );
                (async () => {
                    if (
                        urls.length >=
                        Services.prefs.getIntPref("browser.tabs.maxOpenBeforeWarn")
                    ) {
                        // Sync dialog cannot be used inside drop event handler.
                        let answer = await OpenInTabsUtils.promiseConfirmOpenInTabs(
                            urls.length,
                            window
                        );
                        if (!answer) {
                            return;
                        }
                    }
                    gBrowser.loadTabs(urls, {
                        inBackground,
                        replace,
                        allowThirdPartyFixup: true,
                        targetTab,
                        newIndex,
                        userContextId,
                        triggeringPrincipal,
                        csp,
                    });
                })();
            }
            if (draggedTab) {
                delete draggedTab._dragData;
            }
        }
    
        gBrowser.tabContainer._getDropIndex = function(event, isLink) {
            var tabs = this.allTabs;
            var tab = this._getDragTargetTab(event, isLink);
            if (!RTL_UI) {
                for (let i = tab ? tab._tPos : 0; i < tabs.length; i++) {
                    if (
                        event.screenY <
                        tabs[i].screenY + tabs[i].getBoundingClientRect().height
                    ) {
                        if (
                            event.screenX <
                            tabs[i].screenX + tabs[i].getBoundingClientRect().width / 2
                        ) {
                            return i;
                        }
                        if (
                            event.screenX >
                            tabs[i].screenX + tabs[i].getBoundingClientRect().width / 2 &&
                            event.screenX <
                            tabs[i].screenX + tabs[i].getBoundingClientRect().width
                        ) {
                            return i + 1;
                        }
                    }
                }
            } else {
                for (let i = tab ? tab._tPos : 0; i < tabs.length; i++) {
                    if (
                        event.screenY <
                        tabs[i].screenY + tabs[i].getBoundingClientRect().height
                    ) {
                        if (
                            event.screenX <
                            tabs[i].screenX + tabs[i].getBoundingClientRect().width &&
                            event.screenX >
                            tabs[i].screenX + tabs[i].getBoundingClientRect().width / 2
                        ) {
                            return i;
                        }
                        if (
                            event.screenX <
                            tabs[i].screenX + tabs[i].getBoundingClientRect().width / 2
                        ) {
                            return i + 1;
                        }
                    }
                }
            }
            return tabs.length;
        }
    }
    Alles anzeigen

    Hallo und liebe Grüße zurück !
    Mensch hier hat sich ja einiges getan im Thread 😮.

    Genau dieses Script von dir behebt endlich alle Fehler, so wie ich das im Moment sehe.
    Mein Design ist drin, die mehrzeiligen TABs sind drin, die FAV. Leiste läßt sich in beide Richtungen (oben und unten) scrollen und sonst sieht auch alles prima aus.

    Ich danke dir von Herzen für deine ganze Mühe und den Aufwand.
    Mein Dank gilt natürlich auch allen anderen, die bei der Lösung des Problems mitgewirkt haben.

    💖💖💖💖💖

    Ihr seid eine klasse Community ♥♥♥♥

Unterstütze uns!

Jährlich (2025)

104,5 %

104,5% (679,10 von 650 EUR)

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