QGCTextField.qml 4.13 KB
Newer Older
1 2 3 4
import QtQuick                  2.2
import QtQuick.Controls         1.2
import QtQuick.Controls.Styles  1.2
import QtQuick.Layouts          1.2
5

6 7
import QGroundControl.Palette       1.0
import QGroundControl.ScreenTools   1.0
8 9

TextField {
10 11
    id: root

12 13
    property bool   showUnits:  false
    property bool   showHelp:   false
14
    property string unitsLabel: ""
15

16 17 18 19
    signal helpClicked

    property real _helpLayoutWidth: 0

20 21 22 23 24 25
    Component.onCompleted: {
        if (typeof qgcTextFieldforwardKeysTo !== 'undefined') {
            root.Keys.forwardTo = [qgcTextFieldforwardKeysTo]
        }
    }

26
    QGCPalette { id: qgcPal; colorGroupEnabled: enabled }
27

28
    textColor:          qgcPal.textFieldText
29 30

    implicitHeight: Math.round(ScreenTools.defaultFontPixelHeight * (ScreenTools.isMobile ? 2 : 1.2))
31

Don Gagne's avatar
Don Gagne committed
32
    QGCLabel {
33 34
        id:             unitsLabelWidthGenerator
        text:           unitsLabel
dogmaphobic's avatar
dogmaphobic committed
35
        width:          contentWidth + parent.__contentHeight * 0.666
36 37
        visible:        false
        antialiasing:   true
Don Gagne's avatar
Don Gagne committed
38
    }
39

Don Gagne's avatar
Don Gagne committed
40
    style: TextFieldStyle {
41
        font.pointSize: ScreenTools.defaultFontPointSize
Don Gagne's avatar
Don Gagne committed
42 43 44
        background: Item {
            id: backgroundItem

45 46
            property bool showHelp: control.showHelp && control.activeFocus

Don Gagne's avatar
Don Gagne committed
47
            Rectangle {
dogmaphobic's avatar
dogmaphobic committed
48 49 50
                anchors.fill:           parent
                anchors.bottomMargin:   -1
                color:                  "#44ffffff"
Don Gagne's avatar
Don Gagne committed
51 52 53
            }

            Rectangle {
dogmaphobic's avatar
dogmaphobic committed
54 55
                anchors.fill:           parent
                border.color:           control.activeFocus ? "#47b" : "#999"
56
                color:                  qgcPal.textField
Don Gagne's avatar
Don Gagne committed
57 58
            }

59 60 61 62 63 64 65 66 67 68 69 70 71 72 73 74 75 76 77 78 79 80 81 82 83 84 85 86 87 88 89 90 91 92 93 94 95 96 97 98
            RowLayout {
                id:                     unitsHelpLayout
                anchors.top:            parent.top
                anchors.bottom:         parent.bottom
                anchors.rightMargin:    backgroundItem.showHelp ? 0 : control.__contentHeight * 0.333
                anchors.right:          parent.right
                spacing:                4

                Component.onCompleted:  control._helpLayoutWidth = unitsHelpLayout.width
                onWidthChanged:         control._helpLayoutWidth = unitsHelpLayout.width

                Text {
                    anchors.verticalCenter: parent.verticalCenter
                    text:                   control.unitsLabel
                    font.pointSize:         backgroundItem.showHelp ? ScreenTools.smallFontPointSize : ScreenTools.defaultFontPointSize
                    font.family:            ScreenTools.normalFontFamily
                    antialiasing:           true
                    color:                  control.textColor
                    visible:                control.showUnits
                }

                Rectangle {
                    anchors.margins:    2
                    anchors.top:        parent.top
                    anchors.bottom:     parent.bottom
                    anchors.right:      parent.right
                    width:              height * 0.75
                    color:              control.textColor
                    radius:             2
                    visible:            backgroundItem.showHelp

                    QGCLabel {
                        anchors.fill:           parent
                        verticalAlignment:      Text.AlignVCenter
                        horizontalAlignment:    Text.AlignHCenter
                        color:                  qgcPal.textField
                        text:                   "?"
                    }
                }
            }
99

100
            MouseArea {
Don Gagne's avatar
Don Gagne committed
101 102 103 104
                anchors.margins:    ScreenTools.isMobile ? -(ScreenTools.defaultFontPixelWidth * 0.66) : 0 // Larger touch area for mobile
                anchors.fill:       unitsHelpLayout
                enabled:            control.activeFocus
                onClicked:          root.helpClicked()
Don Gagne's avatar
Don Gagne committed
105 106 107
            }
        }

108
        padding.right: control._helpLayoutWidth //control.showUnits ? unitsLabelWidthGenerator.width : control.__contentHeight * 0.333
Don Gagne's avatar
Don Gagne committed
109
    }
Don Gagne's avatar
Don Gagne committed
110 111

    onActiveFocusChanged: {
Don Gagne's avatar
Don Gagne committed
112
        if (!ScreenTools.isMobile && activeFocus) {
Don Gagne's avatar
Don Gagne committed
113 114 115
            selectAll()
        }
    }
116
}