waybar: add waybar to config

This commit is contained in:
Nydragon 2024-05-17 03:24:58 +09:00
parent 5ec1d9e81f
commit 4705a3b248
No known key found for this signature in database
GPG key ID: 14AA30A865EA1209
4 changed files with 368 additions and 0 deletions

View file

@ -9,6 +9,7 @@
imports = [
./swayidle.nix
./swaylock.nix
./waybar
];
wayland.windowManager.sway =

186
home/sway/waybar/config.nix Normal file
View file

@ -0,0 +1,186 @@
{
modules-left = [
"tray"
"privacy"
"clock"
"sway/mode"
];
modules-center = [ "sway/workspaces" ];
modules-right = [
"backlight"
"pulseaudio"
"network"
"group/hardware"
"idle_inhibitor"
"custom/notification"
];
backlight = {
format = "{}% ";
interval = 1;
on-scroll-down = "brightnessctl s 10%-";
on-scroll-up = "brightnessctl s +10%";
tooltip = false;
};
battery = {
format = "{icon} {capacity}%";
format-charging = " {capacity}%";
format-icons = [
""
""
""
""
""
];
format-plugged = " {capacity}%";
states = {
critical = 20;
good = 95;
warning = 30;
};
};
clock = {
actions = {
on-click-backward = "tz_down";
on-click-forward = "tz_up";
on-click-right = "mode";
on-scroll-down = "shift_down";
on-scroll-up = "shift_up";
};
calendar = {
format = {
days = "<span color='#ecc6d9'><b>{}</b></span>";
months = "<span color='#ffead3'><b>{}</b></span>";
today = "<span color='#ff6699'><b><u>{}</u></b></span>";
weekdays = "<span color='#ffcc66'><b>{}</b></span>";
weeks = "<span color='#99ffdd'><b>W{}</b></span>";
};
mode = "year";
mode-mon-col = 3;
on-click-right = "mode";
on-scroll = 1;
weeks-pos = "right";
};
format = "{:%H:%M}";
format-alt = "{:%A, %B %d, %Y (%R)} ";
tooltip-format = "<tt><small>{calendar}</small></tt>";
};
cpu = {
format = " {}%";
interval = 15;
max-length = 10;
};
"custom/notification" = {
c-on-click-right = "swaync-client -d -sw";
escape = true;
exec = "swaync-client -swb";
exec-if = "which swaync-client";
format = "{icon}";
format-icons =
let
dot = "<span foreground='red'><sup></sup></span>";
in
{
dnd-inhibited-none = "";
dnd-inhibited-notification = "${dot}";
dnd-none = "";
dnd-notification = "${dot}";
inhibited-none = "";
inhibited-notification = "${dot}";
none = "";
notification = "${dot}";
};
on-click = "sh -c 'sleep 0.1s; swaync-client -t -sw; sleep 0.1s'";
return-type = "json";
tooltip = false;
};
"group/hardware" = {
drawer = {
transition-left-to-right = false;
};
modules = [
"battery"
"cpu"
"memory"
];
orientation = "horizontal";
};
idle_inhibitor = {
format = "{icon} ";
format-icons = {
activated = "";
deactivated = "";
};
};
layer = "bottom";
memory = {
format = " {}%";
interval = 30;
max-length = 10;
};
network = {
format-wifi = "{essid} ({signalStrength}%) ";
on-click = "alacritty -t nmtui -e nmtui";
};
position = "top";
privacy = {
icon-size = 18;
icon-spacing = 4;
modules = [
{
tooltip = true;
tooltip-icon-size = 24;
type = "screenshare";
}
{
tooltip = true;
tooltip-icon-size = 24;
type = "audio-out";
}
{
tooltip = true;
tooltip-icon-size = 24;
type = "audio-in";
}
];
transition-duration = 250;
};
pulseaudio = {
format = "{volume}% {icon} {format_source}";
format-bluetooth = "{volume}% {icon} {format_source}";
format-bluetooth-muted = " {icon} {format_source}";
format-icons = {
car = "";
default = [
""
"奔"
""
];
hands-free = "";
headphone = "";
headset = "";
phone = "";
portable = "";
};
format-muted = " {format_source}";
format-source = "{volume}% ";
format-source-muted = "";
on-click = "pavucontrol";
scroll-step = 1;
tooltip = false;
};
"sway/mode" = {
format = "{}";
max-length = 50;
};
"sway/workspaces" = {
all-outputs = true;
disable-scroll = true;
format = "{name}";
};
tray = {
icon-size = 18;
show-passive-items = false;
spacing = 10;
};
}

View file

@ -0,0 +1,9 @@
{ pkgs, ... }:
{
programs.waybar = {
enable = true;
settings = {
main = import ./config.nix;
};
};
}

172
home/sway/waybar/style.nix Normal file
View file

@ -0,0 +1,172 @@
''
* {
font-family: "DejaVuSansMNerdFont-Regular";
border: none;
opacity: 50;
border-radius: 10px;
font-size: 13px; }
window#waybar {
background: transparent; }
window#waybar.hidden {
opacity: 0.2; }
#window {
padding-left: 10px;
padding-right: 10px;
border-radius: 10px;
transition: none;
color: transparent;
background: transparent; }
.modules-center {
margin: 3px 0 0 0; }
.modules-right {
margin: 3px 8px 0 0; }
.modules-left {
margin: 3px 0 0 8px; }
#workspaces {
background-color: rgba(13, 214, 250, 0.4); }
#workspaces button {
padding: 1px 5px; }
#workspaces button:hover {
background-color: rgba(159, 255, 255, 0.9); }
#workspaces button.focused {
background-color: rgba(50, 194, 219, 0.7); }
#network {
margin-left: 4px;
margin-right: 4px;
border-radius: 10px;
padding-left: 10px;
padding-right: 10px;
color: #161320;
background: #bd93f9; }
#pulseaudio {
margin-left: 4px;
margin-right: 4px;
border-radius: 10px;
padding-left: 10px;
padding-right: 10px;
min-width: 23px;
color: #1a1826;
background: #fae3b0; }
#backlight {
margin-left: 4px;
margin-right: 4px;
border-radius: 10px;
padding-left: 10px;
padding-right: 10px;
color: #161320;
background: #f8bd96; }
#clock {
margin-left: 4px;
margin-right: 4px;
border-radius: 10px;
padding-left: 10px;
padding-right: 10px;
color: #161320;
background: #abe9b3; }
#memory {
margin-left: 4px;
margin-right: 4px;
border-radius: 10px;
padding-left: 10px;
padding-right: 10px;
color: #161320;
background: #ddb6f2; }
#privacy {
margin-left: 4px;
margin-right: 4px;
border-radius: 10px;
padding-left: 10px;
padding-right: 10px;
color: #161320;
background: #ddb6f2; }
#cpu {
margin-left: 4px;
margin-right: 4px;
border-radius: 10px;
padding-left: 10px;
padding-right: 10px;
color: #161320;
background: #96cdfb; }
#tray {
padding-left: 10px;
margin-right: 4px;
padding-right: 10px;
border-radius: 10px;
color: #b5e8e0;
background: #161320; }
#idle_inhibitor {
margin-left: 4px;
margin-right: 4px;
border-radius: 10px;
padding-left: 10px;
padding-right: 10px;
font-size: 20px;
color: #161320;
background: #f28fad; }
#group-power {
margin-left: 4px;
margin-right: 4px;
border-radius: 10px;
padding-left: 10px;
padding-right: 10px;
font-size: 20px;
transition: none;
color: #161320;
background: #f28fad; }
#custom-notification {
margin-left: 4px;
padding-left: 10px;
padding-right: 10px;
border-radius: 10px;
color: #161320;
background: #f2cdcd;
font-family: "NotoSansMono Nerd Font"; }
#mode {
margin-left: 4px;
margin-right: 4px;
border-radius: 10px;
padding-left: 10px;
padding-right: 10px;
color: #161320;
background: #ddb6f2; }
@keyframes blink {
to {
background-color: #bf616a;
color: #b5e8e0; } }
#battery {
margin-left: 4px;
margin-right: 4px;
border-radius: 10px;
padding-left: 10px;
padding-right: 10px;
color: #161320;
background: #b5e8e0; }
#battery .critical:not(.charging) {
animation-name: blink;
animation-duration: 0.5s;
animation-timing-function: linear;
animation-iteration-count: infinite;
animation-direction: alternate; }
''