lib/sign_in_screen.dart
// Authentication用のパッケージをインポートする
import 'package:firebase_auth/firebase_auth.dart';
import 'package:flutter/material.dart';
import 'package:photoapp/photo_list_screen.dart';
class SignInScreen extends StatefulWidget {
@override
_SignInScreenState createState() => _SignInScreenState();
}
class _SignInScreenState extends State<SignInScreen> {
final GlobalKey<FormState> _formKey = GlobalKey<FormState>();
// メールアドレス用のTextEditingController
final TextEditingController _emailController = TextEditingController();
// パスワード用のTextEditingController
final TextEditingController _passwordController = TextEditingController();
@override
Widget build(BuildContext context) {
return Scaffold(
body: Form(
key: _formKey,
child: Center(
child: Padding(
padding: const EdgeInsets.symmetric(horizontal: 24),
child: Column(
mainAxisAlignment: MainAxisAlignment.center,
children: [
// ...
TextFormField(
// TextEditingControllerを設定
controller: _emailController,
decoration: InputDecoration(
labelText: 'メールアドレス',
),
keyboardType: TextInputType.emailAddress,
// メールアドレス用のバリデーション
validator: (String? value) {
// ...
},
),
SizedBox(height: 8),
TextFormField(
// TextEditingControllerを設定
controller: _passwordController,
decoration: InputDecoration(
labelText: 'パスワード',
),
keyboardType: TextInputType.visiblePassword,
obscureText: true,
validator: (String? value) {
// ...
},
),
// ...
SizedBox(
width: double.infinity,
child: ElevatedButton(
onPressed: () => _onSignUp(),
child: Text('新規登録'),
),
),
],
),
),
),
),
);
}
void _onSignIn() {
// ...
}
// 内部で非同期処理(Future)を扱っているのでasyncを付ける
// この関数自体も非同期処理となるので返り値もFutureとする
Future<void> _onSignUp() async {
try {
if (_formKey.currentState?.validate() != true) {
return;
}
// メールアドレス・パスワードで新規登録
// TextEditingControllerから入力内容を取得
// Authenticationを使った複雑な処理はライブラリがやってくれる
final String email = _emailController.text;
final String password = _passwordController.text;
await FirebaseAuth.instance
.createUserWithEmailAndPassword(email: email, password: password);
// 画像一覧画面に切り替え
Navigator.of(context).pushReplacement(
MaterialPageRoute(
builder: (_) => PhotoListScreen(),
),
);
} catch (e) {
// 失敗したらエラーメッセージを表示
await showDialog(
context: context,
builder: (context) {
return AlertDialog(
title: Text('エラー'),
content: Text(e.toString()),
);
},
);
}
}
}