Dein Block war ein Volltreffer.
Ja, Endor, der Übeltäter dabei ist align-items: center !important;.
Dein Block war ein Volltreffer.
Ja, Endor, der Übeltäter dabei ist align-items: center !important;.
Habt Ihr da eine Idee?
Eine besondere Idee habe ich auch nicht, aber eventuell hilft dir das erst mal weiter. Ich stelle dir mal den Block rein, den ich auf die Schnelle verändert habe. Damit sieht es dann so aus:
.screen{
margin-top: 15px !important;
margin-left: 110px !important;
max-width: 1200px !important; /* Breite der Box */
border: 5px solid dodgerblue! important;
border-radius:24px !important;
padding: -60px -60px !important;
background: #f8f8ff !important;
box-shadow: inset 0 0 15px 15px lightblue !important; /* innerer Schatten */
}
Prima nun passt in beiden Versionen alles. Vielen Dank!
Sollte eventuell ich angesprochen sein (weil Beitrag darüber), es war mir eine Ehre. ![]()
![]()
ist auf den Seiten 2+3 nach oben verschoben - da müßte noch nachgebessert werden.
Hiermit passt es dann bei mir (Blöcke angepasst):
h1{
margin-top: 20px !important;
color: #cc0000 !important;
font-size: 35px !important;
font-weight: bold !important;
min-height: 100px !important;}
.secondary-cta > span:nth-child(1){
color: #1a75ff !important;
font-weight: bold !important;
font-size: 17px !important;}
h2{
color: #1a75ff !important;
margin-top: -15px !important;
margin-bottom: 10px !important;
font-weight: bold !important;
font-size: 17px !important;}
.screen:before {
margin-top: 100px !important;
margin-left: auto !important;
margin-right: auto !important;
justify-content: center!important;
align-items: center!important;
content: "xxx Firefox";
font-weight:bold !important;
font-size: 26px !important;
color:red !important; }
Alles anzeigen
ist so leer, oder was meinst Du?
Genau so ist es, aber der Code von Endor enthält ja noch Bestandteile, die hier nicht mehr benötigt werden, so meine ich.![]()
hier mal ein Schnellschuß für die Höhe.
Prima, Dharkness, das funktioniert schon mal. Aber wir müssen wohl abwarten was Endor mit dem Code macht, denn da hat sich ja Einiges geändert, wie es aussieht.
Hier funktioniert der Throbber unter Win10 seit Firefox 79 ohne ::before
Hier RE: Tab Throbber neues Icon hatte ich ja dazu die Wirkung mit ::before bestätigt. Nur als Ergänzung, nehme ich in meinem Code ::before raus, dann arbeiten beide gemeinsam. Also Original (...), und der aus dem Code.
Ich nutze bis zur Version 82 den identischen Code mit Base64, immer noch mit ::before.![]()
/*********************** bringt den rotierenden Tab-Throbber zurück *****************************/
/*AGENT_SHEET*/
.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;
animation: unset !important;
opacity: unset !important;
animation: 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;
}
Alles anzeigen
Hallo Endor ,
schaust du mal bitte auf den Code about:welcome, dort gibt es ab Version 80 (??) Ungereimtheiten.
Freut mich wenn ich dir damit helfen konnte, war gern geschehen
Nun stelle ich gerade fest, wenn ich dann auf Verwalten gehe, so ist der Eintrag dort noch vorhanden. Wir hatten vor langer Zeit schon einmal darüber gesprochen, aber nun kann ich nicht mehr sagen, welche Ziffer ich dazu ändern muss. Hilf mir mal bitte auf die Sprünge (habe nur die zwei üblichen Plugins).
Edit:
Andreas, nun habe ich den alten Code von hier RE: Nightly 76 Add-on Manager anpassen genommen und nur in Zeile Zwei aus der 4 eine 5 gemacht, damit ist der Code wieder voll funktionsfähig. Danke nochmals für deine Unterstützung.
Teste bitte:
Sehr gut, Andreas, ein großes Dankeschön von mir.![]()
![]()
Im Nightly 81 arbeitet dieser Code nicht mehr unter Plugins, was muss da geändert werden?
/* Unter Plugins - Nachfragen ob aktiviert werden soll - entfernt */
.card > plugin-options:nth-child(4) > panel-list:nth-child(1) > panel-item:nth-child(1),
#main > div:nth-child(1) > addon-list:nth-child(1) > section:nth-child(2) > addon-card:nth-child(2) > div:nth-child(1) > plugin-options:nth-child(4) > panel-list:nth-child(1) > panel-item:nth-child(1),
#main > div:nth-child(1) > addon-list:nth-child(1) > section:nth-child(2) > addon-card:nth-child(3) > div:nth-child(1) > plugin-options:nth-child(4) > panel-list:nth-child(1) > panel-item:nth-child(1) {
display: none !important;
}
und das dann für alle Codes die sich auf die Tableiste beziehen.
Das hatte ich schon mal probiert, die Button werden so nicht angesprochen.![]()
Mit diesem Script RE: Mehrzeilige Tableiste für aktuelle FireFox-Versionen (71+) ist die Tableiste unten. Nun versuche ich die Scrollbutton anzupassen, was auch funktioniert. Hier der Code:
/* NewTab-Button wird ausgeblendet */
#tabs-newtab-button * {
display: none !important;
}
/* Abstand der Tabs vom oberen Rand */
.tabbrowser-tab:not([pinned]) {
margin-top: 5px !important;
}
/* Abstand zur Mitte (Url-Bar) */
#TabsToolbar {
margin-bottom: -2px !important;
}
/* Abstand Menü-Bar zur Url-Bar */
#toolbar-menubar {
margin-bottom: -4px !important;
}
/* Abstand Url-Bar zur Lesezeichen-Symbolleiste */
#PersonalToolbar{
margin-top:-1px!important;
}
/* Titelbar-Box ganz rechts in Tableiste ausblenden */
hbox.titlebar-spacer {
display: none !important;
}
/* bei Tableiste unten - Titelbar-Buttons ganz rechts ausblenden */
#TabsToolbar > .titlebar-buttonbox-container {
display: none !important;
}
/* New-Tab-Button in der Tab-Toolbar ausblenden */
toolbarbutton#new-tab-button {
display: none !important;
}
/* Alltabs-Button (Pfeil nach unten) */
toolbarbutton#alltabs-button {
background: none !important;
border: 1px solid royalblue !important;
margin-top: 3px !important;
margin-bottom: 3px !important;
}
toolbarbutton#alltabs-button:hover {
background: lime !important;
border: 1px solid royalblue !important;
color: red !important;
}
toolbarbutton#scrollbutton-up {
background: none !important;
border: 1px solid royalblue !important;
margin-top: 3px !important;
margin-bottom: 3px !important;
}
toolbarbutton#scrollbutton-up:hover {
background: yellow !important;
border: 1px solid royalblue !important;
color: red !important;
}
toolbarbutton#scrollbutton-down {
background: none !important;
border: 1px solid royalblue !important;
margin-top: 3px !important;
margin-bottom: 3px !important;
}
toolbarbutton#scrollbutton-down:hover {
background: yellow !important;
border: 1px solid royalblue !important;
color: red !important;
}
Alles anzeigen
Doch es gibt ein Problem, denn für die Lesezeichenordner verwende ich einen vergleichbaren Code. Nun stören sich beide Codes, wie kann ich das abändern?
/*** Scrollbutton in Lesezeichenordner ***/
toolbarbutton#scrollbutton-up,
toolbarbutton#scrollbutton-down {
border: 1px solid dodgerblue !important;
border-radius: 5px !important;
}
toolbarbutton#scrollbutton-up:hover,
toolbarbutton#scrollbutton-down:hover {
background: orange !important;
}
Alles anzeigen
Entschuldige bitte, dass ich im anderen Thread nicht geantwortet
habe.
Ich bitte Dich , Endor, das musst Du nicht. Alles ist gut.![]()
Deine Änderung oben werde ich auch mal testen.
Ja, da war ich auch überrascht, dass nur der eine Schnipsel alles richtet. Im Bild etwas Unschärfe wegen der Vergrößerung, aber auch zu erkennen, dass über das Script die Höhe der Tabs so eingestellt werden kann, damit dann z.B. die drei Reihen vollständig angezeigt werden.
Hier RE: Ton Aus auf Tab funktioniert nicht hatte ich die Thematik schon angesprochen, gehört dort eigentlich nicht hin, deswegen hier ein neuer Anlauf.
Inzwischen ist es mir gelungen, das Script so einzurichten, dass auch die Scrollbar wieder bedient werden kann.
Dazu habe ich aber das "alte" Script genommen, dass bei mir in v.79 und 80Beta immer noch funktioniert. Das ist der Code:
// ==UserScript==
// @name zzzz-MultiRowTab_LiteforFx48.uc.js
// @namespace http://space.geocities.yahoo.co.jp/gl/alice0775
// @description Experimentelle CSS Version für Mehrzeilige Tableiste
// @include main
// @compatibility Firefox 73
// @author Alice0775
// @version 2016/08/05 00:00 Firefox 48
// @version 2016/05/01 00:01 hide favicon if busy
// @version 2016/03/09 00:01 Bug 1222490 - Actually remove panorama for Fx45+
// @version 2016/02/09 00:01 workaround css for lwt
// @version 2016/02/09 00:00
// ==/UserScript==
"use strict";
MultiRowTabLiteforFx();
function MultiRowTabLiteforFx() {
/* Symbolleisten und Menüleiste von der Titelleiste in die Navigator-Toolbox verschieben */
document.getElementById("titlebar").parentNode.insertBefore(document.getElementById("toolbar-menubar"),document.getElementById("titlebar"));
var css =` @-moz-document url-prefix("chrome://browser/content/browser.xhtml") {
/* Symbolleiste Sortieren */
#toolbar-menubar { -moz-box-ordinal-group: 1 !important; } /* Menüleiste */
#nav-bar { -moz-box-ordinal-group: 2 !important; } /* Navigationsleiste */
#PersonalToolbar { -moz-box-ordinal-group: 3 !important; } /* Lesezeichen-Symbolleiste */
#titlebar { -moz-box-ordinal-group: 4 !important; } /* Titelleiste */
/* Anpassung der Symbolleiste */
[tabsintitlebar="true"] #toolbar-menubar { height: 29px; }
[tabsintitlebar="true"][sizemode="maximized"] #navigator-toolbox { padding-top: 8px !important; }
#titlebar,#tabbrowser-tabs { -moz-appearance: none !important; }
/* Windows 10 und Firefox Standardtheme, Fensterausenlinie in weiß.
Anpassung für Titelleistenschaltflächen wenn sie in den Hintergrund verschoben sind */
#main-window:not([lwtheme="true"]) #TabsToolbar .titlebar-buttonbox .titlebar-button,
#main-window:not([lwtheme="true"]) #window-controls toolbarbutton { color: rgb(24, 25, 26) !important; }
#main-window:not([lwtheme="true"]) #TabsToolbar .titlebar-buttonbox .titlebar-button:not(.titlebar-close):hover,
#main-window:not([lwtheme="true"]) #window-controls toolbarbutton:not([id="close-button"]):hover {
background-color: var(--lwt-toolbarbutton-hover-background, hsla(0,0%,70%,.4)) !important; }
/* Anpassung für Titelleistenschaltflächen */
#navigator-toolbox:not([style^="margin-top:"])[style=""][inFullscreen="true"] #window-controls,
[tabsintitlebar="true"] .titlebar-buttonbox-container { display: block; position: fixed; right:0; }
[tabsintitlebar="true"][sizemode="normal"] .titlebar-buttonbox-container { top: 1px; }
[tabsintitlebar="true"][sizemode="maximized"] .titlebar-buttonbox-container { top: 8px; }
#navigator-toolbox:not([style^="margin-top:"])[style=""][inFullscreen="true"] #window-controls { top: 0; }
/* auf der rechten Seite Platz für die Schaltflächen der Titelleiste einfügen, damit die
Schaltflächen der Titelleiste und der Navigationsleiste nicht verdeckt werden */
[tabsintitlebar="true"] #toolbar-menubar[autohide="true"][inactive="true"] ~ #nav-bar:not([inFullscreen="true"]) { padding-right: 139px !important; }
#navigator-toolbox[inFullscreen="true"] #nav-bar { padding-right: 109px !important; }
/* Platz für Scrollbar schaffen */
.tabbrowser-tabs {
margin-right: -41px !important;
}
tabs > arrowscrollbox {
display: block;
}
scrollbox[part][orient="horizontal"] {
display: flex;
flex-wrap: wrap;
overflow: visible !important;
overflow-x: hidden !important;
overflow-y: auto !important;
min-height: 22px !important; /* Tab-Höhe(21px) + 2px */
max-height: calc( 3 * 26px ) !important; /* Anzahl der Tabreihen * Minimal-Höhe */
-moz-window-dragging: no-drag !important;
}
/* Buttons/Zwischenräume Ausblenden */
hbox.titlebar-spacer,
[class="scrollbutton-up"],
[class="scrollbutton-up"] + spacer,
scrollbox[part][orient="horizontal"] + spacer,
[class="scrollbutton-down"] {
display: none;
}
#TabsToolbar > .titlebar-buttonbox-container {
display: none !important;
}
/* Drag-Bereich auf der linken und rechten Seite der
Tab-Leiste ausblenden - verstecken
Links und rechts → hbox.titlebar-spacer
links → hbox.titlebar-spacer[type="pre-tabs"]
rechts → hbox.titlebar-spacer[type="post-tabs"] */
hbox.titlebar-spacer
,
/* Ausblenden - Verstecken */
#alltabs-button,
tabs tab:not([fadein]),
#toolbar-menubar[autohide="false"] + #titlebar #TabsToolbar .titlebar-buttonbox-container,
[class="scrollbutton-up"],
[class="scrollbutton-up"] ~ spacer,
[class="scrollbutton-down"] { display: none; }
} `;
var sss = Cc['@mozilla.org/content/style-sheet-service;1'].getService(Ci.nsIStyleSheetService);
var uri = makeURI('data:text/css;charset=UTF=8,' + encodeURIComponent(css));
sss.loadAndRegisterSheet(uri, sss.AGENT_SHEET);
gBrowser.tabContainer.clearDropIndicator = function() {
var tabs = document.getElementsByClassName("tab-background");
for (let i = 0, len = tabs.length; i < len; i++) {
tabs[i].style.removeProperty("border-left-style");
tabs[i].style.removeProperty("border-right-style");
}
}
gBrowser.tabContainer.addEventListener("dragleave", function(event) { this.clearDropIndicator(event); }, true);
gBrowser.tabContainer.on_dragover = function(event) {
this.clearDropIndicator();
var effects = this._getDropEffectForTabDrag(event);
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;
}
return;
}
}
let newIndex = this._getDropIndex(event, effects == "link");
let children = document.getElementsByClassName("tab-background");
if (newIndex == children.length) {
children[newIndex - 1].style.setProperty("border-right","2px solid red","important");
} else {
children[newIndex].style.setProperty("border-left","2px solid 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;
}
}[tt]<span id="selection-marker-1" class="redactor-selection-marker woltlab-bbcode-marker"></span>[/tt]
}
}
return tabs.length;
}
}
Alles anzeigen
Nun habe ich in den Code nur noch diese Werte hinter Zeile 61 hinzugefügt:
Damit funktioniert dann das Script auch wieder in Nightly 81, mit Scrollbar.
Edit:
Im Eifer des Gefechtes habe ich übersehen, dass im Code des Scriptes der Wert
tabs > arrowscrollbox { display: block; }
schon vorhanden ist. Deshalb reicht es aus, wenn
box[class="scrollbox-clip"][orient="horizontal"],
in Zeile 58 eingefügt wird (Komma mit beachten).
Hallo, Endor!![]()
Auch ich muss für Version 81 das Script von hier https://github.com/Endor8/userChr…tabs/Firefox-81 übernehmen. Entschieden habe ich mich für Script 04, das ich in Zeile 60 auf 3 Reihen abgeändert habe. Werden mehr Tabs geöffnet, so erscheint rechts dann die Scrollbar, leider ist diese nicht bedienbar (war mit dem alten Script 03 immer möglich).
Nun steht ja ab Zeile 67 was zu tun ist, wenn die Zeilenzahl überschritten wurde, mit der Maus scrollen.
Nun wäre ich aber dankbar dafür, wenn auch die Scrollbar wieder bedient werden könnte. Lässt sich das so einrichten?
Nehme ich aus dem Unterordner CSS einen Code lautet der Pfad hier:
So habe ich das in der Regel auch, mit einer Ausnahme. Im Ordner css habe ich einen Ordner icons nur für die Bild-Dateien für die Ordner der Lesezeichen. Um diese anzusprechen gibt es im Ordner css eine css-Datei, und darin wird die Bild-Datei so aufgerufen:
list-style-image: url('icons/yellow.png') !important;
Es sind hier also überhaupt keine Punkte erforderlich.