mirror of
https://github.com/cake-tech/cake_wallet.git
synced 2025-01-19 09:15:11 +00:00
4e2e5e708c
* feat: Implement creating new BIP39 wallet with same seed used for other owned BIP39 wallets * feat: Use same seed for BIP39 Wallets * Update pre_existing_seeds_page.dart * Feat: BIP39 Same seed wallet creation using the Common Parent Wallet Strategy * feat: Finalize implementing preexisting seeds * feat: Implement shared bip39 wallet seed for Bitcoin wallet type * feat: Implement shared bip39 wallet seed for Litecoin wallet type * feat: Implement shared bip39 wallet seed for BitcoinCash wallet type * feat: Implement shared bip39 wallet seed for Nano wallet type, although disabled entry for now * fix: Remove non bip39 seed wallet type from listing * feat: Implement grouped and single wallets lists in wallets listing page and implement editing and saving group names * fix: Issue where the ontap always references the leadwallet, also make shared seed wallets section header only display when the multi wallet groups list is not empty * fix: Add translation and adjust the way the groups display * feat: Activate bip39 as an option for creating Nano wallet types * fix: Handle edgecase with creating new wallet with group address, handle case where only bip39 derivation type is allowed with child wallets, activate nano wallet type for shared seed * chore: Modify the UI to fit adjustment made on figma * fix: Disposed box triggering error in hive and causing wallet list view to display error * fix: Switch wallet groups title in wallets list page and also fix issue with renaming groups * Update lib/reactions/bip39_wallet_utils.dart [skip ci] Co-authored-by: Omar Hatem <omarh.ismail1@gmail.com> * Update lib/router.dart [skip ci] Co-authored-by: Omar Hatem <omarh.ismail1@gmail.com> * fix: Review fixes: Combine New Wallet Page Type arguments into a single model * fix: Review fixes: Add failure guard when fetching mnemonic for selected wallet in pre-existing wallets page * fix: Review fixes - Add loading indicator when mnemonic is being selected for wallet * fix: Review fixes - Modify variable name to avoid clashes * fix: Review fixes - Access WalletManager through dependency injection instead of service location * fix: Review fixes - Add testnet to convertWalletInfoToWalletlistItem function, and adjust according where used * fix: Review fixes - Add walletPassword to nano, tron and wownero wallets and confirm it is properly handled as it should be * fix: Remove leadWallet, modify filtering flow to reflect this and not depend on leadWallet, and adjust privacy settings * fix: Review Fixes - Modify restore flow to reflect current nature of bip39 as default for majority of wallet types * fix: QA Fixes - Modify preexisting page to display wallet group names if set, and display them in incremental order if not set * fix: Add wallet group description page and rename pre-existingseeds page to wallet group display page * fix: Product Fix - Rename pre-existing seeds file name to wallet group display filename * fix: Product fix - Separate multiwallets groups from single wallets and display separately * fix - Product Fix - Add empty state for wallet group listing when creating a new wallet, adjust CTAs across buttons relating to the flow also --------- Co-authored-by: Omar Hatem <omarh.ismail1@gmail.com>
221 lines
4.4 KiB
Dart
221 lines
4.4 KiB
Dart
import 'dart:async';
|
|
|
|
import 'package:cw_core/address_info.dart';
|
|
import 'package:cw_core/hive_type_ids.dart';
|
|
import 'package:cw_core/wallet_type.dart';
|
|
import 'package:hive/hive.dart';
|
|
|
|
part 'wallet_info.g.dart';
|
|
|
|
@HiveType(typeId: DERIVATION_TYPE_TYPE_ID)
|
|
enum DerivationType {
|
|
@HiveField(0)
|
|
unknown,
|
|
@HiveField(1)
|
|
def, // default is a reserved word
|
|
@HiveField(2)
|
|
nano,
|
|
@HiveField(3)
|
|
bip39,
|
|
@HiveField(4)
|
|
electrum,
|
|
}
|
|
|
|
@HiveType(typeId: HARDWARE_WALLET_TYPE_TYPE_ID)
|
|
enum HardwareWalletType {
|
|
@HiveField(0)
|
|
ledger,
|
|
}
|
|
|
|
@HiveType(typeId: DerivationInfo.typeId)
|
|
class DerivationInfo extends HiveObject {
|
|
DerivationInfo({
|
|
this.derivationType,
|
|
this.derivationPath,
|
|
this.balance = "",
|
|
this.address = "",
|
|
this.transactionsCount = 0,
|
|
this.scriptType,
|
|
this.description,
|
|
});
|
|
|
|
static const typeId = DERIVATION_INFO_TYPE_ID;
|
|
|
|
@HiveField(0, defaultValue: '')
|
|
String address;
|
|
|
|
@HiveField(1, defaultValue: '')
|
|
String balance;
|
|
|
|
@HiveField(2, defaultValue: 0)
|
|
int transactionsCount;
|
|
|
|
@HiveField(3)
|
|
DerivationType? derivationType;
|
|
|
|
@HiveField(4)
|
|
String? derivationPath;
|
|
|
|
@HiveField(5)
|
|
final String? scriptType;
|
|
|
|
@HiveField(6)
|
|
final String? description;
|
|
}
|
|
|
|
@HiveType(typeId: WalletInfo.typeId)
|
|
class WalletInfo extends HiveObject {
|
|
WalletInfo(
|
|
this.id,
|
|
this.name,
|
|
this.type,
|
|
this.isRecovery,
|
|
this.restoreHeight,
|
|
this.timestamp,
|
|
this.dirPath,
|
|
this.path,
|
|
this.address,
|
|
this.yatEid,
|
|
this.yatLastUsedAddressRaw,
|
|
this.showIntroCakePayCard,
|
|
this.derivationInfo,
|
|
this.hardwareWalletType,
|
|
this.parentAddress,
|
|
) : _yatLastUsedAddressController = StreamController<String>.broadcast();
|
|
|
|
factory WalletInfo.external({
|
|
required String id,
|
|
required String name,
|
|
required WalletType type,
|
|
required bool isRecovery,
|
|
required int restoreHeight,
|
|
required DateTime date,
|
|
required String dirPath,
|
|
required String path,
|
|
required String address,
|
|
bool? showIntroCakePayCard,
|
|
String yatEid = '',
|
|
String yatLastUsedAddressRaw = '',
|
|
DerivationInfo? derivationInfo,
|
|
HardwareWalletType? hardwareWalletType,
|
|
String? parentAddress,
|
|
}) {
|
|
return WalletInfo(
|
|
id,
|
|
name,
|
|
type,
|
|
isRecovery,
|
|
restoreHeight,
|
|
date.millisecondsSinceEpoch,
|
|
dirPath,
|
|
path,
|
|
address,
|
|
yatEid,
|
|
yatLastUsedAddressRaw,
|
|
showIntroCakePayCard,
|
|
derivationInfo,
|
|
hardwareWalletType,
|
|
parentAddress,
|
|
);
|
|
}
|
|
|
|
static const typeId = WALLET_INFO_TYPE_ID;
|
|
static const boxName = 'WalletInfo';
|
|
|
|
@HiveField(0, defaultValue: '')
|
|
String id;
|
|
|
|
@HiveField(1, defaultValue: '')
|
|
String name;
|
|
|
|
@HiveField(2)
|
|
WalletType type;
|
|
|
|
@HiveField(3, defaultValue: false)
|
|
bool isRecovery;
|
|
|
|
@HiveField(4, defaultValue: 0)
|
|
int restoreHeight;
|
|
|
|
@HiveField(5, defaultValue: 0)
|
|
int timestamp;
|
|
|
|
@HiveField(6, defaultValue: '')
|
|
String dirPath;
|
|
|
|
@HiveField(7, defaultValue: '')
|
|
String path;
|
|
|
|
@HiveField(8, defaultValue: '')
|
|
String address;
|
|
|
|
@HiveField(10)
|
|
Map<String, String>? addresses;
|
|
|
|
@HiveField(11)
|
|
String? yatEid;
|
|
|
|
@HiveField(12)
|
|
String? yatLastUsedAddressRaw;
|
|
|
|
@HiveField(13)
|
|
bool? showIntroCakePayCard;
|
|
|
|
@HiveField(14)
|
|
Map<int, List<AddressInfo>>? addressInfos;
|
|
|
|
@HiveField(15)
|
|
List<String>? usedAddresses;
|
|
|
|
@deprecated
|
|
@HiveField(16)
|
|
DerivationType? derivationType; // no longer used
|
|
|
|
@deprecated
|
|
@HiveField(17)
|
|
String? derivationPath; // no longer used
|
|
|
|
@HiveField(18)
|
|
String? addressPageType;
|
|
|
|
@HiveField(19)
|
|
String? network;
|
|
|
|
@HiveField(20)
|
|
DerivationInfo? derivationInfo;
|
|
|
|
@HiveField(21)
|
|
HardwareWalletType? hardwareWalletType;
|
|
|
|
@HiveField(22)
|
|
String? parentAddress;
|
|
|
|
String get yatLastUsedAddress => yatLastUsedAddressRaw ?? '';
|
|
|
|
set yatLastUsedAddress(String address) {
|
|
yatLastUsedAddressRaw = address;
|
|
_yatLastUsedAddressController.add(address);
|
|
}
|
|
|
|
String get yatEmojiId => yatEid ?? '';
|
|
|
|
bool get isShowIntroCakePayCard {
|
|
if (showIntroCakePayCard == null) {
|
|
return type != WalletType.haven;
|
|
}
|
|
return showIntroCakePayCard!;
|
|
}
|
|
|
|
bool get isHardwareWallet => hardwareWalletType != null;
|
|
|
|
DateTime get date => DateTime.fromMillisecondsSinceEpoch(timestamp);
|
|
|
|
Stream<String> get yatLastUsedAddressStream => _yatLastUsedAddressController.stream;
|
|
|
|
StreamController<String> _yatLastUsedAddressController;
|
|
|
|
Future<void> updateRestoreHeight(int height) async {
|
|
restoreHeight = height;
|
|
await save();
|
|
}
|
|
}
|