import QtQuick import QtQuick.Controls as Control import QtQuick.Layouts 1.0 import Linphone ColumnLayout { id: mainItem property string label: "" property string errorMessage: "" property string placeholderText: "" property bool mandatory: false property bool hidden: false property int textInputWidth: 200 property var validator: RegularExpressionValidator{} property bool fillWidth: false property bool enableBackgroundColors: true property string initialText readonly property string text: textField.text readonly property bool hasActiveFocus: textField.activeFocus Component.onCompleted: setText(initialText) function setText(text) { textField.text = text } function resetText() { setText(initialText) } Text { visible: mainItem.label.length > 0 verticalAlignment: Text.AlignVCenter text: mainItem.label + (mainItem.mandatory ? "*" : "") color: textField.activeFocus ? DefaultStyle.formItemFocusBorderColor : DefaultStyle.formItemLabelColor elide: Text.ElideRight wrapMode: Text.Wrap maximumLineCount: 1 font { pointSize: DefaultStyle.formItemLabelSize family: DefaultStyle.defaultFont bold: true } Layout.preferredWidth: mainItem.textInputWidth } Rectangle { id: input Component.onCompleted: { if (mainItem.fillWidth) Layout.fillWidth = true } implicitWidth: mainItem.textInputWidth implicitHeight: 30 radius: 20 color: mainItem.enableBackgroundColors ? DefaultStyle.formItemBackgroundColor : "transparent" border.color: mainItem.enableBackgroundColors ? (mainItem.errorMessage.length > 0 ? DefaultStyle.errorMessageColor : textField.activeFocus ? DefaultStyle.formItemFocusBorderColor : DefaultStyle.formItemBorderColor) : "transparent" Control.TextField { id: textField anchors.left: parent.left anchors.right: eyeButton.visible ? eyeButton.left : parent.right anchors.verticalCenter: parent.verticalCenter placeholderText: mainItem.placeholderText echoMode: (mainItem.hidden && !eyeButton.checked) ? TextInput.Password : TextInput.Normal font.family: DefaultStyle.defaultFont font.pointSize: DefaultStyle.defaultFontPointSize color: DefaultStyle.formItemLabelColor selectByMouse: true validator: mainItem.validator background: Item { opacity: 0. } cursorDelegate: Rectangle { visible: textField.activeFocus color: DefaultStyle.formItemFocusBorderColor width: 2 } } Control.Button { id: eyeButton visible: mainItem.hidden checkable: true background: Rectangle { color: "transparent" } contentItem: Image { fillMode: Image.PreserveAspectFit source: eyeButton.checked ? AppIcons.eyeShow : AppIcons.eyeHide } anchors.top: parent.top anchors.bottom: parent.bottom anchors.right: parent.right } } Text { visible: mainItem.errorMessage.length > 0 verticalAlignment: Text.AlignVCenter text: mainItem.errorMessage color: DefaultStyle.errorMessageColor elide: Text.ElideRight wrapMode: Text.Wrap // maximumLineCount: 1 font { pointSize: DefaultStyle.defaultTextSize family: DefaultStyle.defaultFont bold: true } Layout.preferredWidth: mainItem.textInputWidth } }