home: Rework status bar
This commit is contained in:
parent
7d5746482e
commit
fa23297efd
1 changed files with 105 additions and 105 deletions
|
@ -6,7 +6,9 @@ let
|
||||||
busctl = osConfig.systemd.package + /bin/busctl;
|
busctl = osConfig.systemd.package + /bin/busctl;
|
||||||
gammarelay = lib.getExe pkgs.wl-gammarelay-rs;
|
gammarelay = lib.getExe pkgs.wl-gammarelay-rs;
|
||||||
pwvucontrol = lib.getExe pkgs.pwvucontrol;
|
pwvucontrol = lib.getExe pkgs.pwvucontrol;
|
||||||
|
rfkill = pkgs.util-linux + /bin/rfkill;
|
||||||
wpctl = osConfig.services.pipewire.wireplumber.package + /bin/wpctl;
|
wpctl = osConfig.services.pipewire.wireplumber.package + /bin/wpctl;
|
||||||
|
wttrbar = pkgs.wttrbar + /bin/wttrbar;
|
||||||
|
|
||||||
gr = cmd: "${busctl} --user -- ${cmd} rs.wl-gammarelay / rs.wl.gammarelay";
|
gr = cmd: "${busctl} --user -- ${cmd} rs.wl-gammarelay / rs.wl.gammarelay";
|
||||||
gr-set = gr "set-property";
|
gr-set = gr "set-property";
|
||||||
|
@ -30,6 +32,10 @@ in lib.mkIf (osConfig.hardware.graphics.enable or false) {
|
||||||
font: 600 12pt sans-serif;
|
font: 600 12pt sans-serif;
|
||||||
}
|
}
|
||||||
|
|
||||||
|
window > box {
|
||||||
|
padding: 1.5mm 3mm;
|
||||||
|
}
|
||||||
|
|
||||||
window, tooltip {
|
window, tooltip {
|
||||||
background: ${base00};
|
background: ${base00};
|
||||||
color: ${base05};
|
color: ${base05};
|
||||||
|
@ -40,8 +46,8 @@ in lib.mkIf (osConfig.hardware.graphics.enable or false) {
|
||||||
}
|
}
|
||||||
|
|
||||||
label.module {
|
label.module {
|
||||||
|
padding: 0 3mm;
|
||||||
min-width: 5mm;
|
min-width: 5mm;
|
||||||
padding: 0 2mm;
|
|
||||||
}
|
}
|
||||||
|
|
||||||
#battery.5, #battery.10, #battery.15 {
|
#battery.5, #battery.10, #battery.15 {
|
||||||
|
@ -69,43 +75,80 @@ in lib.mkIf (osConfig.hardware.graphics.enable or false) {
|
||||||
main = {
|
main = {
|
||||||
layer = "top";
|
layer = "top";
|
||||||
position = "bottom";
|
position = "bottom";
|
||||||
height = 32;
|
spacing = 0;
|
||||||
|
|
||||||
modules-left = [
|
|
||||||
"tray"
|
|
||||||
];
|
|
||||||
|
|
||||||
modules-center = [ ];
|
|
||||||
|
|
||||||
|
modules-left = [ "tray" ];
|
||||||
|
modules-center = [ "mpris" ];
|
||||||
modules-right = [
|
modules-right = [
|
||||||
"network#down"
|
"idle_inhibitor"
|
||||||
"network#up"
|
"network"
|
||||||
"bluetooth"
|
"bluetooth"
|
||||||
|
"temperature"
|
||||||
"cpu"
|
"cpu"
|
||||||
"memory"
|
"memory"
|
||||||
"memory#swap"
|
|
||||||
"temperature"
|
|
||||||
"disk"
|
"disk"
|
||||||
"battery"
|
|
||||||
"idle_inhibitor"
|
|
||||||
"backlight"
|
"backlight"
|
||||||
"custom/gammarelay"
|
"custom/gammarelay"
|
||||||
"mpris"
|
|
||||||
"pulseaudio#sink"
|
"pulseaudio#sink"
|
||||||
"pulseaudio#source"
|
"pulseaudio#source"
|
||||||
|
"battery"
|
||||||
|
"custom/weather"
|
||||||
"clock"
|
"clock"
|
||||||
];
|
];
|
||||||
|
|
||||||
"network#down" = {
|
mpris = {
|
||||||
format = " {bandwidthDownBytes}";
|
interval = 1;
|
||||||
|
format = "{status_icon} {dynamic} {player_icon}";
|
||||||
|
dynamic-order = [ "title" "artist" "position" "length" ];
|
||||||
|
dynamic-separator = " – ";
|
||||||
|
ellipsis = "…";
|
||||||
|
|
||||||
|
player-icons = {
|
||||||
|
default = "";
|
||||||
|
mopidy = "";
|
||||||
|
mpv = "";
|
||||||
};
|
};
|
||||||
|
|
||||||
"network#up" = {
|
status-icons = {
|
||||||
format = " {bandwidthUpBytes}";
|
playing = "";
|
||||||
|
paused = "";
|
||||||
|
stopped = "";
|
||||||
|
};
|
||||||
|
};
|
||||||
|
|
||||||
|
idle_inhibitor = {
|
||||||
|
format = "{icon}";
|
||||||
|
format-icons = {
|
||||||
|
activated = "";
|
||||||
|
deactivated = "";
|
||||||
|
};
|
||||||
|
|
||||||
|
timeout = 15.0;
|
||||||
|
};
|
||||||
|
|
||||||
|
"network" = {
|
||||||
|
interval = 10;
|
||||||
|
format = "{icon} {bandwidthDownBytes} {bandwidthUpBytes}";
|
||||||
|
format-icons = {
|
||||||
|
disconnected = "";
|
||||||
|
linked = "";
|
||||||
|
ethernet = "";
|
||||||
|
wifi = [ "" "" "" "" "" ];
|
||||||
|
};
|
||||||
|
|
||||||
|
tooltip-format = "{ifname}";
|
||||||
|
tooltip-format-wifi = "{essid} ({signalStrength} %)";
|
||||||
};
|
};
|
||||||
|
|
||||||
bluetooth = {
|
bluetooth = {
|
||||||
format-connected-battery = " {device_battery_percentage} %";
|
format = "";
|
||||||
|
format-off = "";
|
||||||
|
format-on = "";
|
||||||
|
format-connected = "";
|
||||||
|
format-connected-battery = " {device_battery_percentage} %";
|
||||||
|
|
||||||
|
on-click-right = "${rfkill} toggle bluetooth";
|
||||||
|
|
||||||
tooltip-format-connected-battery = "{device_enumerate}";
|
tooltip-format-connected-battery = "{device_enumerate}";
|
||||||
tooltip-format-enumerate-connected-battery = "{device_alias}\t{device_battery_percentage} %";
|
tooltip-format-enumerate-connected-battery = "{device_alias}\t{device_battery_percentage} %";
|
||||||
};
|
};
|
||||||
|
@ -115,19 +158,14 @@ in lib.mkIf (osConfig.hardware.graphics.enable or false) {
|
||||||
};
|
};
|
||||||
|
|
||||||
memory = {
|
memory = {
|
||||||
format = " {percentage} %";
|
format = " {percentage} % {swapPercentage} %";
|
||||||
tooltip-format = "{used:0.1f} / {total:0.1f} GiB";
|
tooltip-format = "{used:0.1f} / {total:0.1f} GiB\n{swapUsed:0.1f} / {swapTotal:0.1f} GiB";
|
||||||
states = {
|
states = {
|
||||||
warning = 96;
|
warning = 96;
|
||||||
critical = 99;
|
critical = 99;
|
||||||
};
|
};
|
||||||
};
|
};
|
||||||
|
|
||||||
"memory#swap" = {
|
|
||||||
format = " {swapPercentage} %";
|
|
||||||
tooltip-format = "{swapUsed:0.1f} / {swapTotal:0.1f} GiB";
|
|
||||||
};
|
|
||||||
|
|
||||||
temperature = let
|
temperature = let
|
||||||
fmt = "{temperatureC} °C";
|
fmt = "{temperatureC} °C";
|
||||||
in {
|
in {
|
||||||
|
@ -142,96 +180,45 @@ in lib.mkIf (osConfig.hardware.graphics.enable or false) {
|
||||||
tooltip-format = "{used} / {total}";
|
tooltip-format = "{used} / {total}";
|
||||||
};
|
};
|
||||||
|
|
||||||
idle_inhibitor = {
|
"backlight" = let
|
||||||
format = "{icon}";
|
fmt = "{percent} %";
|
||||||
format-icons = {
|
in {
|
||||||
activated = "";
|
format = "{icon} ${fmt}";
|
||||||
deactivated = "";
|
format-icons = [ "" "" "" "" "" "" "" "" "" "" "" ];
|
||||||
};
|
|
||||||
|
|
||||||
timeout = 15.0;
|
on-click = "${brightnessctl} set 100%";
|
||||||
};
|
on-click-right = "${brightnessctl} set 5%";
|
||||||
|
|
||||||
"backlight" = {
|
|
||||||
format = " {percent} %";
|
|
||||||
on-click-right = "${brightnessctl} set 100%";
|
|
||||||
on-scroll-up = "${brightnessctl} set +1%";
|
on-scroll-up = "${brightnessctl} set +1%";
|
||||||
on-scroll-down = "${brightnessctl} set 1%-";
|
on-scroll-down = "${brightnessctl} set 1%-";
|
||||||
|
|
||||||
|
tooltip-format = fmt;
|
||||||
};
|
};
|
||||||
|
|
||||||
"custom/gammarelay" = {
|
"custom/gammarelay" = let
|
||||||
format = " {} K";
|
fmt = "{} K";
|
||||||
|
in {
|
||||||
|
format = " ${fmt}";
|
||||||
exec = "${gammarelay} watch {t}";
|
exec = "${gammarelay} watch {t}";
|
||||||
on-click-right = "${gr-set} Temperature q 6500";
|
|
||||||
|
on-click = "${gr-set} Temperature q 6500";
|
||||||
|
on-click-right = "${gr-set} Temperature q 4500";
|
||||||
on-scroll-up = "${gr-call} UpdateTemperature n +100";
|
on-scroll-up = "${gr-call} UpdateTemperature n +100";
|
||||||
on-scroll-down = "${gr-call} UpdateTemperature n -100";
|
on-scroll-down = "${gr-call} UpdateTemperature n -100";
|
||||||
|
|
||||||
|
tooltip-format = fmt;
|
||||||
};
|
};
|
||||||
|
|
||||||
battery = let
|
battery = {
|
||||||
fmt = "{capacity} %";
|
format = "{icon} {capacity} %";
|
||||||
dis = {
|
format-icons = {
|
||||||
"5" = "";
|
full = "";
|
||||||
"10" = "";
|
plugged = "";
|
||||||
"20" = "";
|
charging = [ "" "" "" "" "" "" "" "" "" "" "" ];
|
||||||
"30" = "";
|
discharging = [ "" "" "" "" "" "" "" "" "" "" "" ];
|
||||||
"40" = "";
|
|
||||||
"50" = "";
|
|
||||||
"60" = "";
|
|
||||||
"70" = "";
|
|
||||||
"80" = "";
|
|
||||||
"90" = "";
|
|
||||||
"100" = "";
|
|
||||||
};
|
};
|
||||||
|
|
||||||
chr = {
|
|
||||||
"5" = "";
|
|
||||||
"10" = "";
|
|
||||||
"20" = "";
|
|
||||||
"30" = "";
|
|
||||||
"40" = "";
|
|
||||||
"50" = "";
|
|
||||||
"60" = "";
|
|
||||||
"70" = "";
|
|
||||||
"80" = "";
|
|
||||||
"90" = "";
|
|
||||||
"100" = "";
|
|
||||||
};
|
|
||||||
in {
|
|
||||||
states = {
|
|
||||||
"5" = 5;
|
|
||||||
"10" = 10;
|
|
||||||
"20" = 20;
|
|
||||||
"30" = 30;
|
|
||||||
"40" = 40;
|
|
||||||
"50" = 50;
|
|
||||||
"60" = 60;
|
|
||||||
"70" = 70;
|
|
||||||
"80" = 80;
|
|
||||||
"90" = 90;
|
|
||||||
"100" = 100;
|
|
||||||
};
|
|
||||||
|
|
||||||
format-full = " ${fmt}";
|
|
||||||
format-plugged = " ${fmt}";
|
|
||||||
format-time = "{H}:{M}";
|
format-time = "{H}:{M}";
|
||||||
weighted-average = true;
|
weighted-average = true;
|
||||||
}
|
|
||||||
// lib.mapAttrs' (state: icon: {
|
|
||||||
name = "format-discharging-${state}";
|
|
||||||
value = "${icon} ${fmt}";
|
|
||||||
}) dis
|
|
||||||
// lib.mapAttrs' (state: icon: {
|
|
||||||
name = "format-charging-${state}";
|
|
||||||
value = "${icon} ${fmt}";
|
|
||||||
}) chr;
|
|
||||||
|
|
||||||
mpris = {
|
|
||||||
format = "{status_icon}";
|
|
||||||
status-icons = {
|
|
||||||
playing = "";
|
|
||||||
paused = "";
|
|
||||||
stopped = "";
|
|
||||||
};
|
|
||||||
};
|
};
|
||||||
|
|
||||||
"pulseaudio#sink" = let
|
"pulseaudio#sink" = let
|
||||||
|
@ -265,9 +252,17 @@ in lib.mkIf (osConfig.hardware.graphics.enable or false) {
|
||||||
on-scroll-down = "${wpctl} set-volume @DEFAULT_AUDIO_SOURCE@ 1%-";
|
on-scroll-down = "${wpctl} set-volume @DEFAULT_AUDIO_SOURCE@ 1%-";
|
||||||
};
|
};
|
||||||
|
|
||||||
|
"custom/weather" = {
|
||||||
|
exec = "${wttrbar} --hide-conditions --custom-indicator '{ICON} {temp_C} °C'";
|
||||||
|
return-type = "json";
|
||||||
|
interval = 900;
|
||||||
|
};
|
||||||
|
|
||||||
clock = {
|
clock = {
|
||||||
format = " {:%H:%M %Z}";
|
interval = 1;
|
||||||
format-alt = " {:%Y-%m-%d}";
|
format = " {:%H:%M:%S %Z}";
|
||||||
|
format-alt = " {:%Y-%m-%d}";
|
||||||
|
|
||||||
tooltip-format = "<tt><small>{calendar}</small></tt>";
|
tooltip-format = "<tt><small>{calendar}</small></tt>";
|
||||||
calendar = {
|
calendar = {
|
||||||
mode = "month";
|
mode = "month";
|
||||||
|
@ -277,6 +272,11 @@ in lib.mkIf (osConfig.hardware.graphics.enable or false) {
|
||||||
weeks = "{:%W}";
|
weeks = "{:%W}";
|
||||||
};
|
};
|
||||||
};
|
};
|
||||||
|
|
||||||
|
actions = {
|
||||||
|
on-scroll-up = "shift_up";
|
||||||
|
on-scroll-down = "shift_down";
|
||||||
|
};
|
||||||
};
|
};
|
||||||
};
|
};
|
||||||
};
|
};
|
||||||
|
|
Loading…
Reference in a new issue