battery: send notifications via dbus instead of internal service or notify-send

This commit is contained in:
Damocles 2026-04-29 18:18:42 +02:00
parent 88f14b26cd
commit 2acb4e70ad
3 changed files with 21 additions and 31 deletions

View file

@ -1,7 +1,7 @@
pragma Singleton
import QtQuick
import Quickshell.Services.Notifications
import Quickshell.Io
import Quickshell.Services.UPower
import "." as S
@ -62,14 +62,31 @@ QtObject {
if (root.percent < root.critThresh && !root._critSent) {
root._critSent = true;
root._warnSent = true;
S.NotifService.send("Very Low Battery", "Connect to power now!", NotificationUrgency.Critical, "battery-low");
root._sendNotif(2, "battery-low", "Very Low Battery", "Connect to power now!");
} else if (root.percent < root.warnThresh && !root._warnSent) {
root._warnSent = true;
S.NotifService.send("Low Battery", "", NotificationUrgency.Normal, "battery-caution");
root._sendNotif(1, "battery-caution", "Low Battery", "");
}
}
}
// Send notification via D-Bus so any active daemon receives it
function _sendNotif(urgency, icon, summary, body) {
_notifProc.command = ["busctl", "--user", "call", "org.freedesktop.Notifications", "/org/freedesktop/Notifications", "org.freedesktop.Notifications", "Notify", "susssasa{sv}i" // signature
, "nova-shell" // app_name
, "0" // replaces_id
, icon // app_icon
, summary // summary
, body // body
, "0" // actions (empty array)
, "1", "urgency", "y", String(urgency) // hints: urgency
, "-1" // expire_timeout
];
_notifProc.running = true;
}
property var _notifProc: Process {}
function fmtTime(secs) {
if (!secs || secs <= 0)
return "";