WIP rework of anon balance calc

This commit is contained in:
julian 2023-05-16 15:15:08 -06:00
parent 02fe1103cb
commit 9725ed32be

View file

@ -2432,61 +2432,54 @@ class FiroWallet extends CoinServiceAPI
lelantusCoins.removeWhere((element) =>
element.values.any((elementCoin) => elementCoin.value == 0));
}
final data = await _txnData;
final lData = await db
.getTransactions(walletId)
.filter()
.isLelantusEqualTo(true)
.findAll();
final currentChainHeight = await chainHeight;
final jindexes = firoGetJIndex();
int intLelantusBalance = 0;
int unconfirmedLelantusBalance = 0;
for (var element in lelantusCoins) {
element.forEach((key, value) {
isar_models.Transaction? tx;
try {
tx = data.firstWhere((e) => e.txid == value.txId);
} catch (_) {
tx = null;
}
for (final element in lelantusCoins) {
element.forEach((key, lelantusCoin) {
isar_models.Transaction? txn = db.isar.transactions
.where()
.txidWalletIdEqualTo(
lelantusCoin.txId,
walletId,
)
.findFirstSync();
isar_models.Transaction? ltx;
try {
ltx = lData.firstWhere((e) => e.txid == value.txId);
} catch (_) {
ltx = null;
}
// Logging.instance.log("$value $tx $ltx");
if (!jindexes!.contains(value.index) && tx == null) {
if (!value.isUsed &&
ltx != null &&
ltx.isConfirmed(currentChainHeight, MINIMUM_CONFIRMATIONS)) {
if (txn == null) {
// TODO: ??????????????????????????????????????
} else {
bool isLelantus = txn.isLelantus == true;
if (!jindexes!.contains(lelantusCoin.index) && isLelantus) {
if (!lelantusCoin.isUsed &&
txn.isConfirmed(currentChainHeight, MINIMUM_CONFIRMATIONS)) {
// mint tx, add value to balance
intLelantusBalance += value.value;
intLelantusBalance += lelantusCoin.value;
} /* else {
// This coin is not confirmed and may be replaced
}*/
} else if (jindexes.contains(value.index) &&
tx == null &&
!value.isUsed &&
ltx != null &&
!ltx.isConfirmed(currentChainHeight, MINIMUM_CONFIRMATIONS)) {
unconfirmedLelantusBalance += value.value;
} else if (jindexes.contains(value.index) && !value.isUsed) {
intLelantusBalance += value.value;
} else if (!value.isUsed &&
(tx == null
} else if (jindexes.contains(lelantusCoin.index) &&
isLelantus &&
!lelantusCoin.isUsed &&
!txn.isConfirmed(currentChainHeight, MINIMUM_CONFIRMATIONS)) {
unconfirmedLelantusBalance += lelantusCoin.value;
} else if (jindexes.contains(lelantusCoin.index) &&
!lelantusCoin.isUsed) {
intLelantusBalance += lelantusCoin.value;
} else if (!lelantusCoin.isUsed &&
(txn.isLelantus == true
? true
: tx.isConfirmed(currentChainHeight, MINIMUM_CONFIRMATIONS) !=
: txn.isConfirmed(
currentChainHeight, MINIMUM_CONFIRMATIONS) !=
false)) {
intLelantusBalance += value.value;
} else if (tx != null &&
tx.isConfirmed(currentChainHeight, MINIMUM_CONFIRMATIONS) ==
intLelantusBalance += lelantusCoin.value;
} else if (!isLelantus &&
txn.isConfirmed(currentChainHeight, MINIMUM_CONFIRMATIONS) ==
false) {
unconfirmedLelantusBalance += value.value;
unconfirmedLelantusBalance += lelantusCoin.value;
}
}
});
}