{ pkgs, config, lib, ... }: let palette = config.colorScheme.palette; betterTransition = "all 0.3s cubic-bezier(.55,-0.68,.48,1.682)"; inherit (import ../../options.nix) slickbar bar-number simplebar clock24h; in with lib; { # Configure & Theme Waybar programs.waybar = { enable = true; package = pkgs.waybar; settings = [{ layer = "top"; position = "top"; modules-center = [ "hyprland/workspaces" ] ; modules-left = [ "custom/startmenu" "hyprland/window" "pulseaudio" "cpu" "memory"]; modules-right = [ "custom/hyprbindings" "custom/exit" "idle_inhibitor" "custom/themeselector" "custom/notification" "battery" "clock" "tray" ]; "hyprland/workspaces" = { format = if bar-number == true then "{name}" else "{icon}"; format-icons = { default = " "; active = " "; urgent = " "; }; on-scroll-up = "hyprctl dispatch workspace e+1"; on-scroll-down = "hyprctl dispatch workspace e-1"; }; "clock" = { format = if clock24h == true then ''{: %H:%M}'' else ''{: %I:%M %p}''; tooltip = true; tooltip-format = "{:%A, %d.%B %Y }{calendar}"; }; "hyprland/window" = { max-length = 25; separate-outputs = false; }; "memory" = { interval = 5; format = " {}%"; tooltip = true; }; "cpu" = { interval = 5; format = " {usage:2}%"; tooltip = true; }; "disk" = { format = " {free}"; tooltip = true; }; "network" = { format-icons = ["󰤯" "󰤟" "󰤢" "󰤥" "󰤨"]; format-ethernet = " {bandwidthDownOctets}"; format-wifi = "{icon} {signalStrength}%"; format-disconnected = "󰤮"; tooltip = false; }; "tray" = { spacing = 12; }; "pulseaudio" = { format = "{icon} {volume}% {format_source}"; format-bluetooth = "{volume}% {icon} {format_source}"; format-bluetooth-muted = " {icon} {format_source}"; format-muted = " {format_source}"; format-source = " {volume}%"; format-source-muted = ""; format-icons = { headphone = ""; hands-free = ""; headset = ""; phone = ""; portable = ""; car = ""; default = ["" "" ""]; }; on-click = "sleep 0.1 && pavucontrol"; }; "custom/themeselector" = { tooltip = false; format = ""; on-click = "sleep 0.1 && theme-selector"; }; "custom/exit" = { tooltip = false; format = ""; on-click = "sleep 0.1 && wlogout"; }; "custom/startmenu" = { tooltip = false; format = " "; # exec = "rofi -show drun"; on-click = "sleep 0.1 && rofi-launcher"; }; "custom/hyprbindings" = { tooltip = false; format = " Bindings"; on-click = "sleep 0.1 && list-hypr-bindings"; }; "idle_inhibitor" = { format = "{icon}"; format-icons = { activated = ""; deactivated = ""; }; tooltip = "true"; }; "custom/notification" = { tooltip = false; format = "{icon} {}"; format-icons = { notification = ""; none = ""; dnd-notification = ""; dnd-none = ""; inhibited-notification = ""; inhibited-none = ""; dnd-inhibited-notification = ""; dnd-inhibited-none = ""; }; return-type = "json"; exec-if = "which swaync-client"; exec = "swaync-client -swb"; on-click = "sleep 0.1 && task-waybar"; escape = true; }; "battery" = { states = { warning = 30; critical = 15; }; format = "{icon} {capacity}%"; format-charging = "󰂄 {capacity}%"; format-plugged = "󱘖 {capacity}%"; format-icons = ["󰁺" "󰁻" "󰁼" "󰁽" "󰁾" "󰁿" "󰂀" "󰂁" "󰂂" "󰁹"]; on-click = ""; tooltip = false; }; }]; style = concatStrings ['' * { font-size: 16px; font-family: JetBrainsMono Nerd Font, Font Awesome, sans-serif; font-weight: bold; } window#waybar { ${if slickbar == true || simplebar == true then '' background-color: rgba(26,27,38,0); border-bottom: 1px solid rgba(26,27,38,0); border-radius: 0px; color: #${palette.base0F}; '' else '' background-color: #${palette.base00}; border-bottom: 1px solid #${palette.base00}; border-radius: 0px; color: #${palette.base0F}; ''} } #workspaces { ${if slickbar == true then '' background: #${palette.base00}; margin: 5px; padding: 0px 1px; border-radius: 15px; border: 0px; font-style: normal; color: #${palette.base00}; '' else if simplebar == true then '' color: #${palette.base00}; background: transparent; margin: 4px; border-radius: 0px; border: 0px; font-style: normal; '' else '' background: #${palette.base01}; margin: 4px; padding: 0px 1px; border-radius: 10px; border: 0px; font-style: normal; color: #${palette.base00}; ''} } #workspaces button { ${if slickbar == true then '' padding: 0px 5px; margin: 4px 3px; border-radius: 15px; border: 0px; color: #${palette.base00}; background: linear-gradient(45deg, #${palette.base0C}, #${palette.base0D}, #${palette.base0E}); opacity: 0.5; transition: ${betterTransition}; '' else if simplebar == true then '' color: #${palette.base03}; background: #${palette.base00}; margin: 4px 3px; opacity: 1; border: 0px; border-radius: 15px; transition: ${betterTransition}; '' else '' padding: 0px 5px; margin: 4px 3px; border-radius: 10px; border: 0px; color: #${palette.base00}; background: linear-gradient(45deg, #${palette.base0E}, #${palette.base0F}, #${palette.base0D}, #${palette.base09}); background-size: 300% 300%; animation: gradient_horizontal 15s ease infinite; opacity: 0.5; transition: ${betterTransition}; ''} } #workspaces button.active { ${if slickbar == true then '' padding: 0px 5px; margin: 4px 3px; border-radius: 15px; border: 0px; color: #${palette.base00}; background: linear-gradient(45deg, #${palette.base0D}, #${palette.base0E}); opacity: 1.0; min-width: 40px; transition: ${betterTransition}; '' else if simplebar == true then '' color: #${palette.base00}; background: linear-gradient(118deg, #${palette.base0D} 5%, #${palette.base0F} 5%, #${palette.base0F} 20%, #${palette.base0D} 20%, #${palette.base0D} 40%, #${palette.base0F} 40%, #${palette.base0F} 60%, #${palette.base0D} 60%, #${palette.base0D} 80%, #${palette.base0F} 80%, #${palette.base0F} 95%, #${palette.base0D} 95%); background-size: 300% 300%; animation: swiping 15s linear infinite; border-radius: 15px; margin: 4px 3px; opacity: 1.0; border: 0px; min-width: 45px; transition: ${betterTransition}; '' else '' padding: 0px 5px; margin: 4px 3px; border-radius: 10px; border: 0px; color: #${palette.base00}; background: linear-gradient(45deg, #${palette.base0E}, #${palette.base0F}, #${palette.base0D}, #${palette.base09}); background-size: 300% 300%; animation: gradient_horizontal 15s ease infinite; transition: ${betterTransition}; opacity: 1.0; min-width: 40px; ''} } #workspaces button:hover { ${if slickbar == true then '' border-radius: 15px; color: #${palette.base00}; background: linear-gradient(45deg, #${palette.base0D}, #${palette.base0E}); opacity: 0.8; transition: ${betterTransition}; '' else if simplebar == true then '' color: #${palette.base05}; border: 0px; border-radius: 15px; transition: ${betterTransition}; '' else '' border-radius: 10px; color: #${palette.base00}; background: linear-gradient(45deg, #${palette.base0E}, #${palette.base0F}, #${palette.base0D}, #${palette.base09}); background-size: 300% 300%; animation: gradient_horizontal 15s ease infinite; opacity: 0.8; transition: ${betterTransition}; ''} } @keyframes gradient_horizontal { 0% { background-position: 0% 50%; } 50% { background-position: 100% 50%; } 100% { background-position: 0% 50%; } } @keyframes swiping { 0% { background-position: 0% 200%; } 100% { background-position: 200% 200%; } } tooltip { background: #${palette.base00}; border: 1px solid #${palette.base0E}; border-radius: 10px; } tooltip label { color: #${palette.base07}; } #window { ${if slickbar == true then '' color: #${palette.base05}; background: #${palette.base00}; border-radius: 50px 15px 50px 15px; margin: 5px; padding: 2px 20px; '' else if simplebar == true then '' color: #${palette.base03}; background: #${palette.base00}; margin: 6px 4px; border-radius: 15px; padding: 0px 10px; '' else '' margin: 4px; padding: 2px 10px; color: #${palette.base05}; background: #${palette.base01}; border-radius: 10px; ''} } #memory { color: #${palette.base0F}; ${if slickbar == true then '' background: #${palette.base00}; border-radius: 50px 15px 50px 15px; margin: 5px; padding: 2px 20px; '' else if simplebar == true then '' background: #${palette.base00}; margin: 6px 4px; padding: 0px 10px; border-radius: 15px; '' else '' background: #${palette.base01}; margin: 4px; padding: 2px 10px; border-radius: 10px; ''} } #clock { color: #${palette.base0B}; ${if slickbar == true then '' background: #${palette.base00}; border-radius: 15px 50px 15px 50px; margin: 5px; padding: 2px 20px; '' else if simplebar == true then '' background: #${palette.base00}; margin: 6px 4px; padding: 0px 10px; border-radius: 15px; '' else '' background: #${palette.base01}; margin: 4px; padding: 2px 10px; border-radius: 10px; ''} } #cpu { color: #${palette.base07}; ${if slickbar == true then '' background: #${palette.base00}; border-radius: 50px 15px 50px 15px; margin: 5px; padding: 2px 20px; '' else if simplebar == true then '' background: #${palette.base00}; margin: 6px 4px; padding: 0px 10px; border-radius: 15px; '' else '' background: #${palette.base01}; margin: 4px; padding: 2px 10px; border-radius: 10px; ''} } #disk { color: #${palette.base03}; ${if slickbar == true then '' background: #${palette.base00}; border-radius: 15px 50px 15px 50px; margin: 5px; padding: 2px 20px; '' else if simplebar == true then '' background: #${palette.base00}; margin: 6px 4px; padding: 0px 10px; border-radius: 15px; '' else '' background: #${palette.base01}; margin: 4px; padding: 2px 10px; border-radius: 10px; ''} } #battery { color: #${palette.base08}; ${if slickbar == true then '' background: #${palette.base00}; border-radius: 15px 50px 15px 50px; margin: 5px; padding: 2px 20px; '' else if simplebar == true then '' background: #${palette.base00}; margin: 6px 4px; padding: 0px 10px; border-radius: 15px; '' else '' background: #${palette.base01}; margin: 4px; padding: 2px 10px; border-radius: 10px; ''} } #network { color: #${palette.base09}; ${if slickbar == true then '' background: #${palette.base00}; border-radius: 50px 15px 50px 15px; margin: 5px; padding: 2px 20px; '' else if simplebar == true then '' background: #${palette.base00}; margin: 6px 4px; padding: 0px 10px; border-radius: 15px; '' else '' background: #${palette.base01}; margin: 4px; padding: 2px 10px; border-radius: 10px; ''} } #custom-hyprbindings { color: #${palette.base0E}; ${if slickbar == true then '' background: #${palette.base00}; border-radius: 15px 50px 15px 50px; margin: 5px; padding: 2px 20px; '' else if simplebar == true then '' background: #${palette.base00}; margin: 6px 4px; padding: 0px 10px; border-radius: 15px; '' else '' background: #${palette.base01}; margin: 4px; padding: 2px 10px; border-radius: 10px; ''} } #tray { color: #${palette.base05}; ${if slickbar == true then '' background: #${palette.base00}; border-radius: 15px 0px 0px 50px; margin: 5px 0px 5px 5px; padding: 2px 20px; '' else if simplebar == true then '' background: #${palette.base00}; margin: 6px 4px; padding: 0px 10px; border-radius: 15px; '' else '' background: #${palette.base01}; margin: 4px; padding: 2px 10px; border-radius: 10px; ''} } #pulseaudio { color: #${palette.base0D}; ${if slickbar == true then '' background: #${palette.base00}; border-radius: 50px 15px 50px 15px; margin: 5px; padding: 2px 20px; '' else if simplebar == true then '' background: #${palette.base00}; margin: 6px 4px; padding: 0px 10px; border-radius: 15px; '' else '' background: #${palette.base01}; margin: 4px; padding: 2px 10px; border-radius: 10px; ''} } #custom-notification { color: #${palette.base0C}; ${if slickbar == true then '' background: #${palette.base00}; border-radius: 15px 50px 15px 50px; margin: 5px; padding: 2px 20px; '' else if simplebar == true then '' background: #${palette.base00}; margin: 6px 4px; padding: 0px 10px; border-radius: 15px; '' else '' background: #${palette.base01}; margin: 4px; padding: 2px 10px; border-radius: 10px; ''} } #custom-themeselector { color: #${palette.base0D}; ${if slickbar == true then '' background: #${palette.base00}; border-radius: 0px 50px 15px 0px; margin: 5px 0px; padding: 2px 15px 2px 5px; '' else if simplebar == true then '' background: #${palette.base00}; margin: 6px 4px 6px 0px; padding: 0px 10px 0px 5px; border-radius: 0px 15px 15px 0px; '' else '' background: #${palette.base01}; margin: 4px 0px; padding: 2px 10px 2px 5px; border-radius: 0px 10px 10px 0px; ''} } #custom-startmenu { color: #${palette.base03}; ${if slickbar == true then '' background: #${palette.base00}; border-radius: 0px 15px 50px 0px; margin: 5px 5px 5px 0px; padding: 2px 20px; '' else if simplebar == true then '' background: #${palette.base00}; margin: 6px 4px; padding: 0px 8px 0px 10px; border-radius: 15px; '' else '' background: #${palette.base01}; margin: 4px; padding: 2px 10px; border-radius: 10px; ''} } #idle_inhibitor { color: #${palette.base09}; ${if slickbar == true then '' background: #${palette.base00}; border-radius: 0px; margin: 5px 0px; padding: 2px 14px; '' else if simplebar == true then '' background: #${palette.base00}; margin: 6px 0px; padding: 0px 14px; border-radius: 0px; '' else '' background: #${palette.base01}; margin: 4px 0px; padding: 2px 14px; border-radius: 0px; ''} } #custom-exit { color: #${palette.base0E}; ${if slickbar == true then '' background: #${palette.base00}; border-radius: 15px 0px 0px 50px; margin: 5px 0px; padding: 2px 5px 2px 15px; '' else if simplebar == true then '' background: #${palette.base00}; margin: 6px 0px 6px 4px; padding: 0px 5px 0px 10px; border-radius: 15px 0px 0px 15px; '' else '' background: #${palette.base01}; margin: 4px 0px; padding: 2px 5px 2px 10px; border-radius: 10px 0px 0px 10px; ''} } '' ]; }; }