mirror of
https://github.com/end-4/dots-hyprland.git
synced 2026-06-05 23:09:26 -05:00
225 lines
7.0 KiB
QML
225 lines
7.0 KiB
QML
import qs
|
|
import qs.services
|
|
import qs.modules.common
|
|
import qs.modules.common.widgets
|
|
import QtQuick
|
|
import QtQuick.Controls
|
|
import QtQuick.Layouts
|
|
import Quickshell
|
|
import Quickshell.Io
|
|
import Quickshell.Wayland
|
|
import Quickshell.Hyprland
|
|
|
|
Scope {
|
|
id: root
|
|
property string protectionMessage: ""
|
|
property var focusedScreen: Quickshell.screens.find(s => s.name === Hyprland.focusedMonitor?.name)
|
|
|
|
property string currentIndicator: "volume"
|
|
property var indicators: [
|
|
{
|
|
id: "volume",
|
|
sourceUrl: "indicators/VolumeIndicator.qml"
|
|
},
|
|
{
|
|
id: "brightness",
|
|
sourceUrl: "indicators/BrightnessIndicator.qml"
|
|
},
|
|
]
|
|
|
|
function triggerOsd() {
|
|
GlobalStates.osdVolumeOpen = true;
|
|
osdTimeout.restart();
|
|
}
|
|
|
|
Timer {
|
|
id: osdTimeout
|
|
interval: Config.options.osd.timeout
|
|
repeat: false
|
|
running: false
|
|
onTriggered: {
|
|
GlobalStates.osdVolumeOpen = false;
|
|
root.protectionMessage = "";
|
|
}
|
|
}
|
|
|
|
Connections {
|
|
target: Brightness
|
|
function onBrightnessChanged() {
|
|
root.protectionMessage = "";
|
|
root.currentIndicator = "brightness";
|
|
root.triggerOsd();
|
|
}
|
|
}
|
|
|
|
Connections {
|
|
// Listen to volume changes
|
|
target: Audio.sink?.audio ?? null
|
|
function onVolumeChanged() {
|
|
if (!Audio.ready)
|
|
return;
|
|
root.currentIndicator = "volume";
|
|
root.triggerOsd();
|
|
}
|
|
function onMutedChanged() {
|
|
if (!Audio.ready)
|
|
return;
|
|
root.currentIndicator = "volume";
|
|
root.triggerOsd();
|
|
}
|
|
}
|
|
|
|
Connections {
|
|
// Listen to protection triggers
|
|
target: Audio
|
|
function onSinkProtectionTriggered(reason) {
|
|
root.protectionMessage = reason;
|
|
root.currentIndicator = "volume";
|
|
root.triggerOsd();
|
|
}
|
|
}
|
|
|
|
Loader {
|
|
id: osdLoader
|
|
active: GlobalStates.osdVolumeOpen
|
|
|
|
sourceComponent: PanelWindow {
|
|
id: osdRoot
|
|
color: "transparent"
|
|
|
|
Connections {
|
|
target: root
|
|
function onFocusedScreenChanged() {
|
|
osdRoot.screen = root.focusedScreen;
|
|
}
|
|
}
|
|
|
|
WlrLayershell.namespace: "quickshell:onScreenDisplay"
|
|
WlrLayershell.layer: WlrLayer.Overlay
|
|
anchors {
|
|
top: !Config.options.bar.bottom
|
|
bottom: Config.options.bar.bottom
|
|
}
|
|
mask: Region {
|
|
item: osdValuesWrapper
|
|
}
|
|
|
|
exclusionMode: ExclusionMode.Ignore
|
|
exclusiveZone: 0
|
|
margins {
|
|
top: Appearance.sizes.barHeight
|
|
bottom: Appearance.sizes.barHeight
|
|
}
|
|
|
|
implicitWidth: columnLayout.implicitWidth
|
|
implicitHeight: columnLayout.implicitHeight
|
|
visible: osdLoader.active
|
|
|
|
ColumnLayout {
|
|
id: columnLayout
|
|
anchors.horizontalCenter: parent.horizontalCenter
|
|
|
|
Item {
|
|
id: osdValuesWrapper
|
|
// Extra space for shadow
|
|
implicitHeight: contentColumnLayout.implicitHeight
|
|
implicitWidth: contentColumnLayout.implicitWidth
|
|
clip: true
|
|
|
|
MouseArea {
|
|
anchors.fill: parent
|
|
hoverEnabled: true
|
|
onEntered: GlobalStates.osdVolumeOpen = false
|
|
}
|
|
|
|
Column {
|
|
id: contentColumnLayout
|
|
anchors {
|
|
top: parent.top
|
|
left: parent.left
|
|
right: parent.right
|
|
}
|
|
spacing: 0
|
|
|
|
Loader {
|
|
id: osdIndicatorLoader
|
|
source: root.indicators.find(i => i.id === root.currentIndicator)?.sourceUrl
|
|
}
|
|
|
|
Item {
|
|
id: protectionMessageWrapper
|
|
anchors.horizontalCenter: parent.horizontalCenter
|
|
implicitHeight: protectionMessageBackground.implicitHeight
|
|
implicitWidth: protectionMessageBackground.implicitWidth
|
|
opacity: root.protectionMessage !== "" ? 1 : 0
|
|
|
|
StyledRectangularShadow {
|
|
target: protectionMessageBackground
|
|
}
|
|
Rectangle {
|
|
id: protectionMessageBackground
|
|
anchors.centerIn: parent
|
|
color: Appearance.m3colors.m3error
|
|
property real padding: 10
|
|
implicitHeight: protectionMessageRowLayout.implicitHeight + padding * 2
|
|
implicitWidth: protectionMessageRowLayout.implicitWidth + padding * 2
|
|
radius: Appearance.rounding.normal
|
|
|
|
RowLayout {
|
|
id: protectionMessageRowLayout
|
|
anchors.centerIn: parent
|
|
MaterialSymbol {
|
|
id: protectionMessageIcon
|
|
text: "dangerous"
|
|
iconSize: Appearance.font.pixelSize.hugeass
|
|
color: Appearance.m3colors.m3onError
|
|
}
|
|
StyledText {
|
|
id: protectionMessageTextWidget
|
|
horizontalAlignment: Text.AlignHCenter
|
|
color: Appearance.m3colors.m3onError
|
|
wrapMode: Text.Wrap
|
|
text: root.protectionMessage
|
|
}
|
|
}
|
|
}
|
|
}
|
|
}
|
|
}
|
|
}
|
|
}
|
|
}
|
|
|
|
IpcHandler {
|
|
target: "osdVolume"
|
|
|
|
function trigger() {
|
|
root.triggerOsd();
|
|
}
|
|
|
|
function hide() {
|
|
GlobalStates.osdVolumeOpen = false;
|
|
}
|
|
|
|
function toggle() {
|
|
GlobalStates.osdVolumeOpen = !GlobalStates.osdVolumeOpen;
|
|
}
|
|
}
|
|
GlobalShortcut {
|
|
name: "osdVolumeTrigger"
|
|
description: "Triggers volume OSD on press"
|
|
|
|
onPressed: {
|
|
root.triggerOsd();
|
|
}
|
|
}
|
|
GlobalShortcut {
|
|
name: "osdVolumeHide"
|
|
description: "Hides volume OSD on press"
|
|
|
|
onPressed: {
|
|
GlobalStates.osdVolumeOpen = false;
|
|
}
|
|
}
|
|
}
|