diff options
| author | 2 * r + 2 * t <61896496+soramanew@users.noreply.github.com> | 2025-05-08 20:58:18 +1000 |
|---|---|---|
| committer | 2 * r + 2 * t <61896496+soramanew@users.noreply.github.com> | 2025-05-08 20:58:18 +1000 |
| commit | a1ed341639fd73ce916eecfce480b14cd8660999 (patch) | |
| tree | b8d12c8f03057246e17a360f69bd83a61465e9bd /modules | |
| parent | refactor: split drawers (diff) | |
| download | caelestia-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.qml | 61 | ||||
| -rw-r--r-- | modules/notifications/Content.qml | 22 | ||||
| -rw-r--r-- | modules/notifications/Notifications.qml | 79 | ||||
| -rw-r--r-- | modules/notifications/Wrapper.qml | 62 |
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" + } + } + } + ] +} |