dynamic_form 0.3.2
dynamic_form: ^0.3.2 copied to clipboard
generate your form with easier way, Pre-existing forms, fields ,customize your form in runtime
example/lib/main.dart
import 'package:dynamic_form/dynamic_form.dart';
import 'package:flutter/material.dart';
void main() => runApp(MyApp());
class MyApp extends StatelessWidget {
// This widget is the root of your application.
@override
Widget build(BuildContext context) {
return MaterialApp(
title: 'Dynamic Form Demo',
theme: ThemeData(
primarySwatch: Colors.blue,
backgroundColor: Colors.grey[300],
),
home: Scaffold(
appBar: AppBar(
title: Text("Demo"),
),
body: MyHomePage(),
),
);
}
}
class MyHomePage extends StatelessWidget {
GlobalKey<SimpleDynamicFormState> _globalKey;
@override
Widget build(BuildContext context) {
_globalKey = GlobalKey<SimpleDynamicFormState>();
return Center(
child: Column(
children: <Widget>[
SimpleDynamicForm(
key: _globalKey,
groupElements: [
GroupElement(
margin: EdgeInsets.only(bottom: 5.0),
directionGroup: DirectionGroup.Horizontal,
sizeElements: [0.3],
textElements: [
TextElement(
initValue: "dali hamza",
label: "first name",
hint: "first name",
validator: (v) {
if (v.isEmpty) {
return "err";
}
return null;
}),
TextElement(label: "last name"),
],
),
GroupElement(
directionGroup: DirectionGroup.Vertical,
textElements: [
TextElement(label: "name"),
EmailElement(label: "name"),
PasswordElement(),
],
),
],
),
RaisedButton(
onPressed: () {
print(_globalKey.currentState.validate());
print(_globalKey.currentState.recuperateAllValues());
},
child: Text("Validate"),
)
],
),
);
}
}