Update copyright headers
[qt:qt.git] / demos / declarative / flickr / qml / flickr / mobile / TitleBar.qml
1 /****************************************************************************
2 **
3 ** Copyright (C) 2015 The Qt Company Ltd.
4 ** Contact: http://www.qt.io/licensing/
5 **
6 ** This file is part of the QtDeclarative module of the Qt Toolkit.
7 **
8 ** $QT_BEGIN_LICENSE:LGPL$
9 ** Commercial License Usage
10 ** Licensees holding valid commercial Qt licenses may use this file in
11 ** accordance with the commercial license agreement provided with the
12 ** Software or, alternatively, in accordance with the terms contained in
13 ** a written agreement between you and The Qt Company. For licensing terms
14 ** and conditions see http://www.qt.io/terms-conditions. For further
15 ** information use the contact form at http://www.qt.io/contact-us.
16 **
17 ** GNU Lesser General Public License Usage
18 ** Alternatively, this file may be used under the terms of the GNU Lesser
19 ** General Public License version 2.1 or version 3 as published by the Free
20 ** Software Foundation and appearing in the file LICENSE.LGPLv21 and
21 ** LICENSE.LGPLv3 included in the packaging of this file. Please review the
22 ** following information to ensure the GNU Lesser General Public License
23 ** requirements will be met: https://www.gnu.org/licenses/lgpl.html and
24 ** http://www.gnu.org/licenses/old-licenses/lgpl-2.1.html.
25 **
26 ** As a special exception, The Qt Company gives you certain additional
27 ** rights. These rights are described in The Qt Company LGPL Exception
28 ** version 1.1, included in the file LGPL_EXCEPTION.txt in this package.
29 **
30 ** GNU General Public License Usage
31 ** Alternatively, this file may be used under the terms of the GNU
32 ** General Public License version 3.0 as published by the Free Software
33 ** Foundation and appearing in the file LICENSE.GPL included in the
34 ** packaging of this file.  Please review the following information to
35 ** ensure the GNU General Public License version 3.0 requirements will be
36 ** met: http://www.gnu.org/copyleft/gpl.html.
37 **
38 ** $QT_END_LICENSE$
39 **
40 ****************************************************************************/
41
42 import QtQuick 1.0
43
44 Item {
45     id: titleBar
46     property string untaggedString: "Uploads from everyone"
47     property string taggedString: "Recent uploads tagged "
48
49     BorderImage { source: "images/titlebar.sci"; width: parent.width; height: parent.height + 14; y: -7 }
50
51     Item {
52         id: container
53         width: (parent.width * 2) - 55 ; height: parent.height
54
55         function accept() {
56             imageDetails.closed()
57             titleBar.state = ""
58             background.state = ""
59             rssModel.tags = editor.text
60         }
61
62         Image {
63             id: quitButton
64             anchors.left: parent.left//; anchors.leftMargin: 0
65             anchors.verticalCenter: parent.verticalCenter
66             source: "images/quit.png"
67             MouseArea {
68                 anchors.fill: parent
69                 onClicked: Qt.quit()
70             }
71         }
72
73         Text {
74             id: categoryText
75             anchors {
76                 left: quitButton.right; right: tagButton.left; leftMargin: 10; rightMargin: 10
77                 verticalCenter: parent.verticalCenter
78             }
79             elide: Text.ElideLeft
80             text: (rssModel.tags=="" ? untaggedString : taggedString + rssModel.tags)
81             font.bold: true; font.pixelSize: 15; color: "White"; style: Text.Raised; styleColor: "Black"
82         }
83
84         Button {
85             id: tagButton; x: titleBar.width - 50; width: 45; height: 32; text: "..."
86             onClicked: if (titleBar.state == "Tags") container.accept(); else titleBar.state = "Tags"
87             anchors.verticalCenter: parent.verticalCenter
88         }
89
90         Item {
91             id: lineEdit
92             y: 4; height: parent.height - 9
93             anchors { left: tagButton.right; leftMargin: 5; right: parent.right; rightMargin: 5 }
94
95             BorderImage { source: "images/lineedit.sci"; anchors.fill: parent }
96
97             TextInput {
98                 id: editor
99                 anchors {
100                     left: parent.left; right: parent.right; leftMargin: 10; rightMargin: 10
101                     verticalCenter: parent.verticalCenter
102                 }
103                 cursorVisible: true; font.bold: true
104                 color: "#151515"; selectionColor: "Green"
105             }
106
107             Keys.forwardTo: [ (returnKey), (editor)]
108
109             Item {
110                 id: returnKey
111                 Keys.onReturnPressed: container.accept()
112                 Keys.onEnterPressed: container.accept()
113                 Keys.onEscapePressed: titleBar.state = ""
114             }
115         }
116     }
117
118     states: State {
119         name: "Tags"
120         PropertyChanges { target: container; x: -tagButton.x + 5 }
121         PropertyChanges { target: tagButton; text: "OK" }
122         PropertyChanges { target: editor; focus: true }
123     }
124
125     transitions: Transition {
126         NumberAnimation { properties: "x"; easing.type: Easing.InOutQuad }
127     }
128 }