Fixup the sfos mpris control
Summary: -Fix type in pause icon -Remove unnescessary label -Size volumne slider correctly -Centre buttons -Make volume control work Reviewers: #kde_connect, nicolasfella, kossebau, albertvaka Reviewed By: #kde_connect, albertvaka Subscribers: albertvaka, apol, kdeconnect Tags: #kde_connect Differential Revision: https://phabricator.kde.org/D14568
This commit is contained in:
parent
1ccf1a8809
commit
064b07c0ce
3 changed files with 79 additions and 19 deletions
|
@ -7,6 +7,10 @@ add_subdirectory(battery)
|
|||
add_subdirectory(sendnotifications)
|
||||
add_subdirectory(clipboard)
|
||||
|
||||
if (NOT WIN32)
|
||||
add_subdirectory(mpriscontrol)
|
||||
endif()
|
||||
|
||||
if(NOT SAILFISHOS)
|
||||
add_subdirectory(contacts)
|
||||
add_subdirectory(share)
|
||||
|
@ -18,7 +22,6 @@ if(NOT SAILFISHOS)
|
|||
if(NOT WIN32)
|
||||
add_subdirectory(runcommand)
|
||||
add_subdirectory(pausemusic)
|
||||
add_subdirectory(mpriscontrol)
|
||||
add_subdirectory(screensaver-inhibit)
|
||||
add_subdirectory(sftp)
|
||||
endif()
|
||||
|
|
|
@ -20,6 +20,7 @@
|
|||
|
||||
import QtQuick 2.0
|
||||
import Sailfish.Silica 1.0
|
||||
import QtQuick.Layouts 1.0
|
||||
import org.kde.kdeconnect 1.0
|
||||
|
||||
Page
|
||||
|
@ -27,19 +28,22 @@ Page
|
|||
id: root
|
||||
property QtObject pluginInterface
|
||||
|
||||
Column
|
||||
Label {
|
||||
id: noPlayersText
|
||||
text: "No players available"
|
||||
anchors.centerIn: parent
|
||||
visible: pluginInterface.playerList.length == 0
|
||||
}
|
||||
ColumnLayout
|
||||
{
|
||||
anchors.fill: parent
|
||||
anchors.margins: Theme.paddingMedium
|
||||
PageHeader { title: "Multimedia Controls" }
|
||||
visible: !noPlayersText.visible
|
||||
|
||||
Component.onCompleted: {
|
||||
pluginInterface.requestPlayerList();
|
||||
}
|
||||
|
||||
Item { height: parent.height }
|
||||
ComboBox {
|
||||
label: "Player"
|
||||
width: parent.width
|
||||
Layout.fillWidth: true
|
||||
onCurrentIndexChanged: root.pluginInterface.player = value
|
||||
|
||||
menu: ContextMenu {
|
||||
|
@ -49,34 +53,86 @@ Page
|
|||
}
|
||||
}
|
||||
}
|
||||
|
||||
Label {
|
||||
width: parent.width
|
||||
id: nowPlaying
|
||||
Layout.fillWidth: true
|
||||
text: root.pluginInterface.nowPlaying
|
||||
visible: root.pluginInterface.title.length == 0
|
||||
wrapMode: Text.Wrap
|
||||
}
|
||||
Row {
|
||||
width: parent.width
|
||||
Label {
|
||||
Layout.fillWidth: true
|
||||
text: root.pluginInterface.title
|
||||
visible: !nowPlaying.visible
|
||||
wrapMode: Text.Wrap
|
||||
}
|
||||
Label {
|
||||
Layout.fillWidth: true
|
||||
text: root.pluginInterface.artist
|
||||
visible: !nowPlaying.visible && !artistAlbum.visible && root.pluginInterface.artist.length > 0
|
||||
wrapMode: Text.Wrap
|
||||
}
|
||||
Label {
|
||||
Layout.fillWidth: true
|
||||
text: root.pluginInterface.album
|
||||
visible: !nowPlaying.visible && !artistAlbum.visible && root.pluginInterface.album.length > 0
|
||||
wrapMode: Text.Wrap
|
||||
}
|
||||
Label {
|
||||
id: artistAlbum
|
||||
Layout.fillWidth: true
|
||||
text: "%1 - %2", root.pluginInterface.artist, root.pluginInterface.album
|
||||
visible: !nowPlaying.visible && root.pluginInterface.album.length > 0 && root.pluginInterface.artist.length > 0
|
||||
wrapMode: Text.Wrap
|
||||
}
|
||||
|
||||
RowLayout {
|
||||
Layout.fillWidth: true
|
||||
height: childrenRect.height
|
||||
IconButton {
|
||||
id: btnPrev
|
||||
Layout.fillWidth: true
|
||||
icon.source: "image://theme/icon-m-previous"
|
||||
onClicked: root.pluginInterface.sendAction("Previous")
|
||||
}
|
||||
IconButton {
|
||||
icon.source: root.pluginInterface.isPlaying ? "icon-m-image://theme/pause" : "image://theme/icon-m-play"
|
||||
id: btnPlay
|
||||
Layout.fillWidth: true
|
||||
icon.source: root.pluginInterface.isPlaying ? "image://theme/icon-m-pause" : "image://theme/icon-m-play"
|
||||
onClicked: root.pluginInterface.sendAction("PlayPause");
|
||||
}
|
||||
IconButton {
|
||||
id: btnNext
|
||||
Layout.fillWidth: true
|
||||
icon.source: "image://theme/icon-m-next"
|
||||
onClicked: root.pluginInterface.sendAction("Next")
|
||||
}
|
||||
}
|
||||
Row {
|
||||
width: parent.width
|
||||
Label { text: ("Volume:") }
|
||||
Slider {
|
||||
value: root.pluginInterface.volume
|
||||
maximumValue: 100
|
||||
width: parent.width
|
||||
|
||||
Slider {
|
||||
id: sldVolume
|
||||
label: "Volume"
|
||||
maximumValue: 100
|
||||
Layout.fillWidth: true
|
||||
//value: root.pluginInterface.volume
|
||||
onValueChanged: {
|
||||
root.pluginInterface.volume = value;
|
||||
}
|
||||
}
|
||||
|
||||
Item { height: parent.height }
|
||||
}
|
||||
|
||||
|
||||
Connections {
|
||||
target: root.pluginInterface
|
||||
onPropertiesChanged: {
|
||||
sldVolume.value = root.pluginInterface.volume;
|
||||
}
|
||||
}
|
||||
|
||||
Component.onCompleted: {
|
||||
pluginInterface.requestPlayerList();
|
||||
}
|
||||
}
|
||||
|
|
|
@ -17,6 +17,7 @@ URL: http://example.org/
|
|||
Source0: %{name}-%{version}.tar.bz2
|
||||
Source100: kdeconnect-sfos.yaml
|
||||
Requires: sailfishsilica-qt5 >= 0.10.9
|
||||
Requires: qt5-qtquickcontrols-layouts
|
||||
BuildRequires: pkgconfig(sailfishapp) >= 1.0.2
|
||||
BuildRequires: pkgconfig(Qt5Core)
|
||||
BuildRequires: pkgconfig(Qt5Qml)
|
||||
|
|
Loading…
Reference in a new issue