- 
          
- 
                Notifications
    You must be signed in to change notification settings 
- Fork 909
Module: Hyprland
The workspaces module displays the currently used workspaces in hyprland compositor.
Addressed by hyprland/workspaces
| option | typeof | default | description | 
|---|---|---|---|
| active-only | bool | false | If set to true only active workspace will be shown on bar. Unless a workspace is persistent, visible, or special. Otherwise all workspace groups are shown. | 
| hide-active | bool | false | If set to true, the active workspace will be hidden. Unless a workspace is persistent or special | 
| all-outputs | bool | false | If set to false workspaces group will be shown only in assigned output. Otherwise all workspace groups are shown. | 
| format | string | {id} | The format, how information should be displayed. | 
| format-icons | object | Based on the workspace name and state, the corresponding icon gets selected. See Icons | |
| persistent-workspaces | object | Lists workspaces that should always be shown, even when nonexistent. See Persistent workspaces | |
| workspace-taskbar | object | Show per-workspace taskbars with app icons (similar to wlr/taskbar) instead of text representations.See Workspace taskbars | |
| persistent-only | bool | false | If set to true only persistent workspaces will be shown on bar | 
| show-special | bool | false | If set to true, will display special workspaces alongside regular workspaces | 
| special-visible-only | bool | false | If this and show-special are to true, special workspaces will be shown only if visible. | 
| sort-by | string | DEFAULT | How to sort workspaces | 
| window-rewrite | object (see example) | empty | An object of regexes to match against window classes (and/or titles, see below and map to a new representation. Mapping firefox→ , for example. | 
| window-rewrite-default | string | ? | The default representation to be used when a window does not match any rules configured in window-rewrite. | 
| format-window-separator | string | <space> | The string used to separate window representations from eachother. | 
| move-to-monitor | bool | false | If set to true, open the workspace on the current monitor when clicking on a workspace button. Otherwise, the workspace will open on the monitor where it was previously assigned. Analog to using focusworkspaceoncurrentmonitordispatcher instead ofworkspacein Hyprland. | 
| ignore-workspaces | array | empty | An array of regexes to match against workspace names. If there's a match, the workspace will be ignored and won't be shown in your bar. | 
| on-scroll-up | string | Command to execute when scrolling up on the module. | |
| on-scroll-down | string | Command to execute when scrolling down on the module. | 
| string | replacement | 
|---|---|
| {icon} | Icon, as defined in format-icons. | 
| {name} | Name of workspace assigned by compositor. | 
| {windows} | All windows representations (ex. window icons) as configured by the user, separated by whichever separator the user configured. | 
The rules are regexes that may match against class, title, or both in order to fine tune window representation. In order to understand them, let's break the possible rules in 4 categories:
| How it appears in config | Category | 
|---|---|
| something | Vague | 
| class<something> | Class-only | 
| title<something> | Title-only | 
| class<something1> title<something2> | Hybrid | 
When a user's config only contains "vague" rules, they will be used to match against windows classes. This is both for backwards compatibility and performance reasons: this feature originally supported only classes, since they usually don't change during a program's lifetime. When the title config was introduced, matching previously existing rules to both classes and titles wound cause a whole lot of "wrong" matches, so it's disabled by default. Additionally, matching against the title requires listening to window title changes via Hyprland's IPC, which is not necessary when not in use.
When the config contains at least one "title-only" or "hybrid" rewrite rule, then all of the "vague" rules will match against both class and title. Though confusing at first, this is in place to allow users to define vague rules, where it doesn't matter whether the class or title matched.
Examples that use all 4 categories are available below.
Additional to workspace name matching, the following format-icons can be set.
| port name | note | 
|---|---|
| active | Will be shown when workspace is active | 
| default | Will be shown when no string matches is found. | 
| empty | Will be shown on active empty workspaces | 
| persistent | Will be shown on non-active persistent workspaces | 
| special | Will be shown on non-active special workspaces | 
| urgent | Will be shown on non-active urgent workspaces | 
How to sort workspaces.
| name | note | 
|---|---|
| default | Default hyprland/workspaces sorting algorithm with custom prioritization | 
| id | Sort workspaces by id | 
| name | Sort workspaces by name | 
| number | Sort workspaces by number | 
| special-centered | Default sorting with special workspaces in the center | 
Screenshot

Each entry of persistent-workspace names a workspace that should always be shown. Associated with that value is a list of outputs indicating where the workspace should be shown, an empty list denoting all outputs
"hyprland/workspaces": {
    "persistent-workspaces": {
             "*": 5, // 5 workspaces by default on every monitor
             "HDMI-A-1": 3 // but only three on HDMI-A-1
       }
}"hyprland/workspaces": {
    "persistent-workspaces": {
      "1": [
        "DP-3" // workspace 1 shown on DP-3
      ],
      "2": [
        "DP-1" // workspace 2 shown on DP-1
      ],
      "3": [
        "DP-1" // workspace 3 shown on DP-1
      ],
    }
}"hyprland/workspaces": {
   "persistent-workspaces": {
      "DP-3": [ 1 ], // workspace 1 shown on DP-3
      "DP-1": [ 2, 3 ], // workspaces 2 and 3 shown on DP-1
    }
}"hyprland/workspaces": {
	"format": "{name}: {icon}",
	"format-icons": {
		"1": "",
		"2": "",
		"3": "",
		"4": "",
		"5": "",
		"active": "",
		"default": ""
	},
       "persistent-workspaces": {
             "*": 5, // 5 workspaces by default on every monitor
             "HDMI-A-1": 3 // but only three on HDMI-A-1
       }
}Starting with Waybar 0.14, you can make hyprland/workspaces behave like wlr/taskbar where the window icons are grouped by workspace.
"hyprland/workspaces": {
    "workspace-taskbar": {
        // Enable the workspace taskbar. Default: false
        "enable": true,
        // If true, the active/focused window will have an 'active' class. Could cause higher CPU usage due to more frequent redraws. Default: false
        "update-active-window": true,
        // Format of the windows in the taskbar. Default: "{icon}". Allowed variables: {icon}, {title}
        "format": "{icon} {title:.20}",
        // Icon size in pixels. Default: 16
        "icon-size": 16,
        // Either the name of an installed icon theme or an array of themes (ordered by priority). If not set, the default icon theme is used.
        "icon-theme": "some_icon_theme",
        // Orientation of the taskbar ("horizontal" or "vertical"). Default: "horizontal".
        "orientation": "horizontal",
        // List of regexes. A window will NOT be shown if its window class or title match one or more items. Default: []
        "ignore-list": [ "code", "Firefox - .*" ],
        // Command to run when a window is clicked. Default: "" (switch to the workspace as usual). Allowed variables: {address}, {button}
        "on-click-window": "/some/arbitrary/script {address} {button}"
    }
}If workspace-taskbar.enable is set to false (or undefined), the other fields in the workspace-taskbar object are ignored. If it is set to true, the following fields are ignored: window-rewrite, window-rewrite-default.
You can use the on-click-window config to set the command that will be executed when a specific window is clicked. For example: hyprctl dispatch focuswindow address:{address}.
- The pattern {address}will be replaced with the Hyprland address of the clicked window.
- The pattern {button}will be replaced with the pressed button number. See GdkEventButton.button.

"hyprland/workspaces": {
    "format": "{icon}: {windows}",
    "format-window-separator": "",
    "workspace-taskbar": {
        "enable": true,
        "update-active-window": true,
        "format": "{icon} {title:.22}",
        "icon-size": 18,
        "on-click-window": "${SCRIPTS}/focus-window.sh {address} {button}"
    }
},See CSS
#workspaces button {
    font-family: "Cantarell";
    font-weight: bold;
    background-color: transparent;
    color: #ffffff;
    box-shadow: none;
    text-shadow: none;
    padding: 0px;
    border-radius: 0;
    padding-left: 5px;
    padding-right: 2px;
}
#workspaces .workspace-label {
    padding-left: 3px;
    border-top: 1px solid transparent;
}
#workspaces .taskbar-window {
    border-top: 1px solid transparent;
    font-weight: normal;
    padding-left: 5px;
    padding-right: 5px;
}
#workspaces button.visible .taskbar-window,
#workspaces button.visible .workspace-label {
    border-color: white;
}
#workspaces .taskbar-window.active {
    background-color: rgba(255, 255, 255, 0.15);
}
#workspaces .taskbar-window image {
    margin-top: 1px;
}
#workspaces button.urgent {
    background-color: @urgent-color;
}See focus-window.sh
#!/bin/sh
address=$1
# https://api.gtkd.org/gdk.c.types.GdkEventButton.button.html
button=$2
if [ $button -eq 1 ]; then
    # Left click: focus window
    hyprctl keyword cursor:no_warps true
    hyprctl dispatch focuswindow address:$address
    hyprctl keyword cursor:no_warps false
elif [ $button -eq 2 ]; then
    # Middle click: close window
    hyprctl dispatch closewindow address:$address
fi- #workspaces
- #workspaces button
- #workspaces button.active
- #workspaces button.empty
- #workspaces button.persistent
- #workspaces button.special
- #workspaces button.visible
- #workspaces button.urgent
- 
#workspaces button.hosting-monitor
- Gets applied if workspace-monitor == waybar-monitor
 
- #workspaces .workspace-label
- 
#workspaces .taskbar-window
- Only if workspace-taskbar.enableistrue
 
- Only if 
- 
#workspaces .taskbar-window.active
- Gets applied if the window is focused
- Only if workspace-taskbar.enableandworkspace-taskbar.update-active-windowaretrue
 
The way the CSS is evaluated you need to order it in order of importance with last taking precedent.
This order makes it so that my priority of styling is special cases override the norm. If you wanted to include persistent in here, I'd throw it in before empty, personally.

Active Monitor:
Green icon for active workspace.

Inactive Monitor: Blue icon for visible but not active.
The window module displays the title of the currently focused window of Hyprland, the Wayland compositor.
Addressed by hyprland/window
| option | typeof | default | description | 
|---|---|---|---|
| format | string | {title} | The format, how information should be displayed. On {}the current window title is displayed. | 
| max-length | integer | The maximum length in character the module should display. | |
| rewrite | object | {} | Rules to rewrite the module format output. The rules are identical to those for sway/window. | 
| separate-outputs | bool | false | Show the active window of the monitor the bar belongs to, instead of the focused window. | 
| icon | bool | false | Option to disable application icon. | 
| icon-size | integer | 24 | Set the size of application icon. | 
See the output of "hyprctl clients" for examples
| string | replacement | 
|---|---|
| {class} | The current class of the focused window. | 
| {initialClass} | The initial class of the focused window. | 
| {initialTitle} | The initial title of the focused window. | 
| {title} | The current title of the focused window. | 
"hyprland/window": {
    "format": "👉 {}",
    "rewrite": {
        "(.*) — Mozilla Firefox": "🌎 $1",
        "(.*) - fish": "> [$1]"
    },
    "separate-outputs": true
}- #window
The following classes can apply styles to the entire Waybar (see the Sway module's page for more info):
- 
window#waybar.emptyWhen no windows are in the workspace
- 
window#waybar.soloWhen one tiled window is visible in the workspace (floating windows may be present)
- 
window#waybar.<app_id>Where<app_id>is the class (e.g.chromium) of the solo tiled window in the workspace (use hyprctl clients to see classes)
- 
window#waybar.floatingWhen there are only floating windows visible in the workspace
- 
window#waybar.fullscreenWhen there is a fullscreen window in the workspace; useful with Hyprland'sfullscreen, 1mode
- 
window#waybar.swallowingWhen there are hidden windows in the workspace; usually occurs due to window swallowing
This will change the color of the entire bar when either Chromium or kitty occupy the screen.
#window {
    border-radius: 20px;
    padding-left: 10px;
    padding-right: 10px;
}
window#waybar.kitty {
    background-color: #111111;
    color: #ffffff;
}
window#waybar.chromium {
    background-color: #eeeeee;
    color: #000000;
}
/* make window module transparent when no windows present */
window#waybar.empty #window {
    background-color: transparent;
}The windowcount module displays the number of windows in the current Hyprland workspace.
Addressed by hyprland/windowcount.
| option | typeof | default | description | 
|---|---|---|---|
| format | string | {} | The format for how information should be displayed. On {}, the current workspace window count is displayed. | 
| format-empty | string | Override the format when the workspace contains no windows. | |
| format-windowed | string | Override the format when the workspace contains no fullscreen windows. | |
| format-fullscreen | string | Override the format when the workspace contains a fullscreen window. | |
| separate-outputs | bool | true | Show the active workspace window count of the monitor the bar belongs to, instead of the focused workspace. | 
"hyprland/windowcount": {
    "format": "[{}]",
    "format-empty": "[X]",
    "format-windowed": "[T]",
    // "format-fullscreen": "[{}]",
    "separate-outputs": true
}- #windowcount
- 
window#waybar.empty #windowcountWhen no windows are in the workspace
- 
window#waybar.fullscreen #windowcountWhen there is a fullscreen window in the workspace; useful with Hyprland's fullscreen, 1 mode
/* Adding margin and padding */
#windowcount {
    margin-left: 0px;
    padding: 0px 5px;
}
/* Different background when empty */
window#waybar.empty #windowcount {
    background: darkred;
}
/* Hide the windowcount module when not in windowed mode (i.e. not fullscreen) */
window#waybar:not(.fullscreen) #windowcount {
    opacity: 0;
}The language module displays the currently selected keyboard language (layout) for Hyprland, the Wayland compositor.
Addressed by hyprland/language
| option | typeof | default | description | 
|---|---|---|---|
| format | string | {} | The format, how information should be displayed. On {}the current layout's full name is displayed. | 
| format-<lang> | string | Provide an alternative name to display per language where is the language of your choosing. Can be passed multiple times with multiple languages as shown by the example below. | |
| keyboard-name | string | Which keyboard to use, from the output of hyprctl devices. You should use the option that begins with "at-translated-set..." | 
"hyprland/language": {
    "format": "Lang: {}",
    "format-en": "AMERICA, HELL YEAH!",
    "format-en-colemak_dh": "AMERICA (Colemak-DH), HELL YEAH",
    "format-tr": "As bayrakları",
    "keyboard-name": "at-translated-set-2-keyboard"
}- #language
#language {
    border-radius: 20px;
    padding-left: 10px;
    padding-right: 10px;
}The submap module displays the currently active submap similar to sway/mode for Hyprland, the Wayland compositor.
Addressed by hyprland/submap
| option | typeof | default | description | 
|---|---|---|---|
| format | string | {} | The format, how information should be displayed. On {} the currently active submap is displayed. | 
| max-length | integer | The maximum length in character the module should display. | |
| on-click | string | Command to execute when clicked on the module. | |
| on-click-middle | string | Command to execute when you middle clicked on the module using mousewheel. | |
| on-click-right | string | Command to execute when you right clicked on the module. | |
| on-scroll-up | string | Command to execute when scrolling up on the module. | |
| on-scroll-down | string | Command to execute when scrolling down on the module. | |
| rotate | integer | Positive value to rotate the text label. | |
| smooth-scrolling-threshold | double | Threshold to be used when scrolling. | |
| tooltip | bool | true | Option to enable tooltip on hover. | 
| always-on | bool | false | Option to display the widget even when there's no active submap. | 
| default-submap | string | Default | Option to display the widget even when there's no active submap. | 
"hyprland/submap": {
    "format": "✌️ {}",
    "max-length": 8,
    "tooltip": false
}- #submap
- #submap.<name>
- Home
- Installation
- Configuration
- Styling
- Examples
- FAQ
- Modules:
- Backlight/Slider
- Backlight
- Battery
- Bluetooth
- CPU
- Cava
- CFFI
- Clock
- Custom
- DWL
- Disk
- Gamemode
- Group
- Hyprland
- Idle Inhibitor
- Image
- JACK
- Keyboard State
- Language
- Load
- MPD
- MPRIS
- Memory
- Network
- Niri
- Power Profiles Daemon
- Privacy
- PulseAudio/Slider
- PulseAudio
- River
- Sndio
- Sway
- Systemd failed units
- Taskbar
- Temperature
- Tray
- UPower
- User
- WirePlumber
- Workspaces
 
- Writing Modules