fix mpris errors and create player selector

This commit is contained in:
Benjamin Palko 2025-08-31 15:48:14 -04:00
parent dddbb82984
commit 2d6cb05015
4 changed files with 105 additions and 93 deletions

View file

@ -8,13 +8,15 @@ import QtQuick
import QtQuick.Layouts import QtQuick.Layouts
import Quickshell.Services.Mpris import Quickshell.Services.Mpris
ColumnLayout { Loader {
id: root id: root
required property MprisPlayer player required property MprisPlayer player
spacing: 12 active: player != null
sourceComponent: ColumnLayout {
spacing: 12
implicitWidth: 800 implicitWidth: 800
StyledText { StyledText {
@ -77,4 +79,5 @@ ColumnLayout {
onTriggered: root.player.positionChanged() onTriggered: root.player.positionChanged()
} }
} }
}
} }

View file

@ -0,0 +1,46 @@
import qs.components
import qs.constants
import qs.services
import qs.widgets
import QtQuick
import QtQuick.Layouts
RowLayout {
spacing: 8
Layout.alignment: Qt.AlignHCenter
StyledIconButton {
id: previousPlayerButton
visible: Mpris.players.length > 1
text: Icons.chevronLeft
onClicked: {
Mpris.previousPlayer();
}
}
StyledText {
text: {
function parseName(name) {
const words = name.split("-");
const capitalized = words.map(val => val.trim().charAt(0).toUpperCase() + val.trim().slice(1));
return capitalized.join(" ");
}
return parseName(Mpris.active?.desktopEntry ?? Mpris.active?.dbusName ?? "unknown");
}
font.pixelSize: 20
}
StyledIconButton {
id: nextPlayerButton
visible: Mpris.players.length > 1
text: Icons.chevronRight
onClicked: {
Mpris.nextPlayer();
}
}
}

View file

@ -1,9 +1,7 @@
pragma ComponentBehavior: Bound pragma ComponentBehavior: Bound
import qs.components import qs.components
import qs.constants
import qs.services import qs.services
import qs.widgets
import QtQuick import QtQuick
import QtQuick.Layouts import QtQuick.Layouts
@ -16,44 +14,9 @@ StyledDrawer {
margin: 32 margin: 32
ColumnLayout { ColumnLayout {
spacing: 8 spacing: 8
RowLayout {
spacing: 8
MprisPlayerSelector {
Layout.alignment: Qt.AlignHCenter Layout.alignment: Qt.AlignHCenter
StyledIconButton {
id: previousPlayerButton
visible: Mpris.players.length > 1
text: Icons.chevronLeft
onClicked: {
Mpris.previousPlayer();
}
}
StyledText {
text: {
if (Mpris.active?.identity) {
const words = Mpris.active?.identity.split("-");
const capitalized = words.map(val => String(val).charAt(0).toUpperCase() + String(val).slice(1));
return capitalized.join(" ");
}
return Mpris.active?.desktopEntry ?? Mpris.active?.dbusName ?? "unknown";
}
font.pixelSize: 20
}
StyledButton {
id: nextPlayerButton
visible: Mpris.players.length > 1
text: Icons.chevronRight
onClicked: {
Mpris.nextPlayer();
}
}
} }
MprisController { MprisController {

View file

@ -8,7 +8,7 @@ Singleton {
id: root id: root
property list<MprisPlayer> players: Mpris.players.values property list<MprisPlayer> players: Mpris.players.values
property MprisPlayer active: players[properties.currentIndex] property MprisPlayer active: players[properties.currentIndex] ?? null
PersistentProperties { PersistentProperties {
id: properties id: properties