summaryrefslogtreecommitdiffstats
path: root/qt-mobile/qml/mobilecomponents/SplitDrawer.qml
diff options
context:
space:
mode:
Diffstat (limited to 'qt-mobile/qml/mobilecomponents/SplitDrawer.qml')
-rw-r--r--qt-mobile/qml/mobilecomponents/SplitDrawer.qml234
1 files changed, 0 insertions, 234 deletions
diff --git a/qt-mobile/qml/mobilecomponents/SplitDrawer.qml b/qt-mobile/qml/mobilecomponents/SplitDrawer.qml
deleted file mode 100644
index 813eae10c..000000000
--- a/qt-mobile/qml/mobilecomponents/SplitDrawer.qml
+++ /dev/null
@@ -1,234 +0,0 @@
-/*
- * Copyright 2012 Marco Martin <mart@kde.org>
- *
- * This program is free software; you can redistribute it and/or modify
- * it under the terms of the GNU Library General Public License as
- * published by the Free Software Foundation; either version 2, 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 Library General Public License for more details
- *
- * You should have received a copy of the GNU Library 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.1
-import QtGraphicalEffects 1.0
-import org.kde.plasma.mobilecomponents 0.2
-import "private"
-
-/**Documented API
-Inherits:
- Item
-
-Imports:
- QtQuick 2.1
-
-Description:
- Split Drawers are used to expose additional UI elements which are optional and can be used in conjunction with the main UI elements. For example the Resource Browser uses a Split Drawer to select different kinds of filters for the main view.
-
-Properties:
- bool open:
- If true the drawer is open showing the contents of the "drawer" component.
-
- Item page:
- It's the default property. it's the main content of the drawer page, the part that is always shown
-
- Item drawer:
- It's the part that can be pulled in and out, will act as a sidebar.
-
- int visibleDrawerWidth: the width of the visible portion of the drawer: it updates while dragging or animating
-**/
-AbstractDrawer {
- id: root
- anchors {
- fill: parent
- }
- visible: true
-
- default property alias page: mainPage.data
- property Item contentItem
- property alias opened: sidebar.open
- property int visibleDrawerWidth: browserFrame.x
-
- Component.onCompleted: {
- mainPage.width = browserFrame.width
- }
-
- onContentItemChanged: contentItem.parent = drawerPage
- MouseArea {
- id: mouseEventListener
- z: 200
- drag.filterChildren: true
- //drag.target: browserFrame
- property int startMouseX
- property int oldMouseX
- property int startBrowserFrameX
- property bool toggle: false
- property string startState
-
- anchors.fill: parent
-
- onPressed: {
- if (drawerPage.children.length == 0 || (browserFrame.state == "Closed" && mouse.x > Units.gridUnit) ||
- mouse.x < browserFrame.x) {
- mouse.accepted = false;
- return;
- }
-
- toggle = true;
- startBrowserFrameX = browserFrame.x;
- oldMouseX = startMouseX = mouse.x;
- startState = browserFrame.state;
- browserFrame.state = "Dragging";
- browserFrame.x = startBrowserFrameX;
- }
-
- onPositionChanged: {
- browserFrame.x = Math.max(0, browserFrame.x + mouse.x - oldMouseX);
- oldMouseX = mouse.x;
- if (Math.abs(mouse.x - startMouseX) > Units.gridUnit * 2) {
- toggle = false;
- }
- }
-
- onReleased: {
- if (toggle) {
- browserFrame.state = startState == "Open" ? "Closed" : "Open"
- } else if (browserFrame.x < sidebar.width / 2) {
- browserFrame.state = "Closed";
- } else {
- browserFrame.state = "Open";
- }
- }
- onClicked: root.clicked()
- }
-
- Rectangle {
- id: browserFrame
- z: 100
- color: Theme.backgroundColor
- state: "Closed"
- onStateChanged: sidebar.open = (state != "Closed")
-
- anchors {
- top: parent.top
- bottom: parent.bottom
- }
- width: root.width;
-
- Item {
- id: mainPage
- onChildrenChanged: mainPage.children[0].anchors.fill = mainPage
-
- anchors.fill: parent
- }
-
- Rectangle {
- anchors.fill: parent
- color: "black"
- opacity: Math.min(0.4, 0.4 * (browserFrame.x / sidebar.width))
- }
- LinearGradient {
- width: Units.gridUnit/2
- anchors {
- right: parent.left
- top: parent.top
- bottom: parent.bottom
- rightMargin: -1
- }
- start: Qt.point(0, 0)
- end: Qt.point(Units.gridUnit/2, 0)
- gradient: Gradient {
- GradientStop {
- position: 0.0
- color: "transparent"
- }
- GradientStop {
- position: 0.7
- color: Qt.rgba(0, 0, 0, 0.15)
- }
- GradientStop {
- position: 1.0
- color: Qt.rgba(0, 0, 0, 0.3)
- }
- }
- }
-
- states: [
- State {
- name: "Open"
- PropertyChanges {
- target: browserFrame
- x: sidebar.width
- }
-
- },
- State {
- name: "Dragging"
- PropertyChanges {
- target: browserFrame
- x: mouseEventListener.startBrowserFrameX
- }
- },
- State {
- name: "Closed"
- PropertyChanges {
- target: browserFrame
- x: 0
- }
- }
- ]
-
- transitions: [
- Transition {
- //Exclude Dragging
- to: "Open,Closed,Hidden"
- NumberAnimation {
- properties: "x"
- duration: Units.longDuration
- easing.type: Easing.InOutQuad
- }
- }
- ]
- }
-
-
- Item {
- id: sidebar
-
- property bool open: false
- onOpenChanged: {
- if (drawerPage.children.length == 0) {
- return;
- }
-
- if (open) {
- browserFrame.state = "Open";
- } else {
- browserFrame.state = "Closed";
- }
- }
-
- width: Math.min(parent.width/4*3, Math.max(root.contentItem ? root.contentItem.implicitWidth : 0, parent.width/4))
-
- anchors {
- left: parent.left
- top: parent.top
- bottom: parent.bottom
- }
-
- Item {
- id: drawerPage
- anchors.fill: parent
- clip: false
- onChildrenChanged: drawerPage.children[0].anchors.fill = drawerPage
- }
- }
-}
-