Ich danke euch beiden ganz herzlich nochmals für die Hilfe und den ganzen Aufwand 2002Andreas und BrokenHeart
Beiträge 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 ! -
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
Alles anzeigenIch 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; } }
-
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 ? -
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. -
Vorher war alles in Butter und prima !
Neuer Versuch:
JavaScript
Alles anzeigen// '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; } }
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 ♥♥♥♥ -
Äh, zwei Fehler hatte ich gemacht, sorry.
JavaScript
Alles anzeigen// '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 20:39] - angepasst für GermanFreme82 /////////////////////////////////////////////////////////////////////////////////////*/ "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 = "15,24,27"; // RGB-Farbwert1 für Hintergrund der Tab-Leiste //var strTabBarBgColor2 = "96,123,134"; // RGB-Farbwert2 für Hintergrund der Tab-Leiste 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 > 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; } }
^ da ist der Fehler immer noch drinnen schau ...
^ dein Script (Fehler)
^ richtig nur im max. Fenster
Es geht hierbei um die Lesezeichen, die nicht mehr angezeigt werden (außerhalb Bildschirm). Bei deinem Skript ist zwar jetzt das Design richtig (denke ich ich),aber der Fehler ist noch immer da.
Oder anders gesagt, Firefox zeigt die LEsezeichen nicht mehr richtig an, wenn ich das Fenster nicht maximiere. Ich nutze aber seid über 10 Jahren nie ein volles Fenster (Gründe) und somit sind die LEsezeichen ausserhalb UNTEN irgendwo unsichtbar udn lassen sich nicht nach unten scrollen. Die Lesezeichen werden erst sichtbar, wenn ich das Fenster 100% maximiere.
Der Fehler kam erst mit dem Update des neuen Script "MultiRowTab_Firefox107.js" und vor FF 130. Vorher war alles in Butter und prima ! -
Dann teste mal dieses:
JavaScript
Alles anzeigen// '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 20:39] - angepasst für GermanFreme82 /////////////////////////////////////////////////////////////////////////////////////*/ "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 = "215,215,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 = "15,24,27"; // RGB-Farbwert1 für Hintergrund der Tab-Leiste //var strTabBarBgColor2 = "96,123,134"; // RGB-Farbwert2 für Hintergrund der Tab-Leiste 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 = 1; // 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 > 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; } }
Das geht leider auch nicht, denn es produziert den gleichen Fehler, wie ich es im Thread Titel erwähnt habe (leider leider). und einige Einstellungen meines TAB Design sind dort nicht drinnen.
-
TAB-Leiste ist jetzt 1-zeilig
Ok, dann muss sich doch BrokenHeart das bitte mal ansehen.
Fehler kann ich bestätigen, also musst du wieder dein altes Skript erstmal nehmen.
Okay ich verstehe.
Ich werde also warten, bis BrokenHeart dazu Zeit hat, sich das mal anzuschauen und hoffentlich findet er den Fehler.
Ich nutze jetzt erstmal die "alte" Version bevor 2002Andreas du es angepaßt hast.Es gibt eine aktuellere Version des Skripts.
BeitragMehrzeilige Tableiste für aktuelle Firefox-Versionen
Neues Update (26.11.2024):
(Versteckter Text)
Wichtig: Für diese Version des Skript wird es von meiner Seite nur noch Fehlerbehebungen geben. Das heißt, dass auf absehbare Zeit keine neuen Features eingebaut werden. Allerdings können Verbesserungsvorschläge und Feature-Requests gerne weiter gemacht werden, ich sammle das und werde versuchen, einen Teil davon bei einer grundlegend neuen Version (Termin steht allerdings in den ✨) zu berücksichtigen...
Für aktuelle Versionen ab FF133+:
Das Script…BrokenHeart8. Dezember 2019 um 01:19 Ich weiß udn die habe ich auch, aber mit meinem TAB Design und Verhalten angepaßt durch BrokenHeart , aber da hat sich wohl beim einstellen ein Fehler eingeschlichen, der aktuell noch nicht gefunden wurde.
-
TAB-Leiste ist jetzt 1-zeilig und läßt sich nicht zurück scrollen und somit sehe ich die TABs nicht mehr als wären sie ausserhalb des Bildschirms. Scrollen geh nur nach rechts in den TABS aber nicht zurück.
-
Update: HALTE STOP FEHLER !!!
Nach deiner Änderung habe ich nur 1 Zeile zum TAB scrollen und wieder den BUG mit dem nicht zurückscrollen können. -
Das sind gute Neuigkeiten
Siehe bitte meinen Nachtrag im Skript über deinem, und teste.
Okay das teste ich sofort !
-
Was muss ich nun ändern
Das kann ich dir leider nicht sagen, da ich mich mit Skripten nicht auskenne.
Ich kann den Fehler aber bestätigen.
Evtl. ließt ja BrokenHeart diesen Thread, und kann sich das bitte mal ansehen.
Das sind gute Neuigkeiten, denn somit bin ich nicht mal wieder das Unikat auf dem Planeten, was nur den Fehler hat, sondern es liegt allgemein am Script und betrifft somit jeden.
Das ist hoch interessant und ich denke BrokenHeart ist sicherlich auch daran interessiert den Fehler zu finden, denn somit sollte ja jeder andere User das gleiche Problem in seinem Firefox auch haben.
Oh Oh 🙀 -
alles andere war unangetastet seid Jahren.
Das hat nichts zu sagen, wenn Mozilla evtl. etwas geändert hat.
Also testen.
Erstmal alle Skripte deaktivieren...testen.
Dann deine userChrome.css mal umbenennen..Neustart..testen..
Ich habe eben das "MultiRowTab_Firefox107.js" aus dem Ordner geworfen zum Test und dann ging es wieder normal mit den FAV. Symbolen und dem scrollen.
Der Fehler liegt also in der Datei "MultiRowTab_Firefox107.js" eindeutig.
MultiRowTab_Firefox107.js.txt
Was muss ich nun ändern, löschen aus der Datei "MultiRowTab_Firefox107.js" damit Firefox wieder "normal" arbeitet ? -
dort gibt es das Problem nicht.
Dann liegt es wohl an einem deiner CSS-Codes, oder evtl. genutzten Skripten.
Aha ich verstehe. Ich habe nur dieses Script geändert (wegen Updae), was von "brokenheart" kam und alles andere war unangetastet seit Jahren.
letzte Änderung: MultiRowTab_Firefox107.js
-
was ich dagegen tun kann
Den Fehlerbehebungsmodus vom Firefox hast du getestet?
Ich habe das eben getestet und dort gibt es das Problem nicht. Ich kann die Favs ganz normal mit dem Mausrad nach unten scrollen.
-
Hallo und liebe Grüße an die Community !
Mir ist aufgefallen, das mein aktueller Firefox leider Probleme hat mit der vollständigen Darstellung "aller" Symbole in der Lesezeichen-Leiste.
Ich habe die Lesezeichen natürlich zensiert, weil es geht ja schließlich niemanden etwas an, was ich dort favorisiere, sondern es geht um die Menge der angezeigten Lesezeichen.
Mein Firefox Fenster ist immer (weil ich das so will) 1370x1050px Pixel groß und dort werden die Favoriten nicht vollständig gezeigt udn ich kann sie auch nicht nach unten scrollen. Nur wenn ich das Fenster maximiere, dann zeigt er mir alle Favoriten richtig an (siehe Screenshots).
Kurz gesagt .... auf Bild 1 sieht man das die Favoriten an einer Stelle aufhören und auf Bild 2 (max. Fenster) sieht man, bis wohin es gehen müßte (Google Übersetzer) und wie viele Zeichen fehlen (außerhalb vom Bildschirm) bis dahin.
Das ist ein völlig komisches Verhalten und ich wollte fragen, was ich dagegen tun kann und wie man den Fehler vielleicht beheben kann, denn vor Firefox 130 ging alles prima !
Bild 1
Bild 2 -
moment
UPDATE:
------------
Ich glaube es klappt jetzt.
Ich werde die Tage noch prüfen ob es Fehler gibt, oder ich was merkwürdiges im Verhalten merke, aber auf den ersten Blick geht alles soweit.
Design = OK
Verhalten = OK
Gott sei DANK oder besser gesagt "BrokenHeart" sei DANK 1 Millionen mal. Ich war schon am verzweifeln. Du hast mir den Tag gerettet ! Vielen herzlichen Dank !!
So bald ich was merkwürdigen mitbekomme melde ich mich.Neuer Versuch (Copy&Paste hatte nicht geklappt):
Ok, ich habe jetzt deine Datei "MultiRowTab_Firefox107.js", wie oben von mir beschrieben, angepasst. Die 'userChrome.css' kann so bleiben wie sie ist:
JavaScript: MultiRowTab_Firefox107.js
Alles anzeigen// '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 > 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; } }
^ das war die Lösung !!! Ich würde dich am liebsten umarmen Kumpel vielen Dank !!!!!!!!!!!!!!!!
-
Das verstehe ich nicht tut mir leid.
Ich möchte das Design der Tabs behalten, wie es jetzt ist.
Bitte 10 TABs nebeneinander, dann sollen sie kleiner werden, bis 12/15 TABs und danach 1 Zeile drunter, bitte.
Welche Scripts muss ich wo einfügen und wo steht die genaue Datei die ich kopieren muss. Ich verstehe das nicht. Bitte keine neue Fragen kreiere, das hilft mir nicht.
MultiRowTab_Firefox107.js.txt
... bitte aus dem dort, die neue Version machen mit meinem Designs der Tabs. Der Name muss so bleiben, weil Gründe. Bitte nur die Änderungen einfügen in die Datei, denn ich habe keine Nerven darauf stundenlang zu suchen, wo welcher Button, wie groß udn klein und farbig wird. Beim letzten mal hat das Stunden gedauert udn die habe ich nicht.
Was muss geändert werden
Wie heißen die Dateien
Welchen Code muss man kopieren
Wo steht mein Design für TABS im Code damit es nicht kaputt geht
....
Bitte Bitte bettel bettel ! -
Oh ich sehe gerade ich habe das gleiche Problem. Könnt ihr mir bitte helfen, [...]
Einfach das aktualisierte Skript von hier nehmen:
BeitragMehrzeilige Tableiste für aktuelle Firefox-Versionen
Neues Update (26.11.2024):
(Versteckter Text)
Wichtig: Für diese Version des Skript wird es von meiner Seite nur noch Fehlerbehebungen geben. Das heißt, dass auf absehbare Zeit keine neuen Features eingebaut werden. Allerdings können Verbesserungsvorschläge und Feature-Requests gerne weiter gemacht werden, ich sammle das und werde versuchen, einen Teil davon bei einer grundlegend neuen Version (Termin steht allerdings in den ✨) zu berücksichtigen...
Für aktuelle Versionen ab FF133+:
Das Script…BrokenHeart8. Dezember 2019 um 01:19 ...und vorher deine alten "UserSettings" sichern und dann wieder in das aktualisierte Skript einfügen!
(Deine separaten CSS-Anpassungen sollten nicht betroffen sein.)
Kannst du bitte nur die Änderung posten hier ich muss sonst das ganze Design udn einfach alles wieder umstellen. icch meine Zeile XYZ ändern, dann läuft wieder alles, sonst ist alles standard und nicht so wie gewollt bei mir.
ich meine das hier => [01.10.2024 19:00]
- Fix: Anpassung der Tableiste FF 131 <=
in welche zeile muss ich was umschreiben, damit es wieder geht ?Keine Ahnung der Code geht nicht zu verkleinern darum Volltext leider.
CSS
Alles anzeigenCODE CODE CODE CODE CODE ---------------------------------------- // '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 [03.08.2023 17:12] - Fix: Import 'Services.jsm' entfernt /////////////////////////////////////////////////////////////////////////////////////*/ "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.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); } } 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); // --- // Scrollbars -> "no-drag" // --- cssIn =` scrollbar, scrollcorner, scrollbar thumb, scrollbar scrollbarbutton { -moz-window-dragging: no-drag !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; } #tabbrowser-tab-tooltip { visibility: 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, tabs > arrowscrollbox::part(scrollbox-clip) { display: block; contain: none !important; } tabs > arrowscrollbox::part(scrollbox) { display: flex !important; position: relative !important; flex-wrap: wrap !important; overflow: visible !important; 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="true"] .tab-label, .tabbrowser-tab[multiselected="true"] .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="true"], [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", "visible"); else cssOut = cssOut.replace("strTabTooltips", "hidden"); 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 ); } 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 =` #alltabs-button, hbox.titlebar-spacer/*, [class="scrollbutton-up"], [class="scrollbutton-up"] + spacer, scrollbox[part][orient="horizontal"] + spacer, [class="scrollbutton-down"]*/ { display: none !important; } #tabbrowser-arrowscrollbox::part(scrollbutton-up), #tabbrowser-arrowscrollbox::part(scrollbutton-down) { display: none !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,350); } 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; } }