Für die Scrollbars nutze ich dasvon Andreas gennante Script (scrollbars.us.js, von hier
Das Skript ist mittlerweile aktualisiert worden. Ich verlinke aus Bequemlichkeit mal auf mich selbst: Aktualisierungshinweis.
Für die Scrollbars nutze ich dasvon Andreas gennante Script (scrollbars.us.js, von hier
Das Skript ist mittlerweile aktualisiert worden. Ich verlinke aus Bequemlichkeit mal auf mich selbst: Aktualisierungshinweis.
Vielen Dank Meister.
Symbol ist eingebaut.
Soll ich das fertige Script Mithrandir rüber schieben?
Aber nur mit einer integrierten Warnung, dass es gelegentlich auch auf Webseiten wirken kann, und wie man dem abhilft samt Hinweis, dass der Eintrag nach einer Import-Regel kommen muss. Entweder in die Readme.md, wo Syntaxhighlighting möglich ist, oder direkt in die Skriptdatei als mehrzeiliger Kommentar (Nachteil bei letzterem ist, dass man keine CSS-Kommentare einfügen kann).
Vorschlag:
Zitat
Sehr allgemein formulierte CSS-Regeln können bei Nutzung dieses Skriptes ungewollt auch auf Webseiten angewandt werden. Dem kann man abhelfen, indem man den gesamten Code in eine Dokumentenregel einbettet, die alles auf die Browseroberfläche begrenzt. Diese Regel muss aber nach jeder Import-Regel eingefügt werden, so dass sie in jede importierte Datei separat eingefügt werden muss!
@import url("andere-datei.css")
@-moz-document url-prefix("chrome://browser/content/browser.xul") {
alle Regeln
}
Ich habe den CSS-Kommentar um alle Regeln weggelassen.
Das Symbol vom dunklen Lord (ach nee, das war ja jemand anderes) ist übrigens wirklich viiiel besser.
Speravir geht es um das Symbol der Schaltfläche, da hätte ich das hier zbs.
[Blockierte Grafik: https://i.imgur.com/r13Ocda.png]
oder
[Blockierte Grafik: https://i.imgur.com/ZURy2Lr.png]was sagt ihr dazu?
Das erste sieht nach Pinterest aus. Deshalb eher das zweite, obwohl ich da nur schlecht erkennen kann, dass dort „CSS“ zu lesen ist.
Ich selbst habe mir das Symbol aus dem erwähnten ReloadTab genommen und leicht verändert, so dass es bei mir besser passt. Hier die URLs mit Base64-Codes, wie man sie einsetzen müsste:
Unverändert rot aus ReloadTab, wobei das selbst eine Abwandlung des bekannten blauen Reload-Pfeils sein muss:
url()
Orange/hellbraun (geändert mit GIMP):
url()
Oha, das ist tückisch. Und da hilft auch die von mir eingefügte Einschränkung nicht. Das Problem mit
ist, dass man es nicht vor der @import-Regel einsetzen darf, das also in jede importierte Datei eingefügt werden müsste – was aufwendig ist, wenn man wie ich größere vorgefertigte Sammlungen nutzt ( hier CustomCSSforFx).
Richtig. :wink:
Ditt sachst Du so lockerflockig daher …
Endor, übernehmen sie! (Zitatmissbrauch zum Anpingen)
Zitat von Endor user_id=37415
Soll die direkt im Fuchs geöffnet werden, oder wie soll sich das verhalten?
Mit Klick auf den Button (man kann sicher noch ein markanteres Symbol finden, z.B. von ReloadTab.uc.xul) wird die userChrome.css neu geladen. Das geht viel schneller als mit Browserneustart, und es entfällt alles mit dem Neustart verbundene.
So sieht der Code jetzt bei mir aus, lokal abgespeichert als reload_userChrome.uc.js und getestet. Beachte, dass ich zu Beginn noch die Einschränkung auf browser.xul eingefügt habe. Sonst nur geänderte ID, Label, Tooltiptext und natürlich der andere Dateiname:
(function() {
if (location != 'chrome://browser/content/browser.xul')
return;
try {
CustomizableUI.createWidget({
id: "ucjs-register-userChrome",
defaultArea: CustomizableUI.AREA_NAVBAR,
removable: true,
label: "register-userChrome",
tooltiptext: "userChrome.css erneut registrieren",
onClick: function() {
var CI = Components.interfaces;
var CC = Components.classes;
let sss = CC["@mozilla.org/content/style-sheet-service;1"].getService( CI.nsIStyleSheetService );
let ios = CC["@mozilla.org/network/io-service;1"].getService( CI.nsIIOService );
var file = Services.dirsvc.get('UChrm', Ci.nsIFile);
//file.append('css'); /* Unterordner für Anpassungen an andere Dateien */
file.append('userChrome.css');
let fileURL = Services.io.getProtocolHandler( 'file' ).QueryInterface( Ci.nsIFileProtocolHandler ).getURLSpecFromFile( file );
let uri = ios.newURI( fileURL , null , null );
sss.loadAndRegisterSheet( uri , sss.AGENT_SHEET );
},
onCreated: function(aNode) {
aNode.style.listStyleImage = 'url()';
return aNode;
}
});
} catch (e) {
Components.utils.reportError(e);
}
})();
Alles anzeigen
Dann habe ich hier noch einen zweiten Button für dich, Andreas.![]()
Ein Klick darauf bindet die editierte Test.css erneut ein und erspart dir somit den Neustart. :wink:
Ääähm, sag mal, EffPeh. Wenn ich stattdessen die userChrome.css verwende, dann sollte ich mir doch ebenfalls den Neustart sparen können, oder? Dass ich die Zeile
dafür löschen und diverse kosmetische Änderungen machen muss, ist mir klar.
Bildlaufleisten / Scrollbar Modifikationen
Dieses "Projekt" auf Github (English).
Aris hat einige Vorschläge einer mir entfernt bekannten Person umgesetzt und das Skript Custom_Scrollbars aktualisiert. Für userChromeJs muss man Methode 2 nehmen: custom_scrollbars.uc.js.
Das ist für den höchst unwahrscheinlichen Fall, […]
:lol:
ROFL
Stimmt. Das ist genauer ausgedrückt. Was ich sagen wollte ist, dass man sich mit Hilfe der Variablen z. B. eine eigene Farbpalette anlegen kann. Ich meinte also Farbnamen:--Rigelblau: #fafaff;
--Beteigeuzerot: #fffafa;
--Kollapsarschwarz: #000;(Bei solchen Farbnamen hätte ich ja gerne einen Farbraum von Radio- bis zu Gammastrahlung.)
:lol:
Auf einen Monitor, der mir Gammastrahlung ins Gesicht schickt, lege ich allerdings keinen allzu großen Wert. :wink:
Ernst beiseite: So ausgedrückt sind wir uns ja einig.
Alles anzeigen
Ich öffne meine gespeicherte Sitzung mit z.B. 30 Tabs
der aktive Tab hat den Tabhintergrund Red, Schrift Black+dick
die restlichen 29 Tabs haben den Hintergrund aus den voreingestellten Theme des FF - bei mir gerade Silver - Schrift Blue, normal
Falls das nicht geht kann es auch ein themenunabhängiger White Hintergrund sein. Diese Tabs sind ungeladen.
klicke ich einen ungeladenen Tab an und gehe dann weg, soll dieser einen Yellow Hintergrund haben, Schrift Black, normal
klicke ich aus dem aktiven Tab einen Link an, soll der neue Tab SkyBlue Hintergrund haben, Schrift Black, normal
Wenn ich dich nicht missverstanden habe, geht das (bei mir) hiermit:
.tabbrowser-tab[pending="true"] .tab-label {
color: blue !important;
}
.tabbrowser-tab[unread="true"] > .tab-stack > .tab-background {
background: skyblue !important;
}
.tabbrowser-tab:not([pending="true"]):not([unread="true"]) > .tab-stack > .tab-background:not([selected="true"]) {
background: yellow !important;
}
.tabbrowser-tab > .tab-stack > .tab-background[selected="true"] {
background: red !important;
}
.tabbrowser-tab[selected="true"] .tab-label {
font-weight: bold !important;
}
Alles anzeigen
Hinweis: Schwarze Schrift ist Standard und musste deshalb nicht festgelegt werden. Ich habe keine Opazität eingefügt. Wenn Du sie haben willst, gib Bescheid oder kopiere dir die entsprechenden Regeln aus Andreas’ Postings oben.
Ich hätte dir gern noch eine Regel für Tabs im Ladevorgang angeboten, aber die will bei mir selbst nicht so richtig. Nachtrag: Das dürfte an der standardmäßig aktivierten Animation liegen, die da stört. Ich will sie nicht abschalten, aber man kann das mit der Konfig-Einstellung toolkit.cosmeticAnimations.enabled tun (damit schaltet man aber alle Animationen ab).
Man kann sich mit CSS auch eigene Farben definieren. Siehe "https://wiki.selfhtml.org/wiki/CSS/Variablen".
Nein, damit definiert man sich eine Variable – die für einen Farbwert genutzt werden kann. Aber auch für andere Werte.
Zitat von kyou
Mozilla macht davon ausgiebig Gebrauch. Es ist z. B. nicht so einfach, die Hover-Hintergrundfarbe der Toolbar-Buttons zu ändern, ohne auf die Variable "--toolbarbutton-hover-background" zurückzugreifen, weil die Buttons unterschiedlich tief verschachtelt sind bzw die Elemente, deren Hintergrundfarbe sich ändert, nicht bei allen Buttons dieselben sind.
Du würdest damit den Wert der Variable ändern.
Also wünschen würde ich mir folgendes:
der aktive Tab hat den Tabhintergrund Red, Schrift Black+dick
[…]
Du willst also nicht nur den Tabhintergrund geändert haben, sondern teilweise auch die Schrift. das ist etwas aufwendiger.
Nebenbei: Bei der Auflistung ist etwas gewaltig schiefgegangen, sieh dir selbst die List-Tags an. Es sollte eigentlich so genutzt werden:
Zitat von lomni
klicke ich aus dem aktiven Tab einen Link an, soll der neue Tab SkyBlue Hintergrund haben, Schrift Black, normal
falls das gehen würde, wäre das traumhaft. Ich verstehe aber wo das Problem ist.
Das letzte ist meiner Ansicht nach wohl nicht möglich, also die Sonderbehandlung im Vergleich zu anderen ungelesenen Tabs. Heißt das übrigens, dass Du neue Tabs immer im Hintergrund öffnest oder missverstehe ich dich da? Das kann durchaus wichtig sein für die Regel. Ha, noch vor dem Abschicken ist mir etwas eingefallen, womit es vielleicht doch möglich ist, aber nur wenn der neue Tab im Hintergrund und direkt neben dem aktiven Tab geladen wird. Ich weiß nicht mehr, ob das der Standard ist. (Edit: Ist es, Einstellung browser.tabs.insertRelatedAfterCurrent=true.)
Während ich das alles schreibe, finde ich diese möglicherweise interessante Erweiterung: Unread Tab (AMO).
Obwohl Andreas schon sehr viel Gutes gepostet hat, werde ich mir das nochmal ansehen und separat posten. Wie Milupo schon richtig angemerkt hat:
Eventuell ist auch die Reihenfolge der Codes von Bedeutung,
Das eventuell können wir streichen. Spätere Regeln überschreiben früheren, wenn sie nicht unspezifischer sind (letzteres macht es gelegentlich komplizierter).
Zitat von lomni
ich frage mich gerade, ob ich diese Einstellung (erst laden wenn sie angewählt werden) für die Farbeinstellung brauche, denn wenn ich eine Sitzung lade, sind die Tabs per se ungeladen, sie kommen ja aus dem Cache. Ich muss dann oben auf "laden" drücken um sie up to date zu haben. Vielleicht hilft das ja?
Das ist eine Einstellungsfrage, ob sie geladen werden oder nicht. Es müsste sich um browser.sessionstore.restore_on_demand handeln, der Standard dafür ist aber true, also (Neu-)Laden erst, wenn man einen Tab aktiviert.
Was wir ja oben schon angesprochen hatten, und, Andreas, ich hatte die ganze Zeit den anderen Thread im Hinterkopf.
Grundsätzlich ist Bugzilla der Ort, an dem man Vorschläge einbringen kann (Komponente: Toolkit > WebExtensions: General). Am besten auch direkt "[design-decision-needed]" ins Whiteboard schreiben, damit es nicht übersehen wird. Hier ein aktuelles Beispiel von mir:https://bugzilla.mozilla.org/show_bug.cgi?id=1427071
Bezüglich konkret dieser Einschränkung, das ist ein bereits diskutiertes Thema. Ich kann jetzt aber aus dem Kopf nicht sagen, wo dies schon diskutiert wurde und mit welchem Ausgang.
Danke, ich seh mir das dann mal später an. Ich komm bisher mit Bugzilla nicht so klar. Dass die API-Einschränkung keine Ad-hoc-Entscheidung zwischen Tür und Angel war, ist mir schon klar, ich bin bloß der Meinung, dass das gelegentlich kontraproduktiv ist und es eine Whitelist geben sollte für einige Addons wie eben dieses deines her.
Alles anzeigen
ich habe gerade zwei Versuche hinter mir:
[…]
=> es ändert sich nichts, ausser dass die blauen Tabs jetzt grau sindzweiter Versuch mit deinem Script aus dem Link
da habe ich einfach den Code kopiert und in eine userChrome.css umgewandelt und in den Ordner chrome gesteckt.=> keine farbigen Tab-Hintergründe
[…]
da ich leider keine Ahnung von Scripts habe, denke ich, wir können das Thema dabei belassen.
Ich hoffe, ich habe das mit Copy und Paste soweit richtig gemacht?
Nicht einfach so wild drauflos kopieren. Mein Code war erstens sehr unvollständig und im zweiten Teil nur für die angepinnten Tabs gültig.
Da es längst nicht mehr nur um den fokusierten (selektierten/aktiven) Tab handelt, ändere bitte den Titel des Threads (Beispiel: „Farbe der Tabs je nach Ladezustand und Fokus definieren“).
Um es zu rekapitulieren:
Sehe ich das richtig, dass Du je nach Zustand den gesamten Tabhintergrund in einer anderen Farbe haben und die Schrift nicht ändern willst? Hast Du konkrete Vorstellungen über die jeweilige gewünschte Farbe? Siehe dir auch Grafik/Farbpaletten – SELFHTML-Wiki an, vor allem die benannten Farben, denn damit kann man schon sehr viel anfangen.
Speravir:
Warum sollte ich das nicht veröffentlichen dürfen? Es muß nur klar erkenntlich dokumentiert sein. Es ist doch egal ob jemand vergißt eine nicht mehr benötigte Regel (deren Selektor nicht mehr vorhanden ist) zu löschen oder ob jemand eine solche mit nicht vorhandenem Selktor bewußt schreibt.
Nicht dürfen ist zu hart gesagt, es ist einfach äußerst schlechter Stil, so etwas absichtlich zu veröffentlichen. Es sollte allerwenigstens deutlich darauf hingewiesen werden. Ich sehe da nämlich sehr wohl einen Unterschied zwischen Absicht und Versehen.
Zitat
Das ist doch ein Fehler der korrekt abgefangen wird, also keiner der Schaden anrichten kann. Es ist also eher ein CSS-Hack, so wie auch der Checkbox-Hack, nicht dafür geplant aber millionenfach verwendet. Das ist so, als ob ich mit einem Kartoffelschälmesser einen Apfel durchschneide, es ist nicht dafür gedacht, funktioniert aber trotzdem gut.
Du solltest niemals darauf vertrauen, dass ein Fehler korrekt abgefangen wird, das kann auch mal böse in die Hose gehen.
Ich bin kein Entwickler, aber die CSS-Hacks, die mir so im Laufe der Zeit über den Weg liefen, waren sauberes CSS, und das trifft auch auf den von dir genannten Checkbox-Hack zu. Deine oben aufgeführten Methoden 1–4 würden gleichfalls dazu gehören – und eine Variante, wie ich sie zur Zeit selbst verwende:
/* deaktiviert mittels nicht existenter Domain */
@-moz-document domain("deaktiviert.local") {
/*
deaktivierter Code
*/
}/* Ende moz-document domain */
Sie hat den Nachteil, dass man an die schließende Klammer denken muss.
Das ist eine API-Einschränkung.
Danke, ich hab’s befürchtet. Was mich zu der Frage führt: Weißt Du auf die Schnelle, wo man sich zu den API-Einschränkungen äußern und Vorschlägen anbringen kann?
Das sollte jeder hinbekommen, denke ich.
Ja, man muss eben nur wissen, dass man in eine Verknüpfung auch Parameter einfügen kann.
Ich würde mir den Portable lieber selbst erstellen, analog zu dem, wie es SemperVideo hier gezeigt hat:Externer Inhalt www.youtube.comInhalte von externen Seiten werden ohne deine Zustimmung nicht automatisch geladen und angezeigt.Durch die Aktivierung der externen Inhalte erklärst du dich damit einverstanden, dass personenbezogene Daten an Drittplattformen übermittelt werden. Mehr Informationen dazu haben wir in unserer Datenschutzerklärung zur Verfügung gestellt.
Dort wird eine Batchdatei erstellt und damit im Hintergrund die Kommandozeilenumgebung von Windows verwendet. Wenn man diese Batch aufruft und eine URL als Parameter übergibt, hat das dann Probleme mit einigen Zeichen zur Folge, vor allem mit dem &.
Abhilfe schaffen würde man mit Nutzung einer Windows-Verknüpfung (LNK-Datei) oder mit Hilfe von AutoIt oder AutoHotkey (eventuell gibt’s noch mehr von der Sorte). Caschys FirefoxLoader.exe ist wohl auch in AutoIt erstellt worden.
Es wär sicherlich möglich, dies mit der Extension umzusetzen. Da es jedoch eher eine Unschönheit als ein tatsächliches Problem (da die Cookies ja nicht weiter versendet werden) darstellt, würd ich das mal niedrig priorisieren.
Ich hab dennoch mal ein Ticket dafür erstellt, damit es nicht vergessen wird: https://github.com/Lusito/forget-me-not/issues/27
OK.
ZitatIch bin verwirrt, was genau du willst oder was dir fehlt. Individuelle Ausnahmen festlegen und den Rest löschen ist die Hauptfunktion der Erweiterung und sollte soweit auch möglich sein. Könntest du einen Anwendungsfall beschreiben, der deine Intention darstellt?
Genauso funktionierten Addons wie der CookieKeeper. In Deinem Addon kann ich nicht auf Cookiebasis filtern.
Beschreibt dieses Ticket was du möchtest? https://github.com/Lusito/forget-me-not/issues/17
Upps, ja, exakt. Und ich hatte es sogar schon mal gesehen, aber nur leider nur überflogen. Soll ich dort noch ein +1 ergänzen?
Nachtrag: Ich muß den "downloads-button" nicht einmal anklicken. Beim download "blitzt" der schwarze (Standard) Pfeil groß auf und dem download ist der schwarze (Standard) Pfeil mit dem Unterstrich sichbar.Das heißt daß der "downloads-button" 2 oder gar 3 verschieden Icons, die man einzeln ansprechen muß, benötigt. Oder sehe ich das falsch? :-??
Ich nutze CustomCSS foFx von Aris und damit geschieht das nicht. Wenn ich mir einen der entsprechenden Stile ansehe, z.B. icons_custom_icons.css, dann ist es tatsächlich etwas komplizierter – Exzerpt:
#downloads-button:not([indicator="true"]) { /* (1) */
list-style-image: /* … */;
}
#downloads-button:not(:-moz-any([progress],[counter],[paused],[attention])) #downloads-indicator-progress-outer,
#downloads-button:not([counter]) > #downloads-indicator-anchor > #downloads-indicator-progress-area > #downloads-indicator-counter,
#downloads-button:not([attention]) > #downloads-indicator-anchor > #downloads-indicator-icon { /* (2) */
background: /* … */; /* background-image sollte auch gehen, weil spezifischer */
}
Im Code bei Aris gibt es weiter unten noch ein Auftreten nach (2), in dem eine Bildregion angegeben ist, weil oben in (1) zunächst nur die Sprite-Graphik ausgewählt wird. Möglicherweise müsste man ohne solche die obige Reihenfolge vertauschen, also (2) vor (1).
Sind die runden Klammern bei den beiden Argumenten richtig oder sollten da nur die eckigen stehen? Drum meine Frage nach der korrekten Syntax.
Abgesehen vom oben schon genannten Problem mit [selected="false"] ist das nicht möglich.
Es sollte aber mit :-moz-any gehen (vgl . :any - CSS | MDN
Edit: Ööhm, Denkfehler von mir, siehe unten.
Edit: :-moz-any ist für den ODER-Fall. Für das gewünschte UND geht es so:
Ich ändere nur die Farbe, deshalb sieht es bei mir etwas anders aus (vgl. auch CustomCSSforFx: custom_text_settings.css), aber hier die (mir bekannten) Möglichkeiten in der verwendeten Reihenfolge:
.tabbrowser-tab /* Standard zuerst */
.tabbrowser-tab[pinned="true"] /* angeheftete Tabs */
.tabbrowser-tab[pending="true"] /* nichtgeladene Tabs */
.tabbrowser-tab[unread="true"] /* ungelesene Tabs */
.tabbrowser-tab[selected="true"] /* aktive/ausgewählte Tabs */
.tabbrowser-tab[busy="true"] /* gerade geladene Tabs */
Wenn man andere Farben definiert, sollten angepinnte Tabs womöglich als letzte oder vorletzte eine Farbe zugewiesen bekommen.
Statt dem [xxx="true"] wird im Originalcode zum Teil auch die Kurzvariante [xxx] verwendet. Für die Selektion der nicht ausgewählten Tabs muss der Negationsselektor genutzt werden, weil inaktive Tabs das Attribut selected nicht enthalten:
Und ohne es getestet zu haben: Eventuell muss man, um selektiver als der Originalcode zu sein, die Farbänderung auf .tab-background anwenden
oder sogar