2022-12-06 23:38:36 +00:00
|
|
|
import 'package:cake_wallet/entities/fiat_api_mode.dart';
|
2023-08-04 17:01:49 +00:00
|
|
|
import 'package:cake_wallet/entities/sort_balance_types.dart';
|
2021-12-24 12:37:24 +00:00
|
|
|
import 'package:cw_core/transaction_history.dart';
|
|
|
|
import 'package:cw_core/wallet_base.dart';
|
|
|
|
import 'package:cw_core/balance.dart';
|
|
|
|
import 'package:cw_core/crypto_currency.dart';
|
|
|
|
import 'package:cw_core/transaction_info.dart';
|
|
|
|
import 'package:cw_core/wallet_type.dart';
|
2021-01-11 17:15:27 +00:00
|
|
|
import 'package:cake_wallet/generated/i18n.dart';
|
2020-09-21 11:50:26 +00:00
|
|
|
import 'package:cake_wallet/entities/balance_display_mode.dart';
|
|
|
|
import 'package:cake_wallet/entities/calculate_fiat_amount.dart';
|
2020-09-24 09:16:13 +00:00
|
|
|
import 'package:cake_wallet/store/app_store.dart';
|
2020-07-23 12:20:52 +00:00
|
|
|
import 'package:cake_wallet/store/settings_store.dart';
|
2020-09-21 11:50:26 +00:00
|
|
|
import 'package:cake_wallet/store/dashboard/fiat_conversion_store.dart';
|
2020-07-23 12:20:52 +00:00
|
|
|
import 'package:mobx/mobx.dart';
|
|
|
|
|
|
|
|
part 'balance_view_model.g.dart';
|
|
|
|
|
2022-03-30 15:57:04 +00:00
|
|
|
class BalanceRecord {
|
2022-10-12 17:09:57 +00:00
|
|
|
const BalanceRecord({
|
|
|
|
required this.availableBalance,
|
|
|
|
required this.additionalBalance,
|
2023-04-20 13:46:41 +00:00
|
|
|
required this.frozenBalance,
|
2022-10-12 17:09:57 +00:00
|
|
|
required this.fiatAvailableBalance,
|
|
|
|
required this.fiatAdditionalBalance,
|
2023-04-20 13:46:41 +00:00
|
|
|
required this.fiatFrozenBalance,
|
2022-10-12 17:09:57 +00:00
|
|
|
required this.asset,
|
|
|
|
required this.formattedAssetTitle});
|
2022-03-30 15:57:04 +00:00
|
|
|
final String fiatAdditionalBalance;
|
|
|
|
final String fiatAvailableBalance;
|
2023-04-20 13:46:41 +00:00
|
|
|
final String fiatFrozenBalance;
|
2022-03-30 15:57:04 +00:00
|
|
|
final String additionalBalance;
|
|
|
|
final String availableBalance;
|
2023-04-20 13:46:41 +00:00
|
|
|
final String frozenBalance;
|
2022-03-30 15:57:04 +00:00
|
|
|
final CryptoCurrency asset;
|
|
|
|
final String formattedAssetTitle;
|
|
|
|
}
|
|
|
|
|
2020-07-23 12:20:52 +00:00
|
|
|
class BalanceViewModel = BalanceViewModelBase with _$BalanceViewModel;
|
|
|
|
|
|
|
|
abstract class BalanceViewModelBase with Store {
|
2020-12-15 16:29:10 +00:00
|
|
|
BalanceViewModelBase(
|
2022-10-12 17:09:57 +00:00
|
|
|
{required this.appStore,
|
|
|
|
required this.settingsStore,
|
|
|
|
required this.fiatConvertationStore})
|
|
|
|
: isReversing = false,
|
|
|
|
isShowCard = appStore.wallet!.walletInfo.isShowIntroCakePayCard,
|
|
|
|
wallet = appStore.wallet! {
|
2021-05-07 07:36:38 +00:00
|
|
|
reaction((_) => appStore.wallet, _onWalletChange);
|
2020-12-16 18:39:53 +00:00
|
|
|
}
|
2020-07-23 12:20:52 +00:00
|
|
|
|
2020-09-24 09:16:13 +00:00
|
|
|
final AppStore appStore;
|
2020-07-23 12:20:52 +00:00
|
|
|
final SettingsStore settingsStore;
|
2020-09-21 11:50:26 +00:00
|
|
|
final FiatConversionStore fiatConvertationStore;
|
2020-07-23 12:20:52 +00:00
|
|
|
|
2021-01-11 17:15:27 +00:00
|
|
|
bool get canReverse => false;
|
2020-12-15 16:29:10 +00:00
|
|
|
|
2020-09-29 08:45:35 +00:00
|
|
|
@observable
|
|
|
|
bool isReversing;
|
|
|
|
|
2020-12-16 18:39:53 +00:00
|
|
|
@observable
|
2021-05-07 07:36:38 +00:00
|
|
|
WalletBase<Balance, TransactionHistoryBase<TransactionInfo>, TransactionInfo>
|
|
|
|
wallet;
|
2020-12-16 18:39:53 +00:00
|
|
|
|
2020-09-29 08:45:35 +00:00
|
|
|
@computed
|
2022-10-12 17:09:57 +00:00
|
|
|
double get price {
|
|
|
|
final price = fiatConvertationStore.prices[appStore.wallet!.currency];
|
|
|
|
|
|
|
|
if (price == null) {
|
2023-07-27 01:08:12 +00:00
|
|
|
// price should update on next fetch:
|
|
|
|
return 0;
|
2022-10-12 17:09:57 +00:00
|
|
|
}
|
|
|
|
|
|
|
|
return price;
|
|
|
|
}
|
2020-09-29 08:45:35 +00:00
|
|
|
|
|
|
|
@computed
|
2020-12-15 16:29:10 +00:00
|
|
|
BalanceDisplayMode get savedDisplayMode => settingsStore.balanceDisplayMode;
|
2020-09-29 08:45:35 +00:00
|
|
|
|
2022-11-04 11:58:04 +00:00
|
|
|
@computed
|
2022-12-07 20:07:32 +00:00
|
|
|
bool get isFiatDisabled => settingsStore.fiatApiMode == FiatApiMode.disabled;
|
2022-11-04 11:58:04 +00:00
|
|
|
|
2023-08-04 17:01:49 +00:00
|
|
|
@computed
|
|
|
|
bool get isHomeScreenSettingsEnabled => wallet.type == WalletType.ethereum;
|
|
|
|
|
2023-11-03 05:41:17 +00:00
|
|
|
@computed
|
|
|
|
bool get hasAccounts => wallet.type == WalletType.monero;
|
|
|
|
|
2023-08-04 17:01:49 +00:00
|
|
|
@computed
|
|
|
|
SortBalanceBy get sortBalanceBy => settingsStore.sortBalanceBy;
|
|
|
|
|
|
|
|
@computed
|
|
|
|
bool get pinNativeToken => settingsStore.pinNativeTokenAtTop;
|
|
|
|
|
2022-03-30 15:57:04 +00:00
|
|
|
@computed
|
2022-03-18 10:47:57 +00:00
|
|
|
String get asset {
|
2022-10-12 17:09:57 +00:00
|
|
|
final typeFormatted = walletTypeToString(appStore.wallet!.type);
|
2022-03-30 15:57:04 +00:00
|
|
|
|
|
|
|
switch(wallet.type) {
|
|
|
|
case WalletType.haven:
|
|
|
|
return '$typeFormatted Assets';
|
2022-03-18 10:47:57 +00:00
|
|
|
default:
|
2022-03-30 15:57:04 +00:00
|
|
|
return typeFormatted;
|
2022-03-18 10:47:57 +00:00
|
|
|
}
|
|
|
|
}
|
|
|
|
|
2020-07-23 12:20:52 +00:00
|
|
|
@computed
|
2022-03-30 15:57:04 +00:00
|
|
|
BalanceDisplayMode get displayMode {
|
|
|
|
if (isReversing) {
|
|
|
|
if (savedDisplayMode == BalanceDisplayMode.hiddenBalance) {
|
|
|
|
return BalanceDisplayMode.displayableBalance;
|
|
|
|
} else {
|
|
|
|
return BalanceDisplayMode.hiddenBalance;
|
|
|
|
}
|
|
|
|
}
|
|
|
|
|
|
|
|
return savedDisplayMode;
|
|
|
|
}
|
2020-07-23 12:20:52 +00:00
|
|
|
|
|
|
|
@computed
|
2021-01-11 17:15:27 +00:00
|
|
|
String get availableBalanceLabel {
|
2022-03-30 15:57:04 +00:00
|
|
|
switch(wallet.type) {
|
|
|
|
case WalletType.monero:
|
|
|
|
case WalletType.haven:
|
2023-08-04 17:01:49 +00:00
|
|
|
case WalletType.ethereum:
|
2022-03-30 15:57:04 +00:00
|
|
|
return S.current.xmr_available_balance;
|
|
|
|
default:
|
|
|
|
return S.current.confirmed;
|
2020-07-23 12:20:52 +00:00
|
|
|
}
|
2021-01-11 17:15:27 +00:00
|
|
|
}
|
|
|
|
|
|
|
|
@computed
|
|
|
|
String get additionalBalanceLabel {
|
2022-03-30 15:57:04 +00:00
|
|
|
switch(wallet.type) {
|
|
|
|
case WalletType.monero:
|
|
|
|
case WalletType.haven:
|
2023-08-04 17:01:49 +00:00
|
|
|
case WalletType.ethereum:
|
2022-03-30 15:57:04 +00:00
|
|
|
return S.current.xmr_full_balance;
|
|
|
|
default:
|
|
|
|
return S.current.unconfirmed;
|
2020-07-23 12:20:52 +00:00
|
|
|
}
|
|
|
|
}
|
|
|
|
|
2022-03-30 15:57:04 +00:00
|
|
|
@computed
|
2022-10-12 17:09:57 +00:00
|
|
|
bool get hasMultiBalance => appStore.wallet!.type == WalletType.haven;
|
2022-03-30 15:57:04 +00:00
|
|
|
|
2020-07-23 12:20:52 +00:00
|
|
|
@computed
|
2021-01-11 17:15:27 +00:00
|
|
|
String get availableBalance {
|
2020-09-24 09:16:13 +00:00
|
|
|
final walletBalance = _walletBalance;
|
2020-07-23 12:20:52 +00:00
|
|
|
|
2021-03-31 16:18:33 +00:00
|
|
|
if (displayMode == BalanceDisplayMode.hiddenBalance) {
|
2021-01-11 17:15:27 +00:00
|
|
|
return '---';
|
|
|
|
}
|
2020-07-23 12:20:52 +00:00
|
|
|
|
2021-01-11 17:15:27 +00:00
|
|
|
return walletBalance.formattedAvailableBalance;
|
|
|
|
}
|
2020-07-23 12:20:52 +00:00
|
|
|
|
2023-04-20 13:46:41 +00:00
|
|
|
@computed
|
|
|
|
String get frozenBalance {
|
|
|
|
final walletBalance = _walletBalance;
|
|
|
|
|
|
|
|
if (displayMode == BalanceDisplayMode.hiddenBalance) {
|
|
|
|
return '---';
|
|
|
|
}
|
|
|
|
|
|
|
|
return getFormattedFrozenBalance(walletBalance);
|
|
|
|
}
|
|
|
|
|
|
|
|
@computed
|
|
|
|
String get frozenFiatBalance {
|
|
|
|
final walletBalance = _walletBalance;
|
|
|
|
final fiatCurrency = settingsStore.fiatCurrency;
|
|
|
|
|
|
|
|
if (displayMode == BalanceDisplayMode.hiddenBalance) {
|
|
|
|
return '---';
|
|
|
|
}
|
|
|
|
|
2023-11-15 23:12:23 +00:00
|
|
|
return _getFiatBalance(price: price, cryptoAmount: getFormattedFrozenBalance(walletBalance)) +
|
|
|
|
' ${fiatCurrency.toString()}';
|
2023-04-20 13:46:41 +00:00
|
|
|
}
|
|
|
|
|
2021-01-11 17:15:27 +00:00
|
|
|
@computed
|
|
|
|
String get additionalBalance {
|
|
|
|
final walletBalance = _walletBalance;
|
2020-07-23 12:20:52 +00:00
|
|
|
|
2021-03-31 16:18:33 +00:00
|
|
|
if (displayMode == BalanceDisplayMode.hiddenBalance) {
|
2021-01-11 17:15:27 +00:00
|
|
|
return '---';
|
2020-07-23 12:20:52 +00:00
|
|
|
}
|
|
|
|
|
2021-01-11 17:15:27 +00:00
|
|
|
return walletBalance.formattedAdditionalBalance;
|
2020-07-23 12:20:52 +00:00
|
|
|
}
|
|
|
|
|
2020-09-24 09:16:13 +00:00
|
|
|
@computed
|
2021-01-11 17:15:27 +00:00
|
|
|
String get availableFiatBalance {
|
|
|
|
final walletBalance = _walletBalance;
|
|
|
|
final fiatCurrency = settingsStore.fiatCurrency;
|
2020-09-24 09:16:13 +00:00
|
|
|
|
2021-03-31 16:18:33 +00:00
|
|
|
if (displayMode == BalanceDisplayMode.hiddenBalance) {
|
2021-01-11 17:15:27 +00:00
|
|
|
return '---';
|
2020-09-24 09:16:13 +00:00
|
|
|
}
|
|
|
|
|
2023-11-15 23:12:23 +00:00
|
|
|
return _getFiatBalance(price: price, cryptoAmount: walletBalance.formattedAvailableBalance) +
|
|
|
|
' ${fiatCurrency.toString()}';
|
2021-01-11 17:15:27 +00:00
|
|
|
}
|
|
|
|
|
|
|
|
@computed
|
|
|
|
String get additionalFiatBalance {
|
|
|
|
final walletBalance = _walletBalance;
|
|
|
|
final fiatCurrency = settingsStore.fiatCurrency;
|
|
|
|
|
2021-03-31 16:18:33 +00:00
|
|
|
if (displayMode == BalanceDisplayMode.hiddenBalance) {
|
2021-01-11 17:15:27 +00:00
|
|
|
return '---';
|
2020-09-24 09:16:13 +00:00
|
|
|
}
|
|
|
|
|
2023-11-15 23:12:23 +00:00
|
|
|
return _getFiatBalance(price: price, cryptoAmount: walletBalance.formattedAdditionalBalance) +
|
|
|
|
' ${fiatCurrency.toString()}';
|
2020-09-24 09:16:13 +00:00
|
|
|
}
|
|
|
|
|
2021-01-11 17:15:27 +00:00
|
|
|
@computed
|
2022-03-30 15:57:04 +00:00
|
|
|
Map<CryptoCurrency, BalanceRecord> get balances {
|
|
|
|
return wallet.balance.map((key, value) {
|
|
|
|
if (displayMode == BalanceDisplayMode.hiddenBalance) {
|
|
|
|
return MapEntry(key, BalanceRecord(
|
|
|
|
availableBalance: '---',
|
|
|
|
additionalBalance: '---',
|
2023-04-20 13:46:41 +00:00
|
|
|
frozenBalance: '---',
|
2022-12-07 20:07:32 +00:00
|
|
|
fiatAdditionalBalance: isFiatDisabled ? '' : '---',
|
|
|
|
fiatAvailableBalance: isFiatDisabled ? '' : '---',
|
2023-04-20 13:46:41 +00:00
|
|
|
fiatFrozenBalance: isFiatDisabled ? '' : '---',
|
2022-03-30 15:57:04 +00:00
|
|
|
asset: key,
|
|
|
|
formattedAssetTitle: _formatterAsset(key)));
|
|
|
|
}
|
|
|
|
final fiatCurrency = settingsStore.fiatCurrency;
|
2022-10-12 17:09:57 +00:00
|
|
|
final price = fiatConvertationStore.prices[key] ?? 0;
|
|
|
|
|
|
|
|
// if (price == null) {
|
|
|
|
// throw Exception('Price is null for: $key');
|
|
|
|
// }
|
|
|
|
|
2022-12-07 20:07:32 +00:00
|
|
|
final additionalFiatBalance = isFiatDisabled ? '' : (fiatCurrency.toString()
|
2022-11-04 11:58:04 +00:00
|
|
|
+ ' '
|
2022-03-30 15:57:04 +00:00
|
|
|
+ _getFiatBalance(
|
2022-10-12 17:09:57 +00:00
|
|
|
price: price,
|
2022-11-04 11:58:04 +00:00
|
|
|
cryptoAmount: value.formattedAdditionalBalance));
|
2022-03-30 15:57:04 +00:00
|
|
|
|
2022-12-07 20:07:32 +00:00
|
|
|
final availableFiatBalance = isFiatDisabled ? '' : (fiatCurrency.toString()
|
2022-11-04 11:58:04 +00:00
|
|
|
+ ' '
|
2022-03-30 15:57:04 +00:00
|
|
|
+ _getFiatBalance(
|
2022-10-12 17:09:57 +00:00
|
|
|
price: price,
|
2022-11-04 11:58:04 +00:00
|
|
|
cryptoAmount: value.formattedAvailableBalance));
|
2022-03-30 15:57:04 +00:00
|
|
|
|
2023-04-20 13:46:41 +00:00
|
|
|
|
|
|
|
final frozenFiatBalance = isFiatDisabled ? '' : (fiatCurrency.toString()
|
|
|
|
+ ' '
|
|
|
|
+ _getFiatBalance(
|
|
|
|
price: price,
|
|
|
|
cryptoAmount: getFormattedFrozenBalance(value)));
|
|
|
|
|
|
|
|
|
|
|
|
return MapEntry(
|
|
|
|
key,
|
|
|
|
BalanceRecord(
|
|
|
|
availableBalance: value.formattedAvailableBalance,
|
|
|
|
additionalBalance: value.formattedAdditionalBalance,
|
|
|
|
frozenBalance: getFormattedFrozenBalance(value),
|
|
|
|
fiatAdditionalBalance: additionalFiatBalance,
|
|
|
|
fiatAvailableBalance: availableFiatBalance,
|
|
|
|
fiatFrozenBalance: frozenFiatBalance,
|
|
|
|
asset: key,
|
|
|
|
formattedAssetTitle: _formatterAsset(key)));
|
2022-03-30 15:57:04 +00:00
|
|
|
});
|
|
|
|
}
|
|
|
|
|
2023-08-04 17:01:49 +00:00
|
|
|
@computed
|
|
|
|
bool get hasAdditionalBalance => wallet.type != WalletType.ethereum;
|
|
|
|
|
2022-03-30 15:57:04 +00:00
|
|
|
@computed
|
|
|
|
List<BalanceRecord> get formattedBalances {
|
|
|
|
final balance = balances.values.toList();
|
|
|
|
|
|
|
|
balance.sort((BalanceRecord a, BalanceRecord b) {
|
2023-08-04 17:01:49 +00:00
|
|
|
if (wallet.currency == CryptoCurrency.xhv) {
|
|
|
|
if (b.asset == CryptoCurrency.xhv) {
|
|
|
|
return 1;
|
|
|
|
}
|
|
|
|
|
|
|
|
if (b.asset == CryptoCurrency.xusd) {
|
|
|
|
if (a.asset == CryptoCurrency.xhv) {
|
|
|
|
return -1;
|
|
|
|
}
|
2022-03-30 15:57:04 +00:00
|
|
|
|
2023-08-04 17:01:49 +00:00
|
|
|
return 1;
|
2022-03-30 15:57:04 +00:00
|
|
|
}
|
|
|
|
|
2023-08-04 17:01:49 +00:00
|
|
|
if (b.asset == CryptoCurrency.xbtc) {
|
|
|
|
return 1;
|
|
|
|
}
|
2022-03-30 15:57:04 +00:00
|
|
|
|
2023-08-04 17:01:49 +00:00
|
|
|
if (b.asset == CryptoCurrency.xeur) {
|
|
|
|
return 1;
|
|
|
|
}
|
|
|
|
|
|
|
|
return 0;
|
2022-03-30 15:57:04 +00:00
|
|
|
}
|
|
|
|
|
2023-08-04 17:01:49 +00:00
|
|
|
if (pinNativeToken) {
|
|
|
|
if (b.asset == wallet.currency) return 1;
|
|
|
|
if (a.asset == wallet.currency) return -1;
|
2022-03-30 15:57:04 +00:00
|
|
|
}
|
|
|
|
|
2023-08-04 17:01:49 +00:00
|
|
|
switch (sortBalanceBy) {
|
|
|
|
case SortBalanceBy.FiatBalance:
|
|
|
|
final aFiatBalance = _getFiatBalance(
|
|
|
|
price: fiatConvertationStore.prices[a.asset] ?? 0, cryptoAmount: a.availableBalance);
|
|
|
|
final bFiatBalance = _getFiatBalance(
|
|
|
|
price: fiatConvertationStore.prices[b.asset] ?? 0, cryptoAmount: b.availableBalance);
|
|
|
|
|
|
|
|
return (double.tryParse(bFiatBalance) ?? 0)
|
|
|
|
.compareTo((double.tryParse(aFiatBalance)) ?? 0);
|
|
|
|
case SortBalanceBy.GrossBalance:
|
|
|
|
return (double.tryParse(b.availableBalance) ?? 0)
|
|
|
|
.compareTo(double.tryParse(a.availableBalance) ?? 0);
|
|
|
|
case SortBalanceBy.Alphabetical:
|
|
|
|
return a.asset.title.compareTo(b.asset.title);
|
|
|
|
}
|
2022-03-30 15:57:04 +00:00
|
|
|
});
|
|
|
|
|
|
|
|
return balance;
|
|
|
|
}
|
|
|
|
|
|
|
|
@computed
|
2022-10-12 17:09:57 +00:00
|
|
|
Balance get _walletBalance {
|
|
|
|
final balance = wallet.balance[wallet.currency];
|
|
|
|
|
|
|
|
if (balance == null) {
|
|
|
|
throw Exception('No balance for ${wallet.currency}');
|
|
|
|
}
|
|
|
|
|
|
|
|
return balance;
|
|
|
|
}
|
2021-01-11 17:15:27 +00:00
|
|
|
|
2020-09-26 12:19:33 +00:00
|
|
|
@computed
|
2022-10-12 17:09:57 +00:00
|
|
|
CryptoCurrency get currency => appStore.wallet!.currency;
|
2020-09-26 12:19:33 +00:00
|
|
|
|
2022-08-30 18:03:02 +00:00
|
|
|
@observable
|
|
|
|
bool isShowCard;
|
|
|
|
|
2022-10-12 17:09:57 +00:00
|
|
|
ReactionDisposer? _onCurrentWalletChangeReaction;
|
2021-01-05 19:49:14 +00:00
|
|
|
|
2020-12-16 18:39:53 +00:00
|
|
|
@action
|
2021-05-07 07:36:38 +00:00
|
|
|
void _onWalletChange(
|
|
|
|
WalletBase<Balance, TransactionHistoryBase<TransactionInfo>,
|
2022-10-12 17:09:57 +00:00
|
|
|
TransactionInfo>?
|
2021-05-07 07:36:38 +00:00
|
|
|
wallet) {
|
2022-10-12 17:09:57 +00:00
|
|
|
if (wallet == null) {
|
|
|
|
return;
|
|
|
|
}
|
|
|
|
|
|
|
|
this.wallet = wallet;
|
|
|
|
_onCurrentWalletChangeReaction?.reaction.dispose();
|
2022-08-30 18:03:02 +00:00
|
|
|
isShowCard = wallet.walletInfo.isShowIntroCakePayCard;
|
|
|
|
}
|
|
|
|
|
|
|
|
@action
|
|
|
|
Future<void> disableIntroCakePayCard () async {
|
|
|
|
const cardDisplayStatus = false;
|
|
|
|
wallet.walletInfo.showIntroCakePayCard = cardDisplayStatus;
|
|
|
|
await wallet.walletInfo.save();
|
|
|
|
isShowCard = cardDisplayStatus;
|
2021-01-05 19:49:14 +00:00
|
|
|
}
|
2020-12-16 18:39:53 +00:00
|
|
|
|
2022-10-12 17:09:57 +00:00
|
|
|
String _getFiatBalance({required double price, String? cryptoAmount}) {
|
2023-08-04 17:01:49 +00:00
|
|
|
if (cryptoAmount == null || cryptoAmount.isEmpty || double.tryParse(cryptoAmount) == null) {
|
2020-09-24 09:16:13 +00:00
|
|
|
return '0.00';
|
|
|
|
}
|
|
|
|
|
|
|
|
return calculateFiatAmount(price: price, cryptoAmount: cryptoAmount);
|
|
|
|
}
|
2022-03-30 15:57:04 +00:00
|
|
|
|
|
|
|
String _formatterAsset(CryptoCurrency asset) {
|
|
|
|
switch (wallet.type) {
|
|
|
|
case WalletType.haven:
|
|
|
|
final assetStringified = asset.toString();
|
|
|
|
|
|
|
|
if (asset != CryptoCurrency.xhv && assetStringified[0].toUpperCase() == 'X') {
|
|
|
|
return assetStringified.replaceFirst('X', 'x');
|
|
|
|
}
|
|
|
|
|
2023-04-20 13:46:41 +00:00
|
|
|
return asset.toString();
|
2022-03-30 15:57:04 +00:00
|
|
|
default:
|
|
|
|
return asset.toString();
|
|
|
|
}
|
|
|
|
}
|
2023-04-20 13:46:41 +00:00
|
|
|
|
2023-11-16 23:22:10 +00:00
|
|
|
String getFormattedFrozenBalance(Balance walletBalance) => walletBalance.formattedUnAvailableBalance;
|
2021-01-05 19:49:14 +00:00
|
|
|
}
|
2022-03-18 10:47:57 +00:00
|
|
|
|