Waybar: Unterschied zwischen den Versionen

Aus wiki.archlinux.de
KKeine Bearbeitungszusammenfassung
KKeine Bearbeitungszusammenfassung
 
(8 dazwischenliegende Versionen desselben Benutzers werden nicht angezeigt)
Zeile 1: Zeile 1:
{{inuse|[[Benutzer:Dirk|Dirk]] ([[Benutzer Diskussion:Dirk|Diskussion]])}}
Waybar ist ein hochgradig konfigurierbares und erweiterbares Panel für [[Wayland|Wayland-Kompositoren]]. Die Konfiguration erfolgt in JSONC, das Styling ist mittels CSS realisiert. Für die Konfiguration stehen standardmäßig viele Module mit verschiedenen Anzeigen zur Verfügung, und es können sehr einfach eigene Module eingerichtet werden.
Waybar ist ein hochgradig konfigurierbares und erweiterbares Panel für [[Wayland|Wayland-Kompositoren]]. Die Konfiguration erfolgt in JSONC, das Styling ist mittels CSS realisiert. Für die Konfiguration stehen standardmäßig viele Module mit verschiedenen Anzeigen zur Verfügung, und es können sehr einfach eigene Module eingerichtet werden.


Zeile 20: Zeile 19:


Für alle Standardmodule existieren [[Manpages]], die ausführlich auf die Konfiguration eingehen.
Für alle Standardmodule existieren [[Manpages]], die ausführlich auf die Konfiguration eingehen.
Individuelle Konfigurationsdateien werden aus {{ic|~/.config/waybar}} gelesen. {{ic|config}} für die Konfiguration, und {{ic|style.css}} für die stilistische Formatierung.
Es besteht die Möglichkeit, mittels entsprechender Parameter Waybar mit anderen Dateien zu starten.
waybar -s custom_style.css
waybar -c custom_config
Wenn eine individuelle CSS-Datei verwendet wird, werden die meisten Standard-Styles von Waybar nicht angewendet.


=== Beispiele ===
=== Beispiele ===
Zeile 28: Zeile 36:
Um ein Modul um ein individuelles Menü zu erweitern, müssen dem Modul ein Menü-Trigger, eine Menü-Datei und entsprechende Menü-Aktionen hinzugefügt werden.
Um ein Modul um ein individuelles Menü zu erweitern, müssen dem Modul ein Menü-Trigger, eine Menü-Datei und entsprechende Menü-Aktionen hinzugefügt werden.


  "custom/menu": {
"custom/menu": {
    "format": "",
  "format": "",
    "menu": "on-click-right",
  "menu": "on-click-right",
    "menu-file": "system-menu.xml",
  "menu-file": "system-menu.xml",
    "menu-actions": {
  "menu-actions": {
      "htop": "alacrity -e htop",
    "htop": "alacrity -e htop",
      "free": "watch free -m"
    "free": "watch free -m"
    }
  }
  }
}


Damit wird ein Icon angezeigt, über das ein Menü aus {{ic|system-menu.xml}} geöffnet wird. Es werden zudem zwei Aktionen definiert. Die Menüdatei definiert als XML formatiert ein Menü.
Damit wird ein Icon angezeigt, über das ein Menü aus {{ic|system-menu.xml}} geöffnet wird. Es werden zudem zwei Aktionen definiert. Die Menüdatei definiert als XML formatiert ein Menü.
Zeile 60: Zeile 68:
Das Attribut {{ic|1=id=""}} in den jeweiligen {{ic|GtkMenuItem}}-Objekten entspricht den IDs der definierten Menü-Aktionen. Fehlende Menü-Aktionen führen nicht zu einer Fehlermeldung – es wird dann einfach nichts ausgeführt.
Das Attribut {{ic|1=id=""}} in den jeweiligen {{ic|GtkMenuItem}}-Objekten entspricht den IDs der definierten Menü-Aktionen. Fehlende Menü-Aktionen führen nicht zu einer Fehlermeldung – es wird dann einfach nichts ausgeführt.


{{unvollständig|inline=1}}
==== Programmaufruf und Tooltip ====
[[Datei:Waybar custom newsboat.png|thumbnail|Das Icon mit angezeigtem Tooltip mit der Artikelanzahl]]
Der Newsreader {{paket|newsboat}} erlaubt es, an der Befehlszeile die Feeds zu aktualisieren, und die Anzahl der ungelesenen Artikel anzuzeigen. Dies kann man in einem individuellen Modul verwenden.
 
"custom/newsboat": {
  "format": "󰑫",
  "exec": "newsboat --execute reload print-unread",
  "interval": 600,
  "tooltip-format": "{}",
  "exec-on-event": false,
  "on-click": "alacritty --class newsboat -e newsboat"
}
 
Newsboat wird alle 10 Minuten derart ausgeführt, dass die Feeds aktualisiert werden und die Anzahl der neuen Artikel ausgegeben wird. Diese Ausgabe wird im Tooltipo an der Stelle von {{ic|<nowiki>{}</nowiki>}} eingefügt. Beim Anklicken des Icons öffnet sich {{paket|alacritty}} mit newsboat und angepasster Fensterklasse. {{ic|exec-on-event}} ist hier nötig, da sonst beim Anklicken {{ic|exec}} erneut ausgeführt werden würde, was darin resultiert, dass Newsboat in dem Moment wo es geöffnet wird bereits durch das Update läuft, und daher das öffnen mit einer Fehlermeldung abgebrochen werden würde.
 
==== Styling ====
Um Module zu gestalten, wird ein Subset von CSS benutzt. Alle verfügbaren GTK-Eigenschaften die sich per CSS konfigurieren lassen können verwendet werden. Die Manpages der jeweiligen Module listen im Abschnitt „Styles“ alle verfügbaren Elemente für die Gestaltung auf.
 
Zusätzlich kann man mittels der entsprechenden Umgebungsvariablen ({{ic|1=GTK_DEBUG=interactive waybar}}) den GTK-Debugger öffnen und bis ins Detail die CSS-Hierarchie einsehen.
 
===== Taskleiste =====
Waybar beitet mit dem Modul {{ic|wlr/taskbar}} eine Taskleiste für wlroots-Basierdende Kompositoren an, die sich sehr gut stilistisch anpassen lässt.
 
"wlr/taskbar": {
  "format": "{icon} {title}",
  "on-click": "activate",
  "on-click-middle": "minimize",
}
 
Dies konfiguriert die Taskbar. Beim anklicken eines Fensterbuttons wird das Fenster aktiviert (falls minimiert, wird es ent-minimiert, der Fokus auf das Fenster gesetzt, und das Fenster in den Vordergrund geholt). Mittels Mittelklick wird das Fenster minimiert.
 
Durch diesen Code wird der Hintergrund der Taskleiste auf einen Farbgradient gesetzt. Es kann selbstverständlich auch eine einheitliche Farbe benutzt werden, oder mittels {{ic|background: transparent}} der Hintergrund transparent gemacht werden.
 
#taskbar {
  background: linear-gradient(221deg,
    rgba(255,191,0,1) 0%,
    rgba(114,159,207,1) 51%,
    rgba(0,212,255,1) 100%
  );
}
 
Hiermit werden die Fensterbuttons als solche einheitlich konfiguriert. Mittels {{ic|all: unset}} wird sichergestellt, dass keine Standardkonfiguration mehr verwendet wird.
 
#taskbar button {
  all: unset;
  border-radius: 5px;
  margin: 5px;
  padding: 5px;
  border: 2px solid #2e3436;
  background: #babdb6;
}
 
Mittels dieser Angaben werden die Buttons in verschiedenen Zuständen zusätzlich stilistisch angepasst.
 
#taskbar button.maximized { font-weight: bold; }
#taskbar button.minimized { opacity: 0.5; }
#taskbar button.active { background: #d3d7cf; border: 2px solid #204a87; }
 
Die Vollständig gestaltete Taskleiste mit geöffneten Fenstern sieht dann so aus:
 
[[Bild:Waybar wlr-taskbar_styling.png|800px|thumbnail|center|Die vollständig gestaltete Taskbar zeigt einige Fensterbuttons an.]]
 
Alacritty ist das aktive Fenster, [[Thunar]] ist normal aber nicht fokussiert, [[Neovim]] ist minimiert, [[Firefox]] ist maximiert.
 
===== Tooltips =====
[[Datei:Waybar_tooltip_style.png|thumbnail|205px|Oben: angepasst<br />Unten: original]]
Tooltips haben unangepasst nur einen sehr minimalistischen Stil. Dieser lässt sich allerdings leicht erweitern. Zuerst wird das Tooltip-Popup angepasst, danach wird dem eigentlichen Label des Tooltips noch eine zur anpassung passende Farbe gegeben.
 
tooltip {
  all: unset;
  background: #f6f5f4;
  border: 3px solid #2e3436;
  border-radius: 10px;
}
tooltip label {
  color: #2e3436;
}
 
===== Kalender-Tooltip =====
[[Datei:Waybar clock calendar styles.png|thumbnail|300px|Das Uhren-Tooltip zeigt den Kalender an. Links vollständig angepasst, rechts ohne jegliche Anpassung]]
Das Uhr-Modul erlaubt es, einen Kalender als Tooltip anzuzeigen. Dieser Kalender ist ein sehr rudimentärer Monatskalender ohne jegliche stilistische Gestaltung. Um den Kalender optisch ansprechender zu gestalten, muss man in der Format-definition des Kalenders einige Formatierungen vornehmen.
 
"clock": {
  "locale": "de_DE.UTF-8",
  "timezone": "Europe/Berlin",
  "tooltip-format": "<nowiki><tt>{calendar}</tt></nowiki>",
  "format": "{:L%H:%M}",
  "calendar": {
    "mode" : "month",
    "weeks-pos" : "left",
    "format": {
      "months": "<nowiki><span color='#2e3436'><big><b>{}</b></big>\n</span></nowiki>",
      "days": "<nowiki><span color='#888a85'>{}</span></nowiki>",
      "weeks": "<nowiki><span color='#204a87'><i> {}</i></span></nowiki>",
      "weekdays": "<nowiki><span color='#8f5902'><u>{} </u></span></nowiki>",
      "today": "<nowiki><span color='#2e3436'><b>{}</b></span></nowiki>"
    }
  }
}


=== Styling ===
Es werden also diverse Farbkonfigurationen direkt im Format des Kalenders übergeben. Waybar interpretiert diese korrekt, und zeigt die Inhalte entsprechend formatiert an.
{{unvollständig|inline=1}}


== Weblinks ==
== Weblinks ==

Aktuelle Version vom 16. Januar 2025, 14:27 Uhr

Waybar ist ein hochgradig konfigurierbares und erweiterbares Panel für Wayland-Kompositoren. Die Konfiguration erfolgt in JSONC, das Styling ist mittels CSS realisiert. Für die Konfiguration stehen standardmäßig viele Module mit verschiedenen Anzeigen zur Verfügung, und es können sehr einfach eigene Module eingerichtet werden.

Installation

Waybar ist als waybar in extra verfügbar, und kann von dort mittels Pacman installiert werden.

# Waybar an sich
pacman -S waybar

# Für die Icons der standardmäßig vorkonfigurierten Module benötigt.
pacman -S otf-font-awesome

Einige der Standardmodule benötigen weitere installierte Programme um zu funktionieren. Dies ist durch Fehlermeldungen der entsprechenden Module ersichtlich. Waybar hängt von den Programmen nicht ab.

Konfiguration

In der Standardkonfiguration wird Waybar an die obere Bildschirmseite gebunden, die vorkonfigurierten Module werden dabei rechtsbündig angezeigt.

Waybar in der Standardkonfiguration

Von links sind dies der idle-inhibitor (verhindern von Bildschirmschoner, Standby, etc. bei Inaktivität), Lautstärkeinformationen, Netzwerkkonnektivität, Prozessorauslastung, Arbeitsspeicherauslastung, Temperatur der thermal-zone 2 (dies ist konfigurierbar und Systemabhängig), die Uhrzeit, sowie ein Energie-Menü als individuelles Modul umgesetzt.

Für alle Standardmodule existieren Manpages, die ausführlich auf die Konfiguration eingehen.

Individuelle Konfigurationsdateien werden aus ~/.config/waybar gelesen. config für die Konfiguration, und style.css für die stilistische Formatierung.

Es besteht die Möglichkeit, mittels entsprechender Parameter Waybar mit anderen Dateien zu starten.

waybar -s custom_style.css
waybar -c custom_config

Wenn eine individuelle CSS-Datei verwendet wird, werden die meisten Standard-Styles von Waybar nicht angewendet.

Beispiele

Da Waybar sehr umfangreich und individuell anpassbar ist, sei hier nur exemplarisch auf einige Dinge eingegangen.

Individuelles Menü

Das in diesem Beispiel definierte individuelle Menü, per Rechtsklick auf das definierte Zahnrad-Icon geöffnet.

Um ein Modul um ein individuelles Menü zu erweitern, müssen dem Modul ein Menü-Trigger, eine Menü-Datei und entsprechende Menü-Aktionen hinzugefügt werden.

"custom/menu": {
  "format": "",
  "menu": "on-click-right",
  "menu-file": "system-menu.xml",
  "menu-actions": {
    "htop": "alacrity -e htop",
    "free": "watch free -m"
  }
}

Damit wird ein Icon angezeigt, über das ein Menü aus system-menu.xml geöffnet wird. Es werden zudem zwei Aktionen definiert. Die Menüdatei definiert als XML formatiert ein Menü.

system-menu.xml
<?xml version="1.0" encoding="UTF-8"?>
<interface>
  <object class="GtkMenu" id="menu">
    <child>
      <object class="GtkMenuItem" id="htop">
        <property name="label">Systemauslastung mit htop anzeigen</property>
      </object>
    </child>
    <child>
      <object class="GtkMenuItem" id="free">
        <property name="label">Arbeitsspeicherverwendung anzeigen</property>
      </object>
    </child>
  </object>
</interface>

Das Attribut id="" in den jeweiligen GtkMenuItem-Objekten entspricht den IDs der definierten Menü-Aktionen. Fehlende Menü-Aktionen führen nicht zu einer Fehlermeldung – es wird dann einfach nichts ausgeführt.

Programmaufruf und Tooltip

Das Icon mit angezeigtem Tooltip mit der Artikelanzahl

Der Newsreader newsboat erlaubt es, an der Befehlszeile die Feeds zu aktualisieren, und die Anzahl der ungelesenen Artikel anzuzeigen. Dies kann man in einem individuellen Modul verwenden.

"custom/newsboat": {
  "format": "󰑫",
  "exec": "newsboat --execute reload print-unread",
  "interval": 600,
  "tooltip-format": "{}",
  "exec-on-event": false,
  "on-click": "alacritty --class newsboat -e newsboat"
}

Newsboat wird alle 10 Minuten derart ausgeführt, dass die Feeds aktualisiert werden und die Anzahl der neuen Artikel ausgegeben wird. Diese Ausgabe wird im Tooltipo an der Stelle von {} eingefügt. Beim Anklicken des Icons öffnet sich alacritty mit newsboat und angepasster Fensterklasse. exec-on-event ist hier nötig, da sonst beim Anklicken exec erneut ausgeführt werden würde, was darin resultiert, dass Newsboat in dem Moment wo es geöffnet wird bereits durch das Update läuft, und daher das öffnen mit einer Fehlermeldung abgebrochen werden würde.

Styling

Um Module zu gestalten, wird ein Subset von CSS benutzt. Alle verfügbaren GTK-Eigenschaften die sich per CSS konfigurieren lassen können verwendet werden. Die Manpages der jeweiligen Module listen im Abschnitt „Styles“ alle verfügbaren Elemente für die Gestaltung auf.

Zusätzlich kann man mittels der entsprechenden Umgebungsvariablen (GTK_DEBUG=interactive waybar) den GTK-Debugger öffnen und bis ins Detail die CSS-Hierarchie einsehen.

Taskleiste

Waybar beitet mit dem Modul wlr/taskbar eine Taskleiste für wlroots-Basierdende Kompositoren an, die sich sehr gut stilistisch anpassen lässt.

"wlr/taskbar": {
  "format": "{icon} {title}",
  "on-click": "activate",
  "on-click-middle": "minimize",
}

Dies konfiguriert die Taskbar. Beim anklicken eines Fensterbuttons wird das Fenster aktiviert (falls minimiert, wird es ent-minimiert, der Fokus auf das Fenster gesetzt, und das Fenster in den Vordergrund geholt). Mittels Mittelklick wird das Fenster minimiert.

Durch diesen Code wird der Hintergrund der Taskleiste auf einen Farbgradient gesetzt. Es kann selbstverständlich auch eine einheitliche Farbe benutzt werden, oder mittels background: transparent der Hintergrund transparent gemacht werden.

#taskbar {
  background: linear-gradient(221deg,
    rgba(255,191,0,1) 0%,
    rgba(114,159,207,1) 51%,
    rgba(0,212,255,1) 100%
  );
}

Hiermit werden die Fensterbuttons als solche einheitlich konfiguriert. Mittels all: unset wird sichergestellt, dass keine Standardkonfiguration mehr verwendet wird.

#taskbar button {
  all: unset;
  border-radius: 5px;
  margin: 5px;
  padding: 5px;
  border: 2px solid #2e3436;
  background: #babdb6;
}

Mittels dieser Angaben werden die Buttons in verschiedenen Zuständen zusätzlich stilistisch angepasst.

#taskbar button.maximized { font-weight: bold; }
#taskbar button.minimized { opacity: 0.5; }
#taskbar button.active { background: #d3d7cf; border: 2px solid #204a87; }

Die Vollständig gestaltete Taskleiste mit geöffneten Fenstern sieht dann so aus:

Die vollständig gestaltete Taskbar zeigt einige Fensterbuttons an.

Alacritty ist das aktive Fenster, Thunar ist normal aber nicht fokussiert, Neovim ist minimiert, Firefox ist maximiert.

Tooltips
Oben: angepasst
Unten: original

Tooltips haben unangepasst nur einen sehr minimalistischen Stil. Dieser lässt sich allerdings leicht erweitern. Zuerst wird das Tooltip-Popup angepasst, danach wird dem eigentlichen Label des Tooltips noch eine zur anpassung passende Farbe gegeben.

tooltip {
  all: unset;
  background: #f6f5f4;
  border: 3px solid #2e3436;
  border-radius: 10px;
}

tooltip label {
  color: #2e3436;
}
Kalender-Tooltip
Das Uhren-Tooltip zeigt den Kalender an. Links vollständig angepasst, rechts ohne jegliche Anpassung

Das Uhr-Modul erlaubt es, einen Kalender als Tooltip anzuzeigen. Dieser Kalender ist ein sehr rudimentärer Monatskalender ohne jegliche stilistische Gestaltung. Um den Kalender optisch ansprechender zu gestalten, muss man in der Format-definition des Kalenders einige Formatierungen vornehmen.

"clock": {
  "locale": "de_DE.UTF-8",
  "timezone": "Europe/Berlin",
  "tooltip-format": "<tt>{calendar}</tt>",
  "format": "{:L%H:%M}",
  "calendar": {
    "mode" : "month",
    "weeks-pos" : "left",
    "format": {
      "months": "<span color='#2e3436'><big><b>{}</b></big>\n</span>",
      "days": "<span color='#888a85'>{}</span>",
      "weeks": "<span color='#204a87'><i> {}</i></span>",
      "weekdays": "<span color='#8f5902'><u>{} </u></span>",
      "today": "<span color='#2e3436'><b>{}</b></span>"
    }
  }
}

Es werden also diverse Farbkonfigurationen direkt im Format des Kalenders übergeben. Waybar interpretiert diese korrekt, und zeigt die Inhalte entsprechend formatiert an.

Weblinks