mirror of
https://github.com/cypherstack/stack_wallet.git
synced 2025-01-25 11:45:59 +00:00
first simplex service stash
This commit is contained in:
parent
7c58a3a47e
commit
8e8816fe05
9 changed files with 127 additions and 189 deletions
|
@ -41,6 +41,7 @@ import 'package:stackwallet/providers/global/trades_service_provider.dart';
|
||||||
import 'package:stackwallet/providers/providers.dart';
|
import 'package:stackwallet/providers/providers.dart';
|
||||||
import 'package:stackwallet/providers/ui/color_theme_provider.dart';
|
import 'package:stackwallet/providers/ui/color_theme_provider.dart';
|
||||||
import 'package:stackwallet/route_generator.dart';
|
import 'package:stackwallet/route_generator.dart';
|
||||||
|
import 'package:stackwallet/services/buy/buy_data_loading_service.dart';
|
||||||
import 'package:stackwallet/services/debug_service.dart';
|
import 'package:stackwallet/services/debug_service.dart';
|
||||||
import 'package:stackwallet/services/exchange/change_now/change_now_exchange.dart';
|
import 'package:stackwallet/services/exchange/change_now/change_now_exchange.dart';
|
||||||
import 'package:stackwallet/services/exchange/exchange_data_loading_service.dart';
|
import 'package:stackwallet/services/exchange/exchange_data_loading_service.dart';
|
||||||
|
@ -287,11 +288,15 @@ class _MaterialAppWithThemeState extends ConsumerState<MaterialAppWithTheme>
|
||||||
// unawaited(_nodeService.updateCommunityNodes());
|
// unawaited(_nodeService.updateCommunityNodes());
|
||||||
|
|
||||||
// run without awaiting
|
// run without awaiting
|
||||||
if (Constants.enableExchange &&
|
if (ref.read(prefsChangeNotifierProvider).externalCalls &&
|
||||||
ref.read(prefsChangeNotifierProvider).externalCalls &&
|
|
||||||
await ref.read(prefsChangeNotifierProvider).isExternalCallsSet()) {
|
await ref.read(prefsChangeNotifierProvider).isExternalCallsSet()) {
|
||||||
|
if (Constants.enableExchange) {
|
||||||
unawaited(ExchangeDataLoadingService().loadAll(ref));
|
unawaited(ExchangeDataLoadingService().loadAll(ref));
|
||||||
}
|
}
|
||||||
|
if (Constants.enableBuy) {
|
||||||
|
unawaited(BuyDataLoadingService().loadAll(ref));
|
||||||
|
}
|
||||||
|
}
|
||||||
|
|
||||||
if (ref.read(prefsChangeNotifierProvider).isAutoBackupEnabled) {
|
if (ref.read(prefsChangeNotifierProvider).isAutoBackupEnabled) {
|
||||||
switch (ref.read(prefsChangeNotifierProvider).backupFrequencyType) {
|
switch (ref.read(prefsChangeNotifierProvider).backupFrequencyType) {
|
||||||
|
|
|
@ -15,6 +15,7 @@ import 'package:stackwallet/providers/global/notifications_provider.dart';
|
||||||
import 'package:stackwallet/providers/global/prefs_provider.dart';
|
import 'package:stackwallet/providers/global/prefs_provider.dart';
|
||||||
import 'package:stackwallet/providers/ui/home_view_index_provider.dart';
|
import 'package:stackwallet/providers/ui/home_view_index_provider.dart';
|
||||||
import 'package:stackwallet/providers/ui/unread_notifications_provider.dart';
|
import 'package:stackwallet/providers/ui/unread_notifications_provider.dart';
|
||||||
|
import 'package:stackwallet/services/buy/buy_data_loading_service.dart';
|
||||||
import 'package:stackwallet/services/exchange/exchange_data_loading_service.dart';
|
import 'package:stackwallet/services/exchange/exchange_data_loading_service.dart';
|
||||||
import 'package:stackwallet/utilities/assets.dart';
|
import 'package:stackwallet/utilities/assets.dart';
|
||||||
import 'package:stackwallet/utilities/constants.dart';
|
import 'package:stackwallet/utilities/constants.dart';
|
||||||
|
@ -46,6 +47,7 @@ class _HomeViewState extends ConsumerState<HomeView> {
|
||||||
bool _exitEnabled = false;
|
bool _exitEnabled = false;
|
||||||
|
|
||||||
final _exchangeDataLoadingService = ExchangeDataLoadingService();
|
final _exchangeDataLoadingService = ExchangeDataLoadingService();
|
||||||
|
final _buyDataLoadingService = BuyDataLoadingService();
|
||||||
|
|
||||||
Future<bool> _onWillPop() async {
|
Future<bool> _onWillPop() async {
|
||||||
// go to home view when tapping back on the main exchange view
|
// go to home view when tapping back on the main exchange view
|
||||||
|
@ -93,6 +95,16 @@ class _HomeViewState extends ConsumerState<HomeView> {
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
|
||||||
|
void _loadSimplexData() {
|
||||||
|
// unawaited future
|
||||||
|
if (ref.read(prefsChangeNotifierProvider).externalCalls) {
|
||||||
|
_buyDataLoadingService.loadAll(ref);
|
||||||
|
} else {
|
||||||
|
Logging.instance.log("User does not want to use external calls",
|
||||||
|
level: LogLevel.Info);
|
||||||
|
}
|
||||||
|
}
|
||||||
|
|
||||||
@override
|
@override
|
||||||
void initState() {
|
void initState() {
|
||||||
_pageController = PageController();
|
_pageController = PageController();
|
||||||
|
@ -308,6 +320,9 @@ class _HomeViewState extends ConsumerState<HomeView> {
|
||||||
if (next == 1) {
|
if (next == 1) {
|
||||||
_exchangeDataLoadingService.loadAll(ref);
|
_exchangeDataLoadingService.loadAll(ref);
|
||||||
}
|
}
|
||||||
|
if (next == 2) {
|
||||||
|
_buyDataLoadingService.loadAll(ref);
|
||||||
|
}
|
||||||
if (next >= 0 && next <= 2) {
|
if (next >= 0 && next <= 2) {
|
||||||
_pageController.animateToPage(
|
_pageController.animateToPage(
|
||||||
next,
|
next,
|
||||||
|
|
|
@ -1,6 +1,7 @@
|
||||||
import 'package:flutter/material.dart';
|
import 'package:flutter/material.dart';
|
||||||
import 'package:flutter_riverpod/flutter_riverpod.dart';
|
import 'package:flutter_riverpod/flutter_riverpod.dart';
|
||||||
import 'package:stackwallet/providers/providers.dart';
|
import 'package:stackwallet/providers/providers.dart';
|
||||||
|
import 'package:stackwallet/services/buy/buy_data_loading_service.dart';
|
||||||
import 'package:stackwallet/services/exchange/exchange_data_loading_service.dart';
|
import 'package:stackwallet/services/exchange/exchange_data_loading_service.dart';
|
||||||
import 'package:stackwallet/utilities/text_styles.dart';
|
import 'package:stackwallet/utilities/text_styles.dart';
|
||||||
import 'package:stackwallet/utilities/theme/stack_colors.dart';
|
import 'package:stackwallet/utilities/theme/stack_colors.dart';
|
||||||
|
@ -148,6 +149,7 @@ class _HomeViewButtonBarState extends ConsumerState<HomeViewButtonBar> {
|
||||||
if (selectedIndex != 2) {
|
if (selectedIndex != 2) {
|
||||||
ref.read(homeViewPageIndexStateProvider.state).state = 2;
|
ref.read(homeViewPageIndexStateProvider.state).state = 2;
|
||||||
}
|
}
|
||||||
|
await BuyDataLoadingService().loadAll(ref);
|
||||||
},
|
},
|
||||||
child: Text(
|
child: Text(
|
||||||
"Buy",
|
"Buy",
|
||||||
|
|
|
@ -8,6 +8,7 @@ import 'package:stackwallet/pages/pinpad_views/create_pin_view.dart';
|
||||||
import 'package:stackwallet/pages_desktop_specific/password/create_password_view.dart';
|
import 'package:stackwallet/pages_desktop_specific/password/create_password_view.dart';
|
||||||
import 'package:stackwallet/providers/global/prefs_provider.dart';
|
import 'package:stackwallet/providers/global/prefs_provider.dart';
|
||||||
import 'package:stackwallet/providers/global/price_provider.dart';
|
import 'package:stackwallet/providers/global/price_provider.dart';
|
||||||
|
import 'package:stackwallet/services/buy/buy_data_loading_service.dart';
|
||||||
import 'package:stackwallet/services/exchange/exchange_data_loading_service.dart';
|
import 'package:stackwallet/services/exchange/exchange_data_loading_service.dart';
|
||||||
import 'package:stackwallet/utilities/assets.dart';
|
import 'package:stackwallet/utilities/assets.dart';
|
||||||
import 'package:stackwallet/utilities/constants.dart';
|
import 'package:stackwallet/utilities/constants.dart';
|
||||||
|
@ -232,6 +233,8 @@ class _StackPrivacyCalls extends ConsumerState<StackPrivacyCalls> {
|
||||||
if (isEasy) {
|
if (isEasy) {
|
||||||
unawaited(ExchangeDataLoadingService()
|
unawaited(ExchangeDataLoadingService()
|
||||||
.loadAll(ref));
|
.loadAll(ref));
|
||||||
|
unawaited(
|
||||||
|
BuyDataLoadingService().loadAll(ref));
|
||||||
ref
|
ref
|
||||||
.read(priceAnd24hChangeNotifierProvider)
|
.read(priceAnd24hChangeNotifierProvider)
|
||||||
.start(true);
|
.start(true);
|
||||||
|
|
|
@ -17,6 +17,7 @@ import 'package:stackwallet/pages_desktop_specific/my_stack_view/wallet_view/sub
|
||||||
import 'package:stackwallet/providers/global/auto_swb_service_provider.dart';
|
import 'package:stackwallet/providers/global/auto_swb_service_provider.dart';
|
||||||
import 'package:stackwallet/providers/providers.dart';
|
import 'package:stackwallet/providers/providers.dart';
|
||||||
import 'package:stackwallet/providers/ui/transaction_filter_provider.dart';
|
import 'package:stackwallet/providers/ui/transaction_filter_provider.dart';
|
||||||
|
import 'package:stackwallet/services/buy/buy_data_loading_service.dart';
|
||||||
import 'package:stackwallet/services/coins/firo/firo_wallet.dart';
|
import 'package:stackwallet/services/coins/firo/firo_wallet.dart';
|
||||||
import 'package:stackwallet/services/event_bus/events/global/wallet_sync_status_changed_event.dart';
|
import 'package:stackwallet/services/event_bus/events/global/wallet_sync_status_changed_event.dart';
|
||||||
import 'package:stackwallet/services/event_bus/global_event_bus.dart';
|
import 'package:stackwallet/services/event_bus/global_event_bus.dart';
|
||||||
|
@ -64,6 +65,7 @@ class _DesktopWalletViewState extends ConsumerState<DesktopWalletView> {
|
||||||
late final bool _shouldDisableAutoSyncOnLogOut;
|
late final bool _shouldDisableAutoSyncOnLogOut;
|
||||||
|
|
||||||
final _cnLoadingService = ExchangeDataLoadingService();
|
final _cnLoadingService = ExchangeDataLoadingService();
|
||||||
|
final _buyDataLoadingService = BuyDataLoadingService();
|
||||||
|
|
||||||
Future<void> onBackPressed() async {
|
Future<void> onBackPressed() async {
|
||||||
await _logout();
|
await _logout();
|
||||||
|
@ -103,6 +105,16 @@ class _DesktopWalletViewState extends ConsumerState<DesktopWalletView> {
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
|
||||||
|
void _loadSimplexData() {
|
||||||
|
// unawaited future
|
||||||
|
if (ref.read(prefsChangeNotifierProvider).externalCalls) {
|
||||||
|
_buyDataLoadingService.loadAll(ref);
|
||||||
|
} else {
|
||||||
|
Logging.instance.log("User does not want to use external calls",
|
||||||
|
level: LogLevel.Info);
|
||||||
|
}
|
||||||
|
}
|
||||||
|
|
||||||
void _onExchangePressed(BuildContext context) async {
|
void _onExchangePressed(BuildContext context) async {
|
||||||
final managerProvider = ref
|
final managerProvider = ref
|
||||||
.read(walletsChangeNotifierProvider)
|
.read(walletsChangeNotifierProvider)
|
||||||
|
|
11
lib/providers/buy/simplex_initial_load_status.dart
Normal file
11
lib/providers/buy/simplex_initial_load_status.dart
Normal file
|
@ -0,0 +1,11 @@
|
||||||
|
import 'package:flutter_riverpod/flutter_riverpod.dart';
|
||||||
|
|
||||||
|
enum SimplexLoadStatus {
|
||||||
|
waiting,
|
||||||
|
loading,
|
||||||
|
success,
|
||||||
|
failed,
|
||||||
|
}
|
||||||
|
|
||||||
|
final simplexLoadStatusStateProvider =
|
||||||
|
StateProvider<SimplexLoadStatus>((ref) => SimplexLoadStatus.waiting);
|
|
@ -1,4 +1,5 @@
|
||||||
export './buy/buy_form_state_provider.dart';
|
export './buy/buy_form_state_provider.dart';
|
||||||
|
export './buy/simplex_initial_load_status.dart';
|
||||||
export './exchange/available_changenow_currencies_provider.dart';
|
export './exchange/available_changenow_currencies_provider.dart';
|
||||||
export './exchange/available_simpleswap_currencies_provider.dart';
|
export './exchange/available_simpleswap_currencies_provider.dart';
|
||||||
export './exchange/changenow_initial_load_status.dart';
|
export './exchange/changenow_initial_load_status.dart';
|
||||||
|
|
|
@ -1,17 +1,13 @@
|
||||||
import 'package:flutter_riverpod/flutter_riverpod.dart';
|
import 'package:flutter_riverpod/flutter_riverpod.dart';
|
||||||
import 'package:stackwallet/providers/providers.dart';
|
import 'package:stackwallet/providers/providers.dart';
|
||||||
import 'package:stackwallet/services/buy/simplex/simplex_api.dart';
|
import 'package:stackwallet/services/buy/simplex/simplex_api.dart';
|
||||||
import 'package:stackwallet/utilities/enums/coin_enum.dart';
|
|
||||||
import 'package:stackwallet/utilities/logger.dart';
|
import 'package:stackwallet/utilities/logger.dart';
|
||||||
|
|
||||||
class BuyDataLoadingService {
|
class BuyDataLoadingService {
|
||||||
Future<void> loadAll(WidgetRef ref, {Coin? coin}) async {
|
Future<void> loadAll(WidgetRef ref) async {
|
||||||
try {
|
try {
|
||||||
await Future.wait([
|
await Future.wait([
|
||||||
_loadFixedRateMarkets(ref, coin: coin),
|
_loadSimplexCurrencies(ref),
|
||||||
_loadChangeNowStandardCurrencies(ref, coin: coin),
|
|
||||||
loadSimpleswapFixedRateCurrencies(ref),
|
|
||||||
loadSimpleswapFloatingRateCurrencies(ref),
|
|
||||||
]);
|
]);
|
||||||
} catch (e, s) {
|
} catch (e, s) {
|
||||||
Logging.instance.log("BuyDataLoadingService.loadAll failed: $e\n$s",
|
Logging.instance.log("BuyDataLoadingService.loadAll failed: $e\n$s",
|
||||||
|
@ -19,183 +15,77 @@ class BuyDataLoadingService {
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
|
||||||
Future<void> _loadFixedRateMarkets(WidgetRef ref, {Coin? coin}) async {
|
Future<void> _loadSimplexCurrencies(WidgetRef ref) async {
|
||||||
if (ref.read(changeNowFixedInitialLoadStatusStateProvider.state).state ==
|
// if (ref
|
||||||
ChangeNowLoadStatus.loading) {
|
// .read(changeNowEstimatedInitialLoadStatusStateProvider.state)
|
||||||
// already in progress so just
|
// .state ==
|
||||||
|
// ChangeNowLoadStatus.loading) {
|
||||||
|
// // already in progress so just
|
||||||
|
// return;
|
||||||
|
// }
|
||||||
|
|
||||||
|
ref.read(simplexLoadStatusStateProvider.state).state =
|
||||||
|
SimplexLoadStatus.loading;
|
||||||
|
|
||||||
|
print(11);
|
||||||
|
|
||||||
|
final response = await SimplexAPI.instance.getSupported();
|
||||||
|
|
||||||
return;
|
return;
|
||||||
}
|
// if (response.value != null) {
|
||||||
|
// ref
|
||||||
ref.read(changeNowFixedInitialLoadStatusStateProvider.state).state =
|
// .read(availableChangeNowCurrenciesProvider)
|
||||||
ChangeNowLoadStatus.loading;
|
// .updateCurrencies(response.value!);
|
||||||
|
//
|
||||||
final response3 =
|
// if (response2.value != null) {
|
||||||
await ChangeNowAPI.instance.getAvailableFixedRateMarkets();
|
// ref
|
||||||
if (response3.value != null) {
|
// .read(availableChangeNowCurrenciesProvider)
|
||||||
ref
|
// .updateFloatingPairs(response2.value!);
|
||||||
.read(availableChangeNowCurrenciesProvider)
|
//
|
||||||
.updateMarkets(response3.value!);
|
// String fromTicker = "btc";
|
||||||
|
// String toTicker = "xmr";
|
||||||
if (ref.read(buyFormStateProvider).market == null) {
|
//
|
||||||
String fromTicker = "btc";
|
// if (coin != null) {
|
||||||
String toTicker = "xmr";
|
// fromTicker = coin.ticker.toLowerCase();
|
||||||
|
// }
|
||||||
if (coin != null) {
|
//
|
||||||
fromTicker = coin.ticker.toLowerCase();
|
// if (response.value!.length > 1) {
|
||||||
}
|
// if (ref.read(buyFormStateProvider).from == null) {
|
||||||
|
// if (response.value!
|
||||||
final matchingMarkets = response3.value!
|
// .where((e) => e.ticker == fromTicker)
|
||||||
.where((e) => e.to == toTicker && e.from == fromTicker);
|
// .isNotEmpty) {
|
||||||
if (matchingMarkets.isNotEmpty) {
|
// await ref.read(buyFormStateProvider).updateFrom(
|
||||||
await ref
|
// response.value!.firstWhere((e) => e.ticker == fromTicker),
|
||||||
.read(buyFormStateProvider)
|
// false);
|
||||||
.updateMarket(matchingMarkets.first, true);
|
// }
|
||||||
}
|
// }
|
||||||
}
|
// if (ref.read(buyFormStateProvider).to == null) {
|
||||||
} else {
|
// if (response.value!.where((e) => e.ticker == toTicker).isNotEmpty) {
|
||||||
Logging.instance.log(
|
// await ref.read(buyFormStateProvider).updateTo(
|
||||||
"Failed to load changeNOW fixed rate markets: ${response3.exception?.errorMessage}",
|
// response.value!.firstWhere((e) => e.ticker == toTicker),
|
||||||
level: LogLevel.Error);
|
// false);
|
||||||
|
// }
|
||||||
ref.read(changeNowFixedInitialLoadStatusStateProvider.state).state =
|
// }
|
||||||
ChangeNowLoadStatus.failed;
|
// }
|
||||||
return;
|
// } else {
|
||||||
}
|
// Logging.instance.log(
|
||||||
|
// "Failed to load changeNOW available floating rate pairs: ${response2.exception?.errorMessage}",
|
||||||
ref.read(changeNowFixedInitialLoadStatusStateProvider.state).state =
|
// level: LogLevel.Error);
|
||||||
ChangeNowLoadStatus.success;
|
// ref.read(changeNowEstimatedInitialLoadStatusStateProvider.state).state =
|
||||||
}
|
// ChangeNowLoadStatus.failed;
|
||||||
|
// return;
|
||||||
Future<void> _loadChangeNowStandardCurrencies(
|
// }
|
||||||
WidgetRef ref, {
|
// } else {
|
||||||
Coin? coin,
|
// Logging.instance.log(
|
||||||
}) async {
|
// "Failed to load changeNOW currencies: ${response.exception?.errorMessage}",
|
||||||
if (ref
|
// level: LogLevel.Error);
|
||||||
.read(changeNowEstimatedInitialLoadStatusStateProvider.state)
|
// await Future<void>.delayed(const Duration(seconds: 3));
|
||||||
.state ==
|
// ref.read(changeNowEstimatedInitialLoadStatusStateProvider.state).state =
|
||||||
ChangeNowLoadStatus.loading) {
|
// ChangeNowLoadStatus.failed;
|
||||||
// already in progress so just
|
// return;
|
||||||
return;
|
// }
|
||||||
}
|
//
|
||||||
|
// ref.read(changeNowEstimatedInitialLoadStatusStateProvider.state).state =
|
||||||
ref.read(changeNowEstimatedInitialLoadStatusStateProvider.state).state =
|
// ChangeNowLoadStatus.success;
|
||||||
ChangeNowLoadStatus.loading;
|
|
||||||
|
|
||||||
final response = await ChangeNowAPI.instance.getAvailableCurrencies();
|
|
||||||
final response2 =
|
|
||||||
await ChangeNowAPI.instance.getAvailableFloatingRatePairs();
|
|
||||||
if (response.value != null) {
|
|
||||||
ref
|
|
||||||
.read(availableChangeNowCurrenciesProvider)
|
|
||||||
.updateCurrencies(response.value!);
|
|
||||||
|
|
||||||
if (response2.value != null) {
|
|
||||||
ref
|
|
||||||
.read(availableChangeNowCurrenciesProvider)
|
|
||||||
.updateFloatingPairs(response2.value!);
|
|
||||||
|
|
||||||
String fromTicker = "btc";
|
|
||||||
String toTicker = "xmr";
|
|
||||||
|
|
||||||
if (coin != null) {
|
|
||||||
fromTicker = coin.ticker.toLowerCase();
|
|
||||||
}
|
|
||||||
|
|
||||||
if (response.value!.length > 1) {
|
|
||||||
if (ref.read(buyFormStateProvider).from == null) {
|
|
||||||
if (response.value!
|
|
||||||
.where((e) => e.ticker == fromTicker)
|
|
||||||
.isNotEmpty) {
|
|
||||||
await ref.read(buyFormStateProvider).updateFrom(
|
|
||||||
response.value!.firstWhere((e) => e.ticker == fromTicker),
|
|
||||||
false);
|
|
||||||
}
|
|
||||||
}
|
|
||||||
if (ref.read(buyFormStateProvider).to == null) {
|
|
||||||
if (response.value!.where((e) => e.ticker == toTicker).isNotEmpty) {
|
|
||||||
await ref.read(buyFormStateProvider).updateTo(
|
|
||||||
response.value!.firstWhere((e) => e.ticker == toTicker),
|
|
||||||
false);
|
|
||||||
}
|
|
||||||
}
|
|
||||||
}
|
|
||||||
} else {
|
|
||||||
Logging.instance.log(
|
|
||||||
"Failed to load changeNOW available floating rate pairs: ${response2.exception?.errorMessage}",
|
|
||||||
level: LogLevel.Error);
|
|
||||||
ref.read(changeNowEstimatedInitialLoadStatusStateProvider.state).state =
|
|
||||||
ChangeNowLoadStatus.failed;
|
|
||||||
return;
|
|
||||||
}
|
|
||||||
} else {
|
|
||||||
Logging.instance.log(
|
|
||||||
"Failed to load changeNOW currencies: ${response.exception?.errorMessage}",
|
|
||||||
level: LogLevel.Error);
|
|
||||||
await Future<void>.delayed(const Duration(seconds: 3));
|
|
||||||
ref.read(changeNowEstimatedInitialLoadStatusStateProvider.state).state =
|
|
||||||
ChangeNowLoadStatus.failed;
|
|
||||||
return;
|
|
||||||
}
|
|
||||||
|
|
||||||
ref.read(changeNowEstimatedInitialLoadStatusStateProvider.state).state =
|
|
||||||
ChangeNowLoadStatus.success;
|
|
||||||
}
|
|
||||||
|
|
||||||
Future<void> loadSimpleswapFloatingRateCurrencies(WidgetRef ref) async {
|
|
||||||
final buy = SimpleSwapBuy();
|
|
||||||
final responseCurrencies = await buy.getAllCurrencies(false);
|
|
||||||
|
|
||||||
if (responseCurrencies.value != null) {
|
|
||||||
ref
|
|
||||||
.read(availableSimpleswapCurrenciesProvider)
|
|
||||||
.updateFloatingCurrencies(responseCurrencies.value!);
|
|
||||||
|
|
||||||
final responsePairs = await buy.getAllPairs(false);
|
|
||||||
|
|
||||||
if (responsePairs.value != null) {
|
|
||||||
ref
|
|
||||||
.read(availableSimpleswapCurrenciesProvider)
|
|
||||||
.updateFloatingPairs(responsePairs.value!);
|
|
||||||
} else {
|
|
||||||
Logging.instance.log(
|
|
||||||
"loadSimpleswapFloatingRateCurrencies: $responsePairs",
|
|
||||||
level: LogLevel.Warning,
|
|
||||||
);
|
|
||||||
}
|
|
||||||
} else {
|
|
||||||
Logging.instance.log(
|
|
||||||
"loadSimpleswapFloatingRateCurrencies: $responseCurrencies",
|
|
||||||
level: LogLevel.Warning,
|
|
||||||
);
|
|
||||||
}
|
|
||||||
}
|
|
||||||
|
|
||||||
Future<void> loadSimpleswapFixedRateCurrencies(WidgetRef ref) async {
|
|
||||||
final buy = SimpleSwapBuy();
|
|
||||||
final responseCurrencies = await buy.getAllCurrencies(true);
|
|
||||||
|
|
||||||
if (responseCurrencies.value != null) {
|
|
||||||
ref
|
|
||||||
.read(availableSimpleswapCurrenciesProvider)
|
|
||||||
.updateFixedCurrencies(responseCurrencies.value!);
|
|
||||||
|
|
||||||
final responsePairs = await buy.getAllPairs(true);
|
|
||||||
|
|
||||||
if (responsePairs.value != null) {
|
|
||||||
ref
|
|
||||||
.read(availableSimpleswapCurrenciesProvider)
|
|
||||||
.updateFixedPairs(responsePairs.value!);
|
|
||||||
} else {
|
|
||||||
Logging.instance.log(
|
|
||||||
"loadSimpleswapFixedRateCurrencies: $responsePairs",
|
|
||||||
level: LogLevel.Warning,
|
|
||||||
);
|
|
||||||
}
|
|
||||||
} else {
|
|
||||||
Logging.instance.log(
|
|
||||||
"loadSimpleswapFixedRateCurrencies: $responseCurrencies",
|
|
||||||
level: LogLevel.Warning,
|
|
||||||
);
|
|
||||||
}
|
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
|
|
@ -1,6 +1,5 @@
|
||||||
import 'dart:convert';
|
import 'dart:convert';
|
||||||
|
|
||||||
import 'package:flutter/foundation.dart';
|
|
||||||
import 'package:http/http.dart' as http;
|
import 'package:http/http.dart' as http;
|
||||||
// import 'package:stackwallet/models/exchange/response_objects/fixed_rate_market.dart';
|
// import 'package:stackwallet/models/exchange/response_objects/fixed_rate_market.dart';
|
||||||
// import 'package:stackwallet/models/exchange/response_objects/pair.dart';
|
// import 'package:stackwallet/models/exchange/response_objects/pair.dart';
|
||||||
|
@ -140,16 +139,16 @@ class SimplexAPI {
|
||||||
// }
|
// }
|
||||||
// }
|
// }
|
||||||
|
|
||||||
Future<BuyResponse<List<Fiat>>> getAllCurrencies({
|
dynamic /*Future<BuyResponse<List<Fiat>>>*/ getSupported() async {
|
||||||
String? apiKey,
|
|
||||||
required bool fixedRate,
|
|
||||||
}) async {
|
|
||||||
final uri = _buildUri("/quote", {});
|
final uri = _buildUri("/quote", {});
|
||||||
|
|
||||||
try {
|
try {
|
||||||
final jsonArray = await _makeGetRequest(uri);
|
final jsonArray = await _makeGetRequest(uri);
|
||||||
|
|
||||||
return await compute(_parseAvailableCurrenciesJson, jsonArray as List);
|
print(jsonArray);
|
||||||
|
return null;
|
||||||
|
|
||||||
|
// return await compute(_parseAvailableCurrenciesJson, jsonArray as List);
|
||||||
} catch (e, s) {
|
} catch (e, s) {
|
||||||
Logging.instance.log("getAvailableCurrencies exception: $e\n$s",
|
Logging.instance.log("getAvailableCurrencies exception: $e\n$s",
|
||||||
level: LogLevel.Error);
|
level: LogLevel.Error);
|
||||||
|
|
Loading…
Reference in a new issue