123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263646566676869707172737475767778798081828384858687888990919293949596979899100101102103104105106107108109110111112113114115116117118119120121122123124125126127128129130131132133134135136137138139140141142143144145146147148149150151152153154155156157158159160161162163164165166167168169170171172173174175176177178179180181182183184185186187188189190191192193194195196197198199200201202203204205206207208209210211212213214215216217218219220221222223224225226227228229230231232233234235236237238239240241242243244245246247248249250251252253254255256257258259260261262263264265266267268269270271272273274275276277278279280281282283284285286287288289290291292293294295296297298299300301302303304305306307 |
- import 'dart:async';
- import 'package:flutter/material.dart';
- import 'package:flutter_habit/common/BaseArchitectural.dart';
- import 'package:flutter_habit/common/I18N.dart';
- import 'package:flutter_habit/provider/UserProvider.dart';
- import 'package:flutter_habit/common/utils/VerificationUtils.dart';
- import 'package:flutter_habit/network/Repository.dart';
- import 'package:provider/provider.dart';
- class ModifyPwdPage extends StatelessWidget {
- @override
- Widget build(BuildContext context) {
- return MultiProvider(
- providers: [
- ChangeNotifierProvider<ModifyPwdPageService>(
- create: (_) => ModifyPwdPageService(context)),
- ChangeNotifierProvider<ModifyPwdPageModel>(
- create: (_) => ModifyPwdPageModel(context)),
- ],
- child: _ModifyPwdPageView(),
- );
- }
- }
- // model
- class ModifyPwdPageModel extends BaseModel {
- ModifyPwdPageModel(BuildContext context) : super(context);
- late bool isRequesting;
- late bool isPwdVisible;
- int? counter;
- GlobalKey emailFormKey = GlobalKey<FormState>();
- GlobalKey pwdFormKey = GlobalKey<FormState>();
- TextEditingController? emailController;
- TextEditingController? authCodeController;
- TextEditingController? pwdController;
- TextEditingController? pwdRepeatController;
- Timer? timer;
- @override
- void init(BuildContext context) {
-
- super.init(context);
- isRequesting = false;
- isPwdVisible = false;
- counter = 0;
- emailFormKey = GlobalKey<FormState>();
- pwdFormKey = GlobalKey<FormState>();
- emailController = TextEditingController();
- emailController!.text =
- Provider.of<UserProvider>(context, listen: false).email ?? "";
- authCodeController = TextEditingController();
- pwdController = TextEditingController();
- pwdRepeatController = TextEditingController();
- timer = null;
- }
- @override
- void dispose() {
-
- super.dispose();
- if (timer != null) {
- timer!.cancel();
- }
- }
- }
- // service
- class ModifyPwdPageService extends BaseProvider {
- ModifyPwdPageService(BuildContext context) : super(context);
- String? validatorEmail(String? v) {
- if (VerifyUtils.isEmail(v)) {
- return null;
- } else {
- return I18N.of("邮箱格式有误");
- }
- }
- String? validatorPwd(String? v) {
- if (VerifyUtils.isPassword(v)) {
- return null;
- } else {
- return I18N.of("字母开头,必须包含大小写字母,可以包含字母、数字、特殊符号\n长度为8~16位");
- }
- }
- String? validatorPwdRepeat(BuildContext context) {
- ModifyPwdPageModel model =
- Provider.of<ModifyPwdPageModel>(context, listen: false);
- if (model.pwdController!.text == model.pwdRepeatController!.text) {
- return null;
- } else {
- return I18N.of("两次输入不一致");
- }
- }
- void pwdChangeVisible(BuildContext context) {
- ModifyPwdPageModel model =
- Provider.of<ModifyPwdPageModel>(context, listen: false);
- model.isPwdVisible = !model.isPwdVisible;
- model.refresh();
- }
- Future<void> sendAuthCode(BuildContext context) async {
- ModifyPwdPageModel model =
- Provider.of<ModifyPwdPageModel>(context, listen: false);
- model.isRequesting = true;
- model.refresh();
- if ((model.emailFormKey.currentState as FormState).validate()) {
- bool isSuccess = await Repository.getInstance()!.sendAuthCode(
- context,
- model.emailController!.text,
- "RESET_PWD",
- );
- if (isSuccess) {
- startCounter(context);
- }
- }
- model.isRequesting = false;
- model.refresh();
- }
- void startCounter(BuildContext context) {
- ModifyPwdPageModel model =
- Provider.of<ModifyPwdPageModel>(context, listen: false);
- model.counter = 60;
- model.refresh();
- model.timer = Timer.periodic(Duration(seconds: 1), (t) {
- model.counter--;
- model.refresh();
- if (model.counter == 0) {
- model.timer!.cancel();
- }
- });
- }
- Future<void> pwdReset(BuildContext context) async {
- ModifyPwdPageModel model =
- Provider.of<ModifyPwdPageModel>(context, listen: false);
- model.isRequesting = true;
- model.refresh();
- if ((model.pwdFormKey.currentState as FormState).validate()) {
- bool isSuccess = await Repository.getInstance()!.resetPwd(
- context,
- model.authCodeController!.text,
- model.emailController!.text,
- model.pwdController!.text,
- );
- if (isSuccess) {
- Navigator.of(context).pop(model.emailController!.text);
- }
- }
- model.isRequesting = false;
- model.refresh();
- }
- }
- // view
- class _ModifyPwdPageView extends StatelessWidget {
- @override
- Widget build(BuildContext context) {
- ModifyPwdPageService service =
- Provider.of<ModifyPwdPageService>(context, listen: false);
- ModifyPwdPageModel model =
- Provider.of<ModifyPwdPageModel>(context, listen: true);
- return Scaffold(
- appBar: AppBar(
- title: Text(I18N.of("重置密码")),
- ),
- body: Padding(
- padding: EdgeInsets.all(16),
- child: ListView(
- children: <Widget>[
- model.isRequesting ? LinearProgressIndicator() : Container(),
- Center(
- child: Icon(
- Icons.refresh,
- size: 220,
- color: Theme.of(context).unselectedWidgetColor,
- ),
- ),
- Form(
- key: model.emailFormKey,
- child: Column(
- children: <Widget>[
- TextFormField(
- controller: model.emailController,
- enabled: !model.isRequesting &&
- Provider.of<UserProvider>(context, listen: false)
- .token ==
- null,
- decoration: InputDecoration(
- labelText: I18N.of("邮箱"),
- hintText: I18N.of("请输入您注册时的邮箱"),
- prefixIcon: Icon(Icons.email),
- ),
- validator: (v) => service.validatorEmail(v),
- ),
- TextFormField(
- controller: model.authCodeController,
- enabled: !model.isRequesting,
- keyboardType: TextInputType.number,
- decoration: InputDecoration(
- labelText: I18N.of("验证码"),
- hintText: I18N.of("请输入6位验证码"),
- prefixIcon: Icon(Icons.security),
- suffixIcon: Padding(
- padding: EdgeInsets.only(top: 10),
- child: ElevatedButton(
- child: Text(
- I18N.of("获取验证码") +
- ((model.counter != 0)
- ? " ${model.counter}"
- : ""),
- style: TextStyle(
- color: Theme.of(context).cardColor,
- ),
- ),
- style: ButtonStyle(
- backgroundColor: MaterialStateProperty.all(
- Theme.of(context).colorScheme.secondary),
- shape: MaterialStateProperty.all(
- RoundedRectangleBorder(
- borderRadius: BorderRadius.circular(5.0),
- ))),
- onPressed: model.isRequesting || model.counter != 0
- ? null
- : () => service.sendAuthCode(context),
- ),
- ),
- ),
- ),
- ],
- ),
- ),
- Form(
- key: model.pwdFormKey,
- child: Column(
- children: <Widget>[
- TextFormField(
- controller: model.pwdController,
- enabled: !model.isRequesting,
- obscureText: !model.isPwdVisible,
- decoration: InputDecoration(
- labelText: I18N.of("新密码"),
- hintText: I18N.of("请输入您的新密码"),
- prefixIcon: Icon(Icons.lock_outline),
- suffixIcon: IconButton(
- icon: Icon(
- model.isPwdVisible
- ? Icons.visibility
- : Icons.visibility_off,
- ),
- onPressed: () => service.pwdChangeVisible(context),
- ),
- ),
- validator: (v) => service.validatorPwd(v),
- ),
- TextFormField(
- controller: model.pwdRepeatController,
- enabled: !model.isRequesting,
- obscureText: true,
- decoration: InputDecoration(
- labelText: I18N.of("重复密码"),
- hintText: I18N.of("请重复输入您的新密码"),
- prefixIcon: Icon(Icons.lock),
- ),
- validator: (v) => service.validatorPwdRepeat(context),
- ),
- ],
- ),
- ),
- Padding(
- padding: EdgeInsets.only(top: 10),
- child: ElevatedButton(
- child: Text(
- I18N.of("提交"),
- style: TextStyle(
- color: Theme.of(context).cardColor,
- ),
- ),
- style: ButtonStyle(
- backgroundColor: MaterialStateProperty.all(
- Theme.of(context).colorScheme.secondary),
-
- shape: MaterialStateProperty.all(RoundedRectangleBorder(
- borderRadius: BorderRadius.circular(5.0),
- ))),
-
- onPressed:
- model.isRequesting ? null : () => service.pwdReset(context),
- ),
- ),
- ],
- ),
- ),
- );
- }
- }
|