mirror of
https://github.com/cake-tech/cake_wallet.git
synced 2024-11-01 09:57:46 +00:00
71444219be
* - push change pin page as a replacement for auth page to avoid closing it once its opened - Add cool-down duration after popping flushbars and pushing new routes
156 lines
5 KiB
Dart
156 lines
5 KiB
Dart
import 'package:another_flushbar/flushbar.dart';
|
|
import 'package:cake_wallet/utils/show_bar.dart';
|
|
import 'package:mobx/mobx.dart';
|
|
import 'package:flutter/material.dart';
|
|
import 'package:flutter/cupertino.dart';
|
|
import 'package:cake_wallet/generated/i18n.dart';
|
|
import 'package:cake_wallet/view_model/auth_state.dart';
|
|
import 'package:cake_wallet/view_model/auth_view_model.dart';
|
|
import 'package:cake_wallet/src/screens/pin_code/pin_code.dart';
|
|
import 'package:cake_wallet/src/screens/pin_code/pin_code_widget.dart';
|
|
import 'package:cake_wallet/core/execution_state.dart';
|
|
|
|
typedef OnAuthenticationFinished = void Function(bool, AuthPageState);
|
|
|
|
class AuthPage extends StatefulWidget {
|
|
AuthPage(this.authViewModel,
|
|
{required this.onAuthenticationFinished,
|
|
this.closable = true});
|
|
|
|
final AuthViewModel authViewModel;
|
|
final OnAuthenticationFinished onAuthenticationFinished;
|
|
final bool closable;
|
|
|
|
@override
|
|
AuthPageState createState() => AuthPageState();
|
|
}
|
|
|
|
class AuthPageState extends State<AuthPage> {
|
|
final _key = GlobalKey<ScaffoldState>();
|
|
final _pinCodeKey = GlobalKey<PinCodeState>();
|
|
final _backArrowImageDarkTheme =
|
|
Image.asset('assets/images/close_button.png');
|
|
ReactionDisposer? _reaction;
|
|
Flushbar<void>? _authBar;
|
|
Flushbar<void>? _progressBar;
|
|
|
|
@override
|
|
void initState() {
|
|
_reaction ??=
|
|
reaction((_) => widget.authViewModel.state, (ExecutionState state) {
|
|
if (state is ExecutedSuccessfullyState) {
|
|
WidgetsBinding.instance.addPostFrameCallback((_) {
|
|
widget.onAuthenticationFinished(true, this);
|
|
});
|
|
setState(() {});
|
|
}
|
|
|
|
if (state is IsExecutingState) {
|
|
WidgetsBinding.instance.addPostFrameCallback((_) {
|
|
// null duration to make it indefinite until its disposed
|
|
_authBar =
|
|
createBar<void>(S.of(context).authentication, duration: null)
|
|
..show(context);
|
|
});
|
|
}
|
|
|
|
if (state is FailureState) {
|
|
print('X');
|
|
print(state.error);
|
|
WidgetsBinding.instance.addPostFrameCallback((_) async {
|
|
_pinCodeKey.currentState?.clear();
|
|
dismissFlushBar(_authBar);
|
|
showBar<void>(
|
|
context, S.of(context).failed_authentication(state.error));
|
|
|
|
widget.onAuthenticationFinished(false, this);
|
|
});
|
|
}
|
|
|
|
if (state is AuthenticationBanned) {
|
|
WidgetsBinding.instance.addPostFrameCallback((_) async {
|
|
_pinCodeKey.currentState?.clear();
|
|
dismissFlushBar(_authBar);
|
|
showBar<void>(
|
|
context, S.of(context).failed_authentication(state.error));
|
|
|
|
widget.onAuthenticationFinished(false, this);
|
|
});
|
|
}
|
|
});
|
|
|
|
if (widget.authViewModel.isBiometricalAuthenticationAllowed) {
|
|
WidgetsBinding.instance.addPostFrameCallback((_) async {
|
|
await Future<void>.delayed(Duration(milliseconds: 100));
|
|
await widget.authViewModel.biometricAuth();
|
|
});
|
|
}
|
|
|
|
super.initState();
|
|
}
|
|
|
|
@override
|
|
void dispose() {
|
|
_reaction?.reaction.dispose();
|
|
super.dispose();
|
|
}
|
|
|
|
void changeProcessText(String text) {
|
|
dismissFlushBar(_authBar);
|
|
_progressBar = createBar<void>(text, duration: null)
|
|
..show(_key.currentContext!);
|
|
}
|
|
|
|
void hideProgressText() {
|
|
dismissFlushBar(_progressBar);
|
|
_progressBar = null;
|
|
}
|
|
|
|
Future<void> close({String? route, dynamic arguments}) async {
|
|
if (_key.currentContext == null) {
|
|
throw Exception('Key context is null. Should be not happened');
|
|
}
|
|
|
|
/// not the best scenario, but WidgetsBinding is not behaving correctly on Android
|
|
await Future<void>.delayed(Duration(milliseconds: 50));
|
|
await _authBar?.dismiss();
|
|
await Future<void>.delayed(Duration(milliseconds: 50));
|
|
await _progressBar?.dismiss();
|
|
await Future<void>.delayed(Duration(milliseconds: 50));
|
|
if (route != null) {
|
|
Navigator.of(_key.currentContext!).pushReplacementNamed(route, arguments: arguments);
|
|
} else {
|
|
Navigator.of(_key.currentContext!).pop();
|
|
}
|
|
}
|
|
|
|
@override
|
|
Widget build(BuildContext context) {
|
|
return Scaffold(
|
|
key: _key,
|
|
appBar: CupertinoNavigationBar(
|
|
leading: widget.closable
|
|
? Container(
|
|
padding: EdgeInsets.only(top: 10),
|
|
child: SizedBox(
|
|
height: 37,
|
|
width: 37,
|
|
child: InkWell(
|
|
onTap: () => Navigator.of(context).pop(),
|
|
child: _backArrowImageDarkTheme,
|
|
),
|
|
))
|
|
: Container(),
|
|
backgroundColor: Theme.of(context).backgroundColor,
|
|
border: null),
|
|
resizeToAvoidBottomInset: false,
|
|
body: PinCode((pin, _) => widget.authViewModel.auth(password: pin),
|
|
(_) => null, widget.authViewModel.pinLength, false, _pinCodeKey));
|
|
}
|
|
|
|
void dismissFlushBar(Flushbar<dynamic>? bar) {
|
|
WidgetsBinding.instance.addPostFrameCallback((_) async {
|
|
await bar?.dismiss();
|
|
});
|
|
}
|
|
}
|