forked from Shinonome/dots-hyprland
59 lines
1.8 KiB
QML
59 lines
1.8 KiB
QML
import "root:/modules/common"
|
|
import "root:/modules/common/widgets"
|
|
import "root:/services"
|
|
import Qt5Compat.GraphicalEffects
|
|
import QtQuick
|
|
import QtQuick.Controls
|
|
import QtQuick.Layouts
|
|
import Quickshell.Widgets
|
|
import Quickshell.Services.Pipewire
|
|
|
|
Item {
|
|
id: root
|
|
required property PwNode node;
|
|
PwObjectTracker { objects: [ node ] }
|
|
|
|
implicitHeight: rowLayout.implicitHeight
|
|
|
|
RowLayout {
|
|
id: rowLayout
|
|
anchors.fill: parent
|
|
spacing: 10
|
|
|
|
Image {
|
|
Layout.alignment: Qt.AlignHCenter | Qt.AlignVCenter
|
|
visible: source != ""
|
|
sourceSize.width: 50
|
|
sourceSize.height: 50
|
|
source: {
|
|
const icon = root.node.properties["application.icon-name"] ?? "audio-volume-high-symbolic";
|
|
return `image://icon/${icon}`;
|
|
}
|
|
}
|
|
|
|
ColumnLayout {
|
|
Layout.fillWidth: true
|
|
RowLayout {
|
|
StyledText {
|
|
Layout.fillWidth: true
|
|
font.pixelSize: Appearance.font.pixelSize.normal
|
|
elide: Text.ElideRight
|
|
text: {
|
|
// application.name -> description -> name
|
|
const app = root.node.properties["application.name"] ?? (root.node.description != "" ? root.node.description : root.node.name);
|
|
const media = root.node.properties["media.name"];
|
|
return media != undefined ? `${app} • ${media}` : app;
|
|
}
|
|
}
|
|
}
|
|
|
|
RowLayout {
|
|
StyledSlider {
|
|
id: slider
|
|
value: root.node.audio.volume
|
|
onValueChanged: root.node.audio.volume = value
|
|
}
|
|
}
|
|
}
|
|
}
|
|
} |