summaryrefslogtreecommitdiffstats
path: root/qml/DemoHeader.qml
diff options
context:
space:
mode:
authorLasse Räihä <lasse.raiha@qt.io>2017-09-21 14:44:43 +0300
committerSami Nurmenniemi <sami.nurmenniemi@qt.io>2017-11-22 10:42:41 +0000
commitc0a91aab1a5e5ac4a0e6effcd410e43bd8b6cc16 (patch)
tree60c54024bfbab4f5ef31aa684b2562aea6648259 /qml/DemoHeader.qml
parentd2ec2dc7034c31e3602003b55d5f2a2c98983651 (diff)
Launcher update
Task-number: QTBUG-63091 Done-with: Juho Annunen <juho.annunen@qt.io> Change-Id: I4395becf8539e95ab3fa90b03e71565a2d087398 Reviewed-by: Kari Oikarinen <kari.oikarinen@qt.io>
Diffstat (limited to 'qml/DemoHeader.qml')
-rw-r--r--qml/DemoHeader.qml134
1 files changed, 134 insertions, 0 deletions
diff --git a/qml/DemoHeader.qml b/qml/DemoHeader.qml
new file mode 100644
index 0000000..da0ef57
--- /dev/null
+++ b/qml/DemoHeader.qml
@@ -0,0 +1,134 @@
+/****************************************************************************
+**
+** Copyright (C) 2017 The Qt Company Ltd.
+** Contact: https://www.qt.io/licensing/
+**
+** This file is part of Qt for Device Creation.
+**
+** $QT_BEGIN_LICENSE:GPL$
+** Commercial License Usage
+** Licensees holding valid commercial Qt licenses may use this file in
+** accordance with the commercial license agreement provided with the
+** Software or, alternatively, in accordance with the terms contained in
+** a written agreement between you and The Qt Company. For licensing terms
+** and conditions see https://www.qt.io/terms-conditions. For further
+** information use the contact form at https://www.qt.io/contact-us.
+**
+** GNU General Public License Usage
+** Alternatively, this file may be used under the terms of the GNU
+** General Public License version 3 or (at your option) any later version
+** approved by the KDE Free Qt Foundation. The licenses are as published by
+** the Free Software Foundation and appearing in the file LICENSE.GPL3
+** included in the packaging of this file. Please review the following
+** information to ensure the GNU General Public License requirements will
+** be met: https://www.gnu.org/licenses/gpl-3.0.html.
+**
+** $QT_END_LICENSE$
+**
+****************************************************************************/
+import QtQuick 2.0
+
+Rectangle {
+ id: demoHeaderBar
+ width: parent.width
+ height: viewSettings.demoHeaderHeight
+ color: "#09102b"
+ opacity: 0.9
+ y: 0
+ z: 1
+ visible: engine.state === "app-running"
+ Behavior on y { NumberAnimation { duration: 100 } }
+
+ property bool open: y > -height/2
+
+ signal infoClicked()
+ signal closeClicked()
+
+ Row {
+ anchors.top: parent.top
+ anchors.bottom: parent.bottom
+ anchors.left: parent.left
+ anchors.margins: viewSettings.pageMargin * 0.3
+ spacing: viewSettings.pageMargin
+
+ Image {
+ id: headerLogo
+ source: "icons/qt_logo_green_rgb.svg"
+ height: parent.height
+ width: height / sourceSize.height * sourceSize.width
+ }
+
+ Text {
+ id: demoName
+ height: parent.height
+ verticalAlignment: Text.AlignVCenter
+ font.pixelSize: parent.height * 0.5
+ font.family: viewSettings.appFont
+ font.styleName: "SemiBold"
+ color: "white"
+ text: engine.applicationName
+ }
+ }
+
+ Row {
+ anchors.top: parent.top
+ anchors.bottom: parent.bottom
+ anchors.right: parent.right
+ anchors.margins: viewSettings.pageMargin * 0.3
+ spacing: viewSettings.pageMargin
+
+ Image {
+ id: infoImg
+ height: parent.height
+ width: height
+ source: "icons/info_icon.svg"
+ MouseArea {
+ anchors.fill: parent
+ anchors.margins: -parent.height * 0.2
+ onClicked: demoHeaderBar.infoClicked()
+ }
+ }
+
+ Image {
+ id: applicationCloseButton
+ height: parent.height
+ width: height
+ source: "icons/close_icon.svg"
+ MouseArea {
+ anchors.fill: parent
+ anchors.margins: -parent.height * 0.2
+ onClicked: demoHeaderBar.closeClicked()
+ }
+ }
+ }
+
+ Image {
+ id: headerToggleButton
+ source: "icons/header_toggle_icon.svg"
+ height: parent.height * 0.5
+ width: height / sourceSize.height * sourceSize.width
+ anchors.horizontalCenter: parent.horizontalCenter
+ y: open ? parent.height - height/2 : parent.height
+ rotation: open ? 180 : 0
+
+ Behavior on rotation { NumberAnimation { duration: 100 } }
+ Behavior on y { NumberAnimation { duration: 100 } }
+
+ MouseArea {
+ anchors.fill: parent
+ anchors.margins: -parent.height * 0.5
+ drag.target: demoHeaderBar
+ drag.axis: Drag.YAxis
+ drag.minimumX: -demoHeaderBar.height
+ drag.maximumY: 0
+
+ onClicked: {
+ if (demoHeaderBar.y < -demoHeaderBar.height / 2)
+ demoHeaderBar.y = 0
+ else
+ demoHeaderBar.y = -demoHeaderBar.height
+ }
+ onReleased: demoHeaderBar.y = demoHeaderBar.y > -demoHeaderBar.height / 4 ? 0 : -demoHeaderBar.height
+ }
+ }
+}