mirror of
https://github.com/cypherstack/stack_wallet.git
synced 2025-01-11 05:04:35 +00:00
do not partially open monero wallets at the same time on startup
This commit is contained in:
parent
bdab241d7e
commit
57add19e88
4 changed files with 86 additions and 36 deletions
|
@ -60,6 +60,14 @@ class CoinWalletsTable extends ConsumerWidget {
|
||||||
ref.read(currentWalletIdProvider.state).state =
|
ref.read(currentWalletIdProvider.state).state =
|
||||||
walletIds[i];
|
walletIds[i];
|
||||||
|
|
||||||
|
final manager = ref
|
||||||
|
.read(walletsChangeNotifierProvider)
|
||||||
|
.getManager(walletIds[i]);
|
||||||
|
if (manager.coin == Coin.monero ||
|
||||||
|
manager.coin == Coin.wownero) {
|
||||||
|
await manager.initializeExisting();
|
||||||
|
}
|
||||||
|
|
||||||
await Navigator.of(context).pushNamed(
|
await Navigator.of(context).pushNamed(
|
||||||
DesktopWalletView.routeName,
|
DesktopWalletView.routeName,
|
||||||
arguments: walletIds[i],
|
arguments: walletIds[i],
|
||||||
|
|
|
@ -792,27 +792,48 @@ class MoneroWallet extends CoinServiceAPI {
|
||||||
}
|
}
|
||||||
};
|
};
|
||||||
|
|
||||||
|
Future<void> _updateCachedBalance(int sats) async {
|
||||||
|
await DB.instance.put<dynamic>(
|
||||||
|
boxName: walletId,
|
||||||
|
key: "cachedMoneroBalanceSats",
|
||||||
|
value: sats,
|
||||||
|
);
|
||||||
|
}
|
||||||
|
|
||||||
|
int _getCachedBalance() =>
|
||||||
|
DB.instance.get<dynamic>(
|
||||||
|
boxName: walletId,
|
||||||
|
key: "cachedMoneroBalanceSats",
|
||||||
|
) as int? ??
|
||||||
|
0;
|
||||||
|
|
||||||
@override
|
@override
|
||||||
Future<Decimal> get totalBalance async {
|
Future<Decimal> get totalBalance async {
|
||||||
final balanceEntries = walletBase?.balance?.entries;
|
try {
|
||||||
if (balanceEntries != null) {
|
final balanceEntries = walletBase?.balance?.entries;
|
||||||
int bal = 0;
|
if (balanceEntries != null) {
|
||||||
for (var element in balanceEntries) {
|
int bal = 0;
|
||||||
bal = bal + element.value.fullBalance;
|
for (var element in balanceEntries) {
|
||||||
}
|
bal = bal + element.value.fullBalance;
|
||||||
return Format.satoshisToAmount(bal, coin: coin);
|
}
|
||||||
} else {
|
await _updateCachedBalance(bal);
|
||||||
final transactions = walletBase!.transactionHistory!.transactions;
|
return Format.satoshisToAmount(bal, coin: coin);
|
||||||
int transactionBalance = 0;
|
} else {
|
||||||
for (var tx in transactions!.entries) {
|
final transactions = walletBase!.transactionHistory!.transactions;
|
||||||
if (tx.value.direction == TransactionDirection.incoming) {
|
int transactionBalance = 0;
|
||||||
transactionBalance += tx.value.amount!;
|
for (var tx in transactions!.entries) {
|
||||||
} else {
|
if (tx.value.direction == TransactionDirection.incoming) {
|
||||||
transactionBalance += -tx.value.amount! - tx.value.fee!;
|
transactionBalance += tx.value.amount!;
|
||||||
|
} else {
|
||||||
|
transactionBalance += -tx.value.amount! - tx.value.fee!;
|
||||||
|
}
|
||||||
}
|
}
|
||||||
}
|
|
||||||
|
|
||||||
return Format.satoshisToAmount(transactionBalance, coin: coin);
|
await _updateCachedBalance(transactionBalance);
|
||||||
|
return Format.satoshisToAmount(transactionBalance, coin: coin);
|
||||||
|
}
|
||||||
|
} catch (_) {
|
||||||
|
return Format.satoshisToAmount(_getCachedBalance(), coin: coin);
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
|
||||||
|
|
|
@ -820,27 +820,48 @@ class WowneroWallet extends CoinServiceAPI {
|
||||||
}
|
}
|
||||||
};
|
};
|
||||||
|
|
||||||
|
Future<void> _updateCachedBalance(int sats) async {
|
||||||
|
await DB.instance.put<dynamic>(
|
||||||
|
boxName: walletId,
|
||||||
|
key: "cachedWowneroBalanceSats",
|
||||||
|
value: sats,
|
||||||
|
);
|
||||||
|
}
|
||||||
|
|
||||||
|
int _getCachedBalance() =>
|
||||||
|
DB.instance.get<dynamic>(
|
||||||
|
boxName: walletId,
|
||||||
|
key: "cachedWowneroBalanceSats",
|
||||||
|
) as int? ??
|
||||||
|
0;
|
||||||
|
|
||||||
@override
|
@override
|
||||||
Future<Decimal> get totalBalance async {
|
Future<Decimal> get totalBalance async {
|
||||||
final balanceEntries = walletBase?.balance?.entries;
|
try {
|
||||||
if (balanceEntries != null) {
|
final balanceEntries = walletBase?.balance?.entries;
|
||||||
int bal = 0;
|
if (balanceEntries != null) {
|
||||||
for (var element in balanceEntries) {
|
int bal = 0;
|
||||||
bal = bal + element.value.fullBalance;
|
for (var element in balanceEntries) {
|
||||||
}
|
bal = bal + element.value.fullBalance;
|
||||||
return Format.satoshisToAmount(bal, coin: coin);
|
}
|
||||||
} else {
|
await _updateCachedBalance(bal);
|
||||||
final transactions = walletBase!.transactionHistory!.transactions;
|
return Format.satoshisToAmount(bal, coin: coin);
|
||||||
int transactionBalance = 0;
|
} else {
|
||||||
for (var tx in transactions!.entries) {
|
final transactions = walletBase!.transactionHistory!.transactions;
|
||||||
if (tx.value.direction == TransactionDirection.incoming) {
|
int transactionBalance = 0;
|
||||||
transactionBalance += tx.value.amount!;
|
for (var tx in transactions!.entries) {
|
||||||
} else {
|
if (tx.value.direction == TransactionDirection.incoming) {
|
||||||
transactionBalance += -tx.value.amount! - tx.value.fee!;
|
transactionBalance += tx.value.amount!;
|
||||||
|
} else {
|
||||||
|
transactionBalance += -tx.value.amount! - tx.value.fee!;
|
||||||
|
}
|
||||||
}
|
}
|
||||||
}
|
|
||||||
|
|
||||||
return Format.satoshisToAmount(transactionBalance, coin: coin);
|
await _updateCachedBalance(transactionBalance);
|
||||||
|
return Format.satoshisToAmount(transactionBalance, coin: coin);
|
||||||
|
}
|
||||||
|
} catch (_) {
|
||||||
|
return Format.satoshisToAmount(_getCachedBalance(), coin: coin);
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
|
||||||
|
|
|
@ -238,7 +238,7 @@ class Wallets extends ChangeNotifier {
|
||||||
walletIdsToEnableAutoSync.contains(manager.walletId);
|
walletIdsToEnableAutoSync.contains(manager.walletId);
|
||||||
|
|
||||||
if (manager.coin == Coin.monero || manager.coin == Coin.wownero) {
|
if (manager.coin == Coin.monero || manager.coin == Coin.wownero) {
|
||||||
walletsToInitLinearly.add(Tuple2(manager, shouldSetAutoSync));
|
// walletsToInitLinearly.add(Tuple2(manager, shouldSetAutoSync));
|
||||||
} else {
|
} else {
|
||||||
walletInitFutures.add(manager.initializeExisting().then((value) {
|
walletInitFutures.add(manager.initializeExisting().then((value) {
|
||||||
if (shouldSetAutoSync) {
|
if (shouldSetAutoSync) {
|
||||||
|
@ -328,7 +328,7 @@ class Wallets extends ChangeNotifier {
|
||||||
walletIdsToEnableAutoSync.contains(manager.walletId);
|
walletIdsToEnableAutoSync.contains(manager.walletId);
|
||||||
|
|
||||||
if (manager.coin == Coin.monero || manager.coin == Coin.wownero) {
|
if (manager.coin == Coin.monero || manager.coin == Coin.wownero) {
|
||||||
walletsToInitLinearly.add(Tuple2(manager, shouldSetAutoSync));
|
// walletsToInitLinearly.add(Tuple2(manager, shouldSetAutoSync));
|
||||||
} else {
|
} else {
|
||||||
walletInitFutures.add(manager.initializeExisting().then((value) {
|
walletInitFutures.add(manager.initializeExisting().then((value) {
|
||||||
if (shouldSetAutoSync) {
|
if (shouldSetAutoSync) {
|
||||||
|
|
Loading…
Reference in a new issue