Merge branch 'release-1.2'

main v1.2.0
Ruakij 2 years ago
commit f21d019f50

@ -32,7 +32,11 @@ This script aims to fix this.
Adding a script to `notifyrc` as event makes it possible to change settings when screen-locking begins. Adding a script to `notifyrc` as event makes it possible to change settings when screen-locking begins.
So after x seconds the screen will simply be forcefully turned off using `xset`. When the screen is locked, the script will change the screen-timeout to a custom-value in the config `~/.config/powermanagementprofilesrc` (or a default of 10s).
This is done, so even after the System wakes up and activates the screens e.g. when mouse is moved, but no unlock is done, the screen begins to sleep quickly again.
After a successful unlock, the value from the config is reapplied.
<br> <br>
@ -40,4 +44,10 @@ So after x seconds the screen will simply be forcefully turned off using `xset`.
Place the file `event_screensaver` to a bin-location, for a local user this is typically `~/.local/bin/` and make it executeable. Place the file `event_screensaver` to a bin-location, for a local user this is typically `~/.local/bin/` and make it executeable.
In Settings under `Notifications > Applications > Configure > 'Screen Saver' > Configure Events...` for event `Screen locked`, enable `Run command` and add your script-location for `event_screensaver`. In Settings under `Notifications > Applications > Configure > 'Screen Saver' > Configure Events...` for event locked & unlocked, enable `Run command` and add your script-location for `event_screensaver` and the event triggered.
Example:
```
Screen locked
Run Command: ~/.local/bin/event_screenSaver locked
```

@ -1,18 +1,25 @@
#!/bin/sh #!/bin/sh
SCREENSAVER_TIMEOUT_DEFAULT=10
NORMAL_TIMEOUT_DEFAULT=1800
is_screen_locked() case "$1" in
{ "locked")
if dbus-send --session --dest=org.freedesktop.ScreenSaver --type=method_call --print-reply /org/freedesktop/ScreenSaver org.freedesktop.ScreenSaver.GetActive | grep 'boolean true' > /dev/null; then # Read timeout from KDE
return 0 SCREENSAVER_TIMEOUT=$(kreadconfig5 --file powermanagementprofilesrc --group AC --group DPMSControl --key idleTime_screenSaver)
else TIMEOUT="${NORMAL_TIMEOUT:-$SCREENSAVER_TIMEOUT_DEFAULT}"
return 1 ;;
fi
}
# Sleep to timeout "unlocked")
sleep 15 # Read timeout from KDE
NORMAL_TIMEOUT=$(kreadconfig5 --file powermanagementprofilesrc --group AC --group DPMSControl --key idleTime)
TIMEOUT="${NORMAL_TIMEOUT:-$NORMAL_TIMEOUT_DEFAULT}"
;;
if is_screen_locked; then *)
# Disable screens echo "$0 <locked|unlocked>"
xset dpms force off exit 1
fi ;;
esac
# Set timeout-value
xset s ${TIMEOUT} ${TIMEOUT}

Loading…
Cancel
Save