Pass the correct url to video player
[harmattan/cameraplus] / qml / PostCaptureItem.qml
1 // -*- qml -*-
2
3 /*!
4  * This file is part of CameraPlus.
5  *
6  * Copyright (C) 2012 Mohammed Sameer <msameer@foolab.org>
7  *
8  * This library is free software; you can redistribute it and/or
9  * modify it under the terms of the GNU Lesser General Public
10  * License as published by the Free Software Foundation; either
11  * version 2.1 of the License, or (at your option) any later version.
12  *
13  * This library is distributed in the hope that it will be useful,
14  * but WITHOUT ANY WARRANTY; without even the implied warranty of
15  * MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE.  See the GNU
16  * Lesser General Public License for more details.
17  *
18  * You should have received a copy of the GNU Lesser General Public
19  * License along with this library; if not, write to the Free Software
20  * Foundation, Inc., 51 Franklin Street, Fifth Floor, Boston, MA  02110-1301  USA
21  */
22
23 import QtQuick 1.1
24 import com.nokia.meego 1.1
25 import CameraPlus 1.0
26
27 Item {
28         id: postCaptureItem
29         property bool isVideo: itemData.type.search("nmm#Video") > 0
30         property bool error: false
31         property variant itemData: item
32         property bool isCurrentItem: PathView.isCurrentItem
33         onIsCurrentItemChanged: {
34                 if (isCurrentItem) {
35                         page.currentItem = postCaptureItem;
36                 }
37         }
38
39         function startPlayback() {
40                 openFileNow("VideoPlayerPage.qml");
41                 pageStack.currentPage.source = itemData.url;
42                 pageStack.currentPage.play();
43         }
44
45         Label {
46                 anchors.fill: parent
47                 visible: image.error && page.status == PageStatus.Active
48                 text: qsTr("Failed to load preview");
49                 verticalAlignment: Text.AlignVCenter
50                 horizontalAlignment: Text.AlignHCenter
51                 font.pixelSize: 32
52         }
53
54         QuillItem {
55                 id: image
56                 anchors.fill: parent
57                 visible: page.status == PageStatus.Activating || page.status == PageStatus.Active
58
59                 Component.onCompleted: initialize(itemData.url, itemData.mimetype);
60
61                 MouseArea {
62                         id: mouse
63                         anchors.fill: parent
64                         enabled: true
65                         onClicked: toolBar.visible = !toolBar.visible
66                 }
67
68                 ToolIcon {
69                         id: playIcon
70                         anchors.centerIn: parent
71                         iconSource: "image://theme/icon-s-music-video-play"
72                         visible: isVideo
73                         onClicked: startPlayback();
74                 }
75         }
76 }