import QtQuick 2.6 import Sailfish.Silica 1.0 import nl.netsoj.chris.Jellyfin 1.0 import "../components" import "../compontents/details" Page { id: pageRoot property string itemId: "" property var itemData: ({}) property bool _loading: true readonly property bool _hasLogo: itemData.ImageTags.Logo !== undefined readonly property string _logo: itemData.ImageTags.Logo readonly property var _backdropImages: itemData.BackdropImageTags readonly property var _parentBackdropImages: itemData.ParentBackdropImageTags readonly property string parentId: itemData.ParentId on_BackdropImagesChanged: updateBackdrop() on_ParentBackdropImagesChanged: updateBackdrop() function updateBackdrop() { if (_backdropImages && _backdropImages.length > 0) { var rand = Math.floor(Math.random() * (_backdropImages.length - 0.001)) console.log("Random: ", rand) backdrop.source = ApiClient.baseUrl + "/Items/" + itemId + "/Images/Backdrop/" + rand + "?tag=" + _backdropImages[rand] } else if (_parentBackdropImages && _parentBackdropImages.length > 0) { console.log(parentId) backdrop.source = ApiClient.baseUrl + "/Items/" + itemData.ParentBackdropItemId + "/Images/Backdrop/0?tag=" + _parentBackdropImages[0] } } allowedOrientations: Orientation.All GlassyBackground { id: backdrop anchors.fill: parent } SilicaFlickable { anchors.fill: parent contentHeight: content.height Column { id: content width: parent.width PageHeader { title: itemData.Name visible: !_hasLogo } Column { width: parent.width Item { width: 1 height: Theme.paddingLarge } RemoteImage { anchors { horizontalCenter: parent.horizontalCenter } source: _hasLogo ? ApiClient.baseUrl + "/Items/" + itemId + "/Images/Logo?tag=" + _logo : undefined } Item { width: 1 height: Theme.paddingLarge } visible: _hasLogo } Item { width: 1 height: Theme.paddingLarge } PlainLabel { id: overviewText text: itemData.Overview visible: text.length > 0 font.pixelSize: Theme.fontSizeSmall } Item { visible: overviewText.visible width: 1 height: Theme.paddingLarge } Row { anchors { //left: parent.left right: parent.right leftMargin: Theme.horizontalPageMargin rightMargin: Theme.horizontalPageMargin } spacing: Theme.paddingMedium IconButton { id: favouriteButton icon.source: "image://theme/icon-m-favorite" } IconButton { id: playButton icon.source: "image://theme/icon-l-play" onPressed: pageStack.push(Qt.resolvedUrl("VideoPage.qml"), {"itemId": itemId, "itemData": itemData}) } } } } PageBusyIndicator { running: pageRoot._loading } onItemIdChanged: { itemData = {} if (itemId.length > 0) { pageRoot._loading = true ApiClient.fetchItem(itemId) } } onStatusChanged: { if (status == PageStatus.Deactivating) { backdrop.clear() appWindow.itemData = ({}) } } Connections { target: ApiClient onItemFetched: { if (itemId === pageRoot.itemId) { //console.log(JSON.stringify(result)) pageRoot.itemData = result pageRoot._loading = false appWindow.itemData = result } } } }