ParameterEditor.qml 14.2 KB
Newer Older
Don Gagne's avatar
Don Gagne committed
1 2 3 4 5 6 7 8 9 10 11 12 13 14 15 16 17 18 19 20 21 22 23
/*=====================================================================

 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/>.

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

24 25 26
/// @file
///     @author Don Gagne <don@thegagnes.com>

Don Gagne's avatar
Don Gagne committed
27
import QtQuick 2.3
28
import QtQuick.Controls 1.3
Don Gagne's avatar
Don Gagne committed
29
import QtQuick.Controls.Styles 1.2
Don Gagne's avatar
Don Gagne committed
30
import QtQuick.Dialogs 1.2
Don Gagne's avatar
Don Gagne committed
31 32 33 34 35 36 37 38

import QGroundControl.Controls 1.0
import QGroundControl.Palette 1.0
import QGroundControl.ScreenTools 1.0
import QGroundControl.Controllers 1.0
import QGroundControl.FactSystem 1.0
import QGroundControl.FactControls 1.0

Don Gagne's avatar
Don Gagne committed
39
QGCView {
40
    viewPanel: panel
Don Gagne's avatar
Don Gagne committed
41

Don Gagne's avatar
Don Gagne committed
42 43
    QGCPalette { id: __qgcPal; colorGroupEnabled: true }
    property Fact __editorDialogFact: Fact { }
Don Gagne's avatar
Don Gagne committed
44

Don Gagne's avatar
Don Gagne committed
45 46 47
    readonly property real __leftMargin: 10
    readonly property real __rightMargin: 20
    readonly property int __maxParamChars: 16
Don Gagne's avatar
Don Gagne committed
48

Don Gagne's avatar
Don Gagne committed
49 50 51
    property bool _searchFilter: false  ///< true: showing results of search
    property var _searchResults         ///< List of parameter names from search results

52 53 54 55 56 57 58 59
    ParameterEditorController {
        id: controller;
        factPanel: panel

        onShowErrorMessage: {
            showMessage("Parameter Load Errors", errorMsg, StandardButton.Ok)
        }
    }
Don Gagne's avatar
Don Gagne committed
60

Don Gagne's avatar
Don Gagne committed
61 62
    Component {
        id: editorDialogComponent
Don Gagne's avatar
Don Gagne committed
63

Don Gagne's avatar
Don Gagne committed
64
        ParameterEditorDialog { fact: __editorDialogFact }
dogmaphobic's avatar
dogmaphobic committed
65
    }
Don Gagne's avatar
Don Gagne committed
66

Don Gagne's avatar
Don Gagne committed
67 68 69 70 71 72
    Component {
        id: searchDialogComponent

        QGCViewDialog {

            function accept() {
73
                _searchResults = controller.searchParametersForComponent(-1, searchFor.text, true /*searchInName.checked*/, true /*searchInDescriptions.checked*/)
Don Gagne's avatar
Don Gagne committed
74 75 76 77 78 79 80 81 82 83 84 85 86 87 88 89 90 91 92 93 94
                _searchFilter = true
                hideDialog()
            }

            function reject() {
                _searchFilter = false
                hideDialog()
            }

            QGCLabel {
                id:     searchForLabel
                text:   "Search for:"
            }

            QGCTextField {
                id:                 searchFor
                anchors.topMargin:  defaultTextHeight / 3
                anchors.top:        searchForLabel.bottom
                width:              defaultTextWidth * 20
            }

95 96
/*
            // Leaving in for possible future use. We'll see if needed from user comments.
Don Gagne's avatar
Don Gagne committed
97 98 99 100 101 102 103 104 105 106 107 108 109 110 111 112 113 114 115 116
            QGCLabel {
                id:                 searchInLabel
                anchors.topMargin:  defaultTextHeight
                anchors.top:        searchFor.bottom
                text:               "Search in:"
            }

            QGCCheckBox {
                id:                 searchInName
                anchors.topMargin:  defaultTextHeight / 3
                anchors.top:        searchInLabel.bottom
                text:               "Name"
            }

            QGCCheckBox {
                id:                 searchInDescriptions
                anchors.topMargin:  defaultTextHeight / 3
                anchors.top:        searchInName.bottom
                text:               "Descriptions"
            }
117
*/
Don Gagne's avatar
Don Gagne committed
118 119 120

            QGCLabel {
                anchors.topMargin:  defaultTextHeight
121
                anchors.top:        searchFor.bottom
Don Gagne's avatar
Don Gagne committed
122 123 124 125 126 127 128
                width:              parent.width
                wrapMode:           Text.WordWrap
                text:               "Hint: Leave 'Search For' blank and click Apply to list all parameters sorted by name."
            }
        }
    }

Don Gagne's avatar
Don Gagne committed
129 130
    Component {
        id: factRowsComponent
Don Gagne's avatar
Don Gagne committed
131

Don Gagne's avatar
Don Gagne committed
132 133 134
        Column {
            id:     factColumn
            x:      __leftMargin
Don Gagne's avatar
Don Gagne committed
135

Don Gagne's avatar
Don Gagne committed
136 137 138 139 140
            QGCLabel {
                text:               group
                verticalAlignment:	Text.AlignVCenter
                font.pixelSize:     ScreenTools.mediumFontPixelSize
            }
Don Gagne's avatar
Don Gagne committed
141

Don Gagne's avatar
Don Gagne committed
142 143 144 145 146
            Rectangle {
                width:  parent.width
                height: 1
                color:  __qgcPal.text
            }
Don Gagne's avatar
Don Gagne committed
147

Don Gagne's avatar
Don Gagne committed
148
            Repeater {
Don Gagne's avatar
Don Gagne committed
149
                model: parameterNames
Don Gagne's avatar
Don Gagne committed
150

Don Gagne's avatar
Don Gagne committed
151 152
                Column {
                    property Fact modelFact: controller.getParameterFact(componentId, modelData)
Don Gagne's avatar
Don Gagne committed
153

Don Gagne's avatar
Don Gagne committed
154 155 156 157
                    Item {
                        x:			__leftMargin
                        width:      parent.width
                        height:		ScreenTools.defaultFontPixelSize * 1.75
Don Gagne's avatar
Don Gagne committed
158

Don Gagne's avatar
Don Gagne committed
159 160 161 162 163 164 165
                        QGCLabel {
                            id:                 nameLabel
                            width:              defaultTextWidth * (__maxParamChars + 1)
                            height:             parent.height
                            verticalAlignment:	Text.AlignVCenter
                            text:               modelFact.name
                        }
Don Gagne's avatar
Don Gagne committed
166

Don Gagne's avatar
Don Gagne committed
167 168 169 170 171 172 173 174 175 176 177 178 179 180 181
                        QGCLabel {
                            id:                 valueLabel
                            width:              defaultTextWidth * 20
                            height:             parent.height
                            anchors.left:       nameLabel.right
                            verticalAlignment:	Text.AlignVCenter
                            color:              modelFact.valueEqualsDefault ? __qgcPal.text : "orange"
                            text:               modelFact.valueString + " " + modelFact.units
                        }

                        QGCLabel {
                            height:             parent.height
                            anchors.left:       valueLabel.right
                            verticalAlignment:	Text.AlignVCenter
                            text:               modelFact.shortDescription
182
                        }
Don Gagne's avatar
Don Gagne committed
183

Don Gagne's avatar
Don Gagne committed
184 185 186 187 188 189
                        MouseArea {
                            anchors.fill:       parent
                             acceptedButtons:   Qt.LeftButton

                            onClicked: {
                                __editorDialogFact = modelFact
Don Gagne's avatar
Don Gagne committed
190
                                showDialog(editorDialogComponent, "Parameter Editor", 50, StandardButton.Cancel | StandardButton.Save)
Don Gagne's avatar
Don Gagne committed
191
                            }
192
                        }
Don Gagne's avatar
Don Gagne committed
193 194 195 196 197 198 199 200 201 202 203 204 205
                    }

                    Rectangle {
                        x:      __leftMargin
                        width:  factColumn.width - __leftMargin - __rightMargin
                        height: 1
                        color:  __qgcPal.windowShade
                    }
                } // Column - Fact
            } // Repeater - Facts
        } // Column - Facts
    } // Component - factRowsComponent

Don Gagne's avatar
Don Gagne committed
206 207 208 209
    Component {
        id: groupedViewComponent

        Item {
dogmaphobic's avatar
dogmaphobic committed
210 211 212 213 214 215 216 217 218
            Flickable {
                id :                groupScroll
                width:              defaultTextWidth * 25
                height:             parent.height
                clip:               true
                contentHeight:      groupedViewComponentColumn.height
                contentWidth:       groupedViewComponentColumn.width
                boundsBehavior:     Flickable.StopAtBounds
                flickableDirection: Flickable.VerticalFlick
Don Gagne's avatar
Don Gagne committed
219
                Column {
dogmaphobic's avatar
dogmaphobic committed
220
                    id: groupedViewComponentColumn
Don Gagne's avatar
Don Gagne committed
221 222 223 224 225 226 227 228 229 230 231 232 233 234 235 236 237 238 239 240 241 242 243 244 245 246 247 248 249 250 251 252 253 254 255 256 257 258 259 260 261 262 263 264 265 266
                    Repeater {
                        model: controller.componentIds

                        Column {
                            id: componentColumn

                            readonly property int componentId: parseInt(modelData)

                            QGCLabel {
                                height:				contentHeight + (ScreenTools.defaultFontPixelHeight * 0.5)
                                text:               "Component #: " + componentId.toString()
                                verticalAlignment:	Text.AlignVCenter
                                font.pixelSize:     ScreenTools.mediumFontPixelSize
                            }

                            Repeater {
                                model: controller.getGroupsForComponent(componentColumn.componentId)

                                Column {
                                    QGCButton {
                                        x:		__leftMargin
                                        width: groupScroll.width - __leftMargin - __rightMargin
                                        text:	modelData

                                        onClicked: {
                                            factRowsLoader.sourceComponent = null
                                            factRowsLoader.componentId = componentId
                                            factRowsLoader.group = modelData
                                            factRowsLoader.sourceComponent = factRowsComponent
                                        }
                                    }

                                    Item {
                                        width:  1
                                        height: ScreenTools.defaultFontPixelSize * 0.25
                                    }
                                } // Column - Group
                            } // Repeater - Groups

                            Item {
                                height: 10
                                width:	10
                            }
                        } // Column - Component
                    } // Repeater - Components
                } // Column - Component
dogmaphobic's avatar
dogmaphobic committed
267
            } // Flickable - Groups
Don Gagne's avatar
Don Gagne committed
268

dogmaphobic's avatar
dogmaphobic committed
269
            Flickable {
Don Gagne's avatar
Don Gagne committed
270 271 272 273
                id:             factScrollView
                anchors.left:   groupScroll.right
                anchors.right:  parent.right
                height:         parent.height
dogmaphobic's avatar
dogmaphobic committed
274 275 276 277
                contentHeight:  factRowsLoader.height
                contentWidth:   panel.width * 2 //-- TODO: Find how to get actual resulting width. "factRowsLoader.sourceComponent.width" doesn't work.
                boundsBehavior: Flickable.StopAtBounds
                clip:           true
Don Gagne's avatar
Don Gagne committed
278 279 280 281 282 283 284 285 286

                Loader {
                    id:                 factRowsLoader
                    sourceComponent:    factRowsComponent

                    property int componentId:       controller.componentIds[0]
                    property string group:          controller.getGroupsForComponent(controller.componentIds[0])[0]
                    property var parameterNames:    controller.getParametersForGroup(componentId, group)
                }
dogmaphobic's avatar
dogmaphobic committed
287
            } // Flickable - Facts
Don Gagne's avatar
Don Gagne committed
288 289 290 291 292 293 294 295 296 297 298 299
        } // Item
    } // Component - groupedViewComponent

    Component {
        id: searchResultsViewComponent

        Item {
            ScrollView {
                id:             factScrollView
                anchors.left:   parent.left
                anchors.right:  parent.right
                height:         parent.height
dogmaphobic's avatar
dogmaphobic committed
300 301
                horizontalScrollBarPolicy:  Qt.ScrollBarAlwaysOff
                verticalScrollBarPolicy:    Qt.ScrollBarAlwaysOff
Don Gagne's avatar
Don Gagne committed
302 303 304 305 306 307 308 309 310 311 312 313 314 315

                Loader {
                    id:                 factRowsLoader
                    width:              factScrollView.width
                    sourceComponent:    factRowsComponent

                    property int componentId:       -1
                    property string group:          "Search results"
                    property var parameterNames:    _searchResults
                }
            } // ScrollView - Facts
        } // Item
    } // Component - sortedViewComponent

Don Gagne's avatar
Don Gagne committed
316 317 318 319
    QGCViewPanel {
        id:             panel
        anchors.fill:   parent

Don Gagne's avatar
Don Gagne committed
320

321 322
        Column {
            anchors.fill: parent
Don Gagne's avatar
Don Gagne committed
323

324 325
            Item {
                width:  parent.width
326
                height: toolsButton.height
Don Gagne's avatar
Don Gagne committed
327

328
                QGCLabel {
Don Gagne's avatar
Don Gagne committed
329
                    id:             titleText
Don Gagne's avatar
Don Gagne committed
330 331
                    font.pixelSize: ScreenTools.mediumFontPixelSize
                    text:           "PARAMETERS"
332
                }
Don Gagne's avatar
Don Gagne committed
333

334 335 336 337
                QGCButton {
                    id:             toolsButton
                    anchors.right:  parent.right
                    text:           "Tools"
338

339 340 341 342 343 344 345 346 347
                    menu: Menu {
                        MenuItem {
                            text:           "Refresh"
                            onTriggered:	controller.refresh()
                        }
                        MenuItem {
                            text:           "Reset all to defaults"
                            onTriggered:	controller.resetAllToDefaults()
                        }
Don Gagne's avatar
Don Gagne committed
348 349 350 351
                        MenuItem {
                            text:           "Search..."
                            onTriggered:    showDialog(searchDialogComponent, "Parameter Search", 50, StandardButton.Reset | StandardButton.Apply)
                        }
352 353
                        MenuSeparator { }
                        MenuItem {
Don Gagne's avatar
Don Gagne committed
354
                            text:           "Load from file..."
355 356 357
                            onTriggered:	controller.loadFromFile()
                        }
                        MenuItem {
Don Gagne's avatar
Don Gagne committed
358
                            text:           "Save to file..."
359 360 361 362 363 364 365
                            onTriggered:	controller.saveToFile()
                        }
                        MenuSeparator { }
                        MenuItem {
                            text:           "Clear RC to Param"
                            onTriggered:	controller.clearRCToParam()
                        }
366
                    }
Don Gagne's avatar
Don Gagne committed
367
                }
368
            }
369

370 371 372 373 374
            Item {
                id:		lastSpacer
                height: 10
                width:	5
            }
375

Don Gagne's avatar
Don Gagne committed
376 377 378 379 380
            Loader {
                width:              parent.width
                height:             parent.height - (lastSpacer.y + lastSpacer.height)
                sourceComponent:    _searchFilter ? searchResultsViewComponent: groupedViewComponent
            }
381
        } // Column - Outer
Don Gagne's avatar
Don Gagne committed
382
    } // QGCViewPanel
383
} // QGCView