mirror of
https://github.com/cake-tech/cake_wallet.git
synced 2024-11-01 18:07:44 +00:00
166 lines
5.2 KiB
Dart
166 lines
5.2 KiB
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/domain/common/biometric_auth.dart';
|
|
|
|
typedef OnAuthenticationFinished = void Function(bool, AuthPageState);
|
|
|
|
class AuthPage extends StatefulWidget {
|
|
AuthPage(
|
|
{@required this.allowBiometricalAuthentication,
|
|
this.onAuthenticationFinished,
|
|
this.authViewModel,
|
|
this.closable = true});
|
|
|
|
final AuthViewModel authViewModel;
|
|
final OnAuthenticationFinished onAuthenticationFinished;
|
|
final bool allowBiometricalAuthentication;
|
|
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/back_arrow_dark_theme.png');
|
|
ReactionDisposer _reaction;
|
|
|
|
@override
|
|
void initState() {
|
|
_reaction ??=
|
|
reaction((_) => widget.authViewModel.state, (AuthState state) {
|
|
if (state is AuthenticatedSuccessfully) {
|
|
WidgetsBinding.instance.addPostFrameCallback((_) {
|
|
if (widget.onAuthenticationFinished != null) {
|
|
widget.onAuthenticationFinished(true, this);
|
|
} else {
|
|
_key.currentState.showSnackBar(
|
|
SnackBar(
|
|
content: Text(S.of(context).authenticated),
|
|
backgroundColor: Colors.green,
|
|
),
|
|
);
|
|
}
|
|
});
|
|
}
|
|
|
|
if (state is AuthenticationInProgress) {
|
|
WidgetsBinding.instance.addPostFrameCallback((_) {
|
|
_key.currentState.showSnackBar(
|
|
SnackBar(
|
|
content: Text(S.of(context).authentication),
|
|
backgroundColor: Colors.green,
|
|
),
|
|
);
|
|
});
|
|
}
|
|
|
|
if (state is AuthenticationFailure) {
|
|
WidgetsBinding.instance.addPostFrameCallback((_) {
|
|
_pinCodeKey.currentState.clear();
|
|
_key.currentState.hideCurrentSnackBar();
|
|
_key.currentState.showSnackBar(
|
|
SnackBar(
|
|
content: Text(S.of(context).failed_authentication(state.error)),
|
|
backgroundColor: Colors.red,
|
|
),
|
|
);
|
|
|
|
if (widget.onAuthenticationFinished != null) {
|
|
widget.onAuthenticationFinished(false, this);
|
|
}
|
|
});
|
|
}
|
|
|
|
if (state is AuthenticationBanned) {
|
|
WidgetsBinding.instance.addPostFrameCallback((_) {
|
|
_pinCodeKey.currentState.clear();
|
|
_key.currentState.hideCurrentSnackBar();
|
|
_key.currentState.showSnackBar(
|
|
SnackBar(
|
|
content: Text(S.of(context).failed_authentication(state.error)),
|
|
backgroundColor: Colors.red,
|
|
),
|
|
);
|
|
|
|
if (widget.onAuthenticationFinished != null) {
|
|
widget.onAuthenticationFinished(false, this);
|
|
}
|
|
});
|
|
}
|
|
});
|
|
|
|
if (widget.allowBiometricalAuthentication) {
|
|
WidgetsBinding.instance.addPostFrameCallback((_) async {
|
|
print('post');
|
|
await Future<void>.delayed(Duration(milliseconds: 100));
|
|
print('after timeout');
|
|
final biometricAuth = BiometricAuth();
|
|
final isAuth = await biometricAuth.isAuthenticated();
|
|
|
|
if (isAuth) {
|
|
widget.authViewModel.biometricAuth();
|
|
_key.currentState.showSnackBar(
|
|
SnackBar(
|
|
content: Text(S.of(context).authenticated),
|
|
backgroundColor: Colors.green,
|
|
),
|
|
);
|
|
}
|
|
});
|
|
}
|
|
|
|
super.initState();
|
|
}
|
|
|
|
@override
|
|
void dispose() {
|
|
_reaction.reaction.dispose();
|
|
super.dispose();
|
|
}
|
|
|
|
void changeProcessText(String text) => _key.currentState.showSnackBar(
|
|
SnackBar(content: Text(text), backgroundColor: Colors.green));
|
|
|
|
void close() => Navigator.of(_key.currentContext).pop();
|
|
|
|
@override
|
|
Widget build(BuildContext context) {
|
|
print('start');
|
|
|
|
return Scaffold(
|
|
key: _key,
|
|
appBar: CupertinoNavigationBar(
|
|
leading: widget.closable
|
|
? SizedBox(
|
|
height: 37,
|
|
width: 20,
|
|
child: ButtonTheme(
|
|
minWidth: double.minPositive,
|
|
child: FlatButton(
|
|
highlightColor: Colors.transparent,
|
|
splashColor: Colors.transparent,
|
|
padding: EdgeInsets.all(0),
|
|
onPressed: () => Navigator.of(context).pop(),
|
|
child: _backArrowImageDarkTheme),
|
|
),
|
|
)
|
|
: Container(),
|
|
backgroundColor: Theme.of(context).backgroundColor,
|
|
border: null,
|
|
),
|
|
resizeToAvoidBottomPadding: false,
|
|
body: PinCode(
|
|
(pin, _) => widget.authViewModel
|
|
.auth(password: pin.fold('', (ac, val) => ac + '$val')),
|
|
false,
|
|
_pinCodeKey));
|
|
}
|
|
}
|