/**************************************************************************** * * (c) 2009-2020 QGROUNDCONTROL PROJECT * * 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 QtQuick.Controls.Styles 1.4 import QGroundControl 1.0 import QGroundControl.FactSystem 1.0 import QGroundControl.Controls 1.0 import QGroundControl.ScreenTools 1.0 import QGroundControl.MultiVehicleManager 1.0 import QGroundControl.Palette 1.0 Rectangle { id: _summaryRoot anchors.fill: parent anchors.rightMargin: ScreenTools.defaultFontPixelWidth anchors.leftMargin: ScreenTools.defaultFontPixelWidth color: qgcPal.window property real _minSummaryW: ScreenTools.isTinyScreen ? ScreenTools.defaultFontPixelWidth * 28 : ScreenTools.defaultFontPixelWidth * 36 property real _summaryBoxWidth: _minSummaryW property real _summaryBoxSpace: ScreenTools.defaultFontPixelWidth * 2 function computeSummaryBoxSize() { var sw = 0 var rw = 0 var idx = Math.floor(_summaryRoot.width / (_minSummaryW + ScreenTools.defaultFontPixelWidth)) if(idx < 1) { _summaryBoxWidth = _summaryRoot.width _summaryBoxSpace = 0 } else { _summaryBoxSpace = 0 if(idx > 1) { _summaryBoxSpace = ScreenTools.defaultFontPixelWidth * 2 sw = _summaryBoxSpace * (idx - 1) } rw = _summaryRoot.width - sw _summaryBoxWidth = rw / idx } } function capitalizeWords(sentence) { return sentence.replace(/(?:^|\s)\S/g, function(a) { return a.toUpperCase(); }); } QGCPalette { id: qgcPal colorGroupEnabled: enabled } Component.onCompleted: { computeSummaryBoxSize() } onWidthChanged: { computeSummaryBoxSize() } QGCFlickable { clip: true anchors.fill: parent contentHeight: summaryColumn.height contentWidth: _summaryRoot.width flickableDirection: Flickable.VerticalFlick Column { id: summaryColumn width: _summaryRoot.width spacing: ScreenTools.defaultFontPixelHeight QGCLabel { width: parent.width wrapMode: Text.WordWrap color: setupComplete ? qgcPal.text : qgcPal.warningText font.family: ScreenTools.demiboldFontFamily horizontalAlignment: Text.AlignHCenter text: setupComplete ? qsTr("Below you will find a summary of the settings for your vehicle. To the left are the setup menus for each component.") : qsTr("WARNING: Your vehicle requires setup prior to flight. Please resolve the items marked in red using the menu on the left.") property bool setupComplete: QGroundControl.multiVehicleManager.activeVehicle ? QGroundControl.multiVehicleManager.activeVehicle.autopilot.setupComplete : false } Flow { id: _flowCtl width: _summaryRoot.width spacing: _summaryBoxSpace Repeater { model: QGroundControl.multiVehicleManager.activeVehicle ? QGroundControl.multiVehicleManager.activeVehicle.autopilot.vehicleComponents : undefined // Outer summary item rectangle Rectangle { width: _summaryBoxWidth height: ScreenTools.defaultFontPixelHeight * 13 color: qgcPal.windowShade visible: modelData.summaryQmlSource.toString() !== "" border.width: 1 border.color: qgcPal.text Component.onCompleted: { border.color = Qt.rgba(border.color.r, border.color.g, border.color.b, 0.1) } readonly property real titleHeight: ScreenTools.defaultFontPixelHeight * 2 // Title bar QGCButton { id: titleBar width: parent.width height: titleHeight text: capitalizeWords(modelData.name) // Setup indicator Rectangle { anchors.rightMargin: ScreenTools.defaultFontPixelWidth anchors.right: parent.right anchors.verticalCenter: parent.verticalCenter width: ScreenTools.defaultFontPixelWidth * 1.75 height: width radius: width / 2 color: modelData.setupComplete ? "#00d932" : "red" visible: modelData.requiresSetup && modelData.setupSource !== "" } onClicked : { //console.log(modelData.setupSource) if (modelData.setupSource !== "") { setupView.showVehicleComponentPanel(modelData) } } } // Summary Qml Rectangle { anchors.top: titleBar.bottom width: parent.width Loader { anchors.fill: parent anchors.margins: ScreenTools.defaultFontPixelWidth source: modelData.summaryQmlSource } } } } } } } }