Themed waybar

This commit is contained in:
Emmet 2023-08-18 22:44:34 -05:00
parent a8f47c5603
commit c9891c5774

View file

@ -4,7 +4,10 @@
imports = [ imports = [
../../app/terminal/alacritty.nix ../../app/terminal/alacritty.nix
../../app/terminal/kitty.nix ../../app/terminal/kitty.nix
( import ../../app/dmenu-scripts/networkmanager-dmenu.nix {dmenu_command = "fuzzel -d"; inherit config lib pkgs;}) (import ../../app/dmenu-scripts/networkmanager-dmenu.nix {
dmenu_command = "fuzzel -d";
inherit config lib pkgs;
})
]; ];
wayland.windowManager.hyprland = { wayland.windowManager.hyprland = {
@ -155,11 +158,8 @@
decoration { decoration {
rounding = 8 rounding = 8
} }
''; '';
xwayland = { xwayland = { enable = true; };
enable = true;
};
systemdIntegration = true; systemdIntegration = true;
}; };
@ -292,22 +292,27 @@
mainBar = { mainBar = {
layer = "top"; layer = "top";
position = "top"; position = "top";
height = 30; height = 35;
margin = "7 7 3 7";
# width = 1280; # width = 1280;
spacing = 4; spacing = 2;
modules-left = [ ]; modules-left = [ "battery" "backlight" "pulseaudio" "cpu" "memory" ];
modules-center = [ "wlr/workspaces" ]; modules-center = [ "wlr/workspaces" ];
modules-right = [ "idle_inhibitor" "pulseaudio" "network" "cpu" "memory" "backlight" "battery" "clock" "tray"]; modules-right = [ "idle_inhibitor" "clock" "tray" ];
"wlr/workspaces" = { "wlr/workspaces" = {
"format" = "{icon}"; "format" = "{icon}";
"format-icons" = { "format-icons" = {
"1" = ""; "1" = "󱚌 ¹";
"2" = ""; "2" = "󰈹 ²";
"3" = ""; "3" = "󰈮 ³";
"4" = ""; "4" = "󱍙 ";
"5" = ""; "5" = "";
"6" = "󰄄 ";
"7" = "";
"8" = "";
"9" = "";
}; };
"persistent_workspaces" = { "persistent_workspaces" = {
"1" = [ ]; "1" = [ ];
@ -325,8 +330,8 @@
"idle_inhibitor" = { "idle_inhibitor" = {
format = "{icon}"; format = "{icon}";
format-icons = { format-icons = {
activated = ""; activated = "󰅶";
deactivated = ""; deactivated = "󰾪";
}; };
}; };
tray = { tray = {
@ -334,17 +339,19 @@
"spacing" = 10; "spacing" = 10;
}; };
clock = { clock = {
"interval" = 1;
"format" = "{:%a %Y-%m-%d %I:%M:%S %p}";
"timezone" = "America/New_York"; "timezone" = "America/New_York";
"tooltip-format" = "<big>{:%Y %B}</big>\n<tt><small>{calendar}</small></tt>"; "tooltip-format" = ''
"format-alt" = "{:%Y-%m-%d}"; <big>{:%Y %B}</big>
<tt><small>{calendar}</small></tt>'';
"format-alt" = "{:%I:%M:%S %p}";
}; };
cpu = { cpu = {
"format" = "{usage}% "; "format" = "{usage}% ";
"tooltip" = false; "tooltip" = false;
}; };
memory = { memory = { "format" = "{}% "; };
"format" = "{}% ";
};
backlight = { backlight = {
"format" = "{percent}% {icon}"; "format" = "{percent}% {icon}";
"format-icons" = [ "" "" "" "" "" "" "" "" "" ]; "format-icons" = [ "" "" "" "" "" "" "" "" "" ];
@ -363,14 +370,6 @@
#"format-full" = ""; #"format-full" = "";
"format-icons" = [ "" "" "" "" "" ]; "format-icons" = [ "" "" "" "" "" ];
}; };
network = {
"format-wifi" = "{essid} ({signalStrength}%) ";
"format-ethernet" = "{ipaddr}/{cidr} ";
"tooltip-format" = "{ifname} via {gwaddr} ";
"format-linked" = "{ifname} (No IP) ";
"format-disconnected" = "Disconnected ";
"format-alt" = "{ifname}: {ipaddr}/{cidr}";
};
pulseaudio = { pulseaudio = {
"scroll-step" = 1; "scroll-step" = 1;
"format" = "{volume}% {icon} {format_source}"; "format" = "{volume}% {icon} {format_source}";
@ -395,45 +394,30 @@
style = '' style = ''
* { * {
/* `otf-font-awesome` is required to be installed for icons */ /* `otf-font-awesome` is required to be installed for icons */
font-family: FontAwesome, Roboto, Helvetica, Arial, sans-serif; font-family: FontAwesome, Inconsolata;
font-size: 13px; font-size: 20px;
} }
window#waybar { window#waybar {
background-color: rgba(43, 48, 59, 0.9); background-color: #'' + config.lib.stylix.colors.base00 + '';
color: #ffffff; opacity: 0.87;
border-radius: 8px;
color: #'' + config.lib.stylix.colors.base07 + '';
transition-property: background-color; transition-property: background-color;
transition-duration: .5s; transition-duration: .2s;
}
window > box {
border-radius: 8px;
opacity: 0.87;
} }
window#waybar.hidden { window#waybar.hidden {
opacity: 0.2; opacity: 0.2;
} }
/*
window#waybar.empty {
background-color: transparent;
}
window#waybar.solo {
background-color: #FFFFFF;
}
*/
window#waybar.termite {
background-color: #3F3F3F;
}
window#waybar.chromium {
background-color: #000000;
border: none;
}
button { button {
/* Use box-shadow instead of border so the text isn't offset */
box-shadow: inset 0 -3px transparent;
/* Avoid rounded borders under each button name */
border: none; border: none;
border-radius: 2;
} }
/* https://github.com/Alexays/Waybar/wiki/FAQ#the-workspace-buttons-have-a-strange-hover-effect */ /* https://github.com/Alexays/Waybar/wiki/FAQ#the-workspace-buttons-have-a-strange-hover-effect */
@ -444,33 +428,27 @@
#workspaces button { #workspaces button {
padding: 0 7px; padding: 0 7px;
background-color: transparent; background-color: transparent;
color: #ffffff; color: #'' + config.lib.stylix.colors.base04 + '';
} }
#workspaces button:hover { #workspaces button:hover {
background: rgba(0, 0, 0, 0.2); color: #'' + config.lib.stylix.colors.base07 + '';
}
#workspaces button.focused {
background-color: #64727D;
box-shadow: inset 0 -3px #ffffff;
} }
#workspaces button.active { #workspaces button.active {
background-color: #ff0000; color: #'' + config.lib.stylix.colors.base08 + '';
}
#workspaces button.focused {
color: #'' + config.lib.stylix.colors.base0A + '';
} }
#workspaces button.visible { #workspaces button.visible {
background-color: #0000ff; color: #'' + config.lib.stylix.colors.base07 + '';
} }
#workspaces button.urgent { #workspaces button.urgent {
background-color: #eb4d4b; color: #'' + config.lib.stylix.colors.base09 + '';
}
#mode {
background-color: #64727D;
border-bottom: 3px solid #ffffff;
} }
#clock, #clock,
@ -490,7 +468,9 @@
#scratchpad, #scratchpad,
#mpd { #mpd {
padding: 0 10px; padding: 0 10px;
color: #ffffff; color: #'' + config.lib.stylix.colors.base07 + '';
border: none;
border-radius: 8px;
} }
#window, #window,
@ -509,29 +489,27 @@
} }
#clock { #clock {
background-color: #64727D; color: #'' + config.lib.stylix.colors.base0D + '';
} }
#battery { #battery {
background-color: #ffffff; color: #'' + config.lib.stylix.colors.base0B + '';
color: #000000;
} }
#battery.charging, #battery.plugged { #battery.charging, #battery.plugged {
color: #ffffff; color: #'' + config.lib.stylix.colors.base0C + '';
background-color: #26A65B;
} }
@keyframes blink { @keyframes blink {
to { to {
background-color: #ffffff; background-color: #'' + config.lib.stylix.colors.base07 + '';
color: #000000; color: #'' + config.lib.stylix.colors.base00 + '';
} }
} }
#battery.critical:not(.charging) { #battery.critical:not(.charging) {
background-color: #f53c3c; background-color: #'' + config.lib.stylix.colors.base08 + '';
color: #ffffff; color: #'' + config.lib.stylix.colors.base07 + '';
animation-name: blink; animation-name: blink;
animation-duration: 0.5s; animation-duration: 0.5s;
animation-timing-function: linear; animation-timing-function: linear;
@ -540,77 +518,31 @@
} }
label:focus { label:focus {
background-color: #000000; background-color: #'' + config.lib.stylix.colors.base00 + '';
} }
#cpu { #cpu {
background-color: #2ecc71; color: #'' + config.lib.stylix.colors.base0D + '';
color: #000000;
} }
#memory { #memory {
background-color: #9b59b6; color: #'' + config.lib.stylix.colors.base0E + '';
} }
#disk { #disk {
background-color: #964B00; color: #'' + config.lib.stylix.colors.base0F + '';
} }
#backlight { #backlight {
background-color: #90b1b1; color: #'' + config.lib.stylix.colors.base0A + '';
}
#network {
background-color: #2980b9;
}
#network.disconnected {
background-color: #f53c3c;
} }
#pulseaudio { #pulseaudio {
background-color: #f1c40f; color: #'' + config.lib.stylix.colors.base0C + '';
color: #000000;
} }
#pulseaudio.muted { #pulseaudio.muted {
background-color: #90b1b1; color: #'' + config.lib.stylix.colors.base04 + '';
color: #2a5c45;
}
#wireplumber {
background-color: #fff0f5;
color: #000000;
}
#wireplumber.muted {
background-color: #f53c3c;
}
#custom-media {
background-color: #66cc99;
color: #2a5c45;
min-width: 100px;
}
#custom-media.custom-spotify {
background-color: #66cc99;
}
#custom-media.custom-vlc {
background-color: #ffa000;
}
#temperature {
background-color: #f0932b;
}
#temperature.critical {
background-color: #eb4d4b;
}
#tray {
background-color: #2980b9;
} }
#tray > .passive { #tray > .passive {
@ -619,67 +551,15 @@
#tray > .needs-attention { #tray > .needs-attention {
-gtk-icon-effect: highlight; -gtk-icon-effect: highlight;
background-color: #eb4d4b;
} }
#idle_inhibitor { #idle_inhibitor {
background-color: #2d3436; color: #'' + config.lib.stylix.colors.base04 + '';
} }
#idle_inhibitor.activated { #idle_inhibitor.activated {
background-color: #ecf0f1; color: #'' + config.lib.stylix.colors.base0F + '';
color: #2d3436;
} }
#mpd {
background-color: #66cc99;
color: #2a5c45;
}
#mpd.disconnected {
background-color: #f53c3c;
}
#mpd.stopped {
background-color: #90b1b1;
}
#mpd.paused {
background-color: #51a37a;
}
#language {
background: #00b093;
color: #740864;
padding: 0 5px;
margin: 0 5px;
min-width: 16px;
}
#keyboard-state {
background: #97e1ad;
color: #000000;
padding: 0 0px;
margin: 0 5px;
min-width: 16px;
}
#keyboard-state > label {
padding: 0 5px;
}
#keyboard-state > label.locked {
background: rgba(0, 0, 0, 0.2);
}
#scratchpad {
background: rgba(0, 0, 0, 0.2);
}
#scratchpad.empty {
background-color: transparent;
}
''; '';
}; };
programs.fuzzel.enable = true; programs.fuzzel.enable = true;