mirror of
https://github.com/cake-tech/cake_wallet.git
synced 2025-01-09 20:39:35 +00:00
c50eeee58b
* Add 'Exchange provider picker' Save user selections * Save user's exchange providers selection * Add text for selected providers availability * Fix selected providers not updating * Load limits based on highest maximum in the selected providers * Change received and deposit amount to be the best value from the selected providers * Add provider name next to Trade ID Set selected provider based on amount calculated * Grey out providers who doesn't support selected currency pair * Fix disabled providers * Add Provider logo in Confirm Screen * Only choose a provider if it satisfies its limits * Fix amount validation * Fix typo in error message * Add a queue of possible exchange providers sorted by the best rate to try next if one failed * Fix string locale typo * Add Localization for other languages * Add Placeholder text when there are no providers selected * Check Exchange provider availability before creating a trade * Fix "Fixed Rate" changing unconditionally * Enable "convert to" field regardless of the provider * Remove "Choose one" from providers picker * Merge Master * Fix Conflicts with master * Add missing isEnabled field in simple swap provider
143 lines
4.2 KiB
Dart
143 lines
4.2 KiB
Dart
import 'dart:async';
|
|
import 'package:cake_wallet/exchange/sideshift/sideshift_exchange_provider.dart';
|
|
import 'package:cake_wallet/exchange/simpleswap/simpleswap_exchange_provider.dart';
|
|
import 'package:cw_core/wallet_base.dart';
|
|
import 'package:cw_core/crypto_currency.dart';
|
|
import 'package:cake_wallet/exchange/changenow/changenow_exchange_provider.dart';
|
|
import 'package:cake_wallet/exchange/exchange_provider.dart';
|
|
import 'package:cake_wallet/exchange/exchange_provider_description.dart';
|
|
import 'package:cake_wallet/exchange/morphtoken/morphtoken_exchange_provider.dart';
|
|
import 'package:cake_wallet/exchange/trade.dart';
|
|
import 'package:cake_wallet/exchange/xmrto/xmrto_exchange_provider.dart';
|
|
import 'package:cake_wallet/store/dashboard/trades_store.dart';
|
|
import 'package:cake_wallet/view_model/send/send_view_model.dart';
|
|
import 'package:hive/hive.dart';
|
|
import 'package:mobx/mobx.dart';
|
|
import 'package:cake_wallet/src/screens/exchange_trade/exchange_trade_item.dart';
|
|
import 'package:cake_wallet/generated/i18n.dart';
|
|
|
|
part 'exchange_trade_view_model.g.dart';
|
|
|
|
class ExchangeTradeViewModel = ExchangeTradeViewModelBase
|
|
with _$ExchangeTradeViewModel;
|
|
|
|
abstract class ExchangeTradeViewModelBase with Store {
|
|
ExchangeTradeViewModelBase(
|
|
{this.wallet, this.trades, this.tradesStore, this.sendViewModel}) {
|
|
trade = tradesStore.trade;
|
|
|
|
isSendable = trade.from == wallet.currency ||
|
|
trade.provider == ExchangeProviderDescription.xmrto;
|
|
|
|
switch (trade.provider) {
|
|
case ExchangeProviderDescription.xmrto:
|
|
_provider = XMRTOExchangeProvider();
|
|
break;
|
|
case ExchangeProviderDescription.changeNow:
|
|
_provider = ChangeNowExchangeProvider();
|
|
break;
|
|
case ExchangeProviderDescription.morphToken:
|
|
_provider = MorphTokenExchangeProvider(trades: trades);
|
|
break;
|
|
case ExchangeProviderDescription.sideShift:
|
|
_provider = SideShiftExchangeProvider();
|
|
break;
|
|
case ExchangeProviderDescription.simpleSwap:
|
|
_provider = SimpleSwapExchangeProvider();
|
|
break;
|
|
}
|
|
|
|
items = ObservableList<ExchangeTradeItem>();
|
|
|
|
_updateItems();
|
|
|
|
_updateTrade();
|
|
|
|
timer = Timer.periodic(Duration(seconds: 20), (_) async => _updateTrade());
|
|
}
|
|
|
|
final WalletBase wallet;
|
|
final Box<Trade> trades;
|
|
final TradesStore tradesStore;
|
|
final SendViewModel sendViewModel;
|
|
|
|
@observable
|
|
Trade trade;
|
|
|
|
@observable
|
|
bool isSendable;
|
|
|
|
@computed
|
|
String get extraInfo => trade.from == CryptoCurrency.xlm
|
|
? '\n\n' + S.current.xlm_extra_info
|
|
: trade.from == CryptoCurrency.xrp
|
|
? '\n\n' + S.current.xrp_extra_info
|
|
: '';
|
|
|
|
@observable
|
|
ObservableList<ExchangeTradeItem> items;
|
|
|
|
ExchangeProvider _provider;
|
|
|
|
Timer timer;
|
|
|
|
@action
|
|
Future confirmSending() async {
|
|
if (!isSendable) {
|
|
return;
|
|
}
|
|
|
|
sendViewModel.clearOutputs();
|
|
final output = sendViewModel.outputs.first;
|
|
|
|
output.address = trade.inputAddress;
|
|
output.setCryptoAmount(trade.amount);
|
|
await sendViewModel.createTransaction();
|
|
}
|
|
|
|
@action
|
|
Future<void> _updateTrade() async {
|
|
try {
|
|
final updatedTrade = await _provider.findTradeById(id: trade.id);
|
|
|
|
if (updatedTrade.createdAt == null && trade.createdAt != null) {
|
|
updatedTrade.createdAt = trade.createdAt;
|
|
}
|
|
|
|
trade = updatedTrade;
|
|
|
|
_updateItems();
|
|
} catch (e) {
|
|
print(e.toString());
|
|
}
|
|
}
|
|
|
|
void _updateItems() {
|
|
items?.clear();
|
|
|
|
items.add(ExchangeTradeItem(
|
|
title: "${trade.provider.title} ${S.current.id}", data: '${trade.id}', isCopied: true));
|
|
|
|
if (trade.extraId != null) {
|
|
final title = trade.from == CryptoCurrency.xrp
|
|
? S.current.destination_tag
|
|
: trade.from == CryptoCurrency.xlm
|
|
? S.current.memo
|
|
: S.current.extra_id;
|
|
|
|
items.add(ExchangeTradeItem(
|
|
title: title, data: '${trade.extraId}', isCopied: false));
|
|
}
|
|
|
|
items.addAll([
|
|
ExchangeTradeItem(
|
|
title: S.current.amount, data: '${trade.amount}', isCopied: false),
|
|
ExchangeTradeItem(
|
|
title: S.current.status, data: '${trade.state}', isCopied: false),
|
|
ExchangeTradeItem(
|
|
title: S.current.widgets_address + ':',
|
|
data: trade.inputAddress,
|
|
isCopied: true),
|
|
]);
|
|
}
|
|
}
|