Getting started on NixOS
Requires NixOS unstable or 25.11. Note that Lumen was added only recently, so update to the latest version before trying to install it.
Install package
Lumen is available as pkgs.lumen package, but if you use home-manager there is a module so you don't have to install the package manually.
home-manager usage
# put this directly into your home-manager config or into a home-manager import
{
services.lumen = {
enable = true;
# Whether to automatically install soft dependencies used by lumen that
# will be required based on your config.
autoInstallDependencies = true;
# tip: you can automatically translate your TOML config to Nix by running
# nix-instantiate --eval --expr 'builtins.fromTOML (builtins.readFile ./config.toml)' | nixfmt
settings = {
bar = {
layout = [
# add more attribute sets with different monitors if lumen should
# have different layouts on each
{
monitor = "DP-1"; # replace "DP-1" with "*" for all monitors
show = true;
center = [
"clock"
"weather"
];
left = [ "dashboard" ];
right = [ "volume" ];
} # this is a 'list' of 'attribute sets', no semi-colons after the closing braces needed
];
};
modules = {
clock = {
format = "%H:%M:%S";
dropdown-show-seconds = false;
};
weather = {
location = "Denver";
units = "imperial";
};
};
osd = {
monitor = "DP-1";
};
styling = {
palette = {
bg = "#282a36";
blue = "#8be9fd";
# ...
};
# wallust will be automatically installed if this is set
theme-provider = "wallust";
};
# the following wallpaper option can be omitted if you're not using
# lumen's wallpaper engine
wallpaper = {
# this will automatically install aww
engine-enabled = true;
cycling-directory = "/home/horsey/Pictures/Backgrounds/1/";
cycling-mode = "shuffle";
};
};
};
}Settings GUI
lumen panel settingsThis launches lumen-settings, which edits the same config the shell reads. Changes apply live. Anything the GUI doesn't cover can still be edited by hand in config.toml.
WARNING
If you configured theming using matugen/wallust/pywal or wallpapers using AWW, do not forget to install these dependencies! Home-manager module will do this automatically for you.
After configuring Lumen using GUI, there should be a new .config/lumen/runtime.toml file. To automatically convert it to Nix, run
cd ~/.config/lumen
nix-instantiate --eval --expr '(builtins.fromTOML (builtins.readFile ./config.toml)) // (builtins.fromTOML (builtins.readFile ./runtime.toml))' | nixfmtIf one of those files does not exist run the following command, replacing config.toml with runtime.toml if appropriate.
nix-instantiate --eval --expr 'builtins.fromTOML (builtins.readFile ./config.toml)' | nixfmtThen you can copy-paste this into the services.lumen.settings option provided by the home-manager module.
Configuration
If you want to edit the raw config.toml, refer to the Editing config page (note that Tombi doesn't work when config is symlinked to /nix/store, you need to create a normal file first).