From fca3386cec724ed7d6094342879674604a4056d8 Mon Sep 17 00:00:00 2001 From: Pascal Precht Date: Fri, 23 Jul 2021 13:17:14 +0200 Subject: [PATCH] feat(StatusInput): implement error message and charlimit APIs Usage: ```qml StatusInput { label: "Fieldname" charLimit: 30 errorMessage: "Some error occured" input.valid: false input.text: "Some invalid value" input.valid: false } ``` Closes #289, #290 --- ui/StatusQ/sandbox/StatusInputPage.qml | 25 ++++++++ .../src/StatusQ/Controls/StatusInput.qml | 57 ++++++++++++++++--- 2 files changed, 75 insertions(+), 7 deletions(-) diff --git a/ui/StatusQ/sandbox/StatusInputPage.qml b/ui/StatusQ/sandbox/StatusInputPage.qml index 86549f6f71..167197ee39 100644 --- a/ui/StatusQ/sandbox/StatusInputPage.qml +++ b/ui/StatusQ/sandbox/StatusInputPage.qml @@ -15,6 +15,7 @@ Column { } StatusInput { + label: "Label" input.placeholderText: "Disabled" input.enabled: false } @@ -32,6 +33,30 @@ Column { StatusInput { label: "Label" input.placeholderText: "Placeholder" + input.clearable: true + } + + StatusInput { + charLimit: 30 + input.placeholderText: "Placeholder" + input.clearable: true + } + + StatusInput { + label: "Label" + charLimit: 30 + input.placeholderText: "Placeholder" + input.clearable: true + } + + StatusInput { + label: "Label" + charLimit: 30 + errorMessage: "Error message" + + input.clearable: true + input.valid: false + input.placeholderText: "Placeholder" } StatusInput { diff --git a/ui/StatusQ/src/StatusQ/Controls/StatusInput.qml b/ui/StatusQ/src/StatusQ/Controls/StatusInput.qml index 288860d32f..65ab5ead26 100644 --- a/ui/StatusQ/src/StatusQ/Controls/StatusInput.qml +++ b/ui/StatusQ/src/StatusQ/Controls/StatusInput.qml @@ -4,17 +4,29 @@ import StatusQ.Core 0.1 import StatusQ.Core.Theme 0.1 import StatusQ.Controls 0.1 -Item { +Rectangle { id: root implicitWidth: 480 - height: label.anchors.topMargin + - label.height + + height: (label.visible ? + label.anchors.topMargin + + label.height : + charLimitLabel.visible ? + charLimitLabel.anchors.topMargin + + charLimitLabel.height : + 0) + statusBaseInput.anchors.topMargin + - statusBaseInput.height + 8 + statusBaseInput.height + + (errorMessage.visible ? + errorMessage.anchors.topMargin + + errorMessage.height : + 0) + 8 + color: "transparent" property alias input: statusBaseInput property string label: "" + property int charLimit: 0 + property string errorMessage: "" StatusBaseText { id: label @@ -27,16 +39,47 @@ Item { text: root.label font.pixelSize: 15 - color: Theme.palette.directColor1 + color: statusBaseInput.enabled ? Theme.palette.directColor1 : Theme.palette.baseColor1 + } + + StatusBaseText { + id: charLimitLabel + height: visible ? implicitHeight : 0 + anchors.top: parent.top + anchors.right: parent.right + anchors.topMargin: visible ? 11 : 0 + anchors.rightMargin: 16 + visible: !!root.charLimit + + text: "0 / " + root.charLimit + font.pixelSize: 12 + color: statusBaseInput.enabled ? Theme.palette.baseColor1 : Theme.palette.directColor6 } StatusBaseInput { id: statusBaseInput - anchors.top: label.bottom + anchors.top: label.visible ? label.bottom : + charLimitLabel.visible ? charLimitLabel.bottom : parent.top anchors.left: parent.left anchors.right: parent.right - anchors.topMargin: 8 + anchors.topMargin: charLimitLabel.visible ? 11 : 8 anchors.leftMargin: 16 anchors.rightMargin: 16 } + + StatusBaseText { + id: errorMessage + + anchors.top: statusBaseInput.bottom + anchors.topMargin: 11 + anchors.right: parent.right + anchors.rightMargin: 16 + + height: visible ? implicitHeight : 0 + visible: !!root.errorMessage && !statusBaseInput.valid + + font.pixelSize: 12 + color: Theme.palette.dangerColor1 + text: root.errorMessage + } }