summaryrefslogtreecommitdiff
path: root/modules
diff options
context:
space:
mode:
author2 * r + 2 * t <61896496+soramanew@users.noreply.github.com>2025-05-08 20:58:18 +1000
committer2 * r + 2 * t <61896496+soramanew@users.noreply.github.com>2025-05-08 20:58:18 +1000
commita1ed341639fd73ce916eecfce480b14cd8660999 (patch)
treeb8d12c8f03057246e17a360f69bd83a61465e9bd /modules
parentrefactor: split drawers (diff)
downloadcaelestia-shell-a1ed341639fd73ce916eecfce480b14cd8660999.tar.gz
caelestia-shell-a1ed341639fd73ce916eecfce480b14cd8660999.tar.bz2
caelestia-shell-a1ed341639fd73ce916eecfce480b14cd8660999.zip
feat: notification popup area
Diffstat (limited to 'modules')
-rw-r--r--modules/notifications/Background.qml61
-rw-r--r--modules/notifications/Content.qml22
-rw-r--r--modules/notifications/Notifications.qml79
-rw-r--r--modules/notifications/Wrapper.qml62
4 files changed, 224 insertions, 0 deletions
diff --git a/modules/notifications/Background.qml b/modules/notifications/Background.qml
new file mode 100644
index 0000000..e3289af
--- /dev/null
+++ b/modules/notifications/Background.qml
@@ -0,0 +1,61 @@
+import "root:/services"
+import "root:/config"
+import QtQuick
+import QtQuick.Shapes
+
+Shape {
+ id: root
+
+ required property real wrapperWidth
+ required property real wrapperHeight
+ readonly property real rounding: BorderConfig.rounding
+ readonly property bool flatten: wrapperHeight < rounding * 2
+ readonly property real roundingY: flatten ? wrapperHeight / 2 : rounding
+
+ preferredRendererType: Shape.CurveRenderer
+ opacity: Colours.transparency.enabled ? Colours.transparency.base : 1
+
+ ShapePath {
+ strokeWidth: -1
+ fillColor: BorderConfig.colour
+
+ startX: root.wrapperWidth
+
+ PathLine {}
+ PathArc {
+ relativeX: root.rounding
+ relativeY: root.roundingY
+ radiusX: root.rounding
+ radiusY: Math.min(root.rounding, root.wrapperHeight)
+ }
+ PathLine {
+ relativeX: 0
+ y: root.flatten ? root.roundingY : root.wrapperHeight - root.rounding
+ }
+ PathArc {
+ relativeX: root.rounding
+ relativeY: root.roundingY
+ radiusX: root.rounding
+ radiusY: Math.min(root.rounding, root.wrapperHeight)
+ direction: PathArc.Counterclockwise
+ }
+ PathLine {
+ x: root.wrapperWidth - root.rounding - 1
+ relativeY: 0
+ }
+ PathArc {
+ relativeX: root.rounding
+ relativeY: root.rounding
+ radiusX: root.rounding
+ radiusY: root.rounding
+ }
+
+ Behavior on fillColor {
+ ColorAnimation {
+ duration: Appearance.anim.durations.normal
+ easing.type: Easing.BezierSpline
+ easing.bezierCurve: Appearance.anim.curves.standard
+ }
+ }
+ }
+}
diff --git a/modules/notifications/Content.qml b/modules/notifications/Content.qml
new file mode 100644
index 0000000..86cef8b
--- /dev/null
+++ b/modules/notifications/Content.qml
@@ -0,0 +1,22 @@
+import "root:/widgets"
+import "root:/services"
+import "root:/config"
+import Quickshell
+import QtQuick
+
+Column {
+ id: root
+
+ // padding: Appearance.padding.large
+
+ anchors.bottom: parent.bottom
+ anchors.right: parent.right
+
+ spacing: Appearance.spacing.normal
+
+ StyledRect {
+ width: 300
+ height: 100
+ // color: Qt.rgba(255, 0, 0, 0.4)
+ }
+}
diff --git a/modules/notifications/Notifications.qml b/modules/notifications/Notifications.qml
new file mode 100644
index 0000000..9496a7f
--- /dev/null
+++ b/modules/notifications/Notifications.qml
@@ -0,0 +1,79 @@
+import "root:/widgets"
+import "root:/services"
+import "root:/config"
+import Quickshell
+import Quickshell.Wayland
+import QtQuick
+
+Variants {
+ model: Quickshell.screens
+
+ Scope {
+ id: root
+
+ required property ShellScreen modelData
+ property bool osdVisible
+
+ Timer {
+ running: true
+ repeat: true
+ interval: 2000
+ onTriggered: root.osdVisible = !root.osdVisible
+ }
+
+ LazyLoader {
+ loading: true
+
+ StyledWindow {
+ id: win
+
+ screen: root.modelData
+ name: "notifications"
+ visible: wrapper.shouldBeVisible
+ exclusionMode: ExclusionMode.Normal
+
+ mask: Region {
+ item: wrapper
+ }
+
+ anchors.top: true
+ anchors.bottom: true
+ anchors.right: true
+ width: wrapper.width
+ height: wrapper.height
+
+ Background {
+ id: bg
+
+ visible: false
+
+ anchors.top: parent.top
+ anchors.right: parent.right
+
+ wrapperWidth: wrapper.width
+ wrapperHeight: Math.min(wrapper.height, content.height)
+ }
+
+ LayerShadow {
+ source: bg
+ }
+
+ Wrapper {
+ id: wrapper
+
+ anchors.top: parent.top
+ anchors.right: parent.right
+
+ implicitWidth: content.width + bg.rounding
+
+ osdVisible: root.osdVisible
+ contentHeight: content.height
+
+ Content {
+ id: content
+ }
+ }
+ }
+ }
+ }
+}
diff --git a/modules/notifications/Wrapper.qml b/modules/notifications/Wrapper.qml
new file mode 100644
index 0000000..1d650f6
--- /dev/null
+++ b/modules/notifications/Wrapper.qml
@@ -0,0 +1,62 @@
+import "root:/config"
+import QtQuick
+
+Item {
+ id: root
+
+ required property bool osdVisible
+ required property real contentHeight
+ property bool shouldBeVisible
+
+ visible: height > 0
+ height: 0
+
+ states: State {
+ name: "visible"
+ when: root.osdVisible
+
+ PropertyChanges {
+ root.height: contentHeight
+ root.shouldBeVisible: true
+ }
+ }
+
+ transitions: [
+ Transition {
+ from: ""
+ to: "visible"
+
+ SequentialAnimation {
+ PropertyAction {
+ target: root
+ property: "shouldBeVisible"
+ }
+ NumberAnimation {
+ target: root
+ property: "height"
+ duration: Appearance.anim.durations.large
+ easing.type: Easing.BezierSpline
+ easing.bezierCurve: Appearance.anim.curves.emphasizedDecel
+ }
+ }
+ },
+ Transition {
+ from: "visible"
+ to: ""
+
+ SequentialAnimation {
+ NumberAnimation {
+ target: root
+ property: "height"
+ duration: Appearance.anim.durations.normal
+ easing.type: Easing.BezierSpline
+ easing.bezierCurve: Appearance.anim.curves.emphasizedAccel
+ }
+ PropertyAction {
+ target: root
+ property: "shouldBeVisible"
+ }
+ }
+ }
+ ]
+}