DynamicForm class

The main widget for building a dynamic form based on a list of DynamicField.

Inheritance

Constructors

DynamicForm({Key? key, required List<DynamicField> config, DynamicFormController? controller, DynamicFormTheme? theme, Map<String, FieldBuilder>? customBuilders, void onSubmit(Map<String, dynamic> values)?, Widget wrapper(Widget form)?, Widget submitButtonBuilder(VoidCallback onSubmit)?, Map<String, dynamic>? initialValues, bool wrapInForm = true})
Creates a new DynamicForm instance.
const

Properties

config List<DynamicField>
The list of field configurations defining the form structure.
final
controller DynamicFormController?
Optional controller to manage form state and validation externally.
final
customBuilders Map<String, FieldBuilder>?
Map of custom builders to handle custom field types or override default ones.
final
hashCode int
The hash code for this object.
no setterinherited
initialValues Map<String, dynamic>?
Optional initial values to pre-populate the form.
final
key Key?
Controls how one widget replaces another widget in the tree.
finalinherited
onSubmit → void Function(Map<String, dynamic> values)?
Callback function triggered when the form is submitted and validation passes.
final
runtimeType Type
A representation of the runtime type of the object.
no setterinherited
submitButtonBuilder Widget Function(VoidCallback onSubmit)?
Optional builder to provide a custom submit button.
final
theme DynamicFormTheme?
Optional theme to customize the appearance of the form and its fields.
final
wrapInForm bool
Whether to wrap the fields in a Flutter Form widget. Defaults to true.
final
wrapper Widget Function(Widget form)?
Optional wrapper widget to wrap the entire form.
final

Methods

createElement() StatefulElement
Creates a StatefulElement to manage this widget's location in the tree.
inherited
createState() State<DynamicForm>
Creates the mutable state for this widget at a given location in the tree.
override
debugDescribeChildren() List<DiagnosticsNode>
Returns a list of DiagnosticsNode objects describing this node's children.
inherited
debugFillProperties(DiagnosticPropertiesBuilder properties) → void
Add additional properties associated with the node.
inherited
noSuchMethod(Invocation invocation) → dynamic
Invoked when a nonexistent method or property is accessed.
inherited
toDiagnosticsNode({String? name, DiagnosticsTreeStyle? style}) DiagnosticsNode
Returns a debug representation of the object that is used by debugging tools and by DiagnosticsNode.toStringDeep.
inherited
toString({DiagnosticLevel minLevel = DiagnosticLevel.info}) String
A string representation of this object.
inherited
toStringDeep({String prefixLineOne = '', String? prefixOtherLines, DiagnosticLevel minLevel = DiagnosticLevel.debug, int wrapWidth = 65}) String
Returns a string representation of this node and its descendants.
inherited
toStringShallow({String joiner = ', ', DiagnosticLevel minLevel = DiagnosticLevel.debug}) String
Returns a one-line detailed description of the object.
inherited
toStringShort() String
A short, textual description of this widget.
inherited

Operators

operator ==(Object other) bool
The equality operator.
inherited