mirror of
https://github.com/belsabbagh/dotfiles.git
synced 2026-04-11 17:47:09 +00:00
208 lines
5.7 KiB
QML
208 lines
5.7 KiB
QML
pragma ComponentBehavior: Bound
|
|
|
|
import qs.components
|
|
import qs.components.controls
|
|
import qs.components.containers
|
|
import qs.components.effects
|
|
import qs.services
|
|
import qs.config
|
|
import Quickshell
|
|
import Quickshell.Widgets
|
|
import QtQuick
|
|
import QtQuick.Layouts
|
|
|
|
Item {
|
|
id: root
|
|
|
|
required property Props props
|
|
required property var visibilities
|
|
readonly property int notifCount: Notifs.list.reduce((acc, n) => n.closed ? acc : acc + 1, 0)
|
|
|
|
anchors.fill: parent
|
|
anchors.margins: Appearance.padding.normal
|
|
|
|
Component.onCompleted: Notifs.list.forEach(n => n.popup = false)
|
|
|
|
Item {
|
|
id: title
|
|
|
|
anchors.top: parent.top
|
|
anchors.left: parent.left
|
|
anchors.right: parent.right
|
|
anchors.margins: Appearance.padding.small
|
|
|
|
implicitHeight: Math.max(count.implicitHeight, titleText.implicitHeight)
|
|
|
|
StyledText {
|
|
id: count
|
|
|
|
anchors.verticalCenter: parent.verticalCenter
|
|
anchors.left: parent.left
|
|
anchors.leftMargin: root.notifCount > 0 ? 0 : -width - titleText.anchors.leftMargin
|
|
opacity: root.notifCount > 0 ? 1 : 0
|
|
|
|
text: root.notifCount
|
|
color: Colours.palette.m3outline
|
|
font.pointSize: Appearance.font.size.normal
|
|
font.family: Appearance.font.family.mono
|
|
font.weight: 500
|
|
|
|
Behavior on anchors.leftMargin {
|
|
Anim {}
|
|
}
|
|
|
|
Behavior on opacity {
|
|
Anim {}
|
|
}
|
|
}
|
|
|
|
StyledText {
|
|
id: titleText
|
|
|
|
anchors.verticalCenter: parent.verticalCenter
|
|
anchors.left: count.right
|
|
anchors.right: parent.right
|
|
anchors.leftMargin: Appearance.spacing.small
|
|
|
|
text: root.notifCount > 0 ? qsTr("notification%1").arg(root.notifCount === 1 ? "" : "s") : qsTr("Notifications")
|
|
color: Colours.palette.m3outline
|
|
font.pointSize: Appearance.font.size.normal
|
|
font.family: Appearance.font.family.mono
|
|
font.weight: 500
|
|
elide: Text.ElideRight
|
|
}
|
|
}
|
|
|
|
ClippingRectangle {
|
|
id: clipRect
|
|
|
|
anchors.left: parent.left
|
|
anchors.right: parent.right
|
|
anchors.top: title.bottom
|
|
anchors.bottom: parent.bottom
|
|
anchors.topMargin: Appearance.spacing.smaller
|
|
|
|
radius: Appearance.rounding.small
|
|
color: "transparent"
|
|
|
|
Loader {
|
|
anchors.centerIn: parent
|
|
active: opacity > 0
|
|
opacity: root.notifCount > 0 ? 0 : 1
|
|
|
|
sourceComponent: ColumnLayout {
|
|
spacing: Appearance.spacing.large
|
|
|
|
Image {
|
|
asynchronous: true
|
|
source: Qt.resolvedUrl(`${Quickshell.shellDir}/assets/dino.png`)
|
|
fillMode: Image.PreserveAspectFit
|
|
sourceSize.width: clipRect.width * 0.8
|
|
|
|
layer.enabled: true
|
|
layer.effect: Colouriser {
|
|
colorizationColor: Colours.palette.m3outlineVariant
|
|
brightness: 1
|
|
}
|
|
}
|
|
|
|
StyledText {
|
|
Layout.alignment: Qt.AlignHCenter
|
|
text: qsTr("No Notifications")
|
|
color: Colours.palette.m3outlineVariant
|
|
font.pointSize: Appearance.font.size.large
|
|
font.family: Appearance.font.family.mono
|
|
font.weight: 500
|
|
}
|
|
}
|
|
|
|
Behavior on opacity {
|
|
Anim {
|
|
duration: Appearance.anim.durations.extraLarge
|
|
}
|
|
}
|
|
}
|
|
|
|
StyledFlickable {
|
|
id: view
|
|
|
|
anchors.fill: parent
|
|
|
|
flickableDirection: Flickable.VerticalFlick
|
|
contentWidth: width
|
|
contentHeight: notifList.implicitHeight
|
|
|
|
StyledScrollBar.vertical: StyledScrollBar {
|
|
flickable: view
|
|
}
|
|
|
|
NotifDockList {
|
|
id: notifList
|
|
|
|
props: root.props
|
|
visibilities: root.visibilities
|
|
container: view
|
|
}
|
|
}
|
|
}
|
|
|
|
Timer {
|
|
id: clearTimer
|
|
|
|
repeat: true
|
|
interval: 50
|
|
onTriggered: {
|
|
let next = null;
|
|
for (let i = 0; i < notifList.repeater.count; i++) {
|
|
next = notifList.repeater.itemAt(i);
|
|
if (!next?.closed)
|
|
break;
|
|
}
|
|
if (next)
|
|
next.closeAll();
|
|
else
|
|
stop();
|
|
}
|
|
}
|
|
|
|
Loader {
|
|
anchors.right: parent.right
|
|
anchors.bottom: parent.bottom
|
|
anchors.margins: Appearance.padding.normal
|
|
|
|
scale: root.notifCount > 0 ? 1 : 0.5
|
|
opacity: root.notifCount > 0 ? 1 : 0
|
|
active: opacity > 0
|
|
|
|
sourceComponent: IconButton {
|
|
id: clearBtn
|
|
|
|
icon: "clear_all"
|
|
radius: Appearance.rounding.normal
|
|
padding: Appearance.padding.normal
|
|
font.pointSize: Math.round(Appearance.font.size.large * 1.2)
|
|
onClicked: clearTimer.start()
|
|
|
|
Elevation {
|
|
anchors.fill: parent
|
|
radius: parent.radius
|
|
z: -1
|
|
level: clearBtn.stateLayer.containsMouse ? 4 : 3
|
|
}
|
|
}
|
|
|
|
Behavior on scale {
|
|
Anim {
|
|
duration: Appearance.anim.durations.expressiveFastSpatial
|
|
easing.bezierCurve: Appearance.anim.curves.expressiveFastSpatial
|
|
}
|
|
}
|
|
|
|
Behavior on opacity {
|
|
Anim {
|
|
duration: Appearance.anim.durations.expressiveFastSpatial
|
|
}
|
|
}
|
|
}
|
|
}
|