Swayidle: Difference between revisions
Appearance
mNo edit summary |
Fix events with duplicated entries not working |
||
Line 57: | Line 57: | ||
{ | { | ||
event = "before-sleep"; | event = "before-sleep"; | ||
command = display "off"; | # adding duplicated entries for the same event may not work | ||
command = (display "off") + "; " + lock; | |||
} | } | ||
{ | { | ||
Line 69: | Line 66: | ||
{ | { | ||
event = "lock"; | event = "lock"; | ||
command = | command = (display "off") + "; " + lock; | ||
} | } | ||
{ | { |
Latest revision as of 02:53, 5 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 (typically Swaylock is used)
- 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";
# adding duplicated entries for the same event may not work
command = (display "off") + "; " + lock;
}
{
event = "after-resume";
command = display "on";
}
{
event = "lock";
command = (display "off") + "; " + lock;
}
{
event = "unlock";
command = display "on";
}
];
};
See the man page for further information.