nix-config/home/waybar.nix

191 lines
5.1 KiB
Nix
Raw Normal View History

{ config, lib, ... }:
2023-06-22 17:13:46 +02:00
2023-06-26 18:01:50 +02:00
let
opacity = lib.strings.floatToString config.stylix.opacity.terminal;
icons = false;
2023-07-02 04:37:01 +02:00
position = "right";
opposite = builtins.replaceStrings [ "left" "right" "top" "bottom" ] [ "right" "left" "bottom" "top" ] position;
isVertical = position == "left" || position == "right";
modules = {
tray = {
icon-size = if isVertical then 24 else 13;
spacing = 8;
};
"wlr/taskbar" = {
icon-size = if isVertical then 32 else 16;
on-click = "activate";
on-click-middle = "activate";
on-click-right = "activate";
};
"hyprland/window" = {
rotate = if isVertical then 90 else 0;
};
"wlr/workspaces" = {
on-click = "activate";
sort-by-number = true;
format = "{icon}";
format-icons = {
"1" = "";
"2" = "";
"3" = "";
"4" = "";
"5" = "";
"6" = "";
"7" = "";
"8" = "";
"9" = "";
"10" = "";
};
};
wireplumber = {
format = "{icon}";
tooltip-format = "{volume}% {node_name}";
format-muted = "";
format-icons = [ "" "" ];
};
battery = {
format = "{icon}";
tooltip-format = "{capacity}% {timeTo}";
format-icons = [ "" "" "" "" "" ];
};
clock = {
format = if isVertical then "{:%H\n%M}" else "{:%H:%M}";
tooltip-format = "<tt>{calendar}</tt>";
calendar = {
mode = "month";
weeks-pos = "right";
format = {
months = "<span color='#ffead3'><b>{}</b></span>";
days = "<span color='#ecc6d9'><b>{}</b></span>";
weeks = "<span size='14pt' color='#99ffdd'><b>W{}</b></span>";
weekdays = "<span size='18pt' color='#ffcc66'><b>{}</b></span>";
today = "<span color='#ff6699'><b>{}</b></span>";
};
};
};
backlight = {
format = "{icon}";
format-icons = [ "" "" ];
};
"custom/new-workspace" = {
format = "+";
on-click = "hyprctl dispatch workspace empty && sleep 0.1 && rofi -show drun";
on-click-right = "sleep 0.1 && rofi -show drun";
on-click-middle = "hyprctl dispatch workspace empty";
tooltip = false;
};
"custom/wallpaper" = {
2023-07-02 03:11:48 +02:00
format = if isVertical then "\n" else "";
on-click = "bash -c ~/wallhaven/timer.sh";
tooltip = false;
};
"custom/gaps" = {
format = if isVertical then "\n" else "";
on-click = "bash -c ~/.config/hypr/gaps.sh";
tooltip = false;
};
};
2023-06-26 18:01:50 +02:00
in
2023-06-22 17:13:46 +02:00
{
programs.waybar = {
enable = true;
settings = {
mainBar = modules // {
layer = "top";
position = position;
width = if isVertical then 45 else null;
height = if isVertical then null else 30;
spacing = 8;
2023-07-02 03:11:48 +02:00
modules-left = if icons then [ "wlr/taskbar" ] else [ "wlr/workspaces" ];
modules-center = [ "custom/wallpaper" "custom/gaps" ];
modules-right = [ "wireplumber" "backlight" "battery" "clock" ];
};
};
2023-06-25 18:24:57 +02:00
style = with config.lib.stylix.colors; lib.mkForce /* css */ ''
* {
2023-06-29 06:45:37 +02:00
color: #${base05};
font-size: ${if isVertical then "16px" else "13px"};
}
window#waybar {
2023-06-29 06:45:37 +02:00
background: alpha(#${base00}, ${opacity});
border-${opposite}: 1px solid alpha(#${base02}, 0.67);
}
2023-06-22 13:17:51 +02:00
window#waybar.fullscreen #workspaces button.active {
2023-06-29 06:45:37 +02:00
background: alpha(#${base09}, 0.5);
2023-06-22 13:17:51 +02:00
}
#workspaces button {
padding: ${if isVertical then "12px 0" else "0 12px"};
border-radius: 0;
2023-06-29 06:45:37 +02:00
border-bottom: 1px solid alpha(#${base02}, 0.5);
}
#workspaces button:hover {
background: inherit;
}
#workspaces button.active {
2023-06-29 06:45:37 +02:00
background: alpha(#${base02}, 0.5);
}
#window {
padding-${if isVertical then "top" else "left"}: 8px;
padding-${if isVertical then "bottom" else "right"}: 12px;
}
tooltip, #tray menu {
2023-06-29 06:45:37 +02:00
background: #${base00};
border: 1px solid alpha(#${base09}, 0.93);
padding: 8px;
}
#backlight, #battery, #wireplumber {
font-family: "Font Awesome 6 Free Solid";
font-size: ${if isVertical then "24px" else "13px"};
}
#custom-new-workspace {
font-family: "Font Awesome 6 Free Solid";
padding-${if isVertical then "top" else "left"}: 8px;
padding-${if isVertical then "bottom" else "right"}: 8px;
2023-06-29 06:45:37 +02:00
color: alpha(#${base0A}, 0.67);
}
2023-07-02 04:36:24 +02:00
#custom-wallpaper {
border-top: 1px solid alpha(#${base02}, 0.5);
}
#custom-wallpaper, #custom-gaps {
font-weight: bold;
padding: ${if isVertical then "12px 0" else "0 12px"};
border-bottom: 1px solid alpha(#${base02}, 0.5);
}
#custom-wallpaper label:hover {
background: alpha(#${base02}, 0.5);
}
#clock {
font-size: ${if isVertical then "18px" else "13px"};
font-weight: bold;
padding-${if isVertical then "bottom" else "right"}: 8px;
}
'';
};
}