ToolStrip.qml 3.77 KB
Newer Older
1 2 3 4 5 6 7 8 9
/****************************************************************************
 *
 *   (c) 2009-2016 QGROUNDCONTROL PROJECT <http://www.qgroundcontrol.org>
 *
 * QGroundControl is licensed according to the terms in the file
 * COPYING.md in the root of the source code directory.
 *
 ****************************************************************************/

Don Gagne's avatar
Don Gagne committed
10
import QtQuick          2.11
11
import QtQuick.Controls 2.2
12

Gus Grubba's avatar
Gus Grubba committed
13
import QGroundControl               1.0
14 15
import QGroundControl.ScreenTools   1.0
import QGroundControl.Palette       1.0
16
import QGroundControl.Controls      1.0
17 18 19

Rectangle {
    id:         _root
Gus Grubba's avatar
Gus Grubba committed
20
    color:      qgcPal.globalTheme === QGCPalette.Light ? QGroundControl.corePlugin.options.toolbarBackgroundLight : QGroundControl.corePlugin.options.toolbarBackgroundDark
21
    width:      _idealWidth < repeater.contentWidth ? repeater.contentWidth : _idealWidth
Don Gagne's avatar
Don Gagne committed
22
    height:     toolStripColumn.height + (toolStripColumn.anchors.margins * 2)
23
    radius:     ScreenTools.defaultFontPixelWidth / 2
24 25

    property alias  model:              repeater.model
26
    property real   maxHeight           ///< Maximum height for control, determines whether text is hidden to make control shorter
27

28
    property AbstractButton lastClickedButton: null
29

30
    // Ensure we don't get narrower than content
31
    property real _idealWidth: (ScreenTools.isMobile ? ScreenTools.minTouchPixels : ScreenTools.defaultFontPixelWidth * 8) + toolStripColumn.anchors.margins * 2
32

33
    signal clicked(int index, bool checked)
34

Gus Grubba's avatar
Gus Grubba committed
35 36 37 38 39 40 41 42
    function setChecked(idx, check) {
        repeater.itemAt(idx).checked = check
    }

    function getChecked(idx) {
        return repeater.itemAt(idx).checked
    }

43
    ButtonGroup {
Gus Grubba's avatar
Gus Grubba committed
44 45
        id:         buttonGroup
        buttons:    toolStripColumn.children
46 47
    }

48
    Column {
Don Gagne's avatar
Don Gagne committed
49
        id:                 toolStripColumn
50
        anchors.margins:    ScreenTools.defaultFontPixelWidth * 0.4
51 52 53
        anchors.top:        parent.top
        anchors.left:       parent.left
        anchors.right:      parent.right
Gus Grubba's avatar
Gus Grubba committed
54
        spacing:            ScreenTools.defaultFontPixelWidth * 0.25
55

56 57
        Repeater {
            id: repeater
58

59
            QGCHoverButton {
Gus Grubba's avatar
Gus Grubba committed
60
                id:             buttonTemplate
61

62 63 64 65
                anchors.left:   toolStripColumn.left
                anchors.right:  toolStripColumn.right
                height:         width
                radius:         ScreenTools.defaultFontPixelWidth / 2
66
                fontPointSize:  ScreenTools.smallFontPointSize
Gus Grubba's avatar
Gus Grubba committed
67
                autoExclusive:  true
68

Gus Grubba's avatar
Gus Grubba committed
69 70 71
                enabled:        modelData.buttonEnabled
                visible:        modelData.buttonVisible
                imageSource:    modelData.showAlternateIcon ? modelData.alternateIconSource : modelData.iconSource
72
                text:           modelData.name
Gus Grubba's avatar
Gus Grubba committed
73
                checked:        modelData.checked !== undefined ? modelData.checked : checked
74

75 76 77 78 79 80 81 82 83 84 85 86
                ButtonGroup.group: buttonGroup
                // Only drop pannel and toggleable are checkable
                checkable: modelData.dropPanelComponent !== undefined || (modelData.toggle !== undefined && modelData.toggle)

                onClicked: {
                    dropPanel.hide()    // DropPanel will call hide on "lastClickedButton"
                    if (modelData.dropPanelComponent === undefined) {
                        _root.clicked(index, checked)
                    } else if (checked) {
                        var panelEdgeTopPoint = mapToItem(_root, width, 0)
                        dropPanel.show(panelEdgeTopPoint, height, modelData.dropPanelComponent)
                    }
Gus Grubba's avatar
Gus Grubba committed
87 88
                    if(_root && buttonTemplate)
                        _root.lastClickedButton = buttonTemplate
89
                }
90 91 92 93 94 95 96 97 98
            }
        }
    }

    DropPanel {
        id:         dropPanel
        toolStrip:  _root
    }
}