flutter_login_widget/lib/plugins/login/forgot_password.dart

161 lines
5.6 KiB
Dart
Raw Normal View History

2022-09-20 16:32:46 +02:00
import 'package:flutter/material.dart';
import 'package:flutter_login/flutter_login_view.dart';
import '../form/inputs/validators/email_validator.dart';
class ForgotPassword extends StatefulWidget {
const ForgotPassword({super.key});
2022-09-20 16:32:46 +02:00
@override
ForgotPasswordState createState() => ForgotPasswordState();
2022-09-20 16:32:46 +02:00
}
class ForgotPasswordState extends State<ForgotPassword> {
2022-09-20 16:32:46 +02:00
String? email;
bool showError = false;
@override
Widget build(BuildContext context) {
void showAlert({
required String title,
required String text,
required String buttonTitle,
VoidCallback? buttonAction,
}) =>
showDialog<String>(
context: context,
builder: (BuildContext context) => AlertDialog(
title: Text(title),
content: Text(text),
actions: <Widget>[
TextButton(
onPressed: () {
Navigator.pop(context);
if (buttonAction != null) {
buttonAction();
}
},
child: Text(buttonTitle),
),
],
),
);
return Material(
child: Scaffold(
2022-09-22 15:57:02 +02:00
backgroundColor: Theme.of(context).backgroundColor,
appBar: AppBar(
title: Text(
context.translate('forgot_password.text.title'),
),
),
2022-09-21 14:58:46 +02:00
body: Column(
children: [
Expanded(
child: ListView(
children: [
2022-09-21 14:58:46 +02:00
Padding(
padding: const EdgeInsets.all(30.0),
child: Text(
context.translate('forgot_password.text.body'),
style: Theme.of(context).textTheme.subtitle1,
textAlign: TextAlign.left,
),
),
Padding(
padding: const EdgeInsets.only(left: 30, right: 30),
child: Column(
children: [
const Padding(
padding: EdgeInsets.only(bottom: 20),
),
2022-09-21 14:58:46 +02:00
context.login().config.appTheme.inputs.textField(
title: context.translate(
'forgot_password.input.email',
),
2022-09-21 14:58:46 +02:00
validators: [
EmailValidator(
errorMessage: context.translate(
'forgot_password.error.invalid_email',
),
2022-09-21 14:58:46 +02:00
)
2022-09-20 16:32:46 +02:00
],
2022-09-21 14:58:46 +02:00
onChange: (value, valid) {
setState(() {
showError = false;
});
if (valid) {
email = value;
}
},
),
if (showError) ...[
Text(
context.translate(
'forgot_password.error.email_does_not_exist',
),
style:
Theme.of(context).textTheme.bodyText2!.copyWith(
color: Theme.of(context).errorColor,
),
2022-09-20 16:32:46 +02:00
),
2022-09-21 14:58:46 +02:00
],
const Padding(
padding: EdgeInsets.only(bottom: 30),
),
],
2022-09-20 16:32:46 +02:00
),
),
2022-09-21 14:58:46 +02:00
],
),
),
Container(
margin: const EdgeInsets.symmetric(horizontal: 30),
padding: const EdgeInsets.only(bottom: 40.0),
child: context.login().config.appTheme.buttons.primaryButton(
context: context,
child: Text(
context.translate('forgot_password.button.submit'),
style: Theme.of(context).textTheme.button,
),
onPressed: () async {
if (email != null) {
setState(() {
showError = false;
});
2022-09-20 16:32:46 +02:00
2022-09-21 14:58:46 +02:00
var result = await context
.loginRepository()
.forgotPassword(email!);
2022-09-20 16:32:46 +02:00
2022-09-21 14:58:46 +02:00
if (result) {
showAlert(
title: context.translate(
'forgot_password.dialog.text.title',
),
text: context.translate(
'forgot_password.dialog.text.body',
arguments: [email],
),
buttonTitle: context.translate(
'forgot_password.dialog.text.button',
),
buttonAction: () {
Navigator.pop(context);
},
);
} else {
setState(() {
showError = true;
});
}
}
},
),
),
2022-09-21 14:58:46 +02:00
],
),
),
);
}
2022-09-20 16:32:46 +02:00
}