summaryrefslogtreecommitdiff
path: root/modules/background
diff options
context:
space:
mode:
author2 * r + 2 * t <61896496+soramanew@users.noreply.github.com>2025-08-25 20:13:55 +1000
committer2 * r + 2 * t <61896496+soramanew@users.noreply.github.com>2025-08-25 20:13:55 +1000
commit783057ab0d694de7f3d79e96851bcdcfe1965cbd (patch)
treeb70d2dc09e816ab6a4f3e6bf1b1fca148f258eed /modules/background
parentreadme: fix confusing config statement (diff)
downloadcaelestia-shell-783057ab0d694de7f3d79e96851bcdcfe1965cbd.tar.gz
caelestia-shell-783057ab0d694de7f3d79e96851bcdcfe1965cbd.tar.bz2
caelestia-shell-783057ab0d694de7f3d79e96851bcdcfe1965cbd.zip
background: add visualiser
Also dashboard.visualiserBars -> services.visualiserBars
Diffstat (limited to 'modules/background')
-rw-r--r--modules/background/Background.qml33
-rw-r--r--modules/background/Visualiser.qml120
2 files changed, 152 insertions, 1 deletions
diff --git a/modules/background/Background.qml b/modules/background/Background.qml
index 3da8bf9..bdba570 100644
--- a/modules/background/Background.qml
+++ b/modules/background/Background.qml
@@ -1,4 +1,8 @@
+pragma ComponentBehavior: Bound
+
+import qs.components
import qs.components.containers
+import qs.services
import qs.config
import Quickshell
import Quickshell.Wayland
@@ -27,7 +31,34 @@ Loader {
anchors.left: true
anchors.right: true
- Wallpaper {}
+ Wallpaper {
+ id: wallpaper
+ }
+
+ Loader {
+ readonly property bool shouldBeActive: Config.background.visualiser.enabled && (!Config.background.visualiser.autoHide || Hypr.monitorFor(win.modelData).activeWorkspace.toplevels.values.every(t => t.lastIpcObject.floating)) ? 1 : 0
+ property real offset: shouldBeActive ? 0 : win.modelData.height * 0.2
+
+ anchors.fill: parent
+ anchors.topMargin: offset
+ anchors.bottomMargin: -offset
+ opacity: shouldBeActive ? 1 : 0
+ active: opacity > 0
+ asynchronous: true
+
+ sourceComponent: Visualiser {
+ screen: win.modelData
+ wallpaper: wallpaper
+ }
+
+ Behavior on offset {
+ Anim {}
+ }
+
+ Behavior on opacity {
+ Anim {}
+ }
+ }
Loader {
anchors.right: parent.right
diff --git a/modules/background/Visualiser.qml b/modules/background/Visualiser.qml
new file mode 100644
index 0000000..6dd0a12
--- /dev/null
+++ b/modules/background/Visualiser.qml
@@ -0,0 +1,120 @@
+pragma ComponentBehavior: Bound
+
+import qs.components
+import qs.components.misc
+import qs.services
+import qs.config
+import Quickshell
+import Quickshell.Widgets
+import QtQuick
+import QtQuick.Effects
+
+Item {
+ id: root
+
+ required property ShellScreen screen
+ required property Wallpaper wallpaper
+
+ Ref {
+ service: Cava
+ }
+
+ MultiEffect {
+ anchors.fill: parent
+ source: root.wallpaper
+ maskSource: wrapper
+ maskEnabled: true
+ blurEnabled: true
+ blur: 1
+ blurMax: 32
+ autoPaddingEnabled: false
+ }
+
+ Item {
+ id: wrapper
+
+ anchors.fill: parent
+ layer.enabled: true
+
+ Item {
+ id: content
+
+ anchors.fill: parent
+ anchors.margins: Config.border.thickness
+ anchors.leftMargin: Visibilities.bars.get(root.screen).exclusiveZone + Appearance.spacing.small * Config.background.visualiser.spacing
+
+ Side {}
+ Side {
+ isRight: true
+ }
+
+ Behavior on anchors.leftMargin {
+ Anim {}
+ }
+ }
+ }
+
+ component Side: Repeater {
+ id: side
+
+ property bool isRight
+
+ model: Config.services.visualiserBars
+
+ ClippingRectangle {
+ id: bar
+
+ required property int modelData
+ property real value: Math.max(1, Math.min(100, Cava.values[side.isRight ? modelData : side.count - modelData - 1])) / 100
+
+ clip: true
+
+ x: modelData * ((content.width * 0.4) / Config.services.visualiserBars) + (side.isRight ? content.width * 0.6 : 0)
+ implicitWidth: (content.width * 0.4) / Config.services.visualiserBars - Appearance.spacing.small * Config.background.visualiser.spacing
+
+ y: content.height - height
+ implicitHeight: bar.value * content.height * 0.4
+
+ color: "transparent"
+ topLeftRadius: Appearance.rounding.small * Config.background.visualiser.rounding
+ topRightRadius: Appearance.rounding.small * Config.background.visualiser.rounding
+
+ Rectangle {
+ topLeftRadius: parent.topLeftRadius
+ topRightRadius: parent.topRightRadius
+
+ gradient: Gradient {
+ orientation: Gradient.Vertical
+
+ GradientStop {
+ position: 0
+ color: Qt.alpha(Colours.palette.m3primary, 0.7)
+
+ Behavior on color {
+ CAnim {}
+ }
+ }
+ GradientStop {
+ position: 1
+ color: Qt.alpha(Colours.palette.m3inversePrimary, 0.7)
+
+ Behavior on color {
+ CAnim {}
+ }
+ }
+ }
+
+ anchors.left: parent.left
+ anchors.right: parent.right
+ y: parent.height - height
+ implicitHeight: content.height * 0.4
+ }
+
+ Behavior on value {
+ Anim {
+ duration: Appearance.anim.durations.small
+ }
+ }
+ }
+ }
+}