MainWindowLeftPanel.qml 11.7 KB
Newer Older
dogmaphobic's avatar
dogmaphobic committed
1 2 3 4 5 6 7 8 9 10 11 12 13 14 15 16 17 18 19 20 21 22 23 24 25 26 27 28 29 30 31 32 33 34 35 36
/*=====================================================================

QGroundControl Open Source Ground Control Station

(c) 2009, 2015 QGROUNDCONTROL PROJECT <http://www.qgroundcontrol.org>

This file is part of the QGROUNDCONTROL project

QGROUNDCONTROL is free software: you can redistribute it and/or modify
it under the terms of the GNU General Public License as published by
the Free Software Foundation, either version 3 of the License, or
(at your option) any later version.

QGROUNDCONTROL 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 General Public License for more details.

You should have received a copy of the GNU General Public License
along with QGROUNDCONTROL. If not, see <http://www.gnu.org/licenses/>.

======================================================================*/

import QtQuick          2.5
import QtQuick.Controls 1.2
import QtPositioning    5.2

import QGroundControl               1.0
import QGroundControl.Palette       1.0
import QGroundControl.Controls      1.0
import QGroundControl.FlightDisplay 1.0
import QGroundControl.ScreenTools   1.0


//-- Left Menu
Item {
37
    id:             settingsMenu
dogmaphobic's avatar
dogmaphobic committed
38 39 40 41 42 43
    anchors.fill:   parent

    property alias animateShowDialog: __animateShowDialog
    property alias animateHideDialog: __animateHideDialog

    readonly property int  __animationDuration: 100
dogmaphobic's avatar
dogmaphobic committed
44 45 46
    readonly property real __closeButtonSize:   ScreenTools.defaultFontPixelHeight * 1.5
    readonly property real _margins:            ScreenTools.defaultFontPixelHeight * 0.5
    readonly property real _buttonHeight:       ScreenTools.isTinyScreen ? ScreenTools.defaultFontPixelHeight * 3 : ScreenTools.defaultFontPixelHeight * 2
dogmaphobic's avatar
dogmaphobic committed
47

48 49
    QGCPalette { id: qgcPal }

dogmaphobic's avatar
dogmaphobic committed
50 51 52 53 54 55 56 57 58
    onVisibleChanged: {
        //-- Unselect any selected button
        panelActionGroup.current = null
        //-- Destroy panel contents if not visible
        if(!visible) {
            __rightPanel.source = ""
        }
    }

59 60 61 62 63
    function closeSettings() {
        __rightPanel.source = ""
        mainWindow.hideLeftMenu()
    }

dogmaphobic's avatar
dogmaphobic committed
64 65 66 67 68 69 70
    ParallelAnimation {
        id: __animateShowDialog
        NumberAnimation {
            target:     __transparentSection
            properties: "opacity"
            from:       0.0
            to:         0.8
71
            duration:   settingsMenu.__animationDuration
dogmaphobic's avatar
dogmaphobic committed
72 73 74 75 76 77
        }
        NumberAnimation {
            target:     __transparentSection
            properties: "width"
            from:       1
            to:         mainWindow.width
78
            duration:   settingsMenu.__animationDuration
dogmaphobic's avatar
dogmaphobic committed
79 80 81 82 83 84 85 86 87 88
        }
    }

    ParallelAnimation {
        id: __animateHideDialog
        NumberAnimation {
            target:     __transparentSection
            properties: "opacity"
            from:       0.8
            to:         0.0
89
            duration:   settingsMenu.__animationDuration
dogmaphobic's avatar
dogmaphobic committed
90 91 92 93 94 95
        }
        NumberAnimation {
            target:     __transparentSection
            properties: "width"
            from:       mainWindow.width
            to:         1
96
            duration:   settingsMenu.__animationDuration
dogmaphobic's avatar
dogmaphobic committed
97 98 99 100 101 102 103 104 105 106 107 108 109 110 111
        }
        onRunningChanged: {
            if (!running) {
                parent.visible = false
            }
        }
    }

    // This covers the screen with a transparent section
    Rectangle {
        id:             __transparentSection
        height:         parent.height - toolBar.height
        anchors.bottom: parent.bottom
        anchors.left:   parent.left
        opacity:        0.0
112
        color:          qgcPal.window
dogmaphobic's avatar
dogmaphobic committed
113 114 115 116 117
        visible:        __rightPanel.source == ""
        // Dismiss if clicked outside menu area
        MouseArea {
            anchors.fill: parent
            onClicked: {
118 119
                if (!__animateShowDialog.running)
                    mainWindow.hideLeftMenu()
dogmaphobic's avatar
dogmaphobic committed
120 121 122 123 124 125 126 127 128 129 130 131 132 133 134 135 136
            }
        }
    }

    //-- Top Separator
    Rectangle {
        id:             __topSeparator
        width:          parent.width
        height:         1
        y:              toolBar.height
        anchors.left:   parent.left
        color:          QGroundControl.isDarkStyle ? "#909090" : "#7f7f7f"
    }

    // This is the menu dialog panel which is anchored to the left edge
    Rectangle {
        id:             __leftMenu
137
        width:          ScreenTools.defaultFontPixelWidth * 16
dogmaphobic's avatar
dogmaphobic committed
138 139 140
        anchors.left:   parent.left
        anchors.top:    __topSeparator.bottom
        anchors.bottom: parent.bottom
141
        color:          qgcPal.windowShadeDark
dogmaphobic's avatar
dogmaphobic committed
142

Don Gagne's avatar
Don Gagne committed
143 144 145 146 147 148 149 150 151 152 153 154 155 156 157 158
        QGCFlickable {
            anchors.fill:       parent
            contentHeight:      buttonColumn.height + _margins
            flickableDirection: Flickable.VerticalFlick
            clip:               true

            ExclusiveGroup { id: panelActionGroup }

            Column {
                id:                     buttonColumn
                anchors.leftMargin:     _margins
                anchors.rightMargin:    _margins
                anchors.left:           parent.left
                anchors.right:          parent.right
                anchors.topMargin:      _margins
                anchors.top:            parent.top
159
                spacing:                ScreenTools.defaultFontPixelHeight * 0.5
Don Gagne's avatar
Don Gagne committed
160 161

                QGCLabel {
Tomaz Canabrava's avatar
Tomaz Canabrava committed
162
                    text:           qsTr("Preferences")
Don Gagne's avatar
Don Gagne committed
163 164
                    anchors.horizontalCenter: parent.horizontalCenter
                }
dogmaphobic's avatar
dogmaphobic committed
165

Don Gagne's avatar
Don Gagne committed
166
                QGCButton {
dogmaphobic's avatar
dogmaphobic committed
167
                    height:         _buttonHeight
Don Gagne's avatar
Don Gagne committed
168 169
                    anchors.left:   parent.left
                    anchors.right:  parent.right
Tomaz Canabrava's avatar
Tomaz Canabrava committed
170
                    text:           qsTr("General")
Don Gagne's avatar
Don Gagne committed
171 172 173 174 175 176
                    exclusiveGroup: panelActionGroup
                    onClicked: {
                        if(__rightPanel.source != "GeneralSettings.qml") {
                            __rightPanel.source = "GeneralSettings.qml"
                        }
                        checked = true
dogmaphobic's avatar
dogmaphobic committed
177 178
                    }
                }
Don Gagne's avatar
Don Gagne committed
179 180

                QGCButton {
dogmaphobic's avatar
dogmaphobic committed
181
                    height:         _buttonHeight
Don Gagne's avatar
Don Gagne committed
182 183
                    anchors.left:   parent.left
                    anchors.right:  parent.right
Tomaz Canabrava's avatar
Tomaz Canabrava committed
184
                    text:           qsTr("Comm Links")
Don Gagne's avatar
Don Gagne committed
185 186 187 188 189 190
                    exclusiveGroup: panelActionGroup
                    onClicked: {
                        if(__rightPanel.source != "LinkSettings.qml") {
                            __rightPanel.source = "LinkSettings.qml"
                        }
                        checked = true
191 192
                    }
                }
Don Gagne's avatar
Don Gagne committed
193 194

                QGCButton {
dogmaphobic's avatar
dogmaphobic committed
195
                    height:         _buttonHeight
Don Gagne's avatar
Don Gagne committed
196 197
                    anchors.left:   parent.left
                    anchors.right:  parent.right
Tomaz Canabrava's avatar
Tomaz Canabrava committed
198
                    text:           qsTr("Offline Maps")
Don Gagne's avatar
Don Gagne committed
199 200 201 202 203 204
                    exclusiveGroup: panelActionGroup
                    onClicked: {
                        if(__rightPanel.source != "OfflineMap.qml") {
                            __rightPanel.source = "OfflineMap.qml"
                        }
                        checked = true
dogmaphobic's avatar
dogmaphobic committed
205 206
                    }
                }
Don Gagne's avatar
Don Gagne committed
207 208

                QGCButton {
dogmaphobic's avatar
dogmaphobic committed
209
                    height:         _buttonHeight
Don Gagne's avatar
Don Gagne committed
210 211
                    anchors.left:   parent.left
                    anchors.right:  parent.right
Tomaz Canabrava's avatar
Tomaz Canabrava committed
212
                    text:           qsTr("MavLink")
Don Gagne's avatar
Don Gagne committed
213 214 215 216 217 218
                    exclusiveGroup: panelActionGroup
                    onClicked: {
                        if(__rightPanel.source != "MavlinkSettings.qml") {
                            __rightPanel.source = "MavlinkSettings.qml"
                        }
                        checked = true
dogmaphobic's avatar
dogmaphobic committed
219 220
                    }
                }
Don Gagne's avatar
Don Gagne committed
221

222
                QGCButton {
dogmaphobic's avatar
dogmaphobic committed
223
                    height:         _buttonHeight
224 225
                    anchors.left:   parent.left
                    anchors.right:  parent.right
226
                    text:           qsTr("Console")
227 228 229 230 231 232 233 234 235
                    exclusiveGroup: panelActionGroup
                    onClicked: {
                        if(__rightPanel.source != "QGroundControl/Controls/AppMessages.qml") {
                            __rightPanel.source = "QGroundControl/Controls/AppMessages.qml"
                        }
                        checked = true
                    }
                }

Don Gagne's avatar
Don Gagne committed
236
                QGCButton {
dogmaphobic's avatar
dogmaphobic committed
237
                    height:         _buttonHeight
Don Gagne's avatar
Don Gagne committed
238 239
                    anchors.left:   parent.left
                    anchors.right:  parent.right
Tomaz Canabrava's avatar
Tomaz Canabrava committed
240
                    text:           qsTr("Mock Link")
Don Gagne's avatar
Don Gagne committed
241 242 243 244 245 246 247
                    visible:        ScreenTools.isDebug
                    exclusiveGroup: panelActionGroup
                    onClicked: {
                        if(__rightPanel.source != "MockLink.qml") {
                            __rightPanel.source = "MockLink.qml"
                        }
                        checked = true
248 249
                    }
                }
Don Gagne's avatar
Don Gagne committed
250 251

                QGCButton {
dogmaphobic's avatar
dogmaphobic committed
252
                    height:         _buttonHeight
Don Gagne's avatar
Don Gagne committed
253 254
                    anchors.left:   parent.left
                    anchors.right:  parent.right
Tomaz Canabrava's avatar
Tomaz Canabrava committed
255
                    text:           qsTr("Debug")
Don Gagne's avatar
Don Gagne committed
256 257 258 259 260 261 262
                    visible:        ScreenTools.isDebug
                    exclusiveGroup: panelActionGroup
                    onClicked: {
                        if(__rightPanel.source != "DebugWindow.qml") {
                            __rightPanel.source = "DebugWindow.qml"
                        }
                        checked = true
dogmaphobic's avatar
dogmaphobic committed
263 264 265 266 267 268 269 270 271 272 273 274 275
                    }
                }
            }
        }
    }

    //-- Clicking in tool bar area dismiss it all
    MouseArea {
        anchors.top:    parent.top
        anchors.left:   parent.left
        anchors.right:  parent.right
        height:         toolBar.height
        onClicked: {
276 277
            if (!__animateShowDialog.running)
                mainWindow.hideLeftMenu()
dogmaphobic's avatar
dogmaphobic committed
278 279 280 281 282 283 284 285 286 287 288 289 290 291 292
        }
    }

    //-- Vertical Separator
    Rectangle {
        id:             __verticalSeparator
        width:          1
        height:         parent.height - toolBar.height
        anchors.left:   __leftMenu.right
        anchors.bottom: parent.bottom
        color:          QGroundControl.isDarkStyle ? "#909090" : "#7f7f7f"
    }

    //-- Main Setting Display Area
    Rectangle {
293
        id:             settingDisplayArea
dogmaphobic's avatar
dogmaphobic committed
294 295 296 297 298
        anchors.left:   __verticalSeparator.right
        width:          mainWindow.width - __leftMenu.width - __verticalSeparator.width
        height:         parent.height - toolBar.height - __topSeparator.height
        anchors.bottom: parent.bottom
        visible:        __rightPanel.source != ""
299
        color:          qgcPal.window
dogmaphobic's avatar
dogmaphobic committed
300 301 302 303 304 305 306 307 308 309 310 311
        //-- Panel Contents
        Loader {
            id:             __rightPanel
            anchors.fill:   parent
        }
        //-- Dismiss it all
        Item {
            id:              closeButton
            width:           __closeButtonSize
            height:          __closeButtonSize
            anchors.right:   parent.right
            anchors.top:     parent.top
312
            anchors.margins: ScreenTools.defaultFontPixelHeight * 0.5
dogmaphobic's avatar
dogmaphobic committed
313 314 315 316
            QGCColoredImage {
                source:       "/res/XDelete.svg"
                mipmap:       true
                fillMode:     Image.PreserveAspectFit
317
                color:        qgcPal.text
dogmaphobic's avatar
dogmaphobic committed
318 319
                width:        parent.width  * 0.75
                height:       parent.height * 0.75
dogmaphobic's avatar
dogmaphobic committed
320
                sourceSize.height: height
dogmaphobic's avatar
dogmaphobic committed
321 322 323 324 325
                anchors.centerIn: parent
            }
            MouseArea {
                anchors.fill: parent
                onClicked: {
326 327 328 329
                    if (!__animateShowDialog.running) {
                        __rightPanel.source = ""
                        mainWindow.hideLeftMenu()
                    }
dogmaphobic's avatar
dogmaphobic committed
330 331 332 333 334 335
                }
            }

        }
    }
}