1
0
Fork 0
mirror of https://github.com/HenkKalkwater/harbour-sailfin.git synced 2024-11-25 18:35:17 +00:00
harbour-sailfin/sailfish/qml/pages/itemdetails/MusicAlbumPage.qml

105 lines
3.8 KiB
QML
Raw Normal View History

2020-10-27 01:35:50 +00:00
/*
Sailfin: a Jellyfin client written using Qt
Copyright (C) 2020 Chris Josten
This library is free software; you can redistribute it and/or
modify it under the terms of the GNU Lesser General Public
License as published by the Free Software Foundation; either
version 2.1 of the License, or (at your option) any later version.
This library is distributed in the hope that it will be useful,
but WITHOUT ANY WARRANTY; without even the implied warranty of
MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the GNU
Lesser General Public License for more details.
You should have received a copy of the GNU Lesser General Public
License along with this library; if not, write to the Free Software
Foundation, Inc., 51 Franklin Street, Fifth Floor, Boston, MA 02110-1301 USA
*/
import QtQuick 2.6
import Sailfish.Silica 1.0
2020-10-27 01:35:50 +00:00
import QtQuick.Layouts 1.1
import nl.netsoj.chris.Jellyfin 1.0
import "../../components"
2020-10-27 01:35:50 +00:00
import "../../components/music"
import "../.."
BaseDetailPage {
2020-10-27 01:35:50 +00:00
id: albumPageRoot
readonly property int _songIndexWidth: 100
2020-10-27 01:35:50 +00:00
width: 800 * Theme.pixelRatio
2021-01-17 20:11:55 +00:00
readonly property bool _twoColumns: albumPageRoot.width / Theme.pixelRatio >= 800
UserItemModel {
id: collectionModel
apiClient: ApiClient
sortBy: ["SortName"]
fields: ["ItemCounts","PrimaryImageAspectRatio","BasicSyncInfo","CanDelete","MediaSourceCount"]
parentId: itemData.jellyfinId
onParentIdChanged: reload()
}
2020-10-27 01:35:50 +00:00
RowLayout {
anchors.fill: parent
2020-10-27 01:35:50 +00:00
Item {height: 1; width: Theme.horizontalPageMargin; visible: wideAlbumCover.visible; }
Loader {
id: wideAlbumCover
2021-01-17 20:11:55 +00:00
visible: _twoColumns
2020-10-27 01:35:50 +00:00
Layout.minimumWidth: 1000 / Theme.pixelRatio
Layout.fillHeight: true
source: visible
? "../../components/music/WideAlbumCover.qml" : ""
onLoaded: bindAlbum(item)
}
2020-10-27 01:35:50 +00:00
Item {height: 1; width: Theme.horizontalPageMargin; visible: wideAlbumCover.visible; }
SilicaListView {
id: list
Layout.fillHeight: true
Layout.fillWidth: true
model: collectionModel
header: Loader {
width: parent.width
2021-01-17 20:11:55 +00:00
source: "../../components/music/NarrowAlbumCover.qml"
2020-10-27 01:35:50 +00:00
onLoaded: bindAlbum(item)
}
2020-10-27 01:35:50 +00:00
section {
property: "parentIndexNumber"
delegate: SectionHeader {
text: qsTr("Disc %1").arg(section)
}
}
2020-10-27 01:35:50 +00:00
delegate: SongDelegate {
id: songDelegate
2020-10-27 01:35:50 +00:00
name: model.name
artists: model.artists
duration: model.runTimeTicks
indexNumber: model.indexNumber
onClicked: window.playbackManager.playItem(model.jellyfinId)
}
2020-10-27 01:35:50 +00:00
VerticalScrollDecorator {}
}
2020-10-27 01:35:50 +00:00
}
Connections {
target: itemData
onAlbumArtistsChanged: {
}
}
2020-10-27 01:35:50 +00:00
function bindAlbum(item) {
item.albumArt = Qt.binding(function(){ return Utils.itemImageUrl(ApiClient.baseUrl, itemData, "Primary", {"maxWidth": parent.width})})
item.name = Qt.binding(function(){ return itemData.name})
item.releaseYear = Qt.binding(function() { return itemData.productionYear})
item.albumArtist = Qt.binding(function() { return itemData.albumArtist})
2020-10-27 01:35:50 +00:00
item.duration = Qt.binding(function() { return itemData.runTimeTicks})
item.songCount = Qt.binding(function() { return itemData.childCount})
item.listview = Qt.binding(function() { return list})
item.blurhash = Qt.binding(function() { return itemData.imageBlurHashes["Primary"][itemData.imageTags["Primary"]]; })
2021-01-17 20:11:55 +00:00
item.twoColumns = Qt.binding(function() { return _twoColumns })
2020-10-27 01:35:50 +00:00
}
}