mirror of
https://github.com/cake-tech/cake_wallet.git
synced 2024-11-01 09:57:46 +00:00
5eabdcdca1
* CW-503 Prepare Ledger integration * CW-503 Revert Tor ignore * CW-503 Add Connect Device Page * CW-503 Add createWalletFromDevice for monero * CW-503 Add Connect Device Page * CW-503 Add Connect Device Page * CW-503 Add Debug Options * CW-503 Add proper hardware wallet selection screen * CW-503 Minor design changes on connect_device_page * CW-503 Add Create Wallet from Ledger * CW-503 Spent Ledger ETH Funds * CW-503 Minor fixes * CW-503 Fix Merge conflicts * CW-503 Fix Merge conflicts * CW-503 Fix Merge conflicts * CW-503 Fix minor conflicts * CW-503 Improve Ledger BLE Communication * CW-503 Improve Ledger BLE Communication * CW-503 Rollback Monero Test code * CW-503 Fix Execution failed for task :app:checkReleaseDuplicateClasses * CW-503 Better Error-Exceptions * CW-503 Add SetPinScreen before restore from hardware-wallet * CW-503 override web3dart to use cake's git hosted version * CW-503 Implement ledger sign messages * CW-503 Implement ledger sign messages and send erc20 tokens * CW-503 Fix merge conflicts * CW-503 Fix merge conflicts * CW-503 Use dep override for ledger_flutter * CW-503 Ledger ERC20 finalisation * CW-503 More graceful error handling * CW-503 Even more graceful error handling & remove debug code * CW-503 Minor Changes for Vik * CW-503 Fix USB connection * CW-503 Maybe this overrides web3dart finally * Indicate Loading on the first 5 Wallet Accounts * Prepare Ledger Bitcoin * Fix conflicts with main * Add Bluetooth permission to iOS [skip ci] * add privacyinfo for ios [skip ci] * update PrivacyInfo.xcprivacy [scip ci] * ios shit [skip ci] * Improve bitcoin xpub * Resolve open Todos regarding iOS Support * Minor debug * Remove erc20 dependency to have more granular control over the tx UX * Create Bitcoin Wallets using xpub * Create Bitcoin Wallets using xpub * Better error handling * Improve Ledger account handling * Add Bitcoin Support for Ledger * Add Bitcoin Support for Ledger * Add Bitcoin Support for Ledger * Implement requested Changes * Implement requested Changes * Minor fix * Implement requested Changes * Implement requested Changes * Add comment to remind me * Enable RBF for Bitcoin Ledger * Fix merge conflicts * Update wallet_info.dart * Cw 503 ledger support (#1310) * CW-503 Prepare Ledger integration * CW-503 Revert Tor ignore * CW-503 Add Connect Device Page * CW-503 Add createWalletFromDevice for monero * CW-503 Add Connect Device Page * CW-503 Add Connect Device Page * CW-503 Add Debug Options * CW-503 Add proper hardware wallet selection screen * CW-503 Minor design changes on connect_device_page * CW-503 Add Create Wallet from Ledger * CW-503 Spent Ledger ETH Funds * CW-503 Minor fixes * CW-503 Fix Merge conflicts * CW-503 Fix Merge conflicts * CW-503 Fix Merge conflicts * CW-503 Fix minor conflicts * CW-503 Improve Ledger BLE Communication * CW-503 Improve Ledger BLE Communication * CW-503 Rollback Monero Test code * CW-503 Fix Execution failed for task :app:checkReleaseDuplicateClasses * CW-503 Better Error-Exceptions * CW-503 Add SetPinScreen before restore from hardware-wallet * CW-503 override web3dart to use cake's git hosted version * CW-503 Implement ledger sign messages * CW-503 Implement ledger sign messages and send erc20 tokens * CW-503 Fix merge conflicts * CW-503 Fix merge conflicts * CW-503 Use dep override for ledger_flutter * CW-503 Ledger ERC20 finalisation * CW-503 More graceful error handling * CW-503 Even more graceful error handling & remove debug code * CW-503 Minor Changes for Vik * CW-503 Fix USB connection * CW-503 Maybe this overrides web3dart finally * Indicate Loading on the first 5 Wallet Accounts * Fix conflicts with main * Add Bluetooth permission to iOS [skip ci] * add privacyinfo for ios [skip ci] * update PrivacyInfo.xcprivacy [scip ci] * ios shit [skip ci] * Resolve open Todos regarding iOS Support * Remove erc20 dependency to have more granular control over the tx UX * Better error handling * Improve Ledger account handling * Implement requested Changes * Implement requested Changes * Implement requested Changes * Implement requested Changes * Fix merge conflicts * Update wallet_info.dart --------- Co-authored-by: Omar Hatem <omarh.ismail1@gmail.com> * Fix merge conflicts * Fix merge conflicts * Minor Fix to derivations * Update cw_bitcoin/lib/bitcoin_wallet.dart [skip ci] * Update cw_bitcoin/lib/bitcoin_wallet.dart [skip ci] * Update cw_bitcoin/lib/electrum_wallet.dart [skip ci] * Fix backward compatibility issues * Merge Tron * Fix Tron with HW changes * fix ble on iOS fix tron address validation --------- Co-authored-by: Omar Hatem <omarh.ismail1@gmail.com>
104 lines
3.5 KiB
Dart
104 lines
3.5 KiB
Dart
import 'package:cake_wallet/.secrets.g.dart' as secrets;
|
|
import 'package:cake_wallet/buy/buy_provider.dart';
|
|
import 'package:cake_wallet/generated/i18n.dart';
|
|
import 'package:cake_wallet/routes.dart';
|
|
import 'package:cake_wallet/store/settings_store.dart';
|
|
import 'package:cake_wallet/themes/extensions/cake_text_theme.dart';
|
|
import 'package:cake_wallet/utils/device_info.dart';
|
|
import 'package:cw_core/crypto_currency.dart';
|
|
import 'package:cw_core/wallet_base.dart';
|
|
import 'package:flutter/material.dart';
|
|
import 'package:url_launcher/url_launcher.dart';
|
|
|
|
class OnRamperBuyProvider extends BuyProvider {
|
|
OnRamperBuyProvider(this._settingsStore,
|
|
{required WalletBase wallet, bool isTestEnvironment = false})
|
|
: super(wallet: wallet, isTestEnvironment: isTestEnvironment, ledgerVM: null);
|
|
|
|
static const _baseUrl = 'buy.onramper.com';
|
|
|
|
final SettingsStore _settingsStore;
|
|
|
|
@override
|
|
String get title => 'Onramper';
|
|
|
|
@override
|
|
String get providerDescription => S.current.onramper_option_description;
|
|
|
|
@override
|
|
String get lightIcon => 'assets/images/onramper_light.png';
|
|
|
|
@override
|
|
String get darkIcon => 'assets/images/onramper_dark.png';
|
|
|
|
String get _apiKey => secrets.onramperApiKey;
|
|
|
|
String get _normalizeCryptoCurrency {
|
|
switch (wallet.currency) {
|
|
case CryptoCurrency.ltc:
|
|
return "LTC_LITECOIN";
|
|
case CryptoCurrency.xmr:
|
|
return "XMR_MONERO";
|
|
case CryptoCurrency.bch:
|
|
return "BCH_BITCOINCASH";
|
|
case CryptoCurrency.nano:
|
|
return "XNO_NANO";
|
|
default:
|
|
return wallet.currency.title;
|
|
}
|
|
}
|
|
|
|
String getColorStr(Color color) {
|
|
return color.value.toRadixString(16).replaceAll(RegExp(r'^ff'), "");
|
|
}
|
|
|
|
Uri requestOnramperUrl(BuildContext context, bool? isBuyAction) {
|
|
String primaryColor,
|
|
secondaryColor,
|
|
primaryTextColor,
|
|
secondaryTextColor,
|
|
containerColor,
|
|
cardColor;
|
|
|
|
primaryColor = getColorStr(Theme.of(context).primaryColor);
|
|
secondaryColor = getColorStr(Theme.of(context).colorScheme.background);
|
|
primaryTextColor =
|
|
getColorStr(Theme.of(context).extension<CakeTextTheme>()!.titleColor);
|
|
secondaryTextColor = getColorStr(
|
|
Theme.of(context).extension<CakeTextTheme>()!.secondaryTextColor);
|
|
containerColor = getColorStr(Theme.of(context).colorScheme.background);
|
|
cardColor = getColorStr(Theme.of(context).cardColor);
|
|
|
|
if (_settingsStore.currentTheme.title == S.current.high_contrast_theme) {
|
|
cardColor = getColorStr(Colors.white);
|
|
}
|
|
|
|
final networkName =
|
|
wallet.currency.fullName?.toUpperCase().replaceAll(" ", "");
|
|
|
|
return Uri.https(_baseUrl, '', <String, dynamic>{
|
|
'apiKey': _apiKey,
|
|
'defaultCrypto': _normalizeCryptoCurrency,
|
|
'sell_defaultCrypto': _normalizeCryptoCurrency,
|
|
'networkWallets': '${networkName}:${wallet.walletAddresses.address}',
|
|
'supportSwap': "false",
|
|
'primaryColor': primaryColor,
|
|
'secondaryColor': secondaryColor,
|
|
'primaryTextColor': primaryTextColor,
|
|
'secondaryTextColor': secondaryTextColor,
|
|
'containerColor': containerColor,
|
|
'cardColor': cardColor,
|
|
'mode': isBuyAction == true ? 'buy' : 'sell',
|
|
});
|
|
}
|
|
|
|
Future<void> launchProvider(BuildContext context, bool? isBuyAction) async {
|
|
final uri = requestOnramperUrl(context, isBuyAction);
|
|
if (DeviceInfo.instance.isMobile) {
|
|
Navigator.of(context)
|
|
.pushNamed(Routes.webViewPage, arguments: [title, uri]);
|
|
} else {
|
|
await launchUrl(uri);
|
|
}
|
|
}
|
|
}
|