Swayidle: Difference between revisions
Appearance
mNo edit summary |
mNo edit summary |
||
Line 25: | Line 25: | ||
# Lock command | # Lock command | ||
lock = "${pkgs.swaylock}/bin/swaylock --daemonize"; | lock = "${pkgs.swaylock}/bin/swaylock --daemonize"; | ||
# TODO: modify "display" function based on your window manager | |||
# Sway | # Sway | ||
display = status: "swaymsg 'output * power ${status}'"; \ | display = status: "swaymsg 'output * power ${status}'"; \ |
Revision as of 15:26, 4 July 2025
Swayidle is an idle management daemon for Wayland.
Installation
Install via Home Manager:
❄︎ ~/.config/home-manager/home.nix
services.swayidle.enable = true;
Configuration
Swayidle has a lot of flexibility in its setup, but what is usually done is as follows:
- Send notification before doing the following
- Lock screen
- Turn off the screen (Note that the command may differ among window managers)
- Suspend the system
which could be set using services.swayidle.timeouts
. services.swayidle.events
is useful to make the behavior consistent with the above in case systemctl suspend
, loginctl lock-session
are manually run.
❄︎ ~/.config/home-manager/home.nix
services.swayidle =
let
# Lock command
lock = "${pkgs.swaylock}/bin/swaylock --daemonize";
# TODO: modify "display" function based on your window manager
# Sway
display = status: "swaymsg 'output * power ${status}'"; \
# Hyprland
# display = status: "hyprctl dispatch dpms ${status}";
# Niri
# display = status: "${pkgs.niri}/bin/niri msg action power-${status}-monitors";
in
{
enable = true;
timeouts = [
{
timeout = 15; # in seconds
command = "${pkgs.libnotify}/bin/notify-send 'Locking in 5 seconds' -t 5000";
}
{
timeout = 20;
command = lock;
}
{
timeout = 25;
command = display "off";
resumeCommand = display "on";
}
{
timeout = 30;
command = "${pkgs.systemd}/bin/systemctl suspend";
}
];
events = [
{
event = "before-sleep";
command = display "off";
}
{
event = "before-sleep";
command = lock;
}
{
event = "after-resume";
command = display "on";
}
{
event = "lock";
command = lock;
}
{
event = "lock";
command = display "off";
}
{
event = "unlock";
command = display "on";
}
];
};
See the man page for further information.