mirror of
https://github.com/cake-tech/cake_wallet.git
synced 2025-01-20 17:54:41 +00:00
00c97c74b8
* CW-462 Mark Places to integrate Polyseed * CW-462 Add Restore from Polyseed * CW-462 Add Restore from Polyseed * CW-462 Add new Monero date-height pairs * CW-462 Little Cleanup * CW-462 Ups I missed that Debug line :/ * CW-462 Fix Polyseed not showing in Wallet-Seed/Keys Page * CW-462 Prepare for Wallet creation * CW-462 Fix merge conflict * CW-462 Fix generating monero.dart * CW-462 Add Polyseed generation * CW-462 Add Polyseed Languages to SeedLanguagePicker * CW-462 Apply requested changes * CW-462 Minor bug fixes in restore screen * Update wallet_restore_from_seed_form.dart * CW-462 Minor Bugfix * CW-462 Fix Restore from QR for Polyseeds * CW-462 Fix null-check-operator exception for Polyseeds and minor inconveniences * CW-462 Fix minor inconveniences * Fix conflicts and review comments and wrap unspent issue with try and catch with reporting failure --------- Co-authored-by: OmarHatem <omarh.ismail1@gmail.com>
63 lines
2.5 KiB
Dart
63 lines
2.5 KiB
Dart
import 'package:cake_wallet/ethereum/ethereum.dart';
|
|
import 'package:cake_wallet/bitcoin_cash/bitcoin_cash.dart';
|
|
import 'package:hive/hive.dart';
|
|
import 'package:mobx/mobx.dart';
|
|
import 'package:cake_wallet/monero/monero.dart';
|
|
import 'package:cake_wallet/nano/nano.dart';
|
|
import 'package:cake_wallet/store/app_store.dart';
|
|
import 'package:cw_core/wallet_base.dart';
|
|
import 'package:cake_wallet/core/wallet_creation_service.dart';
|
|
import 'package:cw_core/wallet_credentials.dart';
|
|
import 'package:cw_core/wallet_info.dart';
|
|
import 'package:cw_core/wallet_type.dart';
|
|
import 'package:cake_wallet/view_model/wallet_creation_vm.dart';
|
|
import 'package:cake_wallet/bitcoin/bitcoin.dart';
|
|
import 'package:cake_wallet/haven/haven.dart';
|
|
|
|
part 'wallet_new_vm.g.dart';
|
|
|
|
class WalletNewVM = WalletNewVMBase with _$WalletNewVM;
|
|
|
|
abstract class WalletNewVMBase extends WalletCreationVM with Store {
|
|
WalletNewVMBase(AppStore appStore, WalletCreationService walletCreationService,
|
|
Box<WalletInfo> walletInfoSource,
|
|
{required WalletType type})
|
|
: selectedMnemonicLanguage = '',
|
|
super(appStore, walletInfoSource, walletCreationService, type: type, isRecovery: false);
|
|
|
|
@observable
|
|
String selectedMnemonicLanguage;
|
|
|
|
bool get hasLanguageSelector => type == WalletType.monero || type == WalletType.haven;
|
|
|
|
@override
|
|
WalletCredentials getCredentials(dynamic _options) {
|
|
final options = _options as List<dynamic>;
|
|
switch (type) {
|
|
case WalletType.monero:
|
|
return monero!.createMoneroNewWalletCredentials(
|
|
name: name, language: options.first as String, isPolyseed: options.last as bool);
|
|
case WalletType.bitcoin:
|
|
return bitcoin!.createBitcoinNewWalletCredentials(name: name);
|
|
case WalletType.litecoin:
|
|
return bitcoin!.createBitcoinNewWalletCredentials(name: name);
|
|
case WalletType.haven:
|
|
return haven!.createHavenNewWalletCredentials(
|
|
name: name, language: options.first as String);
|
|
case WalletType.ethereum:
|
|
return ethereum!.createEthereumNewWalletCredentials(name: name);
|
|
case WalletType.bitcoinCash:
|
|
return bitcoinCash!.createBitcoinCashNewWalletCredentials(name: name);
|
|
case WalletType.nano:
|
|
return nano!.createNanoNewWalletCredentials(name: name);
|
|
default:
|
|
throw Exception('Unexpected type: ${type.toString()}');
|
|
}
|
|
}
|
|
|
|
@override
|
|
Future<WalletBase> process(WalletCredentials credentials) async {
|
|
walletCreationService.changeWalletType(type: type);
|
|
return walletCreationService.create(credentials);
|
|
}
|
|
}
|