summaryrefslogtreecommitdiff
diff options
context:
space:
mode:
-rw-r--r--modules/sidebar/NotifGroup.qml8
-rw-r--r--services/Notifs.qml10
2 files changed, 7 insertions, 11 deletions
diff --git a/modules/sidebar/NotifGroup.qml b/modules/sidebar/NotifGroup.qml
index 95b1f4a..c974ce3 100644
--- a/modules/sidebar/NotifGroup.qml
+++ b/modules/sidebar/NotifGroup.qml
@@ -19,9 +19,9 @@ StyledRect {
readonly property list<var> notifs: Notifs.list.filter(n => n.appName === modelData)
readonly property int notifCount: notifs.reduce((acc, n) => n.closed ? acc : acc + 1, 0)
- readonly property string image: notifs.find(n => n.image.length > 0)?.image ?? ""
- readonly property string appIcon: notifs.find(n => n.appIcon.length > 0)?.appIcon ?? ""
- readonly property int urgency: notifs.some(n => n.urgency === NotificationUrgency.Critical) ? NotificationUrgency.Critical : notifs.some(n => n.urgency === NotificationUrgency.Normal) ? NotificationUrgency.Normal : NotificationUrgency.Low
+ readonly property string image: notifs.find(n => !n.closed && n.image.length > 0)?.image ?? ""
+ readonly property string appIcon: notifs.find(n => !n.closed && n.appIcon.length > 0)?.appIcon ?? ""
+ readonly property int urgency: notifs.some(n => !n.closed && n.urgency === NotificationUrgency.Critical) ? NotificationUrgency.Critical : notifs.some(n => n.urgency === NotificationUrgency.Normal) ? NotificationUrgency.Normal : NotificationUrgency.Low
readonly property int nonAnimHeight: {
const headerHeight = header.implicitHeight + (root.expanded ? Math.round(Appearance.spacing.small / 2) : 0);
@@ -162,7 +162,7 @@ StyledRect {
StyledText {
animate: true
- text: root.notifs[0]?.timeStr ?? ""
+ text: root.notifs.find(n => !n.closed)?.timeStr ?? ""
color: Colours.palette.m3outline
font.pointSize: Appearance.font.size.small
}
diff --git a/services/Notifs.qml b/services/Notifs.qml
index 1de3805..3a81c5f 100644
--- a/services/Notifs.qml
+++ b/services/Notifs.qml
@@ -274,18 +274,14 @@ Singleton {
function unlock(item: Item): void {
locks.delete(item);
-
- if (closed && locks.size === 0 && root.list.includes(this)) {
- root.list.splice(root.list.indexOf(this), 1);
- notification?.dismiss();
- destroy();
- }
+ if (closed)
+ close();
}
function close(): void {
closed = true;
if (locks.size === 0 && root.list.includes(this)) {
- root.list.splice(root.list.indexOf(this), 1);
+ root.list = root.list.filter(n => n !== this);
notification?.dismiss();
destroy();
}