form_builder 2.0.0-alpha3 copy "form_builder: ^2.0.0-alpha3" to clipboard
form_builder: ^2.0.0-alpha3 copied to clipboard

outdated

flutter row-column based form builder, build form quickly,create field fast,less code,more powerful

Form Builder #

a flutter row-column based form builder ! build form quickly,create field fast,less code,more powerful

Simple Usage #

FormKey formKey = FormKey(); // FormKey is a GlobalKey, used to get  a FormManagement
FormBuilder(key:formKey,
	readOnly:true|false,
	onChanged:FormValueChanged,
	child:Widget child,
	);

Form Field #

Form Field types #

FormField
	- StatefulField
		- ValueField
			- NonnullValueField
		- CommonField

attributes supported by all StatefulFields #

attribute type description
name String? name of a field ,used to control field and get error
builder FormContentBuilder used to build field widget
model AbstractFieldStateModel used to determine how to build a field widget
readOnly bool whether field should be readOnly

ValueField #

supported attributes

attribute type description
validator FormFieldValidator? validator
autovalidateMode AutovalidateMode?
initialValue T?
enabled bool
onSaved FormFieldSetter? called when save form

NonnullValueField #

supported attributes

attribute type description
validator NonnullFieldValidator? validator
autovalidateMode AutovalidateMode?
initialValue T
enabled bool
onSaved NonnullFormFieldSetter? called when save form

methods #

FormManagement #

get FormManagement

FormManagement formManagement = formKey.currentFormManagement;// return a nonnull FormManagement
FormManagement? formManagement = formKey.quietlyManagement;// return a FormManagement , return null if not find

check whether form has a name field

bool hasField = formManagement.hasField(String name);

whether form is readOnly

bool readOnly = formManagement.readOnly;

set form readOnly|editable

formManagement.readOnly = true|false;

get form data

Map<String, dynamic> data = formManagement.data;

get form field validate errors

List<FormFieldManagementWithError> errors = formManagement.errors;

quietly vaidate form

List<FormFieldManagementWithError> errors = formManagement.quietlyValidate();

set form data

formManagement.data = data;// will trigger field's onChanged listener
formManagement.setData(data,trigger:bool) // if trigger is false ,won't trigger field's onChanged listener

reset form

formManagement.reset();

validate form

will display error text

bool isValid = formManagement.validate();

whether form is valid

won't display error text

bool isValid = formManagement.isValid;

save form

formManagement.save();

FormFieldManagement #

create FormFieldManagement by name

FormFieldManagement formFieldManagement = formManagement.newFormFieldManagement(String name);

get field's name

String? name = formFieldManagement.name;

whether field is readOnly

bool readOnly = formFieldManagement.readOnly;

set readOnly|editable on field

formFieldManagement.readOnly = true|false;

whether field is focusable

bool focusable = formFieldManagement.focusable;

whether field is focused

bool hasFocus = formFieldManagement.hasFocus;

focus|unfocus a form field

formFieldManagement.focus = true|false;

set focus listener on field

formFieldManagement.focusListener = (key,hasFocus){};

whether field is a value field

bool isValueField = formFieldManagement.isValueField;

whether field support TextSelection

bool supportTextSelection = formFieldManagement.supportTextSelection;

set state model

formFieldManagement.model = AbstractFieldStateModel();

get state model

AbstractFieldStateModel model = formFieldManagement.model;

ensure form field visible

formFieldManagement.ensureVisible();

TextSelectionManagement #

get TextSelectionManagement

TextSelectionManagement textSelectionManagement = formFieldManagement.textSelectionManagement;

select all

textSelectionManagement.selectAll();

select selection

textSelectionManagement.setSelection(int start,int end);

ValueFieldManagement #

get ValueFieldManagement

if field is not a value field , an error will be throw

ValueFieldManagement valueFieldManagement = formFieldManagement.valueFieldManagement;

get field's value

dynamic value = valueFieldManagement.value;

set field value

valueFieldManagement.value = value; // set field value , will trigger onChanged listener
textSelectionManagement.setValue(value,trigger:bool); // if trigger is false ,won't trigger onChanged listener

whether field is valid

won't display error text

bool isValid = valueFieldManagement.isValid;

validate field

will display error text

bool isValid = valueFieldManagement.validate();

get error text

String? errorText = valueFieldManagement.errorText;

quietlyValidate field

won't display error text

String? errorText = valueFieldManagement.quietlyValidate();

currently support fields #

field return value nullable
ClearableTextFormField string false
DateTimeFormField DateTime true
SelectorFormField List< T> false
ListTileFormField List< T> false
InlineFormField bool false
NumberFormField num true
SliderFormField double false
RangeSliderFormField RangeValues false
FilterChipFormField List< T> false
RateFormField dobule true
SingleCheckBoxFormField bool false
SingleSwitchFormField bool false
CupertinoPickerFormField int false

example for helping build a custom field #

build a common field #

https://github.com/wwwqyhme/flutter-form-builder/blob/main/lib/src/field/button.dart

build a nonnull value field #

https://github.com/wwwqyhme/flutter-form-builder/blob/main/lib/src/field/single_switch.dart

build a value field #

https://github.com/wwwqyhme/flutter-form-builder/blob/main/lib/src/field/rate.dart

1
likes
80
points
239
downloads

Publisher

unverified uploader

Weekly Downloads

flutter row-column based form builder, build form quickly,create field fast,less code,more powerful

Repository (GitHub)
View/report issues

Documentation

API reference

License

MIT (license)

Dependencies

flutter

More

Packages that depend on form_builder