forked from Shinonome/dots-hyprland
notif actions
This commit is contained in:
@@ -127,8 +127,10 @@ Singleton {
|
|||||||
property color colPrimaryContainerActive: mix(m3colors.m3primaryContainer, colLayer1Active, 0.6)
|
property color colPrimaryContainerActive: mix(m3colors.m3primaryContainer, colLayer1Active, 0.6)
|
||||||
property color colSecondaryHover: mix(m3colors.m3secondary, colLayer1Hover, 0.85)
|
property color colSecondaryHover: mix(m3colors.m3secondary, colLayer1Hover, 0.85)
|
||||||
property color colSecondaryActive: mix(m3colors.m3secondary, colLayer1Active, 0.4)
|
property color colSecondaryActive: mix(m3colors.m3secondary, colLayer1Active, 0.4)
|
||||||
property color colSecondaryContainerHover: mix(m3colors.m3secondaryContainer, colLayer1Hover, 0.8)
|
property color colSecondaryContainerHover: mix(m3colors.m3secondaryContainer, colLayer1Hover, 0.67)
|
||||||
property color colSecondaryContainerActive: mix(m3colors.m3secondaryContainer, colLayer1Active, 0.6)
|
property color colSecondaryContainerActive: mix(m3colors.m3secondaryContainer, colLayer1Active, 0.6)
|
||||||
|
property color colSurfaceContainerHighestHover: mix(m3colors.m3surfaceContainerHighest, m3colors.m3onSurface, 0.9)
|
||||||
|
property color colSurfaceContainerHighestActive: mix(m3colors.m3surfaceContainerHighest, m3colors.m3onSurface, 0.82)
|
||||||
property color colTooltip: m3colors.m3inverseSurface
|
property color colTooltip: m3colors.m3inverseSurface
|
||||||
property color colOnTooltip: m3colors.m3inverseOnSurface
|
property color colOnTooltip: m3colors.m3inverseOnSurface
|
||||||
property color colScrim: transparentize(m3colors.m3scrim, 0.5)
|
property color colScrim: transparentize(m3colors.m3scrim, 0.5)
|
||||||
|
|||||||
@@ -0,0 +1,34 @@
|
|||||||
|
import "root:/modules/common"
|
||||||
|
import "root:/services"
|
||||||
|
import QtQuick
|
||||||
|
import QtQuick.Controls
|
||||||
|
import QtQuick.Layouts
|
||||||
|
import Quickshell
|
||||||
|
import Quickshell.Services.Notifications
|
||||||
|
|
||||||
|
Button {
|
||||||
|
id: button
|
||||||
|
property string buttonText
|
||||||
|
property string urgency
|
||||||
|
|
||||||
|
implicitHeight: 30
|
||||||
|
leftPadding: 10
|
||||||
|
rightPadding: 10
|
||||||
|
|
||||||
|
background: Rectangle {
|
||||||
|
radius: Appearance.rounding.small
|
||||||
|
color: (urgency == NotificationUrgency.Critical) ?
|
||||||
|
(button.down ? Appearance.colors.colSecondaryContainerActive :
|
||||||
|
button.hovered ? Appearance.colors.colSecondaryContainerHover :
|
||||||
|
Appearance.m3colors.m3secondaryContainer) :
|
||||||
|
(button.down ? Appearance.colors.colSurfaceContainerHighestActive :
|
||||||
|
button.hovered ? Appearance.colors.colSurfaceContainerHighestHover :
|
||||||
|
Appearance.m3colors.m3surfaceContainerHighest)
|
||||||
|
}
|
||||||
|
|
||||||
|
contentItem: StyledText {
|
||||||
|
horizontalAlignment: Text.AlignHCenter
|
||||||
|
text: buttonText
|
||||||
|
color: (urgency == NotificationUrgency.Critical) ? Appearance.m3colors.m3onSurfaceVariant : Appearance.m3colors.m3onSurface
|
||||||
|
}
|
||||||
|
}
|
||||||
@@ -24,8 +24,8 @@ Item {
|
|||||||
Behavior on implicitHeight {
|
Behavior on implicitHeight {
|
||||||
enabled: enableAnimation
|
enabled: enableAnimation
|
||||||
NumberAnimation {
|
NumberAnimation {
|
||||||
duration: Appearance.animation.elementDecel.duration
|
duration: Appearance.animation.elementDecelFast.duration
|
||||||
easing.type: Appearance.animation.elementDecel.type
|
easing.type: Appearance.animation.elementDecelFast.type
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
|
||||||
@@ -42,7 +42,7 @@ Item {
|
|||||||
|
|
||||||
Timer {
|
Timer {
|
||||||
id: destroyTimer
|
id: destroyTimer
|
||||||
interval: Appearance.animation.elementDecel.duration
|
interval: Appearance.animation.elementDecelFast.duration
|
||||||
repeat: false
|
repeat: false
|
||||||
onTriggered: {
|
onTriggered: {
|
||||||
root.destroy()
|
root.destroy()
|
||||||
@@ -51,11 +51,12 @@ Item {
|
|||||||
|
|
||||||
MouseArea { // Middle click to close
|
MouseArea { // Middle click to close
|
||||||
anchors.fill: parent
|
anchors.fill: parent
|
||||||
acceptedButtons: Qt.MiddleButton
|
acceptedButtons: Qt.MiddleButton | Qt.RightButton
|
||||||
onClicked: (mouse) => {
|
onClicked: (mouse) => {
|
||||||
if (mouse.button == Qt.MiddleButton) {
|
if (mouse.button == Qt.MiddleButton)
|
||||||
Notifications.discardNotification(notificationObject.id)
|
Notifications.discardNotification(notificationObject.id);
|
||||||
}
|
else if (mouse.button == Qt.RightButton)
|
||||||
|
root.expanded = !root.expanded;
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
|
||||||
@@ -64,7 +65,7 @@ Item {
|
|||||||
anchors.fill: parent
|
anchors.fill: parent
|
||||||
anchors.topMargin: notificationListSpacing
|
anchors.topMargin: notificationListSpacing
|
||||||
color: (notificationObject.urgency == NotificationUrgency.Critical) ?
|
color: (notificationObject.urgency == NotificationUrgency.Critical) ?
|
||||||
Appearance.m3colors.m3secondaryContainer : Appearance.colors.colLayer2
|
Appearance.mix(Appearance.m3colors.m3secondaryContainer, Appearance.colors.colLayer2, 0.35) : Appearance.colors.colLayer2
|
||||||
radius: Appearance.rounding.normal
|
radius: Appearance.rounding.normal
|
||||||
}
|
}
|
||||||
|
|
||||||
@@ -92,14 +93,15 @@ Item {
|
|||||||
Layout.alignment: Qt.AlignTop
|
Layout.alignment: Qt.AlignTop
|
||||||
Layout.fillWidth: false
|
Layout.fillWidth: false
|
||||||
radius: Appearance.rounding.full
|
radius: Appearance.rounding.full
|
||||||
color: (notificationObject.urgency == NotificationUrgency.Critical) ?
|
color: Appearance.m3colors.m3secondaryContainer
|
||||||
Appearance.m3colors.m3secondary : Appearance.m3colors.m3secondaryContainer
|
|
||||||
MaterialSymbol {
|
MaterialSymbol {
|
||||||
visible: notificationObject.appIcon == ""
|
visible: notificationObject.appIcon == ""
|
||||||
text: NotificationUtils.guessMessageType(notificationObject.summary)
|
text: (notificationObject.urgency == NotificationUrgency.Critical) ? "release_alert" :
|
||||||
|
NotificationUtils.guessMessageType(notificationObject.summary)
|
||||||
anchors.fill: parent
|
anchors.fill: parent
|
||||||
color: (notificationObject.urgency == NotificationUrgency.Critical) ?
|
color: (notificationObject.urgency == NotificationUrgency.Critical) ?
|
||||||
Appearance.m3colors.m3onSecondary : Appearance.m3colors.m3onSecondaryContainer
|
Appearance.mix(Appearance.m3colors.m3onSecondary, Appearance.m3colors.m3onSecondaryContainer, 0.1) :
|
||||||
|
Appearance.m3colors.m3onSecondaryContainer
|
||||||
font.pixelSize: 27
|
font.pixelSize: 27
|
||||||
horizontalAlignment: Text.AlignHCenter
|
horizontalAlignment: Text.AlignHCenter
|
||||||
verticalAlignment: Text.AlignVCenter
|
verticalAlignment: Text.AlignVCenter
|
||||||
@@ -192,17 +194,56 @@ Item {
|
|||||||
|
|
||||||
StyledText { // Notification body
|
StyledText { // Notification body
|
||||||
Layout.fillWidth: true
|
Layout.fillWidth: true
|
||||||
Layout.bottomMargin: 10
|
|
||||||
Layout.leftMargin: 10
|
Layout.leftMargin: 10
|
||||||
Layout.rightMargin: 10
|
Layout.rightMargin: 10
|
||||||
|
Layout.bottomMargin: 10
|
||||||
clip: true
|
clip: true
|
||||||
|
|
||||||
wrapMode: expanded ? Text.Wrap : Text.NoWrap
|
wrapMode: expanded ? Text.Wrap : Text.NoWrap
|
||||||
elide: Text.ElideRight
|
elide: Text.ElideRight
|
||||||
font.pixelSize: Appearance.font.pixelSize.small
|
font.pixelSize: Appearance.font.pixelSize.small
|
||||||
horizontalAlignment: Text.AlignLeft
|
horizontalAlignment: Text.AlignLeft
|
||||||
color: Appearance.m3colors.m3outline
|
color: Appearance.m3colors.m3outline
|
||||||
// textFormat: Text.MarkdownText
|
// textFormat: Text.MarkdownText
|
||||||
text: notificationObject.body
|
text: notificationObject.body
|
||||||
|
}
|
||||||
|
|
||||||
|
Flickable {
|
||||||
|
Layout.fillWidth: true
|
||||||
|
Layout.topMargin: -5
|
||||||
|
Layout.leftMargin: 10
|
||||||
|
Layout.rightMargin: 10
|
||||||
|
Layout.bottomMargin: 10
|
||||||
|
visible: expanded
|
||||||
|
implicitHeight: actionRowLayout.implicitHeight
|
||||||
|
contentWidth: actionRowLayout.implicitWidth
|
||||||
|
|
||||||
|
RowLayout { // Actions
|
||||||
|
id: actionRowLayout
|
||||||
|
|
||||||
|
Repeater {
|
||||||
|
id: actionRepeater
|
||||||
|
model: notificationObject.actions
|
||||||
|
NotificationActionButton {
|
||||||
|
Layout.fillWidth: true
|
||||||
|
buttonText: modelData.text
|
||||||
|
urgency: notificationObject.urgency
|
||||||
|
onClicked: {
|
||||||
|
Notifications.attemptInvokeAction(notificationObject.id, modelData.identifier);
|
||||||
|
}
|
||||||
|
}
|
||||||
|
}
|
||||||
|
|
||||||
|
NotificationActionButton {
|
||||||
|
Layout.fillWidth: true
|
||||||
|
buttonText: "Close"
|
||||||
|
urgency: notificationObject.urgency
|
||||||
|
onClicked: {
|
||||||
|
Notifications.discardNotification(notificationObject.id);
|
||||||
|
}
|
||||||
|
}
|
||||||
|
|
||||||
|
}
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
|||||||
@@ -19,7 +19,7 @@ Singleton {
|
|||||||
NotificationServer {
|
NotificationServer {
|
||||||
id: notifServer
|
id: notifServer
|
||||||
// actionIconsSupported: true
|
// actionIconsSupported: true
|
||||||
// actionsSupported: true
|
actionsSupported: true
|
||||||
bodyHyperlinksSupported: true
|
bodyHyperlinksSupported: true
|
||||||
// bodyImagesSupported: true
|
// bodyImagesSupported: true
|
||||||
bodyMarkupSupported: true
|
bodyMarkupSupported: true
|
||||||
@@ -32,7 +32,12 @@ Singleton {
|
|||||||
notification.tracked = true
|
notification.tracked = true
|
||||||
const newNotifObject = {
|
const newNotifObject = {
|
||||||
"id": notification.id,
|
"id": notification.id,
|
||||||
"actions": [],
|
"actions": notification.actions.map((action) => {
|
||||||
|
return {
|
||||||
|
"identifier": action.identifier,
|
||||||
|
"text": action.text,
|
||||||
|
}
|
||||||
|
}),
|
||||||
"appIcon": notification.appIcon,
|
"appIcon": notification.appIcon,
|
||||||
"appName": notification.appName,
|
"appName": notification.appName,
|
||||||
"body": notification.body,
|
"body": notification.body,
|
||||||
@@ -60,6 +65,16 @@ Singleton {
|
|||||||
root.discard(id);
|
root.discard(id);
|
||||||
}
|
}
|
||||||
|
|
||||||
|
function attemptInvokeAction(id, notifIdentifier) {
|
||||||
|
const notifServerIndex = notifServer.trackedNotifications.values.findIndex((notif) => notif.id === id);
|
||||||
|
if (notifServerIndex !== -1) {
|
||||||
|
const notifServerNotif = notifServer.trackedNotifications.values[notifServerIndex];
|
||||||
|
const action = notifServerNotif.actions.find((action) => action.identifier === notifIdentifier);
|
||||||
|
action.invoke()
|
||||||
|
} else console.log("Notification not found in server: " + id)
|
||||||
|
root.discard(id);
|
||||||
|
}
|
||||||
|
|
||||||
function triggerListChange() {
|
function triggerListChange() {
|
||||||
root.list = root.list.slice(0)
|
root.list = root.list.slice(0)
|
||||||
}
|
}
|
||||||
|
|||||||
Reference in New Issue
Block a user