PostCapturePage can now play video
[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: item
29         property bool isImage: mimetype.toLowerCase().search("video") < 0
30         property bool error: false
31
32         property bool isCurrentItem: PathView.isCurrentItem
33         onIsCurrentItemChanged: page.currentItem = item;
34
35         property string fileName: filename
36
37         function startPlayback() {
38                 openFileNow("VideoPlayerPage.qml");
39                 pageStack.currentPage.source = url;
40                 pageStack.currentPage.play();
41         }
42
43         Label {
44                 anchors.fill: parent
45                 visible: image.error && page.status == PageStatus.Active
46                 text: qsTr("Failed to load preview");
47                 verticalAlignment: Text.AlignVCenter
48                 horizontalAlignment: Text.AlignHCenter
49                 font.pixelSize: 32
50         }
51
52         QuillItem {
53                 id: image
54                 anchors.fill: parent
55                 visible: page.status == PageStatus.Activating || page.status == PageStatus.Active
56
57                 Component.onCompleted: initialize(url, mimetype);
58
59                 MouseArea {
60                         id: mouse
61                         anchors.fill: parent
62                         enabled: true
63                         onClicked: toolBar.visible = !toolBar.visible
64                 }
65
66                 ToolIcon {
67                         id: playIcon
68                         anchors.centerIn: parent
69                         iconSource: "image://theme/icon-s-music-video-play"
70                         visible: !isImage
71                         onClicked: startPlayback();
72                 }
73         }
74 }