-
-
Notifications
You must be signed in to change notification settings - Fork 22
/
Copy pathmain.dart
108 lines (102 loc) · 3.6 KB
/
main.dart
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
24
25
26
27
28
29
30
31
32
33
34
35
36
37
38
39
40
41
42
43
44
45
46
47
48
49
50
51
52
53
54
55
56
57
58
59
60
61
62
63
64
65
66
67
68
69
70
71
72
73
74
75
76
77
78
79
80
81
82
83
84
85
86
87
88
89
90
91
92
93
94
95
96
97
98
99
100
101
102
103
104
105
106
107
108
import 'package:flutter/material.dart';
import 'package:flutter_form_builder/flutter_form_builder.dart';
import 'package:form_builder_phone_field/form_builder_phone_field.dart';
import 'package:form_builder_validators/form_builder_validators.dart';
import 'package:flutter_localizations/flutter_localizations.dart';
void main() {
runApp(const MyApp());
}
class MyApp extends StatelessWidget {
const MyApp({super.key});
@override
Widget build(BuildContext context) {
return MaterialApp(
title: 'Flutter Demo',
// Locale config required by form_builder_validators
// https://github.com/danvick/flutter_form_builder/blob/master/packages/form_builder_validators/example/lib/main.dart
supportedLocales: const [...FormBuilderLocalizations.supportedLocales],
localizationsDelegates: const [
GlobalMaterialLocalizations.delegate,
GlobalWidgetsLocalizations.delegate,
GlobalCupertinoLocalizations.delegate,
FormBuilderLocalizations.delegate,
],
theme: ThemeData(
primarySwatch: Colors.blue,
visualDensity: VisualDensity.adaptivePlatformDensity,
),
home: MyHomePage(),
);
}
}
class MyHomePage extends StatelessWidget {
final _formKey = GlobalKey<FormBuilderState>();
MyHomePage({super.key});
@override
Widget build(BuildContext context) {
return Scaffold(
appBar: AppBar(title: const Text("FormBuilderPhoneField")),
body: FormBuilder(
key: _formKey,
child: Padding(
padding: const EdgeInsets.all(8.0),
child: Column(
mainAxisAlignment: MainAxisAlignment.center,
children: <Widget>[
FormBuilderPhoneField(
name: 'phone_number',
decoration: const InputDecoration(
labelText: 'Phone Number',
hintText: 'Hint',
),
// onChanged: _onChanged,
priorityListByIsoCode: const ['KE'],
validator: FormBuilderValidators.compose([
FormBuilderValidators.numeric(),
FormBuilderValidators.required(),
]),
),
const SizedBox(height: 15),
FormBuilderPhoneField(
name: 'phone_number_cupertino',
isCupertinoPicker: true,
decoration: const InputDecoration(
labelText: 'Phone Number',
hintText: 'Hint',
),
// onChanged: _onChanged,
priorityListByIsoCode: const ['US'],
validator: FormBuilderValidators.compose([
FormBuilderValidators.numeric(),
FormBuilderValidators.required(),
]),
),
const SizedBox(height: 15),
Wrap(
spacing: 16,
children: [
ElevatedButton(
onPressed: () {
if (_formKey.currentState!.saveAndValidate()) {
debugPrint(_formKey.currentState!.value.toString());
}
},
child: const Text("Submit"),
),
ElevatedButton(
onPressed: () {
_formKey.currentState?.reset();
debugPrint(
_formKey.currentState!.instantValue.toString());
},
child: const Text("Reset"),
)
],
),
],
),
),
),
);
}
}