diff --git a/shell/lock/LockSurface.qml b/shell/lock/LockSurface.qml index f9148af..0e774b6 100644 --- a/shell/lock/LockSurface.qml +++ b/shell/lock/LockSurface.qml @@ -6,7 +6,6 @@ import Quickshell.Services.Mpris import Quickshell.Services.Pipewire import "../services" as S import "../applets" as C -import "../modules" as M WlSessionLockSurface { id: root @@ -149,7 +148,7 @@ WlSessionLockSurface { visible: (S.Modules.lock.notifications ?? true) && _notifGroups.length > 0 readonly property var _notifGroups: { - const notifs = M.NotifService.list.filter(n => n.state !== "dismissed"); + const notifs = S.NotifService.list.filter(n => n.state !== "dismissed"); const groups = {}; for (const n of notifs) { const key = n.appIcon || n.appName || "unknown"; diff --git a/shell/modules/NotifCenter.qml b/shell/modules/NotifCenter.qml index e49231e..27180a8 100644 --- a/shell/modules/NotifCenter.qml +++ b/shell/modules/NotifCenter.qml @@ -33,8 +33,8 @@ M.HoverPanel { // DND toggle Text { - text: M.NotifService.dnd ? "\uDB82\uDE93" : "\uDB80\uDC9C" - color: M.NotifService.dnd ? S.Theme.base09 : S.Theme.base04 + text: S.NotifService.dnd ? "\uDB82\uDE93" : "\uDB80\uDC9C" + color: S.NotifService.dnd ? S.Theme.base09 : S.Theme.base04 font.pixelSize: S.Theme.fontSize font.family: S.Theme.iconFontFamily anchors.verticalCenter: parent.verticalCenter @@ -42,7 +42,7 @@ M.HoverPanel { MouseArea { anchors.fill: parent cursorShape: Qt.PointingHandCursor - onClicked: M.NotifService.toggleDnd() + onClicked: S.NotifService.toggleDnd() } } @@ -53,7 +53,7 @@ M.HoverPanel { font.pixelSize: S.Theme.fontSize font.family: S.Theme.iconFontFamily anchors.verticalCenter: parent.verticalCenter - visible: M.NotifService.count > 0 + visible: S.NotifService.count > 0 MouseArea { id: clearArea @@ -88,7 +88,7 @@ M.HoverPanel { // Group notifications by appName, sorted by max urgency desc then most recent time desc readonly property var _groups: { const map = {}; - for (const n of M.NotifService.list) { + for (const n of S.NotifService.list) { const key = n.appName || ""; if (!map[key]) map[key] = { @@ -167,14 +167,14 @@ M.HoverPanel { } function _cascadeDismiss() { - if (M.NotifService.list.length === 0) + if (S.NotifService.list.length === 0) return; - const ids = M.NotifService.list.map(n => n.id); + const ids = S.NotifService.list.map(n => n.id); _startCascade(_getVisibleNotifDelegates(), ids); } function _cascadeGroupDismiss(appName) { - const ids = M.NotifService.list.filter(n => n.appName === appName).map(n => n.id); + const ids = S.NotifService.list.filter(n => n.appName === appName).map(n => n.id); if (ids.length === 0) return; _startCascade(_getVisibleNotifDelegates(appName), ids); @@ -184,7 +184,7 @@ M.HoverPanel { const ids = _pendingDismissIds; _pendingDismissIds = []; for (const id of ids) - M.NotifService.dismiss(id); + S.NotifService.dismiss(id); } property Component _cascadeTimer: Component { @@ -467,7 +467,7 @@ M.HoverPanel { ScriptAction { script: { if (notifDelegate._notif && !notifDelegate._skipDismiss) - M.NotifService.dismiss(notifDelegate._notif.id); + S.NotifService.dismiss(notifDelegate._notif.id); } } } @@ -476,7 +476,7 @@ M.HoverPanel { // Empty state Text { - visible: M.NotifService.count === 0 + visible: S.NotifService.count === 0 width: menuWindow.contentWidth height: 48 horizontalAlignment: Text.AlignHCenter diff --git a/shell/modules/NotifPopup.qml b/shell/modules/NotifPopup.qml index d9a5ffb..25ba8fd 100644 --- a/shell/modules/NotifPopup.qml +++ b/shell/modules/NotifPopup.qml @@ -10,7 +10,7 @@ PanelWindow { required property var screen - visible: M.NotifService.popups.length > 0 && !S.NiriIpc.overviewOpen + visible: S.NotifService.popups.length > 0 && !S.NiriIpc.overviewOpen color: "transparent" WlrLayershell.layer: WlrLayer.Overlay @@ -34,7 +34,7 @@ PanelWindow { property var _knownIds: ({}) Repeater { - model: M.NotifService.popups.slice(0, S.Modules.notifications.maxPopups || 4) + model: S.NotifService.popups.slice(0, S.Modules.notifications.maxPopups || 4) delegate: Item { id: popupItem @@ -74,7 +74,7 @@ PanelWindow { } Connections { - target: M.NotifService + target: S.NotifService function onPopupExpiring(notifId) { if (notifId === popupItem.modelData.id) popupItem.animateDismiss(false); @@ -152,7 +152,7 @@ PanelWindow { easing.type: Easing.OutCubic } ScriptAction { - script: popupItem._fullDismiss ? M.NotifService.dismiss(popupItem.modelData.id) : M.NotifService.dismissPopup(popupItem.modelData.id) + script: popupItem._fullDismiss ? S.NotifService.dismiss(popupItem.modelData.id) : S.NotifService.dismissPopup(popupItem.modelData.id) } } diff --git a/shell/modules/NotificationsModule.qml b/shell/modules/NotificationsModule.qml index 4aa19bf..4783f44 100644 --- a/shell/modules/NotificationsModule.qml +++ b/shell/modules/NotificationsModule.qml @@ -8,28 +8,28 @@ M.BarSection { id: root spacing: S.Theme.moduleSpacing tooltip: { - const parts = [M.NotifService.count + " notification" + (M.NotifService.count !== 1 ? "s" : "")]; - if (M.NotifService.dnd) + const parts = [S.NotifService.count + " notification" + (S.NotifService.count !== 1 ? "s" : "")]; + if (S.NotifService.dnd) parts.push("Do not disturb"); return parts.join("\n"); } required property var bar - readonly property bool hasUrgent: M.NotifService.list.some(n => n.urgency === NotificationUrgency.Critical && n.state !== "dismissed") + readonly property bool hasUrgent: S.NotifService.list.some(n => n.urgency === NotificationUrgency.Critical && n.state !== "dismissed") M.BarIcon { icon: { - if (M.NotifService.dnd) - return M.NotifService.count > 0 ? "\uDB80\uDCA0" : "\uDB82\uDE93"; - return M.NotifService.count > 0 ? "\uDB84\uDD6B" : "\uDB80\uDC9C"; + if (S.NotifService.dnd) + return S.NotifService.count > 0 ? "\uDB80\uDCA0" : "\uDB82\uDE93"; + return S.NotifService.count > 0 ? "\uDB84\uDD6B" : "\uDB80\uDC9C"; } - color: M.NotifService.dnd ? S.Theme.base04 : root.accentColor + color: S.NotifService.dnd ? S.Theme.base04 : root.accentColor anchors.verticalCenter: parent.verticalCenter } M.BarLabel { id: countLabel - label: M.NotifService.count > 0 ? String(M.NotifService.count) + (root.hasUrgent ? "!" : "") : "" + label: S.NotifService.count > 0 ? String(S.NotifService.count) + (root.hasUrgent ? "!" : "") : "" color: root.hasUrgent ? S.Theme.base08 : root.accentColor anchors.verticalCenter: parent.verticalCenter @@ -61,9 +61,9 @@ M.BarSection { } Connections { - target: M.NotifService + target: S.NotifService function onCountChanged() { - if (M.NotifService.count > 0) + if (S.NotifService.count > 0) popAnim.start(); } } @@ -77,7 +77,7 @@ M.BarSection { } TapHandler { acceptedButtons: Qt.RightButton - onTapped: M.NotifService.toggleDnd() + onTapped: S.NotifService.toggleDnd() } LazyLoader { diff --git a/shell/modules/qmldir b/shell/modules/qmldir index 49e65fd..2ebf8a6 100644 --- a/shell/modules/qmldir +++ b/shell/modules/qmldir @@ -31,8 +31,6 @@ PowerProfileModule 1.0 PowerProfileModule.qml IdleInhibitorModule 1.0 IdleInhibitorModule.qml NotificationsModule 1.0 NotificationsModule.qml ProcessList 1.0 ProcessList.qml -singleton NotifService 1.0 NotifService.qml -NotifItem 1.0 NotifItem.qml NotifPopup 1.0 NotifPopup.qml NotifCenter 1.0 NotifCenter.qml NotifCard 1.0 NotifCard.qml diff --git a/shell/modules/NotifItem.qml b/shell/services/NotifItem.qml similarity index 92% rename from shell/modules/NotifItem.qml rename to shell/services/NotifItem.qml index ac7f4cf..488f48a 100644 --- a/shell/modules/NotifItem.qml +++ b/shell/services/NotifItem.qml @@ -1,7 +1,6 @@ import QtQuick import Quickshell.Services.Notifications -import "." as M -import "../services" as S +import "." as S QtObject { id: root @@ -32,7 +31,7 @@ QtObject { // Relative time string — recomputed whenever NotifService._now ticks (single global 5s timer) readonly property string timeStr: { - const diff = M.NotifService._now - time; + const diff = S.NotifService._now - time; const m = Math.floor(diff / 60000); if (m < 1) return "now"; @@ -48,7 +47,7 @@ QtObject { target: root.notification function onClosed() { if (root.state !== "dismissed") - M.NotifService.dismiss(root.id); + S.NotifService.dismiss(root.id); } } diff --git a/shell/modules/NotifService.qml b/shell/services/NotifService.qml similarity index 99% rename from shell/modules/NotifService.qml rename to shell/services/NotifService.qml index fe012d9..e3dde41 100644 --- a/shell/modules/NotifService.qml +++ b/shell/services/NotifService.qml @@ -3,8 +3,7 @@ pragma Singleton import QtQuick import Quickshell import Quickshell.Services.Notifications -import "." as M -import "../services" as S +import "." as S QtObject { id: root diff --git a/shell/services/qmldir b/shell/services/qmldir index e411660..62f2550 100644 --- a/shell/services/qmldir +++ b/shell/services/qmldir @@ -4,3 +4,5 @@ singleton SystemStats 1.0 SystemStats.qml singleton Modules 1.0 Modules.qml singleton NiriIpc 1.0 NiriIpc.qml singleton PowerProfileService 1.0 PowerProfileService.qml +singleton NotifService 1.0 NotifService.qml +NotifItem 1.0 NotifItem.qml