|
|
|
|
/*****************************************************************************
|
|
|
|
|
* Copyright (C) 2019 VLC authors and VideoLAN
|
|
|
|
|
*
|
|
|
|
|
* This program is free software; you can redistribute it and/or modify
|
|
|
|
|
* it under the terms of the GNU General Public License as published by
|
|
|
|
|
* the Free Software Foundation; either version 2 of the License, or
|
|
|
|
|
* ( at your option ) any later version.
|
|
|
|
|
*
|
|
|
|
|
* This program 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 General Public License for more details.
|
|
|
|
|
*
|
|
|
|
|
* You should have received a copy of the GNU General Public License
|
|
|
|
|
* along with this program; if not, write to the Free Software
|
|
|
|
|
* Foundation, Inc., 51 Franklin Street, Fifth Floor, Boston MA 02110-1301, USA.
|
|
|
|
|
*****************************************************************************/
|
|
|
|
|
|
|
|
|
|
import QtQuick 2.11
|
|
|
|
|
import QtQuick.Layouts 1.3
|
|
|
|
|
import QtQuick.Controls 2.4
|
|
|
|
|
import org.videolan.vlc 0.1
|
|
|
|
|
|
|
|
|
|
import "qrc:///widgets/" as Widgets
|
|
|
|
|
import "qrc:///style/"
|
|
|
|
|
|
|
|
|
|
import "qrc:///player/" as Player
|
|
|
|
|
import "qrc:///about/" as AB
|
|
|
|
|
import "qrc:///dialogs/" as DG
|
|
|
|
|
import "qrc:///playlist/" as PL
|
|
|
|
|
import QtQuick.Window 2.11
|
|
|
|
|
|
|
|
|
|
Rectangle {
|
|
|
|
|
id: root
|
|
|
|
|
color: "transparent"
|
|
|
|
|
|
|
|
|
|
Loader {
|
|
|
|
|
id: playlistWindowLoader
|
|
|
|
|
active: !rootWindow.playlistDocked && rootWindow.playlistVisible
|
|
|
|
|
sourceComponent: Window {
|
|
|
|
|
visible: true
|
|
|
|
|
title: qsTr("Playlist")
|
|
|
|
|
color: VLCStyle.colors.bg
|
|
|
|
|
onClosing: rootWindow.playlistVisible = false
|
|
|
|
|
PL.PlaylistListView {
|
|
|
|
|
id: playlistView
|
|
|
|
|
focus: true
|
|
|
|
|
anchors.fill: parent
|
|
|
|
|
}
|
|
|
|
|
}
|
|
|
|
|
}
|
|
|
|
|
|
|
|
|
|
PlaylistControllerModel {
|
|
|
|
|
id: mainPlaylistController
|
|
|
|
|
playlistPtr: mainctx.playlist
|
|
|
|
|
}
|
|
|
|
|
|
|
|
|
|
Component {
|
|
|
|
|
id: audioplayerComp
|
|
|
|
|
Player.Player {
|
|
|
|
|
focus: true
|
|
|
|
|
}
|
|
|
|
|
}
|
|
|
|
|
|
|
|
|
|
Component {
|
|
|
|
|
id: aboutComp
|
|
|
|
|
AB.About {
|
|
|
|
|
focus: true
|
|
|
|
|
onActionCancel: {
|
|
|
|
|
console.log("onActionCancel")
|
|
|
|
|
history.previous(History.Go)
|
|
|
|
|
}
|
|
|
|
|
}
|
|
|
|
|
}
|
|
|
|
|
|
|
|
|
|
readonly property var pageModel: [
|
|
|
|
|
{ name: "about", component: aboutComp },
|
|
|
|
|
{ name: "mc", url: "qrc:///medialibrary/MainDisplay.qml" },
|
|
|
|
|
{ name: "playlist", url: "qrc:///playlist/PlaylistMainView.qml" },
|
|
|
|
|
{ name: "player", component: audioplayerComp },
|
|
|
|
|
]
|
|
|
|
|
|
|
|
|
|
function loadCurrentHistoryView() {
|
|
|
|
|
var current = history.current
|
|
|
|
|
if ( !current || !current.view ) {
|
|
|
|
|
console.warn("unable to load requested view, undefined")
|
|
|
|
|
return
|
|
|
|
|
}
|
|
|
|
|
stackView.loadView(root.pageModel, current.view, current.viewProperties)
|
|
|
|
|
}
|
|
|
|
|
|
|
|
|
|
Connections {
|
|
|
|
|
target: history
|
|
|
|
|
onCurrentChanged: loadCurrentHistoryView()
|
|
|
|
|
}
|
|
|
|
|
|
|
|
|
|
Component.onCompleted: {
|
|
|
|
|
//set the initial view
|
|
|
|
|
if (medialib)
|
|
|
|
|
history.push(["mc", "video"], History.Go)
|
|
|
|
|
else
|
|
|
|
|
history.push(["playlist"], History.Go)
|
|
|
|
|
}
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
DropArea {
|
|
|
|
|
anchors.fill: parent
|
|
|
|
|
onEntered: console.log("drop Enter")
|
|
|
|
|
onExited: console.log("drop exit")
|
|
|
|
|
onDropped: {
|
|
|
|
|
if (drop.hasUrls) {
|
|
|
|
|
var list = []
|
|
|
|
|
for (var i = 0; i < drop.urls.length; i++){
|
|
|
|
|
list.push(drop.urls[i])
|
|
|
|
|
}
|
|
|
|
|
mainPlaylistController.append(list, true)
|
|
|
|
|
drop.accept()
|
|
|
|
|
}
|
|
|
|
|
}
|
|
|
|
|
|
|
|
|
|
Widgets.StackViewExt {
|
|
|
|
|
id: stackView
|
|
|
|
|
anchors.fill: parent
|
|
|
|
|
focus: true
|
|
|
|
|
|
|
|
|
|
Connections {
|
|
|
|
|
target: player
|
|
|
|
|
onPlayingStateChanged: {
|
|
|
|
|
if (player.playingState === PlayerController.PLAYING_STATE_STOPPED
|
|
|
|
|
&& history.current.view === "player") {
|
|
|
|
|
history.previous(History.Go)
|
|
|
|
|
}
|
|
|
|
|
}
|
|
|
|
|
}
|
|
|
|
|
|
|
|
|
|
Connections {
|
|
|
|
|
target: player.videoTracks
|
|
|
|
|
onDataChanged: {
|
|
|
|
|
if (player.videoTracks.rowCount() > 0
|
|
|
|
|
&& player.playingState === PlayerController.PLAYING_STATE_PLAYING
|
|
|
|
|
&& history.current.view !== "player") {
|
|
|
|
|
history.push(["player"], History.Go)
|
|
|
|
|
}
|
|
|
|
|
}
|
|
|
|
|
}
|
|
|
|
|
}
|
|
|
|
|
}
|
|
|
|
|
|
|
|
|
|
DG.Dialogs {
|
|
|
|
|
anchors.fill: parent
|
|
|
|
|
bgContent: root
|
|
|
|
|
onRestoreFocus: {
|
|
|
|
|
stackView.focus = true
|
|
|
|
|
}
|
|
|
|
|
}
|
|
|
|
|
}
|