Files
metabuilder/fakemui/qml-components/form/CFormGroup.qml
JohnDoe6345789 58a94d0489 feat(styles): add component-specific styles for TaskDetail, SearchDialog, and Documentation
feat(styles): create global styles entry point and organize global styles

feat(styles): implement base HTML element styles and utility classes for flexbox

feat(styles): establish layout, position, spacing, and text utility classes

feat(styles): introduce mixins for animations, cards, dialogs, flexbox, grid, and responsive design

test(quick_guide): add component and metadata validation tests for quick_guide package

test(ui_level6): implement metadata validation tests for ui_level6 package
2025-12-30 02:29:58 +00:00

60 lines
1.5 KiB
QML

import QtQuick
import QtQuick.Layouts
/**
* CFormGroup.qml - Form field container (mirrors _form.scss)
* Groups label, input, and helper/error text
*/
ColumnLayout {
id: root
property string label: ""
property string helperText: ""
property string errorText: ""
property bool required: false
property bool disabled: false
default property alias content: contentArea.data
spacing: StyleVariables.spacingXs
// Label
RowLayout {
Layout.fillWidth: true
spacing: 2
visible: root.label !== ""
Text {
text: root.label
color: root.disabled ? Theme.onSurfaceVariant : Theme.onSurface
font.pixelSize: StyleVariables.fontSizeSm
font.weight: Font.Medium
opacity: root.disabled ? 0.6 : 1
}
Text {
text: "*"
color: Theme.error
font.pixelSize: StyleVariables.fontSizeSm
visible: root.required
}
}
// Content slot (for input)
Item {
id: contentArea
Layout.fillWidth: true
implicitHeight: childrenRect.height
}
// Helper or error text
Text {
Layout.fillWidth: true
text: root.errorText || root.helperText
color: root.errorText ? Theme.error : Theme.onSurfaceVariant
font.pixelSize: StyleVariables.fontSizeXs
visible: text !== ""
wrapMode: Text.Wrap
}
}