MissionItemEditor.qml 10.5 KB
Newer Older
1 2 3 4 5
import QtQuick                      2.11
import QtQuick.Controls             2.4
import QtQuick.Controls.Styles      1.4
import QtQuick.Dialogs              1.2
import QtQml                        2.2
6
import QtQuick.Layouts              1.11
Don Gagne's avatar
Don Gagne committed
7

8
import QGroundControl               1.0
Don Gagne's avatar
Don Gagne committed
9 10
import QGroundControl.ScreenTools   1.0
import QGroundControl.Vehicle       1.0
Don Gagne's avatar
Don Gagne committed
11 12
import QGroundControl.Controls      1.0
import QGroundControl.FactControls  1.0
Don Gagne's avatar
Don Gagne committed
13 14
import QGroundControl.Palette       1.0

Don Gagne's avatar
Don Gagne committed
15 16 17

/// Mission item edit control
Rectangle {
18 19 20 21 22 23 24
    id:             _root
    height:         editorLoader.visible ? (editorLoader.y + editorLoader.height + (_margin * 2)) : (commandPicker.y + commandPicker.height + _margin / 2)
    color:          _currentItem ? qgcPal.missionItemEditor : qgcPal.windowShade
    radius:         _radius
    opacity:        _currentItem ? 1.0 : 0.7
    border.width:   _readyForSave ? 0 : 1
    border.color:   qgcPal.warningText
25

26
    property var    map                 ///< Map control
27
    property var    masterController
28 29
    property var    missionItem         ///< MissionItem associated with this editor
    property bool   readOnly            ///< true: read only view, false: full editing view
Don Gagne's avatar
Don Gagne committed
30

31 32
    signal clicked
    signal remove
33 34
    signal insertWaypoint
    signal insertComplexItem(string complexItemName)
35
    signal selectNextNotReadyItem
Don Gagne's avatar
Don Gagne committed
36

37 38
    property var    _masterController:          masterController
    property var    _missionController:         _masterController.missionController
39 40 41 42
    property bool   _currentItem:               missionItem.isCurrentItem
    property color  _outerTextColor:            _currentItem ? qgcPal.primaryButtonText : qgcPal.text
    property bool   _noMissionItemsAdded:       ListView.view.model.count === 1
    property real   _sectionSpacer:             ScreenTools.defaultFontPixelWidth / 2  // spacing between section headings
43
    property bool   _singleComplexItem:         _missionController.complexMissionItemNames.length === 1
44
    property bool   _readyForSave:              missionItem.readyForSaveState === VisualMissionItem.ReadyForSave
45

46
    readonly property real  _editFieldWidth:    Math.min(width - _margin * 2, ScreenTools.defaultFontPixelWidth * 12)
47 48
    readonly property real  _margin:            ScreenTools.defaultFontPixelWidth / 2
    readonly property real  _radius:            ScreenTools.defaultFontPixelWidth / 2
49
    readonly property real  _hamburgerSize:     commandPicker.height * 0.75
50
    readonly property real  _trashSize:     commandPicker.height * 0.75
51
    readonly property bool  _waypointsOnlyMode: QGroundControl.corePlugin.options.missionWaypointsOnly
52

Don Gagne's avatar
Don Gagne committed
53 54 55
    QGCPalette {
        id: qgcPal
        colorGroupEnabled: enabled
Don Gagne's avatar
Don Gagne committed
56 57
    }

58 59
    FocusScope {
        id:             currentItemScope
60
        anchors.fill:   parent
61 62 63 64 65 66 67 68

        MouseArea {
            anchors.fill:   parent
            onClicked: {
                currentItemScope.focus = true
                _root.clicked()
            }
        }
69 70
    }

71 72 73 74 75 76 77 78 79
    Component {
        id: editPositionDialog

        EditPositionDialog {
            coordinate: missionItem.coordinate
            onCoordinateChanged: missionItem.coordinate = coordinate
        }
    }

DonLakeFlyer's avatar
DonLakeFlyer committed
80
    Rectangle {
81 82
        id:                     notReadyForSaveIndicator
        anchors.verticalCenter: notReadyForSaveLabel.visible ? notReadyForSaveLabel.verticalCenter : commandPicker.verticalCenter
83 84
        anchors.leftMargin:     _margin
        anchors.left:           parent.left
DonLakeFlyer's avatar
DonLakeFlyer committed
85 86 87
        width:                  readyForSaveLabel.contentHeight
        height:                 width
        border.width:           1
88
        border.color:           qgcPal.warningText
DonLakeFlyer's avatar
DonLakeFlyer committed
89 90
        color:                  "white"
        radius:                 width / 2
91
        visible:                !_readyForSave
DonLakeFlyer's avatar
DonLakeFlyer committed
92 93 94 95 96 97

        QGCLabel {
            id:                 readyForSaveLabel
            anchors.centerIn:   parent
            //: Indicator in Plan view to show mission item is not ready for save/send
            text:               qsTr("?")
98
            color:              qgcPal.warningText
DonLakeFlyer's avatar
DonLakeFlyer committed
99 100 101
            font.pointSize:     ScreenTools.smallFontPointSize
        }
    }
102

103 104 105 106 107 108 109 110 111 112 113 114 115 116 117
    QGCLabel {
        id:                     notReadyForSaveLabel
        anchors.margins:        _margin
        anchors.left:           notReadyForSaveIndicator.right
        anchors.right:          parent.right
        anchors.top:            commandPicker.bottom
        visible:                _currentItem && !_readyForSave
        text:                   missionItem.readyForSaveState === VisualMissionItem.NotReadyForSaveTerrain ?
                                    qsTr("Incomplete: Waiting on terrain data.") :
                                    qsTr("Incomplete: Item not fully specified.")
        wrapMode:               Text.WordWrap
        horizontalAlignment:    Text.AlignHCenter
        color:                  qgcPal.warningText
    }

Gus Grubba's avatar
Gus Grubba committed
118
    QGCColoredImage {
119 120 121 122
        id:                     hamburger
        anchors.rightMargin:    ScreenTools.defaultFontPixelWidth
        anchors.right:          parent.right
        anchors.verticalCenter: commandPicker.verticalCenter
123 124 125
        width:                  _hamburgerSize
        height:                 _hamburgerSize
        sourceSize.height:      _hamburgerSize
126
        source:                 "qrc:/qmlimages/Hamburger.svg"
127
        visible:                missionItem.isCurrentItem && missionItem.sequenceNumber !== 0
Don Gagne's avatar
Don Gagne committed
128
        color:                  qgcPal.text
129
    }
130

131
    QGCMouseArea {
132 133
        fillItem:   hamburger
        visible:    hamburger.visible
134 135
        onClicked: {
            currentItemScope.focus = true
136
            hamburgerMenu.popup()
137
        }
138

139
        QGCMenu {
140
            id: hamburgerMenu
141

142
            QGCMenuItem {
143 144
                text:           qsTr("Edit position...")
                visible:        missionItem.specifiesCoordinate
145
                onTriggered:    mainWindow.showComponentDialog(editPositionDialog, qsTr("Edit Position"), mainWindow.showDialogDefaultWidth, StandardButton.Close)
146 147
            }

148
            QGCMenuSeparator {
149
                visible: missionItem.isSimpleItem && !_waypointsOnlyMode
150
            }
151

152
            QGCMenuItem {
153 154 155
                text:       qsTr("Show all values")
                checkable:  true
                checked:    missionItem.isSimpleItem ? missionItem.rawEdit : false
156
                visible:    missionItem.isSimpleItem && !_waypointsOnlyMode
157

158 159 160 161
                onTriggered:    {
                    if (missionItem.rawEdit) {
                        if (missionItem.friendlyEditAllowed) {
                            missionItem.rawEdit = false
162
                        } else {
163
                            mainWindow.showMessageDialog(qsTr("Mission Edit"), qsTr("You have made changes to the mission item which cannot be shown in Simple Mode"))
164
                        }
165 166
                    } else {
                        missionItem.rawEdit = true
167
                    }
168
                    checked = missionItem.rawEdit
169 170
                }
            }
Don Gagne's avatar
Don Gagne committed
171 172 173 174 175

            QGCMenuItem {
                text:       qsTr("Item #%1").arg(missionItem.sequenceNumber)
                enabled:    false
            }
176 177 178
        }
    }

179 180 181
    QGCColoredImage {
        id:                     deleteButton
        anchors.margins:        _margin
Don Gagne's avatar
Don Gagne committed
182
        anchors.left:           parent.left
183 184 185 186 187 188 189 190 191 192 193 194 195 196 197 198 199 200 201 202 203 204 205 206 207 208 209 210 211 212 213 214 215 216 217 218 219 220 221 222 223
        anchors.verticalCenter: commandPicker.verticalCenter
        height:                 _hamburgerSize
        width:                  height
        sourceSize.height:      height
        fillMode:               Image.PreserveAspectFit
        mipmap:                 true
        smooth:                 true
        color:                  qgcPal.text
        visible:                _currentItem && missionItem.sequenceNumber !== 0
        source:                 "/res/TrashDelete.svg"

        QGCMouseArea {
            fillItem:   parent
            onClicked:  remove()
        }
    }

    Rectangle {
        id:                 commandPicker
        anchors.margins:    _margin
        anchors.left:       deleteButton.right
        anchors.top:        parent.top
        height:             ScreenTools.implicitComboBoxHeight
        width:              innerLayout.x + innerLayout.width + ScreenTools.comboBoxPadding
        visible:            !commandLabel.visible
        color:              qgcPal.window
        border.width:       1
        border.color:       qgcPal.text

        RowLayout {
            id:                 innerLayout
            anchors.margins:    _padding
            anchors.left:       parent.left
            anchors.top:        parent.top
            spacing:            _padding

            property real _padding: ScreenTools.comboBoxPadding

            QGCLabel { text: missionItem.commandName }

            QGCColoredImage {
224
                height:             ScreenTools.defaultFontPixelWidth
225 226 227 228 229
                width:              height
                fillMode:           Image.PreserveAspectFit
                smooth:             true
                antialiasing:       true
                color:              qgcPal.text
230
                source:             "/qmlimages/arrow-down.png"
231 232 233 234 235 236 237
            }
        }

        QGCMouseArea {
            fillItem:   parent
            onClicked:  mainWindow.showComponentDialog(commandDialog, qsTr("Select Mission Command"), mainWindow.showDialogDefaultWidth, StandardButton.Cancel)
        }
238 239 240 241 242

        Component {
            id: commandDialog

            MissionCommandDialog {
243 244
                missionItem:    _root.missionItem
                map:            _root.map
245 246 247 248 249 250
            }
        }

    }

    QGCLabel {
Don Gagne's avatar
Don Gagne committed
251
        id:                     commandLabel
252
        anchors.leftMargin:     ScreenTools.comboBoxPadding
Don Gagne's avatar
Don Gagne committed
253
        anchors.fill:           commandPicker
254
        visible:                !missionItem.isCurrentItem || !missionItem.isSimpleItem || _waypointsOnlyMode || missionItem.isTakeoffItem
Don Gagne's avatar
Don Gagne committed
255 256 257
        verticalAlignment:      Text.AlignVCenter
        text:                   missionItem.commandName
        color:                  _outerTextColor
258 259 260 261
    }

    Loader {
        id:                 editorLoader
262
        anchors.margins:    _margin
263
        anchors.left:       parent.left
264
        anchors.top:        _readyForSave ? commandPicker.bottom : notReadyForSaveLabel.bottom
265
        source:             missionItem.editorQml
266
        visible:            _currentItem
267

268 269 270
        property var    masterController:   _masterController
        property real   availableWidth:     _root.width - (_margin * 2) ///< How wide the editor should be
        property var    editorRoot:         _root
271
    }
Don Gagne's avatar
Don Gagne committed
272
} // Rectangle