mirror of
https://github.com/flutter/samples.git
synced 2025-11-08 13:58:47 +00:00
move experimental/form_app to root of project (#623)
This allows us to reference this sample from other places. See https://github.com/flutter/flutter/pull/70321 for more context.
This commit is contained in:
164
form_app/lib/src/validation.dart
Normal file
164
form_app/lib/src/validation.dart
Normal file
@@ -0,0 +1,164 @@
|
||||
// Copyright 2020, the Flutter project authors. Please see the AUTHORS file
|
||||
// for details. All rights reserved. Use of this source code is governed by a
|
||||
// BSD-style license that can be found in the LICENSE file.
|
||||
|
||||
import 'package:flutter/material.dart';
|
||||
import 'package:english_words/english_words.dart' as english_words;
|
||||
|
||||
class FormValidationDemo extends StatefulWidget {
|
||||
@override
|
||||
_FormValidationDemoState createState() => _FormValidationDemoState();
|
||||
}
|
||||
|
||||
class _FormValidationDemoState extends State<FormValidationDemo> {
|
||||
final _formKey = GlobalKey<FormState>();
|
||||
String adjective;
|
||||
String noun;
|
||||
bool agreedToTerms = false;
|
||||
|
||||
@override
|
||||
Widget build(BuildContext context) {
|
||||
return Scaffold(
|
||||
appBar: AppBar(
|
||||
title: Text('📖 Story Generator'),
|
||||
actions: [
|
||||
Padding(
|
||||
padding: EdgeInsets.all(8),
|
||||
child: FlatButton(
|
||||
textColor: Colors.white,
|
||||
child: Text('Submit'),
|
||||
onPressed: () {
|
||||
// Validate the form by getting the FormState from the GlobalKey
|
||||
// and calling validate() on it.
|
||||
var valid = _formKey.currentState.validate();
|
||||
if (!valid) {
|
||||
return;
|
||||
}
|
||||
|
||||
showDialog(
|
||||
context: context,
|
||||
builder: (context) => AlertDialog(
|
||||
title: Text('Your story'),
|
||||
content: Text('The $adjective developer saw a $noun'),
|
||||
actions: [
|
||||
FlatButton(
|
||||
child: Text('Done'),
|
||||
onPressed: () {
|
||||
Navigator.of(context).pop();
|
||||
},
|
||||
),
|
||||
],
|
||||
),
|
||||
);
|
||||
},
|
||||
),
|
||||
),
|
||||
],
|
||||
),
|
||||
body: Form(
|
||||
key: _formKey,
|
||||
child: Scrollbar(
|
||||
child: SingleChildScrollView(
|
||||
padding: EdgeInsets.all(16),
|
||||
child: Column(
|
||||
children: [
|
||||
// A text field that validates that the text is an adjective.
|
||||
TextFormField(
|
||||
validator: (value) {
|
||||
if (value.isEmpty) {
|
||||
return 'Please enter an adjective.';
|
||||
}
|
||||
if (english_words.adjectives.contains(value)) {
|
||||
return null;
|
||||
}
|
||||
return 'Not a valid adjective.';
|
||||
},
|
||||
decoration: InputDecoration(
|
||||
filled: true,
|
||||
hintText: 'e.g. quick, beautiful, interesting',
|
||||
labelText: 'Enter an adjective',
|
||||
),
|
||||
onChanged: (value) {
|
||||
adjective = value;
|
||||
},
|
||||
),
|
||||
SizedBox(
|
||||
height: 24,
|
||||
),
|
||||
// A text field that validates that the text is a noun.
|
||||
TextFormField(
|
||||
validator: (value) {
|
||||
if (value.isEmpty) {
|
||||
return 'Please enter a noun.';
|
||||
}
|
||||
if (english_words.nouns.contains(value)) {
|
||||
return null;
|
||||
}
|
||||
return 'Not a valid noun.';
|
||||
},
|
||||
decoration: InputDecoration(
|
||||
filled: true,
|
||||
hintText: 'i.e. a person, place or thing',
|
||||
labelText: 'Enter a noun',
|
||||
),
|
||||
onChanged: (value) {
|
||||
noun = value;
|
||||
},
|
||||
),
|
||||
SizedBox(
|
||||
height: 24,
|
||||
),
|
||||
// A custom form field that requires the user to check a
|
||||
// checkbox.
|
||||
FormField(
|
||||
initialValue: false,
|
||||
validator: (value) {
|
||||
if (value == false) {
|
||||
return 'You must agree to the terms of service.';
|
||||
}
|
||||
return null;
|
||||
},
|
||||
builder: (FormFieldState formFieldState) {
|
||||
return Column(
|
||||
crossAxisAlignment: CrossAxisAlignment.start,
|
||||
children: [
|
||||
Row(
|
||||
children: [
|
||||
Checkbox(
|
||||
value: agreedToTerms,
|
||||
onChanged: (value) {
|
||||
// When the value of the checkbox changes,
|
||||
// update the FormFieldState so the form is
|
||||
// re-validated.
|
||||
formFieldState.didChange(value);
|
||||
setState(() {
|
||||
agreedToTerms = value;
|
||||
});
|
||||
},
|
||||
),
|
||||
Text(
|
||||
'I agree to the terms of service.',
|
||||
style: Theme.of(context).textTheme.subtitle1,
|
||||
),
|
||||
],
|
||||
),
|
||||
if (!formFieldState.isValid)
|
||||
Text(
|
||||
formFieldState.errorText ?? "",
|
||||
style: Theme.of(context)
|
||||
.textTheme
|
||||
.caption
|
||||
.copyWith(color: Theme.of(context).errorColor),
|
||||
),
|
||||
],
|
||||
);
|
||||
},
|
||||
),
|
||||
],
|
||||
),
|
||||
),
|
||||
),
|
||||
),
|
||||
);
|
||||
}
|
||||
}
|
||||
Reference in New Issue
Block a user