mirror of
https://github.com/belsabbagh/dotfiles.git
synced 2026-04-11 09:36:46 +00:00
quickshell and hyprland additions
This commit is contained in:
@@ -0,0 +1,144 @@
|
||||
import qs.config
|
||||
import qs.modules.components
|
||||
import qs.services
|
||||
import QtQuick
|
||||
import QtQuick.Layouts
|
||||
import Quickshell
|
||||
import Quickshell.Widgets
|
||||
import Quickshell.Wayland
|
||||
|
||||
Rectangle {
|
||||
id: root
|
||||
|
||||
property bool startAnim: false
|
||||
property string title: "No Title"
|
||||
property string body: "No content"
|
||||
property var rawNotif: null
|
||||
property bool tracked: false
|
||||
property string image: ""
|
||||
property var buttons: [
|
||||
{ label: "Okay!", onClick: () => console.log("Okay") }
|
||||
]
|
||||
|
||||
opacity: tracked ? 1 : (startAnim ? 1 : 0)
|
||||
Behavior on opacity {
|
||||
enabled: Config.runtime.appearance.animations.enabled
|
||||
NumberAnimation {
|
||||
duration: Metrics.chronoDuration("small")
|
||||
easing.type: Easing.InOutExpo
|
||||
}
|
||||
}
|
||||
|
||||
Layout.fillWidth: true
|
||||
radius: Metrics.radius("large")
|
||||
|
||||
property bool hovered: mouseHandler.containsMouse
|
||||
property bool clicked: mouseHandler.containsPress
|
||||
color: hovered ? (clicked ? Appearance.m3colors.m3surfaceContainerHigh : Appearance.m3colors.m3surfaceContainerLow) : Appearance.m3colors.m3surface
|
||||
Behavior on color {
|
||||
enabled: Config.runtime.appearance.animations.enabled
|
||||
ColorAnimation {
|
||||
duration: Metrics.chronoDuration("small")
|
||||
easing.type: Easing.InOutExpo
|
||||
}
|
||||
}
|
||||
implicitHeight: Math.max(content.implicitHeight + 30, 80)
|
||||
|
||||
RowLayout {
|
||||
id: content
|
||||
anchors.fill: parent
|
||||
anchors.margins: Metrics.margin(10)
|
||||
spacing: Metrics.spacing(10)
|
||||
|
||||
ClippingRectangle {
|
||||
width: 50
|
||||
height: 50
|
||||
radius: Metrics.radius("large")
|
||||
clip: true
|
||||
color: root.image === "" ? Appearance.m3colors.m3surfaceContainer : "transparent"
|
||||
Image {
|
||||
anchors.fill: parent
|
||||
source: root.image
|
||||
fillMode: Image.PreserveAspectCrop
|
||||
smooth: true
|
||||
}
|
||||
MaterialSymbol {
|
||||
icon: "chat"
|
||||
color: Appearance.m3colors.m3onSurfaceVariant
|
||||
anchors.centerIn: parent
|
||||
visible: root.image === ""
|
||||
iconSize: Metrics.iconSize(22)
|
||||
}
|
||||
}
|
||||
|
||||
ColumnLayout {
|
||||
StyledText {
|
||||
text: root.title
|
||||
font.bold: true
|
||||
font.pixelSize: Metrics.fontSize(18)
|
||||
wrapMode: Text.Wrap
|
||||
color: Appearance.m3colors.m3onSurface
|
||||
Layout.fillWidth: true
|
||||
}
|
||||
|
||||
StyledText {
|
||||
text: root.body.length > 123 ? root.body.substr(0, 120) + "..." : root.body
|
||||
visible: root.body.length > 0
|
||||
font.pixelSize: Metrics.fontSize(12)
|
||||
color: Appearance.m3colors.m3onSurfaceVariant
|
||||
wrapMode: Text.Wrap
|
||||
Layout.fillWidth: true
|
||||
}
|
||||
|
||||
RowLayout {
|
||||
visible: root.buttons.length > 1
|
||||
Layout.preferredHeight: 40
|
||||
Layout.fillWidth: true
|
||||
spacing: Metrics.spacing(10)
|
||||
|
||||
Repeater {
|
||||
model: buttons
|
||||
|
||||
StyledButton {
|
||||
Layout.fillWidth: true
|
||||
implicitHeight: 30
|
||||
implicitWidth: 0
|
||||
text: modelData.label
|
||||
base_bg: index !== 0
|
||||
? Appearance.m3colors.m3secondaryContainer
|
||||
: Appearance.m3colors.m3primary
|
||||
|
||||
base_fg: index !== 0
|
||||
? Appearance.m3colors.m3onSecondaryContainer
|
||||
: Appearance.m3colors.m3onPrimary
|
||||
onClicked: modelData.onClick()
|
||||
}
|
||||
}
|
||||
}
|
||||
}
|
||||
}
|
||||
MouseArea {
|
||||
id: mouseHandler
|
||||
anchors.fill: parent
|
||||
hoverEnabled: true
|
||||
visible: root.buttons.length === 0 || root.buttons.length === 1
|
||||
cursorShape: Qt.PointingHandCursor
|
||||
onClicked: {
|
||||
if (root.buttons.length === 1 && root.buttons[0].onClick) {
|
||||
root.buttons[0].onClick()
|
||||
root.rawNotif?.notification.dismiss()
|
||||
} else if (root.buttons.length === 0) {
|
||||
console.log("[Notification] Dismissed a notification with no action.")
|
||||
root.rawNotif.notification.tracked = false
|
||||
root.rawNotif.popup = false
|
||||
root.rawNotif?.notification.dismiss()
|
||||
} else {
|
||||
console.log("[Notification] Dismissed a notification with multiple actions.")
|
||||
root.rawNotif?.notification.dismiss()
|
||||
}
|
||||
}
|
||||
}
|
||||
Component.onCompleted: {
|
||||
startAnim = true
|
||||
}
|
||||
}
|
||||
Reference in New Issue
Block a user