/**************************************************************************** ** ** Copyright (c) 2011 Nokia Corporation and/or its subsidiary(-ies). ** All rights reserved. ** Contact: Yoann Lopes (yoann.lopes@nokia.com) ** ** This file is part of the MeeSpot project. ** ** Redistribution and use in source and binary forms, with or without ** modification, are permitted provided that the following conditions ** are met: ** ** Redistributions of source code must retain the above copyright notice, ** this list of conditions and the following disclaimer. ** ** Redistributions in binary form must reproduce the above copyright ** notice, this list of conditions and the following disclaimer in the ** documentation and/or other materials provided with the distribution. ** ** Neither the name of Nokia Corporation and its Subsidiary(-ies) nor the names of its ** contributors may be used to endorse or promote products derived from ** this software without specific prior written permission. ** ** THIS SOFTWARE IS PROVIDED BY THE COPYRIGHT HOLDERS AND CONTRIBUTORS ** "AS IS" AND ANY EXPRESS OR IMPLIED WARRANTIES, INCLUDING, BUT NOT ** LIMITED TO, THE IMPLIED WARRANTIES OF MERCHANTABILITY AND FITNESS ** FOR A PARTICULAR PURPOSE ARE DISCLAIMED. IN NO EVENT SHALL THE COPYRIGHT ** HOLDER OR CONTRIBUTORS BE LIABLE FOR ANY DIRECT, INDIRECT, INCIDENTAL, ** SPECIAL, EXEMPLARY, OR CONSEQUENTIAL DAMAGES (INCLUDING, BUT NOT LIMITED ** TO, PROCUREMENT OF SUBSTITUTE GOODS OR SERVICES; LOSS OF USE, DATA, OR ** PROFITS; OR BUSINESS INTERRUPTION) HOWEVER CAUSED AND ON ANY THEORY OF ** LIABILITY, WHETHER IN CONTRACT, STRICT LIABILITY, OR TORT (INCLUDING ** NEGLIGENCE OR OTHERWISE) ARISING IN ANY WAY OUT OF THE USE OF THIS ** SOFTWARE, EVEN IF ADVISED OF THE POSSIBILITY OF SUCH DAMAGE. ** ** If you have questions regarding the use of this file, please contact ** Nokia at qt-info@nokia.com. ** ****************************************************************************/ import QtQuick 1.1 import com.meego 1.0 import QtSpotify 1.0 import "UIConstants.js" as UI import "Utilities.js" as Utilities Page { orientationLock: PageOrientation.LockPortrait anchors.rightMargin: UI.MARGIN_XLARGE anchors.leftMargin: UI.MARGIN_XLARGE pageStack: parent enabled: !spotifySession.offlineMode onStatusChanged: if (status == PageStatus.Active && !spotifySession.offlineMode) toplist.updateResults() Connections { target: spotifySession onOfflineModeChanged: { if (spotifySession.offlineMode) pageStack.pop(null); else toplist.updateResults() } onConnectionStatusChanged: { if (spotifySession.connectionStatus != SpotifySession.LoggedIn) pageStack.pop(null); } } Rectangle { anchors.fill: parent visible: spotifySession.offlineMode color: "#DD000000" z: 500 Label { anchors.verticalCenter: parent.verticalCenter anchors.horizontalCenter: parent.horizontalCenter text: "Not available in offline mode" font.pixelSize: UI.FONT_XLARGE font.family: UI.FONT_FAMILY_LIGHT font.weight: Font.Light wrapMode: Text.WordWrap width: parent.width - UI.MARGIN_XLARGE * 2 horizontalAlignment: Text.AlignHCenter } } SpotifyToplist { id: toplist } TrackMenu { id: menu deleteVisible: false } AlbumMenu { id: albumMenu playVisible: true artistVisible: true albumBrowse: SpotifyAlbumBrowse { id: menuAlbumBrowse onTracksChanged: albumMenu.open() } } Column { id: whatsNew width: parent.width spacing: UI.MARGIN_XLARGE ViewHeader { text: "New releases" } SpotifySearch { id: searchNew query: "tag:new" Component.onCompleted: search() } ListView { id: newAlbumsView width: parent.width height: 112 orientation: ListView.Horizontal model: searchNew.albums clip: true snapMode: ListView.SnapToItem cacheBuffer: 3000 pressDelay: 50 Component.onCompleted: positionViewAtBeginning() delegate: SpotifyImage { spotifyId: modelData.coverId height: newAlbumsView.height width: height clip: true opacity: newAlbumMouse.pressed ? 0.3 : 1.0 Rectangle { anchors.bottom: parent.bottom width: parent.width height: newAlbumName.height + 2 color: "#BA202020" Column { id: newAlbumName anchors.left: parent.left anchors.leftMargin: 4 anchors.right: parent.right anchors.rightMargin: 4 anchors.verticalCenter: parent.verticalCenter spacing: -3 Label { text: modelData.name font.pixelSize: UI.FONT_XSMALL width: parent.width elide: Text.ElideRight verticalAlignment: Text.AlignVCenter } Label { text: modelData.artist font.pixelSize: UI.FONT_XXSMALL width: parent.width elide: Text.ElideRight verticalAlignment: Text.AlignVCenter } } } MouseArea { id: newAlbumMouse anchors.fill: parent onClicked: { mainPage.tabs.currentTab.push(Qt.resolvedUrl("AlbumPage.qml"), { album: modelData }) } onPressAndHold: { menuAlbumBrowse.album = modelData; if (menuAlbumBrowse.totalDuration > 0) albumMenu.open() } } } } } Column { id: header width: parent.width anchors.top: whatsNew.bottom anchors.topMargin: UI.MARGIN_XLARGE Separator { width: parent.width } Selector { id: selector title: "Top lists" titleFontFamily: UI.FONT_FAMILY_LIGHT titleFontWeight: Font.Light titleFontSize: UI.FONT_LARGE selectedIndex: 0 model: ListModel { ListElement { name: "Tracks" } ListElement { name: "Albums" } ListElement { name: "Artists" } } } Separator { width: parent.width } } Item { anchors.right: parent.right anchors.left: parent.left anchors.top: header.bottom anchors.bottom: parent.bottom anchors.topMargin: UI.MARGIN_XLARGE anchors.rightMargin: -UI.MARGIN_XLARGE anchors.leftMargin: -UI.MARGIN_XLARGE clip: true ListView { id: results anchors.fill: parent anchors.rightMargin: UI.MARGIN_XLARGE anchors.leftMargin: UI.MARGIN_XLARGE cacheBuffer: 8000 Component { id: trackComponent TrackDelegate { name: modelData.name artistAndAlbum: modelData.artists + " | " + modelData.album duration: modelData.duration highlighted: modelData.isCurrentPlayingTrack starred: modelData.isStarred coverId: modelData.albumCoverId showIndex: true available: modelData.isAvailable onClicked: modelData.play() onPressAndHold: { menu.track = modelData; menu.open(); } } } Component { id: albumComponent AlbumDelegate { name: modelData.name artist: modelData.artist albumCover: modelData.coverId showIndex: true onClicked: { mainPage.tabs.currentTab.push(Qt.resolvedUrl("AlbumPage.qml"), { album: modelData }) } onPressAndHold: { menuAlbumBrowse.album = modelData; if (menuAlbumBrowse.totalDuration > 0) albumMenu.open() } } } Component { id: artistComponent ArtistDelegate { name: modelData.name portrait: modelData.pictureId showIndex: true onClicked: { mainPage.tabs.currentTab.push(Qt.resolvedUrl("ArtistPage.qml"), { artist: modelData }) } } } Connections { target: selector onSelectedIndexChanged: results.updateResults() } Connections { target: toplist onResultsChanged: results.updateResults() } function updateResults() { results.model = 0 results.delegate = null if (selector.selectedIndex === 0) { results.delegate = trackComponent results.model = toplist.tracks } else if (selector.selectedIndex == 1) { results.delegate = albumComponent results.model = toplist.albums } else if (selector.selectedIndex == 2) { results.delegate = artistComponent results.model = toplist.artists } } } Scrollbar { listView: results } } BusyIndicator { anchors.centerIn: parent visible: toplist.busy && results.count === 0 running: visible BusyIndicatorStyle { size: "medium" } } }