/* * This file is part of Stack Wallet. * * Copyright (c) 2023 Cypher Stack * All Rights Reserved. * The code is distributed under GPLv3 license, see LICENSE file for details. * Generated by Cypher Stack on 2023-05-26 * */ import 'package:decimal/decimal.dart'; import 'package:flutter_riverpod/flutter_riverpod.dart'; import 'package:stackwallet/models/exchange/active_pair.dart'; import 'package:stackwallet/models/exchange/response_objects/estimate.dart'; import 'package:stackwallet/models/exchange/response_objects/range.dart'; import 'package:stackwallet/providers/global/locale_provider.dart'; import 'package:stackwallet/services/exchange/exchange.dart'; import 'package:stackwallet/services/exchange/exchange_response.dart'; import 'package:stackwallet/utilities/amount/amount.dart'; import 'package:stackwallet/utilities/amount/amount_unit.dart'; import 'package:stackwallet/utilities/enums/coin_enum.dart'; import 'package:stackwallet/utilities/enums/exchange_rate_type_enum.dart'; import 'package:tuple/tuple.dart'; final efEstimatesListProvider = StateProvider.family< Tuple2>, Range?>?, String>((ref, exchangeName) => null); final efRateTypeProvider = StateProvider((ref) => ExchangeRateType.estimated); final efExchangeProvider = StateProvider((ref) => Exchange.defaultExchange); final efExchangeProviderNameProvider = StateProvider((ref) => Exchange.defaultExchange.name); final currentCombinedExchangeIdProvider = Provider((ref) { return "${ref.watch(efExchangeProvider).name}" " (${ref.watch(efExchangeProviderNameProvider)})"; }); final efSendAmountProvider = StateProvider((ref) => null); final efReceiveAmountProvider = StateProvider((ref) => null); final efSendAmountStringProvider = StateProvider((ref) { final refreshing = ref.watch(efRefreshingProvider); final reversed = ref.watch(efReversedProvider); if (refreshing && reversed) { return "-"; } else { final decimal = ref.watch(efSendAmountProvider); String string = ""; if (decimal != null) { final amount = Amount.fromDecimal(decimal, fractionDigits: decimal.scale); final locale = ref.watch(localeServiceChangeNotifierProvider).locale; string = AmountUnit.normal.displayAmount( amount: amount, locale: locale, coin: Coin .nano, // use nano just to ensure decimal.scale < Coin.value.decimals withUnitName: false, maxDecimalPlaces: decimal.scale, ); } return string; } }); final efReceiveAmountStringProvider = StateProvider((ref) { final refreshing = ref.watch(efRefreshingProvider); final reversed = ref.watch(efReversedProvider); if (refreshing && reversed == false) { return "-"; } else { final decimal = ref.watch(efReceiveAmountProvider); String string = ""; if (decimal != null) { final amount = Amount.fromDecimal(decimal, fractionDigits: decimal.scale); final locale = ref.watch(localeServiceChangeNotifierProvider).locale; string = AmountUnit.normal.displayAmount( amount: amount, locale: locale, coin: Coin .nano, // use nano just to ensure decimal.scale < Coin.value.decimals withUnitName: false, maxDecimalPlaces: decimal.scale, ); } return string; } }); final efReversedProvider = StateProvider((ref) => false); final efCurrencyPairProvider = ChangeNotifierProvider( (ref) => ActivePair(), ); final efEstimateProvider = StateProvider((ref) { final exchange = ref.watch(efExchangeProvider); final provider = ref.watch(efExchangeProviderNameProvider); final reversed = ref.watch(efReversedProvider); final fixedRate = ref.watch(efRateTypeProvider) == ExchangeRateType.fixed; final matches = ref .watch(efEstimatesListProvider(exchange.name)) ?.item1 .value ?.where((e) { return e.exchangeProvider == provider && e.fixedRate == fixedRate && e.reversed == reversed; }); Estimate? result; if (matches != null && matches.isNotEmpty) { result = matches.first; } else { result = null; } return result; }); final efCanExchangeProvider = StateProvider((ref) { final Estimate? estimate = ref.watch(efEstimateProvider); final refreshing = ref.watch(efRefreshingProvider); return !refreshing && estimate != null; }); final efRefreshingProvider = StateProvider((ref) => false);