11.stylix/modules/waybar/hm.nix
Sami Liedes 861c3c92a9
waybar: Include CSS style for urgent (#2158)
Link: https://github.com/nix-community/stylix/pull/2158

Reviewed-by: NAHO <90870942+trueNAHO@users.noreply.github.com
Reviewed-by: 0xda157 <da157@voidq.com>
2026-01-29 15:17:52 -08:00

142 lines
4.1 KiB
Nix

{ mkTarget, lib, ... }:
mkTarget {
options = {
background = lib.mkOption {
type = lib.types.nullOr lib.types.str;
description = "Used to set bg even if `opacity` or `colors` is null";
internal = true;
default = null;
};
font = lib.mkOption {
type = lib.types.enum [
"serif"
"sansSerif"
"monospace"
"emoji"
];
default = "monospace";
example = "sansSerif";
description = "The font for waybar to use";
};
addCss = lib.mkOption {
type = lib.types.bool;
default = true;
description = "adds fully functional css (otherwise just adds colors and fonts)";
};
enableLeftBackColors = lib.mkOption {
type = lib.types.bool;
default = false;
description = "enables background colors on the left side of the bar";
};
enableCenterBackColors = lib.mkOption {
type = lib.types.bool;
default = false;
description = "enables background colors on the center of the bar";
};
enableRightBackColors = lib.mkOption {
type = lib.types.bool;
default = false;
description = "enables background colors on the right side of the bar";
};
};
config = [
(
{ cfg }:
{
programs.waybar.style = lib.mkIf (cfg.addCss && cfg.background != null) ''
window#waybar, tooltip {
background: ${cfg.background};
}
'';
}
)
(
{ opacity, colors }:
{
stylix.targets.waybar.background = "alpha(@base00, ${toString opacity.desktop})";
}
)
(
{ cfg, fonts }:
{
programs.waybar.style = ''
* {
font-family: "${fonts.${cfg.font}.name}";
font-size: ${toString fonts.sizes.desktop}pt;
}
'';
}
)
(
{ cfg, colors }:
let
colorlessModules = place: ''
.modules-${place} #workspaces button {
border-bottom: 3px solid transparent;
}
.modules-${place} #workspaces button.focused,
.modules-${place} #workspaces button.active {
border-bottom: 3px solid @base05;
}
.modules-${place} #workspaces button.urgent {
border-bottom: 3px solid @base08;
background-color: @base08;
color: @base00;
}
'';
in
{
stylix.targets.waybar.background = lib.mkDefault "@base00";
programs.waybar.style =
with colors.withHashtag;
''
@define-color base00 ${base00}; @define-color base01 ${base01};
@define-color base02 ${base02}; @define-color base03 ${base03};
@define-color base04 ${base04}; @define-color base05 ${base05};
@define-color base06 ${base06}; @define-color base07 ${base07};
@define-color base08 ${base08}; @define-color base09 ${base09};
@define-color base0A ${base0A}; @define-color base0B ${base0B};
@define-color base0C ${base0C}; @define-color base0D ${base0D};
@define-color base0E ${base0E}; @define-color base0F ${base0F};
''
+ lib.optionalString cfg.addCss (
''
window#waybar, tooltip {
color: @base05;
}
tooltip {
border-color: @base0D;
}
tooltip label {
color: @base05;
}
''
+ (builtins.readFile ./base.css)
+ (
if cfg.enableLeftBackColors then
(import ./colors.nix "left")
else
colorlessModules "left"
)
+ (
if cfg.enableCenterBackColors then
(import ./colors.nix "center")
else
colorlessModules "center"
)
+ (
if cfg.enableRightBackColors then
(import ./colors.nix "right")
else
colorlessModules "right"
)
);
}
)
];
}