mirror of
https://github.com/cake-tech/cake_wallet.git
synced 2025-01-03 17:40:43 +00:00
c8cfc2cff1
* [skip-ci] show mweb confirmations, show last mweb balance while syncing * potential send-all fix * [skip-ci] undo fix that didn't work * [skip-ci] undo unnecessary changes * [skip ci] add export mweb logs screen * [skip ci] cleanup * confirmation fixes * catch electrum call errors * [skip ci] undo some changes * potential electrum fixes + mweb logs display only last 10000 characters * Add question mark and link to MWEB card * updates * show negative unconfirmed mweb balanaces + other fixes [skip ci] * error handling * [skip ci] [wip] check if node supports mweb * check fee before building tx * [skip ci] minor * [skip ci] minor * mweb node setting [wip] [skip ci] * prioritize mweb coins when selecting inputs from the pool * potential connection edgecase fix * translations + mweb node fixes * don't use mweb for exchange refund address * add peg in / out labels and make 6 confs only show up for peg in / out * bump bitcoin_base version to v9 * [skip ci] fix logs page * don't fetch txinfo for non-mweb addresses [skip ci] * fix non-mweb confirmations * rename always scan to enable mweb * Update litecoin_wallet_addresses.dart Co-authored-by: Omar Hatem <omarh.ismail1@gmail.com> * Update cw_mweb.dart Co-authored-by: Omar Hatem <omarh.ismail1@gmail.com> * [skip ci] review updates pt.1 * [skip ci] minor code cleanup * [skip ci] use exception handler * exception handling [skip ci] * [skip ci] exception handling * trigger build * pegout label fixes * fix showing change transactions on peg-out * minor code cleanup and minor peg-out fix * final balance fixes * non-mweb confirmations potential fix * [skip ci] wip * trigger build --------- Co-authored-by: tuxpizza <tuxsudo@tux.pizza> Co-authored-by: Omar Hatem <omarh.ismail1@gmail.com>
70 lines
2 KiB
Dart
70 lines
2 KiB
Dart
import 'dart:convert';
|
|
import 'package:cw_bitcoin/bitcoin_amount_format.dart';
|
|
import 'package:cw_core/balance.dart';
|
|
|
|
class ElectrumBalance extends Balance {
|
|
ElectrumBalance({
|
|
required this.confirmed,
|
|
required this.unconfirmed,
|
|
required this.frozen,
|
|
this.secondConfirmed = 0,
|
|
this.secondUnconfirmed = 0,
|
|
}) : super(
|
|
confirmed,
|
|
unconfirmed,
|
|
secondAvailable: secondConfirmed,
|
|
secondAdditional: secondUnconfirmed,
|
|
);
|
|
|
|
static ElectrumBalance? fromJSON(String? jsonSource) {
|
|
if (jsonSource == null) {
|
|
return null;
|
|
}
|
|
|
|
final decoded = json.decode(jsonSource) as Map;
|
|
|
|
return ElectrumBalance(
|
|
confirmed: decoded['confirmed'] as int? ?? 0,
|
|
unconfirmed: decoded['unconfirmed'] as int? ?? 0,
|
|
frozen: decoded['frozen'] as int? ?? 0,
|
|
secondConfirmed: decoded['secondConfirmed'] as int? ?? 0,
|
|
secondUnconfirmed: decoded['secondUnconfirmed'] as int? ?? 0,
|
|
);
|
|
}
|
|
|
|
int confirmed;
|
|
int unconfirmed;
|
|
final int frozen;
|
|
int secondConfirmed = 0;
|
|
int secondUnconfirmed = 0;
|
|
|
|
@override
|
|
String get formattedAvailableBalance => bitcoinAmountToString(amount: confirmed - frozen);
|
|
|
|
@override
|
|
String get formattedAdditionalBalance => bitcoinAmountToString(amount: unconfirmed);
|
|
|
|
@override
|
|
String get formattedUnAvailableBalance {
|
|
final frozenFormatted = bitcoinAmountToString(amount: frozen);
|
|
return frozenFormatted == '0.0' ? '' : frozenFormatted;
|
|
}
|
|
|
|
@override
|
|
String get formattedSecondAvailableBalance => bitcoinAmountToString(amount: secondConfirmed);
|
|
|
|
@override
|
|
String get formattedSecondAdditionalBalance => bitcoinAmountToString(amount: secondUnconfirmed);
|
|
|
|
@override
|
|
String get formattedFullAvailableBalance =>
|
|
bitcoinAmountToString(amount: confirmed + secondConfirmed - frozen);
|
|
|
|
String toJSON() => json.encode({
|
|
'confirmed': confirmed,
|
|
'unconfirmed': unconfirmed,
|
|
'frozen': frozen,
|
|
'secondConfirmed': secondConfirmed,
|
|
'secondUnconfirmed': secondUnconfirmed
|
|
});
|
|
}
|