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
    • 1. Mai 2025 um 17:45
    Zitat von Endor

    Sa die aktuelle Version des Scriptes auf Deutsch ist jetzt verfügbar:

    https://github.com/Endor8/userChr…LiteforFx.uc.js

    Mfg.
    Endor

    Hallo und liebe Grüße !

    Könntest du vielleicht einmal meine letzten Beiträge lesen und schauen, ob du eventuell in das letzte aktuelle Script die optischen Anpassung reinmachen könntest und die TAB-Leiste wieder unter die Adressleiste verschieben ?

  • Mehrzeilige Tableiste für aktuelle Firefox-Versionen

    • GermanFreme82
    • 1. Mai 2025 um 15:51
    Zitat von Mira_Belle

    GermanFreme82 Lösch' den Code wieder aus der "userChrome.css" !
    Ich weiß nicht weiter, warte auf 2002Andreas eventuell weiß er Rat.

    Okay mach ich dann sind dei TABs erstmal wieder da oben, aber es ist erstmal nur im virtuellen Windows defekt udn hier mache ich mit FF137 erstmal weiter.

    ... so gelöscht !

    Ich hoffe auch das 2002Andreas helfen kann sieht nämlich echt besch### so aus hehehe udn mein Design ist nur halb und halb drinnen.

  • Firefox 1:1 Backup auf neues Windows übertragen

    • GermanFreme82
    • 1. Mai 2025 um 15:48
    Zitat von .DeJaVu
    Zitat von GermanFreme82

    als wäre es mein PC

    Ist das jetzt dein neuer Rechner oder nicht?

    Ich habe 1x physisch meinen PC und 1x virtuell ein Windows (virtual Box) also JA alle beide gehören mir heheheh

    Ich möchte es alles nur in einer sicheren Umgebung testen udn erstmal am "echten" PC mit FF137 weitermachen, bis FF138 richtig geht. Danach führe ich die ganzen Dinge an meinem echten Windows aus.

  • Firefox 1:1 Backup auf neues Windows übertragen

    • GermanFreme82
    • 1. Mai 2025 um 15:40

    Also ich habe FF137 komplett gelöscht auf neuen PC
    Dann Ordner von meinem PC rüber kopiert Local, roaming, Programme
    Dann FF zum ersten mal gestartet und es geht.
    Danach macht FF137 ein Update auf FF138
    Geht immer noch alles bis auf das Script was im Arsch ist dieses "MultiRow" dingens

    Fazit:
    --------
    Ich kann am neuen PC jetzt alles rauf und runter zerstören wie ich möchte und alles testen, als wäre es mein PC
    Ziel erreicht denke ich heheheheh

    Achja nach dem Update auf FF138 war auch alles wie richtig installiert also gut würde ich sagen. Ich kann aber nicht alles testen mir fällt nicht alles ein was normalerweise so kaputt geht bei so eineim großen Update.

  • Mehrzeilige Tableiste für aktuelle Firefox-Versionen

    • GermanFreme82
    • 1. Mai 2025 um 15:35
    Zitat von Mira_Belle

    Trage den Code doch mal in die "userChrome.css" ein.
    Speichern und den Firefox neu starten.

    Habe ich gemacht sieht schlimm aus schau bitte einmal....



    ^^ TAB-Leiste dauerhaft da und leer und TABs sind geöffnet bei mir 3 Stk. aber die sind irgendwo im Jenseits nicht sichtbar.


    userChrome.css.txt

    ^^ Bitte prüfen sieht komisch aus ?????? Scheint irgendwie was dopplet zu sein keien Ahnung



    Tabs im Jenseits lol

  • Firefox 1:1 Backup auf neues Windows übertragen

    • GermanFreme82
    • 1. Mai 2025 um 15:29

    Update:
    -------------
    Habe FF nun vom neuen PC komplett gelöscht richtig mit extra Software nicht nur Windows Zeugs !
    Habe die Ordner einzeln reinkopiert und FF gestartet es ist jetzt alles da.

    Leider hat er gleich das Update auf FF138 gemacht, aber ich weiß nun was ich machen muss um es zu kopieren auf neuen PC.

    Beitrag bitte noch nicht schließen muss noch testen ob wirklich alles geht auf Dauer.

  • Firefox 1:1 Backup auf neues Windows übertragen

    • GermanFreme82
    • 1. Mai 2025 um 15:13
    Zitat von Mira_Belle

    Du hast den Firefox installiert!
    Befolge doch ganz einfach das, was ich geschrieben habe.
    Das geht! Selbst schon so gemacht.

    Ich versteh nicht ganz.
    Ich soll auf dem neuen PC FF installieren, oder nicht ?

    Ich habe auf dem neuen PC FF137.0.2 installiert (nicht gestartet) und dann alles gelöscht in den Ordnern udn meine Daten dann in "Local, Roaming, Programme" kopiert udn danach FF gestartet und das Profil war alles weiß Neu-Install nix da von meinen Sachen und er legt neues Profil an.

  • Firefox 1:1 Backup auf neues Windows übertragen

    • GermanFreme82
    • 1. Mai 2025 um 14:30
    Zitat von Mira_Belle

    Auf dem alten Rechner ganz einfach
    %ProgramFiles%\
    und den ganzen Installationsordner sichern!
    Sollte "Mozilla Firefox" sein.

    Dann
    %appdata%\
    und den kompletten Ordner "Mozilla" sichern.

    Einfach mit Zip oder WinRAR packen.

    Auf dem neuen Rechen dann, wenn Firefox installiert ist,
    Erst den Installationsordner löschen und dann durch die gesicherte Version ersetzen.
    :!:ACHTUNG:!:
    Den Firefox auf gar keinen Fall starten.
    Als nächstes ersetzt Du den kompletten Profilordner. ("Mozilla")

    Jetzt kannst Du den Firefox starten.
    Es sollte alles so sein, wie auf dem alten Rechner.

    Denke aber daran, auch das Update zu machen, wenn alles so ist, wie Du erwartest.

    Alles anzeigen

    Okay ich werde es versuchen.

    Ich habe bisher immer den Fehler gemacht, Firefox dann zuerst 1x zu starten.
    Habe alles so gemacht, aber es geht nicht alles nackt und er legt neues Profil an.

    Habe FF 137.0.2 Local, roaming,Programme bei mir kopiert und auf neuen PC FF137.0.2 isntalliert NICHT gestartet. Danach die Daten aus Local, Roaming und Programme reinkopiert und danach FF137.0.2 auf neuen PC zum ersten mal geöffnet. ER macht dann ein neues Profil und alle Daten von mir werden ignoriert.

    g432iqro.default-release
    0qoqc54j.default-release-1


    Was nun ?
    Soll ich alles nochmal in beide neuen Profile kopieren ?

  • Mehrzeilige Tableiste für aktuelle Firefox-Versionen

    • GermanFreme82
    • 1. Mai 2025 um 14:14
    Zitat von Mira_Belle

    Mit CSS kommst Du klar?

    CSS
        /*--------------------------------------------*/
        /****     Tabbar nach unten verschieben    ****/
        /*--------------------------------------------*/
        
        #navigator-toolbox {
            position: relative !important;
        /*    padding-bottom: calc( var(--tab-min-height) + 8px ); */               /*  44px */
            padding-bottom: 42px !important;
        }
        
        #TabsToolbar {
            position: absolute !important;
            display: block !important;
        }
    Alles anzeigen

    Das geht nicht ist immer noch oben, leider.


    AddonLeisteUnten.uc.txt
    F2URLLeiste.uc.txt
    F12Tabchließen.uc.txt
    HideTabbarWithOneTab.uc.txt
    MultiRowTab_Firefox107.txt
    PopUp.uc.txt
    RestartFirefoxButton2025.txt
    userChrome.txt
    userChrome.txt.js.txt



    ^^^Das ist drinnen bei mir

  • Firefox 1:1 Backup auf neues Windows übertragen

    • GermanFreme82
    • 1. Mai 2025 um 10:47

    Hallo liebe community !

    Könnt ihr mir bitte helfen dabei, ein 1:1 Backup von meinem Firefox 137.0.2 zu erstellen, damit ich es 1:1 wieder so starten kann an einem neuen PC ?

    Ich kopiere immer Local, Roaming und Programme Ordner und für die Daten jeweils in das neue Profil ein.
    Wenn ich FF dann öffne sind zwar alle Addons drinnen und aktiv, aber funktionieren nicht.
    Das sieht merkwürdig aus und ich bekomme es nicht mehr zum Laufen, wie es auf dem alten PC war.

    Mache ich beim Backup was falsch ?
    Wie kopiere ich die Daten richtig, damit es wieder wie früher ist am neuen PC ?

    Bitte keine Anleitungen Links posten, wo ich tagelang Standard XXX lesen muss, denn die Anleitungen habe ich des öfteren gesehen, aber helfen mit nicht wirklich weiter.

  • Mehrzeilige Tableiste für aktuelle Firefox-Versionen

    • GermanFreme82
    • 1. Mai 2025 um 10:22

    Das ist mein Design.

    Tab 8x pro Zeile, dann neue Zeile
    Tab rund
    Tab Breite
    Tab Höhe
    Tab Abstand
    Tab Farbe
    Tab keine Schatten, oder schwarze Ränder
    + Symbol Größe

    Ich versuche jetzt das neue Script, aber ich brauche dieses Design wieder und nur Jesus, oder der ERfinder weiß wo die Sachen stehen, ich nicht. Darum brauche ich bitte die Zeile mit Nummer im Script und was ich dort reinschreiben muss. Für mich ließt sich der Text im Script wie bablblablablablablabla.



    Neues Script geht, aber mein Design ist weg und die TAB Leiste irgendwo, nur nicht da wo sie sein muss.



    Ich möchte mein Design bitte zurück und Firefox soll machen, das die TAB-Leiste wieder unter der Adressleiste ist, so wie vorher. Wie bekomme ich die Änderungen dort rein und in welcher Zeile muss ich was schreiben ?

    Code einfügen hier verstehe ich nicht, darum poste ich die Datei geht schneller für mich.

    MultiRowTab_Firefox107.js.txt <=== aus Beitrag #973

  • Mehrzeilige Tableiste für aktuelle Firefox-Versionen

    • GermanFreme82
    • 1. Mai 2025 um 09:31

    Hallo zusammen ich probiere das jetzt einmal im "virtuellen Windows" aus und melde mich danach gleich nochmal. ich versuche alle eure Kommentare zu beantworten für jeden einzeln. Ich brauche einen Moment dafür.

  • 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 😇.

Unterstütze uns!

Jährlich (2025)

67,1 %

67,1% (435,86 von 650 EUR)

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