2026-01-15 15:14:29 +01:00
|
|
|
import Quickshell
|
|
|
|
|
import QtQuick
|
|
|
|
|
import Quickshell.Services.Pipewire
|
|
|
|
|
import "../../reusables/"
|
|
|
|
|
import "../../settings/"
|
|
|
|
|
import "../../"
|
|
|
|
|
|
|
|
|
|
Item {
|
|
|
|
|
id: root
|
2026-01-16 21:35:03 +01:00
|
|
|
implicitWidth: textRow.width
|
|
|
|
|
implicitHeight: Settings.config.barHeight
|
2026-01-16 14:44:10 +01:00
|
|
|
property var sink: Pipewire.defaultAudioSink
|
|
|
|
|
function getVolumeIcon() {
|
|
|
|
|
// Safety check: if Pipewire is dead or sink is missing
|
|
|
|
|
if (!sink)
|
|
|
|
|
return "volume_off";
|
|
|
|
|
|
|
|
|
|
// If muted, show the hush icon
|
|
|
|
|
if (sink.audio.muted)
|
|
|
|
|
return "volume_off";
|
|
|
|
|
|
|
|
|
|
// Volume is usually 0.0 to 1.0 (0% to 100%)
|
|
|
|
|
const vol = sink.audio.volume;
|
|
|
|
|
|
|
|
|
|
if (vol <= 0.25)
|
|
|
|
|
return "volume_mute";
|
|
|
|
|
if (vol < 0.75)
|
|
|
|
|
return "volume_down";
|
|
|
|
|
if (vol <= 1.00)
|
|
|
|
|
return "volume_up";
|
|
|
|
|
|
|
|
|
|
// If it's loud, prepare the ears!
|
|
|
|
|
return "volume_up";
|
|
|
|
|
}
|
|
|
|
|
Row {
|
2026-01-16 15:15:44 +01:00
|
|
|
id: textRow
|
2026-01-16 21:35:03 +01:00
|
|
|
anchors.verticalCenter: parent.verticalCenter
|
2026-01-17 13:11:37 +01:00
|
|
|
spacing: 0
|
2026-01-16 14:44:10 +01:00
|
|
|
CustomText {
|
|
|
|
|
id: volumeText
|
|
|
|
|
PwObjectTracker {
|
|
|
|
|
objects: Pipewire.ready ? Pipewire.defaultAudioSink : []
|
|
|
|
|
}
|
|
|
|
|
text: Pipewire.ready ? Math.round(root.sink.audio.volume * 100) + "%" : "failure"
|
2026-01-16 21:35:03 +01:00
|
|
|
opacity: Pipewire.ready ? root.sink.audio.muted ? 0.5 : 1 : 0
|
2026-01-16 14:44:10 +01:00
|
|
|
}
|
|
|
|
|
CustomIcon {
|
2026-01-16 15:15:44 +01:00
|
|
|
id: volumeIcon
|
2026-01-16 21:35:03 +01:00
|
|
|
opacity: Pipewire.ready ? root.sink.audio.muted ? 0.5 : 1 : 0
|
|
|
|
|
text: Pipewire.ready ? root.getVolumeIcon() : null
|
2026-01-15 15:14:29 +01:00
|
|
|
}
|
|
|
|
|
}
|
|
|
|
|
}
|