nirilayout is a simple tool to quickly switch your niri output configuration between different layouts. Especially useful for laptop users who move between different setups frequently.
nirilayout works by keeping the output blocks for each user-defined layout in
separate files in the niri config directory, then symlinking the currently
active layout to nirilayout.kdl and including that in the main config.kdl.
A graphical GTK switcher displays the available layouts with a preview of the output arrangement, and allows you to switch between them with the keyboard or mouse. nirilayout-specific comments in the layout files allow you to customize the switcher and the previews.
On Linux x86_64? Download the latest precompiled binary from the releases page. Add it to your path and you're good to go!
Otherwise, to build from source, install Go 1.25+, GTK 4.16+ and GTK4 Layer
Shell. Clone this repo, then run
make install to install nirilayout to $GOBIN. Alternatively, run make to
build nirilayout to the current directory.
In ~/.config/niri, create layouts for your different setups in files
named layout_<name>.kdl.
For example, layout_vertical.kdl might look like this:
//! name "Vertical"
//! shortcut "v"
//! style font-family="sans-serif"
output "Lenovo Group Limited E27q-20 V5HDD696" {
//! name "external"
mode "2560x1440@74.780"
scale 1
position x=0 y=0
}
output "BOE 0x0AC1 Unknown" {
//! name "laptop"
//! style fill=9
mode "2560x1600@120.001"
scale 1.5
position x=427 y=1440
}Each layout file should contain the output blocks that niri should use in this
layout (see docs).
Then, add special comments throughout the file to configure the switcher.
nirilayout reads the existing KDL as well as any line beginning with
//! — these are uncommented and parsed as KDL. As such, follow KDLv1 syntax
rules when writing them.
Global options, outside of any output block, apply to the layout as a whole.
-
//! name "<name>": The name of the layout. This is what will be shown in the switcher. If not specified, the name of the file (without thelayout_prefix and.kdlsuffix) will be used. -
//! shortcut "<shortcut>"...: The shortcut(s) to use for this layout. You can specify multiple shortcuts by providing several strings (e.g.//! shortcut "v" "V"). Shortcuts are case-sensitive.Shortcuts cannot be prefixes of other shortcuts. As soon as you finish typing a shortcut, the switcher will immediately select that layout. This means that if you have both "a" and "ab" as shortcuts, typing "a" will immediately select the first layout and you won't be able to type "ab".
-
//! style [prop=value]...: Customize the preview style defaults for this layout. You can set any of the following properties:fill=<color>: output fill color (default: auto-assigned based on output name)border=<color>: output border color (default: fill at 1.2× brightness)text=<color>: text color (default: auto-assigned based on fill color)border-width=<number>: border width, pixels (default: 2)font-family="<name>": output label font family (default: monospace)font-size=<number>: output label font size, pixels (default: 10)hide-details=<true|false>: whether to hide the output mode and scale in labels (default: false)line-spacing=<number>: line spacing for output labels, pixels (default: 4)
These options should be specified inside the output block they are configuring.
-
//! name "<name>": Specifies a custom name for this output. If not specified, the name given to niri (output "...") will be used. -
//! style [prop=value]...: Set style properties for this output, which override the layout defaults. See the list of style properties above. -
//! color <number>(deprecated): Specifies a custom color for this output. nirilayout will pick a color for each display based on its name, but you can pick a custom color yourself by setting this option to a number between 0 and 17. 0 is gray and 1-17 are preset colors from the Tailwind CSS palette.Index Color Index Color Index Color 0 gray 6 green 12 indigo 1 red 7 emerald 13 violet 2 orange 8 teal 14 purple 3 amber 9 cyan 15 fuchsia 4 yellow 10 sky 16 pink 5 lime 11 blue 17 rose This option is deprecated in favor of using
//! style fill=<color>, but is still supported for backwards compatibility. -
//! mode "WWWxHHH": If you don't want to specify a mode to niri, you'll need to explicitly set a nirilayout-only mode using this option so that the switcher knows how to draw the preview.
Several color formats are understood:
#RGB,#RGBA,#RRGGBB,#RRGGBBAAhex codesrgb(R, G, B)andrgba(R, G, B, A)functions, where R/G/B/A are integers between 0 and 255- A color index between 0 and 17, which corresponds to a preset color in the
Tailwind CSS palette (see the table above). Only valid for
fill/borderor//! color. - A named Tailwind CSS color, like
red500orblue200
You can further customize the look of the switcher by editing the file
~/.config/niri/nirilayout.css. Any styles in this file will be loaded as GTK
user styles, overriding your GTK theme and the default application styles. You
can copy style.css in this repo as a starting point.
For example, to make the window translucent:
/* In ~/.config/niri/nirilayout.css: */
window {
background-color: #00000080;
}Now, run nirilayout once to select an initial layout. This creates
~/.config/niri/nirilayout.kdl, a symlink to the layout you selected.
Finally, remove any output blocks in ~/.config/niri/config.kdl and add an
include to load nirilayout.kdl.
// In config.kdl:
include "nirilayout.kdl"Optionally, add a keybinding to spawn nirilayout to make it easier to switch.
// In config.kdl:
binds {
// ...
Mod+P { spawn "nirilayout"; } // Assuming nirilayout is on $PATH
// ...
}All done!
Run nirilayout again (or use your keybinding) to switch between your layouts.
In the switcher, you can select a layout with ←/→/Return or the mouse. You
can also type the name of a layout or its shortcut to select it. Shortcuts and
names are case-sensitive. As soon as you finish typing a shortcut, the switcher
will immediately select that layout, so make sure your shortcuts are not
prefixes of each other.
Layouts are presented in lexicographical order by name. If you want to change the order, you can rename the files in the config directory.
Contributions are welcome! If you find a bug or have a feature request, please open an issue or a pull request.
nirilayout is licensed under the MIT license. See LICENSE for more information.
