PreFlightCheckList.qml 3.56 KB
Newer Older
1 2 3 4 5 6 7 8 9 10 11 12 13 14 15 16 17 18
/****************************************************************************
 *
 *   (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.
 *
 ****************************************************************************/

import QtQuick          2.3
import QtQuick.Controls 1.2
import QtQml.Models     2.1

import QGroundControl               1.0
import QGroundControl.ScreenTools   1.0
import QGroundControl.Controls      1.0

Rectangle {
19 20 21 22
    width:      mainColumn.width  + ScreenTools.defaultFontPixelWidth * 3
    height:     mainColumn.height + ScreenTools.defaultFontPixelHeight
    color:      qgcPal.windowShade
    radius:     3
23 24 25

    property alias model: checkListRepeater.model

Don Gagne's avatar
Don Gagne committed
26
    property bool _passed:  false
27

Don Gagne's avatar
Don Gagne committed
28 29 30
    function _handleGroupPassedChanged(index, passed) {
        if (passed) {
            // Collapse current group
31 32
            var group = checkListRepeater.itemAt(index)
            group._checked = false
Don Gagne's avatar
Don Gagne committed
33
            // Expand next group
34
            if (index + 1 < checkListRepeater.count) {
35
                group = checkListRepeater.itemAt(index + 1)
36 37 38 39
                group.enabled = true
                group._checked = true
            }
        }
Don Gagne's avatar
Don Gagne committed
40 41 42 43 44 45 46 47 48 49 50
        _passed = passed
    }

    // We delay the updates when a group passes so the user can see all items green for a moment prior to hiding
    Timer {
        id:         delayedGroupPassed
        interval:   750

        property int index

        onTriggered: _handleGroupPassedChanged(index, true /* passed */)
51 52 53 54
    }

    Column {
        id:                     mainColumn
55 56
        width:                  40  * ScreenTools.defaultFontPixelWidth
        spacing:                0.8 * ScreenTools.defaultFontPixelWidth
57 58
        anchors.left:           parent.left
        anchors.top:            parent.top
59 60
        anchors.topMargin:      0.6 * ScreenTools.defaultFontPixelWidth
        anchors.leftMargin:     1.5 * ScreenTools.defaultFontPixelWidth
61

Don Gagne's avatar
Don Gagne committed
62 63 64 65 66 67 68
        function groupPassedChanged(index, passed) {
            if (passed) {
                delayedGroupPassed.index = index
                delayedGroupPassed.restart()
            } else {
                _handleGroupPassedChanged(index, passed)
            }
69
        }
70 71 72

        // Header/title of checklist
        Item {
73 74
            width:      parent.width
            height:     1.75 * ScreenTools.defaultFontPixelHeight
75 76 77 78 79 80 81 82

            QGCLabel {
                text:                   qsTr("Pre-Flight Checklist %1").arg(_passed ? qsTr("(passed)") : "")
                anchors.left:           parent.left
                anchors.verticalCenter: parent.verticalCenter
                font.pointSize:         ScreenTools.mediumFontPointSize
            }
            QGCButton {
83 84
                width:                  1.2 * ScreenTools.defaultFontPixelHeight
                height:                 1.2 * ScreenTools.defaultFontPixelHeight
85 86 87 88
                anchors.right:          parent.right
                anchors.verticalCenter: parent.verticalCenter
                tooltip:                qsTr("Reset the checklist (e.g. after a vehicle reboot)")

89
                onClicked:              model.reset()
90

91 92 93 94 95
                QGCColoredImage {
                    source:         "/qmlimages/MapSyncBlack.svg"
                    color:          qgcPal.buttonText
                    anchors.fill:   parent
                }
96 97 98 99 100 101 102
            }
        }

        // All check list items
        Repeater {
            id: checkListRepeater
        }
103 104
    }
}