feat: add clear all button for notifications

This commit is contained in:
Nydragon 2024-12-21 13:59:06 +01:00
parent 9aa6046cdd
commit 965cb228e7
Signed by: nydragon
SSH key fingerprint: SHA256:WcjW5NJPQ8Dx4uQDmoIlVPLWE27Od3fxoe0IUvuoPHE
3 changed files with 63 additions and 37 deletions

View file

@ -31,6 +31,13 @@ Singleton {
property alias list: server.trackedNotifications
function clearAll() {
const len = server.trackedNotifications.values.length;
for (let i = 0; i < len; i++) {
list.values[0].dismiss();
}
}
signal incomingRemoved(id: int)
signal incomingAdded(id: Notification)
}

View file

@ -1,53 +1,71 @@
import QtQuick
import QtQuick.Layouts
import "../../provider"
import "../../base"
ColumnLayout {
Layout.preferredHeight: 1000
ListView {
id: popupcol
Layout.fillHeight: true
Layout.fillWidth: true
Layout.preferredHeight: 1000
spacing: 10
width: parent.width
Component.onCompleted: () => {}
model: Notifications.list
delegate: NotificationToast {
id: toast
required property var modelData
required property int index
notif: modelData
width: ListView.view.width
onClose: {
toast.notif.dismiss();
BButton {
width: 30
height: 30
onClicked: () => {
Notifications.clearAll();
}
Layout.alignment: Qt.AlignRight
}
addDisplaced: Transition {
NumberAnimation {
properties: "x,y"
duration: 100
}
}
remove: Transition {
PropertyAction {
property: "ListView.delayRemove"
value: true
}
ParallelAnimation {
NumberAnimation {
property: "opacity"
to: 0
duration: 200
ListView {
id: popupcol
Layout.fillHeight: true
Layout.fillWidth: true
spacing: 10
width: parent.width
model: Notifications.list
delegate: NotificationToast {
id: toast
required property var modelData
required property int index
notif: modelData
width: ListView.view.width
onClose: {
toast.notif.dismiss();
}
}
PropertyAction {
property: "ListView.delayRemove"
value: true
addDisplaced: Transition {
NumberAnimation {
properties: "x,y"
duration: 100
}
}
remove: Transition {
PropertyAction {
property: "ListView.delayRemove"
value: true
}
ParallelAnimation {
NumberAnimation {
property: "opacity"
to: 0
duration: 200
}
}
PropertyAction {
property: "ListView.delayRemove"
value: true
}
}
}
}

View file

@ -136,6 +136,7 @@ MouseArea {
}
}
}
GridLayout {
id: actions
width: parent.width