mirror of
https://github.com/cake-tech/cake_wallet.git
synced 2025-01-22 02:34:59 +00:00
chore: refactoring code
This commit is contained in:
parent
591ded61f6
commit
82c32a0910
1 changed files with 26 additions and 23 deletions
|
@ -20,34 +20,37 @@ void startAuthenticationStateChange(
|
||||||
final state = authenticationStore.state;
|
final state = authenticationStore.state;
|
||||||
|
|
||||||
if (state == AuthenticationState.installed) {
|
if (state == AuthenticationState.installed) {
|
||||||
|
await _loadCurrentWallet();
|
||||||
|
return;
|
||||||
|
}
|
||||||
|
|
||||||
|
if (state == AuthenticationState.allowed) {
|
||||||
|
await _navigateBasedOnWalletType(navigatorKey);
|
||||||
|
}
|
||||||
|
},
|
||||||
|
);
|
||||||
|
}
|
||||||
|
|
||||||
|
Future<void> _loadCurrentWallet() async {
|
||||||
try {
|
try {
|
||||||
await loadCurrentWallet();
|
await loadCurrentWallet();
|
||||||
} catch (error, stack) {
|
} catch (error, stack) {
|
||||||
loginError = error;
|
loginError = error;
|
||||||
ExceptionHandler.onError(FlutterErrorDetails(exception: error, stack: stack));
|
ExceptionHandler.onError(FlutterErrorDetails(exception: error, stack: stack));
|
||||||
}
|
}
|
||||||
return;
|
|
||||||
}
|
}
|
||||||
|
|
||||||
if (state == AuthenticationState.allowed) {
|
Future<void> _navigateBasedOnWalletType(GlobalKey<NavigatorState> navigatorKey) async {
|
||||||
final typeRaw =
|
final typeRaw = getIt.get<SharedPreferences>().getInt(PreferencesKey.currentWalletType) ?? 0;
|
||||||
getIt.get<SharedPreferences>().getInt(PreferencesKey.currentWalletType) ?? 0;
|
|
||||||
|
|
||||||
final type = deserializeFromInt(typeRaw);
|
final type = deserializeFromInt(typeRaw);
|
||||||
|
|
||||||
if (type == WalletType.haven) {
|
if (type == WalletType.haven) {
|
||||||
await navigatorKey.currentState!
|
await navigatorKey.currentState!
|
||||||
.pushNamedAndRemoveUntil(Routes.preSeed, (route) => false, arguments: type);
|
.pushNamedAndRemoveUntil(Routes.preSeed, (route) => false, arguments: type);
|
||||||
await navigatorKey.currentState!.pushNamed(Routes.seed, arguments: true);
|
await navigatorKey.currentState!.pushNamed(Routes.seed, arguments: true);
|
||||||
await navigatorKey.currentState!
|
await navigatorKey.currentState!.pushNamedAndRemoveUntil(Routes.welcome, (route) => false);
|
||||||
.pushNamedAndRemoveUntil(Routes.welcome, (route) => false);
|
|
||||||
return;
|
return;
|
||||||
} else {
|
} else {
|
||||||
await navigatorKey.currentState!
|
await navigatorKey.currentState!.pushNamedAndRemoveUntil(Routes.dashboard, (route) => false);
|
||||||
.pushNamedAndRemoveUntil(Routes.dashboard, (route) => false);
|
|
||||||
return;
|
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
},
|
|
||||||
);
|
|
||||||
}
|
|
||||||
|
|
Loading…
Reference in a new issue