mirror of
https://github.com/cake-tech/cake_wallet.git
synced 2024-12-23 12:09:43 +00:00
d1870ba8b8
* chore: Initial setup for Tron Wallet * feat: Create Tron Wallet base flow implemented, keys, address, receive, restore and proxy classes all setup * feat: Display seed and key within the app * feat: Activate restore from key and seed for Tron wallet * feat: Add icon for tron wallet in wallet listing page * feat: Activate display of receive address for tron * feat: Fetch and display tron balance, sending transaction flow setup, fee limit calculation setup * feat: Implement sending of native tron, setup sending of trc20 tokens * chore: Rename function * Delete lib/tron/tron.dart * feat: Activate exchange for tron and its tokens, implement balance display for trc20 tokens and setup secrets configuration for tron * feat: Implement tron token management, add, remove, delete, and get tokens in home settings view, also minor cleanup * feat: Activate buy and sell for tron * feat: Implement restore from QR, transactions history listing for both native transactions and trc20 transactions * feat: Activate send all and do some minor cleanups * chore: Fix some lint infos and warnings * chore: Adjust configurations * ci: Modify CI to create and add secrets for node * fix: Fixes made while self reviewing the PR for this feature * feat: Add guide for adding new wallet types, and add fixes to requested changes * fix: Handle exceptions gracefully * fix: Alternative for trc20 estimated fee * fix: Fixes to display of amount and fee, removing clashes * fix: Fee calculation WIP * fix: Fix issue with handling of send all flow and display of amount and fee values before broadcasting transaction * fix: PR review fixes and fix merge conflicts * fix: Modify fetching assetOfTransaction [skip ci] * fix: Move tron settings migration to 33
92 lines
3.1 KiB
Dart
92 lines
3.1 KiB
Dart
import 'dart:async';
|
|
import 'package:cake_wallet/core/fiat_conversion_service.dart';
|
|
import 'package:cake_wallet/entities/fiat_api_mode.dart';
|
|
import 'package:cake_wallet/entities/update_haven_rate.dart';
|
|
import 'package:cake_wallet/ethereum/ethereum.dart';
|
|
import 'package:cake_wallet/polygon/polygon.dart';
|
|
import 'package:cake_wallet/solana/solana.dart';
|
|
import 'package:cake_wallet/store/app_store.dart';
|
|
import 'package:cake_wallet/store/dashboard/fiat_conversion_store.dart';
|
|
import 'package:cake_wallet/store/settings_store.dart';
|
|
import 'package:cake_wallet/tron/tron.dart';
|
|
import 'package:cw_core/crypto_currency.dart';
|
|
import 'package:cw_core/erc20_token.dart';
|
|
import 'package:cw_core/wallet_type.dart';
|
|
import 'package:mobx/mobx.dart';
|
|
|
|
Timer? _timer;
|
|
|
|
Future<void> startFiatRateUpdate(
|
|
AppStore appStore, SettingsStore settingsStore, FiatConversionStore fiatConversionStore) async {
|
|
if (_timer != null) {
|
|
return;
|
|
}
|
|
|
|
final _updateFiat = (_) async {
|
|
try {
|
|
if (appStore.wallet == null || settingsStore.fiatApiMode == FiatApiMode.disabled) {
|
|
return;
|
|
}
|
|
|
|
if (appStore.wallet!.type == WalletType.haven) {
|
|
await updateHavenRate(fiatConversionStore);
|
|
} else {
|
|
fiatConversionStore.prices[appStore.wallet!.currency] =
|
|
await FiatConversionService.fetchPrice(
|
|
crypto: appStore.wallet!.currency,
|
|
fiat: settingsStore.fiatCurrency,
|
|
torOnly: settingsStore.fiatApiMode == FiatApiMode.torOnly);
|
|
}
|
|
|
|
Iterable<CryptoCurrency>? currencies;
|
|
if (appStore.wallet!.type == WalletType.ethereum) {
|
|
currencies =
|
|
ethereum!.getERC20Currencies(appStore.wallet!).where((element) => element.enabled);
|
|
}
|
|
|
|
if (appStore.wallet!.type == WalletType.polygon) {
|
|
currencies =
|
|
polygon!.getERC20Currencies(appStore.wallet!).where((element) => element.enabled);
|
|
}
|
|
|
|
if (appStore.wallet!.type == WalletType.solana) {
|
|
currencies =
|
|
solana!.getSPLTokenCurrencies(appStore.wallet!).where((element) => element.enabled);
|
|
}
|
|
|
|
if (appStore.wallet!.type == WalletType.tron) {
|
|
currencies =
|
|
tron!.getTronTokenCurrencies(appStore.wallet!).where((element) => element.enabled);
|
|
}
|
|
|
|
|
|
if (currencies != null) {
|
|
for (final currency in currencies) {
|
|
() async {
|
|
fiatConversionStore.prices[currency] = await FiatConversionService.fetchPrice(
|
|
crypto: currency,
|
|
fiat: settingsStore.fiatCurrency,
|
|
torOnly: settingsStore.fiatApiMode == FiatApiMode.torOnly);
|
|
}.call();
|
|
}
|
|
}
|
|
} catch (e) {
|
|
print(e);
|
|
}
|
|
};
|
|
|
|
_timer = Timer.periodic(Duration(seconds: 30), _updateFiat);
|
|
// also run immediately:
|
|
_updateFiat(null);
|
|
|
|
// setup autorun to listen to changes in fiatApiMode
|
|
autorun((_) {
|
|
// restart the timer if fiatApiMode was re-enabled
|
|
if (settingsStore.fiatApiMode != FiatApiMode.disabled) {
|
|
_timer = Timer.periodic(Duration(seconds: 30), _updateFiat);
|
|
_updateFiat(null);
|
|
} else {
|
|
_timer?.cancel();
|
|
}
|
|
});
|
|
}
|