[idle;lock] Switches to swaylock
This commit is contained in:
@@ -4,7 +4,7 @@
|
||||
enable = true;
|
||||
settings = {
|
||||
general = {
|
||||
lock_cmd = "pidof hyprlock || hyprlock"; # avoid starting multiple hyprlock instances.
|
||||
lock_cmd = "pidof swaylock || swaylock"; # avoid starting multiple lock instances.
|
||||
before_sleep_cmd = "loginctl lock-session"; # lock before suspend.
|
||||
after_sleep_cmd = "hyprctl dispatch dpms on"; # to avoid having to press a key twice to turn on the display.
|
||||
};
|
||||
|
||||
@@ -1,6 +1,7 @@
|
||||
{ pkgs, ... }:
|
||||
{
|
||||
imports = [
|
||||
./swaylock.nix
|
||||
./hypr/hypridle.nix
|
||||
];
|
||||
|
||||
@@ -426,7 +427,7 @@
|
||||
};
|
||||
|
||||
programs.hyprlock = {
|
||||
enable = true;
|
||||
enable = false;
|
||||
settings = {
|
||||
general = {
|
||||
disable_loading_bar = true;
|
||||
|
||||
@@ -11,7 +11,7 @@ dir="${HOME}/.config/rofi/powermenu"
|
||||
|
||||
# CMDs
|
||||
uptime="$(uptime | awk -F ' ' '{print $2}' | sed -e 's/,//g')"
|
||||
host=`hostname`
|
||||
host=$(hostname)
|
||||
|
||||
# Options
|
||||
shutdown=''
|
||||
@@ -76,7 +76,9 @@ run_cmd() {
|
||||
qdbus org.kde.ksmserver /KSMServer logout 0 0 0
|
||||
elif [[ "$DESKTOP_SESSION" == 'plasma' ]]; then
|
||||
qdbus org.kde.ksmserver /KSMServer logout 0 0 0
|
||||
elif command -v hyprctl &>/dev/null; then
|
||||
elif [[ "$DESKTOP_SESSION" == 'hyprland-uwsm' ]]; then
|
||||
hyprctl dispatch exit
|
||||
elif [[ "$DESKTOP_SESSION" == 'hyprland' ]]; then
|
||||
hyprctl dispatch exit
|
||||
fi
|
||||
fi
|
||||
@@ -95,13 +97,16 @@ case ${chosen} in
|
||||
run_cmd --reboot
|
||||
;;
|
||||
$lock)
|
||||
if [[ -x '/usr/bin/betterlockscreen' ]]; then
|
||||
betterlockscreen -l
|
||||
elif [[ -x '/usr/bin/i3lock' ]]; then
|
||||
i3lock
|
||||
elif command -v hyprlock &>/dev/null; then
|
||||
hyprlock
|
||||
fi
|
||||
loginctl lock-session
|
||||
# if [[ -x '/usr/bin/betterlockscreen' ]]; then
|
||||
# betterlockscreen -l
|
||||
# elif [[ -x '/usr/bin/i3lock' ]]; then
|
||||
# i3lock
|
||||
# elif command -v hyprlock &>/dev/null; then
|
||||
# hyprlock
|
||||
# elif command -v swaylock &>/dev/null; then
|
||||
# swaylock
|
||||
# fi
|
||||
;;
|
||||
$suspend)
|
||||
run_cmd --suspend
|
||||
|
||||
@@ -1,21 +1,12 @@
|
||||
{
|
||||
config,
|
||||
lib,
|
||||
pkgs,
|
||||
...
|
||||
}:
|
||||
{
|
||||
imports = [
|
||||
./swaync.nix
|
||||
];
|
||||
|
||||
home.packages = with pkgs; [
|
||||
hyprlock # lock screen
|
||||
# swayidle # lock on idle
|
||||
# swayosd # volume pop-up
|
||||
# swaynotificationcenter # notifications
|
||||
# hyprpolkitagent # Privilege managent
|
||||
# hyprshot # Screenshot utility
|
||||
./swaylock.nix
|
||||
];
|
||||
|
||||
services.swayosd = {
|
||||
@@ -23,16 +14,6 @@
|
||||
topMargin = 0.7;
|
||||
};
|
||||
|
||||
services.swayidle = {
|
||||
enable = true;
|
||||
events = [
|
||||
{
|
||||
event = "before-sleep";
|
||||
command = "hyprlock";
|
||||
}
|
||||
];
|
||||
};
|
||||
|
||||
# Enable sway config generation for home.pointerCursor
|
||||
home.pointerCursor.sway.enable = true;
|
||||
|
||||
|
||||
23
home-manager/features/swaylock.nix
Normal file
23
home-manager/features/swaylock.nix
Normal file
@@ -0,0 +1,23 @@
|
||||
{ pkgs, ... }:
|
||||
{
|
||||
programs.swaylock = {
|
||||
enable = true;
|
||||
package = pkgs.swaylock-effects;
|
||||
settings = {
|
||||
clock = true;
|
||||
indicator = true;
|
||||
effect-pixelate = 10;
|
||||
};
|
||||
};
|
||||
|
||||
home.file.".config/swaylock/swaylock.sh" = {
|
||||
executable = true;
|
||||
text = ''
|
||||
#!/bin/env bash
|
||||
|
||||
image=`fd . ~/Pictures/Wallpaper --type f | sort -R | tail -1`
|
||||
|
||||
swaylock --image "$image"
|
||||
'';
|
||||
};
|
||||
}
|
||||
@@ -32,13 +32,6 @@
|
||||
userEmail = "periodic@blazestar.net";
|
||||
};
|
||||
|
||||
# TODO: Hyprlock is not working correctly on this system and is showing the
|
||||
# desktop but the screen is still locked. Disabling it for now.
|
||||
services.hypridle.settings.general = {
|
||||
lock_cmd = lib.mkForce "";
|
||||
before_sleep_cmd = lib.mkForce "";
|
||||
};
|
||||
|
||||
wayland.windowManager.hyprland.settings = {
|
||||
# Set up eww here because it's based on the monitor configuration
|
||||
# Eww is idempotent, so it's fine to just run it on every reload to make sure things are open
|
||||
|
||||
Reference in New Issue
Block a user