mirror of
https://github.com/cake-tech/cake_wallet.git
synced 2024-11-16 17:27:37 +00:00
e5d99313eb
* CW-498 Call updateTransactions on account change * CW-498 Code Cleanup * CW-498 Add Wallet Address to trade to match transactions to trades * CW-498 Fix containsAddress to include only addresses of account * Handle nullability for fromWalletAddress --------- Co-authored-by: OmarHatem <omarh.ismail1@gmail.com>
91 lines
2.3 KiB
Dart
91 lines
2.3 KiB
Dart
import 'package:cw_core/wallet_addresses_with_account.dart';
|
|
import 'package:cw_core/wallet_info.dart';
|
|
import 'package:cw_core/account.dart';
|
|
import 'package:cw_haven/haven_account_list.dart';
|
|
import 'package:cw_haven/haven_subaddress_list.dart';
|
|
import 'package:cw_core/subaddress.dart';
|
|
import 'package:mobx/mobx.dart';
|
|
|
|
part 'haven_wallet_addresses.g.dart';
|
|
|
|
class HavenWalletAddresses = HavenWalletAddressesBase
|
|
with _$HavenWalletAddresses;
|
|
|
|
abstract class HavenWalletAddressesBase extends WalletAddressesWithAccount<Account> with Store {
|
|
HavenWalletAddressesBase(WalletInfo walletInfo)
|
|
: accountList = HavenAccountList(),
|
|
subaddressList = HavenSubaddressList(),
|
|
address = '',
|
|
super(walletInfo);
|
|
|
|
@override
|
|
@observable
|
|
String address;
|
|
|
|
// @override
|
|
@observable
|
|
Account? account;
|
|
|
|
@observable
|
|
Subaddress? subaddress;
|
|
|
|
HavenSubaddressList subaddressList;
|
|
|
|
HavenAccountList accountList;
|
|
|
|
@override
|
|
Future<void> init() async {
|
|
accountList.update();
|
|
account = accountList.accounts.first;
|
|
updateSubaddressList(accountIndex: account?.id ?? 0);
|
|
await updateAddressesInBox();
|
|
}
|
|
|
|
@override
|
|
Future<void> updateAddressesInBox() async {
|
|
try {
|
|
final _subaddressList = HavenSubaddressList();
|
|
|
|
addressesMap.clear();
|
|
|
|
accountList.accounts.forEach((account) {
|
|
_subaddressList.update(accountIndex: account.id);
|
|
_subaddressList.subaddresses.forEach((subaddress) {
|
|
addressesMap[subaddress.address] = subaddress.label;
|
|
});
|
|
});
|
|
|
|
await saveAddressesInBox();
|
|
} catch (e) {
|
|
print(e.toString());
|
|
}
|
|
}
|
|
|
|
bool validate() {
|
|
accountList.update();
|
|
final accountListLength = accountList.accounts.length;
|
|
|
|
if (accountListLength <= 0) {
|
|
return false;
|
|
}
|
|
|
|
subaddressList.update(accountIndex: accountList.accounts.first.id);
|
|
final subaddressListLength = subaddressList.subaddresses.length;
|
|
|
|
if (subaddressListLength <= 0) {
|
|
return false;
|
|
}
|
|
|
|
return true;
|
|
}
|
|
|
|
void updateSubaddressList({required int accountIndex}) {
|
|
subaddressList.update(accountIndex: accountIndex);
|
|
subaddress = subaddressList.subaddresses.first;
|
|
address = subaddress!.address;
|
|
}
|
|
|
|
@override
|
|
bool containsAddress(String address) =>
|
|
addressInfos[account?.id ?? 0]?.any((it) => it.address == address) ?? false;
|
|
}
|