mirror of
https://github.com/johndoe6345789/metabuilder.git
synced 2026-04-24 22:04:56 +00:00
Feedback: CAlert (tonal + accent bar), CDialog (radius 28, scale anim), CSnackbar (inverse surface, slide-in) Navigation: CTabBar (animated indicator pill), CListItem (state layers), CBreadcrumbs (full rewrite) Data: CAvatar (tonal primary), CDivider (theme-aware), CTable (hover rows, sort arrows, proper padding) Typography: CText (full MD3 type scale inline), CTitle (extends CText), CCodeBlock (radius 12), CCodeInline (radius 4) Forms: CFormGroup (focus/error states), CFormLabel (animated color), CLabel (control association), CAutocomplete (styled popup) Co-Authored-By: Claude Opus 4.6 (1M context) <noreply@anthropic.com>
81 lines
2.0 KiB
QML
81 lines
2.0 KiB
QML
import QtQuick
|
|
import QtQuick.Layouts
|
|
import QmlComponents 1.0
|
|
|
|
/**
|
|
* CFormGroup.qml - Material Design 3 form field container
|
|
* Groups label, input, and helper/error text with MD3 spacing
|
|
*/
|
|
ColumnLayout {
|
|
id: root
|
|
|
|
property string label: ""
|
|
property string helperText: ""
|
|
property string errorText: ""
|
|
property bool required: false
|
|
property bool disabled: false
|
|
property bool focused: false
|
|
|
|
default property alias content: contentArea.data
|
|
|
|
spacing: 0
|
|
|
|
// Label
|
|
RowLayout {
|
|
Layout.fillWidth: true
|
|
Layout.bottomMargin: 4
|
|
spacing: 0
|
|
visible: root.label !== ""
|
|
|
|
Text {
|
|
text: root.label
|
|
color: {
|
|
if (root.disabled) return Theme.textDisabled
|
|
if (root.errorText) return Theme.error
|
|
if (root.focused) return Theme.primary
|
|
return Theme.textSecondary
|
|
}
|
|
font.pixelSize: 12
|
|
font.weight: Font.Medium
|
|
font.family: Theme.fontFamily
|
|
|
|
Behavior on color {
|
|
ColorAnimation { duration: Theme.transitionShortest }
|
|
}
|
|
}
|
|
|
|
Text {
|
|
text: " *"
|
|
color: Theme.error
|
|
font.pixelSize: 12
|
|
font.weight: Font.Medium
|
|
font.family: Theme.fontFamily
|
|
visible: root.required
|
|
}
|
|
}
|
|
|
|
// Content slot (for input)
|
|
Item {
|
|
id: contentArea
|
|
Layout.fillWidth: true
|
|
implicitHeight: childrenRect.height
|
|
}
|
|
|
|
// Helper or error text
|
|
Text {
|
|
Layout.fillWidth: true
|
|
Layout.topMargin: 4
|
|
text: root.errorText || root.helperText
|
|
color: root.errorText ? Theme.error : Theme.textSecondary
|
|
font.pixelSize: 12
|
|
font.family: Theme.fontFamily
|
|
visible: text !== ""
|
|
wrapMode: Text.Wrap
|
|
opacity: root.disabled ? 0.38 : 1
|
|
|
|
Behavior on color {
|
|
ColorAnimation { duration: Theme.transitionShortest }
|
|
}
|
|
}
|
|
}
|