mirror of
https://github.com/cake-tech/cake_wallet.git
synced 2025-01-24 11:36:21 +00:00
Merge branch 'main' of https://github.com/cake-tech/cake_wallet into CW-225-pin-timeout
This commit is contained in:
commit
65cbdd3fbb
58 changed files with 767 additions and 790 deletions
|
@ -1,31 +1,24 @@
|
||||||
-
|
-
|
||||||
uri: xmr-node-uk.cakewallet.com:18081
|
uri: xmr-node.cakewallet.com:18081
|
||||||
is_default: true
|
is_default: true
|
||||||
-
|
-
|
||||||
uri: xmr-node-eu.cakewallet.com:18081
|
uri: cakexmrl7bonq7ovjka5kuwuyd3f7qnkz6z6s6dmsy3uckwra7bvggyd.onion:18081
|
||||||
is_default: false
|
is_default: false
|
||||||
-
|
-
|
||||||
uri: xmr-node-usa-east.cakewallet.com:18081
|
uri: node.sethforprivacy.com:18089
|
||||||
|
is_default: false
|
||||||
|
-
|
||||||
|
uri: nodes.hashvault.pro:18081
|
||||||
|
is_default: false
|
||||||
|
-
|
||||||
|
uri: node.c3pool.com:18081
|
||||||
|
is_default: false
|
||||||
|
-
|
||||||
|
uri: node.supportxmr.com:18081
|
||||||
|
is_default: false
|
||||||
|
-
|
||||||
|
uri: node.community.rino.io:18081
|
||||||
is_default: false
|
is_default: false
|
||||||
-
|
-
|
||||||
uri: node.moneroworld.com:18089
|
uri: node.moneroworld.com:18089
|
||||||
is_default: false
|
is_default: false
|
||||||
-
|
|
||||||
uri: node.xmr.pt:18081
|
|
||||||
is_default: false
|
|
||||||
-
|
|
||||||
uri: node.monero.net:18081
|
|
||||||
is_default: false
|
|
||||||
-
|
|
||||||
uri: opennode.xmr-tw.org:18089
|
|
||||||
is_default: false
|
|
||||||
-
|
|
||||||
uri: node.imonero.org:18081
|
|
||||||
is_default: false
|
|
||||||
|
|
||||||
uri: node.c3pool.com:18081
|
|
||||||
is_default: false
|
|
||||||
|
|
||||||
uri: xmr.prprpr.icu:18081
|
|
||||||
is_default: false
|
|
||||||
|
|
||||||
|
|
|
@ -129,7 +129,7 @@ abstract class ElectrumWalletBase extends WalletBase<ElectrumBalance,
|
||||||
@override
|
@override
|
||||||
Future<void> startSync() async {
|
Future<void> startSync() async {
|
||||||
try {
|
try {
|
||||||
syncStatus = StartingSyncStatus();
|
syncStatus = AttemptingSyncStatus();
|
||||||
await walletAddresses.discoverAddresses();
|
await walletAddresses.discoverAddresses();
|
||||||
await updateTransactions();
|
await updateTransactions();
|
||||||
_subscribeForUpdates();
|
_subscribeForUpdates();
|
||||||
|
|
|
@ -17,6 +17,7 @@ class Node extends HiveObject with Keyable {
|
||||||
{this.login,
|
{this.login,
|
||||||
this.password,
|
this.password,
|
||||||
this.useSSL,
|
this.useSSL,
|
||||||
|
this.trusted = false,
|
||||||
String? uri,
|
String? uri,
|
||||||
WalletType? type,}) {
|
WalletType? type,}) {
|
||||||
if (uri != null) {
|
if (uri != null) {
|
||||||
|
@ -31,7 +32,8 @@ class Node extends HiveObject with Keyable {
|
||||||
: uriRaw = map['uri'] as String? ?? '',
|
: uriRaw = map['uri'] as String? ?? '',
|
||||||
login = map['login'] as String?,
|
login = map['login'] as String?,
|
||||||
password = map['password'] as String?,
|
password = map['password'] as String?,
|
||||||
useSSL = map['useSSL'] as bool?;
|
useSSL = map['useSSL'] as bool?,
|
||||||
|
trusted = map['trusted'] as bool? ?? false;
|
||||||
|
|
||||||
static const typeId = 1;
|
static const typeId = 1;
|
||||||
static const boxName = 'Nodes';
|
static const boxName = 'Nodes';
|
||||||
|
@ -51,6 +53,9 @@ class Node extends HiveObject with Keyable {
|
||||||
@HiveField(4)
|
@HiveField(4)
|
||||||
bool? useSSL;
|
bool? useSSL;
|
||||||
|
|
||||||
|
@HiveField(5)
|
||||||
|
bool trusted;
|
||||||
|
|
||||||
bool get isSSL => useSSL ?? false;
|
bool get isSSL => useSSL ?? false;
|
||||||
|
|
||||||
Uri get uri {
|
Uri get uri {
|
||||||
|
|
|
@ -28,7 +28,7 @@ class NotConnectedSyncStatus extends SyncStatus {
|
||||||
double progress() => 0.0;
|
double progress() => 0.0;
|
||||||
}
|
}
|
||||||
|
|
||||||
class StartingSyncStatus extends SyncStatus {
|
class AttemptingSyncStatus extends SyncStatus {
|
||||||
@override
|
@override
|
||||||
double progress() => 0.0;
|
double progress() => 0.0;
|
||||||
}
|
}
|
||||||
|
|
|
@ -927,6 +927,16 @@ extern "C"
|
||||||
return static_cast<int32_t>(rates.size());
|
return static_cast<int32_t>(rates.size());
|
||||||
}
|
}
|
||||||
|
|
||||||
|
void set_trusted_daemon(bool arg)
|
||||||
|
{
|
||||||
|
m_wallet->setTrustedDaemon(arg);
|
||||||
|
}
|
||||||
|
|
||||||
|
bool trusted_daemon()
|
||||||
|
{
|
||||||
|
return m_wallet->trustedDaemon();
|
||||||
|
}
|
||||||
|
|
||||||
#ifdef __cplusplus
|
#ifdef __cplusplus
|
||||||
}
|
}
|
||||||
#endif
|
#endif
|
||||||
|
|
|
@ -138,3 +138,7 @@ typedef get_rate = Pointer<Int64> Function();
|
||||||
typedef size_of_rate = Int32 Function();
|
typedef size_of_rate = Int32 Function();
|
||||||
|
|
||||||
typedef update_rate = Void Function();
|
typedef update_rate = Void Function();
|
||||||
|
|
||||||
|
typedef set_trusted_daemon = Void Function(Int8 trusted);
|
||||||
|
|
||||||
|
typedef trusted_daemon = Int8 Function();
|
|
@ -136,3 +136,7 @@ typedef GetRate = Pointer<Int64> Function();
|
||||||
typedef SizeOfRate = int Function();
|
typedef SizeOfRate = int Function();
|
||||||
|
|
||||||
typedef UpdateRate = void Function();
|
typedef UpdateRate = void Function();
|
||||||
|
|
||||||
|
typedef SetTrustedDaemon = void Function(int);
|
||||||
|
|
||||||
|
typedef TrustedDaemon = int Function();
|
|
@ -116,6 +116,14 @@ final rescanBlockchainAsyncNative = havenApi
|
||||||
.lookup<NativeFunction<rescan_blockchain>>('rescan_blockchain')
|
.lookup<NativeFunction<rescan_blockchain>>('rescan_blockchain')
|
||||||
.asFunction<RescanBlockchainAsync>();
|
.asFunction<RescanBlockchainAsync>();
|
||||||
|
|
||||||
|
final setTrustedDaemonNative = havenApi
|
||||||
|
.lookup<NativeFunction<set_trusted_daemon>>('set_trusted_daemon')
|
||||||
|
.asFunction<SetTrustedDaemon>();
|
||||||
|
|
||||||
|
final trustedDaemonNative = havenApi
|
||||||
|
.lookup<NativeFunction<trusted_daemon>>('trusted_daemon')
|
||||||
|
.asFunction<TrustedDaemon>();
|
||||||
|
|
||||||
int getSyncingHeight() => getSyncingHeightNative();
|
int getSyncingHeight() => getSyncingHeightNative();
|
||||||
|
|
||||||
bool isNeededToRefresh() => isNeededToRefreshNative() != 0;
|
bool isNeededToRefresh() => isNeededToRefreshNative() != 0;
|
||||||
|
@ -351,3 +359,7 @@ Future<bool> isConnected() => compute(_isConnected, 0);
|
||||||
Future<int> getNodeHeight() => compute(_getNodeHeight, 0);
|
Future<int> getNodeHeight() => compute(_getNodeHeight, 0);
|
||||||
|
|
||||||
void rescanBlockchainAsync() => rescanBlockchainAsyncNative();
|
void rescanBlockchainAsync() => rescanBlockchainAsyncNative();
|
||||||
|
|
||||||
|
Future setTrustedDaemon(bool trusted) async => setTrustedDaemonNative(_boolToInt(trusted));
|
||||||
|
|
||||||
|
Future<bool> trustedDaemon() async => trustedDaemonNative() != 0;
|
||||||
|
|
|
@ -121,6 +121,8 @@ abstract class HavenWalletBase extends WalletBase<MoneroBalance,
|
||||||
password: node.password,
|
password: node.password,
|
||||||
useSSL: node.useSSL ?? false,
|
useSSL: node.useSSL ?? false,
|
||||||
isLightWallet: false); // FIXME: hardcoded value
|
isLightWallet: false); // FIXME: hardcoded value
|
||||||
|
|
||||||
|
haven_wallet.setTrustedDaemon(node.trusted);
|
||||||
syncStatus = ConnectedSyncStatus();
|
syncStatus = ConnectedSyncStatus();
|
||||||
} catch (e) {
|
} catch (e) {
|
||||||
syncStatus = FailedSyncStatus();
|
syncStatus = FailedSyncStatus();
|
||||||
|
@ -135,7 +137,7 @@ abstract class HavenWalletBase extends WalletBase<MoneroBalance,
|
||||||
} catch (_) {}
|
} catch (_) {}
|
||||||
|
|
||||||
try {
|
try {
|
||||||
syncStatus = StartingSyncStatus();
|
syncStatus = AttemptingSyncStatus();
|
||||||
haven_wallet.startRefresh();
|
haven_wallet.startRefresh();
|
||||||
_setListeners();
|
_setListeners();
|
||||||
_listener?.start();
|
_listener?.start();
|
||||||
|
|
|
@ -783,6 +783,16 @@ extern "C"
|
||||||
return strdup(get_current_wallet()->getSubaddressLabel(accountIndex, addressIndex).c_str());
|
return strdup(get_current_wallet()->getSubaddressLabel(accountIndex, addressIndex).c_str());
|
||||||
}
|
}
|
||||||
|
|
||||||
|
void set_trusted_daemon(bool arg)
|
||||||
|
{
|
||||||
|
m_wallet->setTrustedDaemon(arg);
|
||||||
|
}
|
||||||
|
|
||||||
|
bool trusted_daemon()
|
||||||
|
{
|
||||||
|
return m_wallet->trustedDaemon();
|
||||||
|
}
|
||||||
|
|
||||||
#ifdef __cplusplus
|
#ifdef __cplusplus
|
||||||
}
|
}
|
||||||
#endif
|
#endif
|
||||||
|
|
|
@ -30,6 +30,9 @@ void set_refresh_from_block_height(uint64_t height);
|
||||||
void set_recovering_from_seed(bool is_recovery);
|
void set_recovering_from_seed(bool is_recovery);
|
||||||
void store(char *path);
|
void store(char *path);
|
||||||
|
|
||||||
|
void set_trusted_daemon(bool arg);
|
||||||
|
bool trusted_daemon();
|
||||||
|
|
||||||
#ifdef __cplusplus
|
#ifdef __cplusplus
|
||||||
}
|
}
|
||||||
#endif
|
#endif
|
|
@ -126,3 +126,7 @@ typedef rescan_blockchain = Void Function();
|
||||||
typedef get_subaddress_label = Pointer<Utf8> Function(
|
typedef get_subaddress_label = Pointer<Utf8> Function(
|
||||||
Int32 accountIndex,
|
Int32 accountIndex,
|
||||||
Int32 addressIndex);
|
Int32 addressIndex);
|
||||||
|
|
||||||
|
typedef set_trusted_daemon = Void Function(Int8 trusted);
|
||||||
|
|
||||||
|
typedef trusted_daemon = Int8 Function();
|
|
@ -124,3 +124,7 @@ typedef RescanBlockchainAsync = void Function();
|
||||||
typedef GetSubaddressLabel = Pointer<Utf8> Function(
|
typedef GetSubaddressLabel = Pointer<Utf8> Function(
|
||||||
int accountIndex,
|
int accountIndex,
|
||||||
int addressIndex);
|
int addressIndex);
|
||||||
|
|
||||||
|
typedef SetTrustedDaemon = void Function(int);
|
||||||
|
|
||||||
|
typedef TrustedDaemon = int Function();
|
|
@ -120,6 +120,14 @@ final getSubaddressLabelNative = moneroApi
|
||||||
.lookup<NativeFunction<get_subaddress_label>>('get_subaddress_label')
|
.lookup<NativeFunction<get_subaddress_label>>('get_subaddress_label')
|
||||||
.asFunction<GetSubaddressLabel>();
|
.asFunction<GetSubaddressLabel>();
|
||||||
|
|
||||||
|
final setTrustedDaemonNative = moneroApi
|
||||||
|
.lookup<NativeFunction<set_trusted_daemon>>('set_trusted_daemon')
|
||||||
|
.asFunction<SetTrustedDaemon>();
|
||||||
|
|
||||||
|
final trustedDaemonNative = moneroApi
|
||||||
|
.lookup<NativeFunction<trusted_daemon>>('trusted_daemon')
|
||||||
|
.asFunction<TrustedDaemon>();
|
||||||
|
|
||||||
int getSyncingHeight() => getSyncingHeightNative();
|
int getSyncingHeight() => getSyncingHeightNative();
|
||||||
|
|
||||||
bool isNeededToRefresh() => isNeededToRefreshNative() != 0;
|
bool isNeededToRefresh() => isNeededToRefreshNative() != 0;
|
||||||
|
@ -360,3 +368,7 @@ void rescanBlockchainAsync() => rescanBlockchainAsyncNative();
|
||||||
String getSubaddressLabel(int accountIndex, int addressIndex) {
|
String getSubaddressLabel(int accountIndex, int addressIndex) {
|
||||||
return convertUTF8ToString(pointer: getSubaddressLabelNative(accountIndex, addressIndex));
|
return convertUTF8ToString(pointer: getSubaddressLabelNative(accountIndex, addressIndex));
|
||||||
}
|
}
|
||||||
|
|
||||||
|
Future setTrustedDaemon(bool trusted) async => setTrustedDaemonNative(_boolToInt(trusted));
|
||||||
|
|
||||||
|
Future<bool> trustedDaemon() async => trustedDaemonNative() != 0;
|
|
@ -136,6 +136,8 @@ abstract class MoneroWalletBase extends WalletBase<MoneroBalance,
|
||||||
password: node.password,
|
password: node.password,
|
||||||
useSSL: node.isSSL,
|
useSSL: node.isSSL,
|
||||||
isLightWallet: false); // FIXME: hardcoded value
|
isLightWallet: false); // FIXME: hardcoded value
|
||||||
|
|
||||||
|
monero_wallet.setTrustedDaemon(node.trusted);
|
||||||
syncStatus = ConnectedSyncStatus();
|
syncStatus = ConnectedSyncStatus();
|
||||||
} catch (e) {
|
} catch (e) {
|
||||||
syncStatus = FailedSyncStatus();
|
syncStatus = FailedSyncStatus();
|
||||||
|
@ -150,7 +152,7 @@ abstract class MoneroWalletBase extends WalletBase<MoneroBalance,
|
||||||
} catch (_) {}
|
} catch (_) {}
|
||||||
|
|
||||||
try {
|
try {
|
||||||
syncStatus = StartingSyncStatus();
|
syncStatus = AttemptingSyncStatus();
|
||||||
monero_wallet.startRefresh();
|
monero_wallet.startRefresh();
|
||||||
_setListeners();
|
_setListeners();
|
||||||
_listener?.start();
|
_listener?.start();
|
||||||
|
|
|
@ -14,8 +14,8 @@ String syncStatusTitle(SyncStatus syncStatus) {
|
||||||
return S.current.sync_status_not_connected;
|
return S.current.sync_status_not_connected;
|
||||||
}
|
}
|
||||||
|
|
||||||
if (syncStatus is StartingSyncStatus) {
|
if (syncStatus is AttemptingSyncStatus) {
|
||||||
return S.current.sync_status_starting_sync;
|
return S.current.sync_status_attempting_sync;
|
||||||
}
|
}
|
||||||
|
|
||||||
if (syncStatus is FailedSyncStatus) {
|
if (syncStatus is FailedSyncStatus) {
|
||||||
|
|
421
lib/di.dart
421
lib/di.dart
|
@ -31,6 +31,10 @@ import 'package:cake_wallet/src/screens/dashboard/widgets/balance_page.dart';
|
||||||
import 'package:cake_wallet/view_model/ionia/ionia_account_view_model.dart';
|
import 'package:cake_wallet/view_model/ionia/ionia_account_view_model.dart';
|
||||||
import 'package:cake_wallet/view_model/ionia/ionia_gift_cards_list_view_model.dart';
|
import 'package:cake_wallet/view_model/ionia/ionia_gift_cards_list_view_model.dart';
|
||||||
import 'package:cake_wallet/view_model/ionia/ionia_purchase_merch_view_model.dart';
|
import 'package:cake_wallet/view_model/ionia/ionia_purchase_merch_view_model.dart';
|
||||||
|
import 'package:cake_wallet/view_model/settings/display_settings_view_model.dart';
|
||||||
|
import 'package:cake_wallet/view_model/settings/other_settings_view_model.dart';
|
||||||
|
import 'package:cake_wallet/view_model/settings/privacy_settings_view_model.dart';
|
||||||
|
import 'package:cake_wallet/view_model/settings/security_settings_view_model.dart';
|
||||||
import 'package:cw_core/unspent_coins_info.dart';
|
import 'package:cw_core/unspent_coins_info.dart';
|
||||||
import 'package:cake_wallet/core/backup_service.dart';
|
import 'package:cake_wallet/core/backup_service.dart';
|
||||||
import 'package:cw_core/wallet_service.dart';
|
import 'package:cw_core/wallet_service.dart';
|
||||||
|
@ -54,7 +58,6 @@ import 'package:cake_wallet/src/screens/exchange_trade/exchange_trade_page.dart'
|
||||||
import 'package:cake_wallet/src/screens/faq/faq_page.dart';
|
import 'package:cake_wallet/src/screens/faq/faq_page.dart';
|
||||||
import 'package:cake_wallet/src/screens/new_wallet/new_wallet_type_page.dart';
|
import 'package:cake_wallet/src/screens/new_wallet/new_wallet_type_page.dart';
|
||||||
import 'package:cake_wallet/src/screens/nodes/node_create_or_edit_page.dart';
|
import 'package:cake_wallet/src/screens/nodes/node_create_or_edit_page.dart';
|
||||||
import 'package:cake_wallet/src/screens/nodes/nodes_list_page.dart';
|
|
||||||
import 'package:cake_wallet/src/screens/order_details/order_details_page.dart';
|
import 'package:cake_wallet/src/screens/order_details/order_details_page.dart';
|
||||||
import 'package:cake_wallet/src/screens/pin_code/pin_code_widget.dart';
|
import 'package:cake_wallet/src/screens/pin_code/pin_code_widget.dart';
|
||||||
import 'package:cake_wallet/src/screens/rescan/rescan_page.dart';
|
import 'package:cake_wallet/src/screens/rescan/rescan_page.dart';
|
||||||
|
@ -119,7 +122,6 @@ import 'package:cake_wallet/view_model/wallet_address_list/wallet_address_list_v
|
||||||
import 'package:cake_wallet/view_model/monero_account_list/monero_account_edit_or_create_view_model.dart';
|
import 'package:cake_wallet/view_model/monero_account_list/monero_account_edit_or_create_view_model.dart';
|
||||||
import 'package:cake_wallet/view_model/monero_account_list/monero_account_list_view_model.dart';
|
import 'package:cake_wallet/view_model/monero_account_list/monero_account_list_view_model.dart';
|
||||||
import 'package:cake_wallet/view_model/send/send_view_model.dart';
|
import 'package:cake_wallet/view_model/send/send_view_model.dart';
|
||||||
import 'package:cake_wallet/view_model/settings/settings_view_model.dart';
|
|
||||||
import 'package:cake_wallet/view_model/wallet_keys_view_model.dart';
|
import 'package:cake_wallet/view_model/wallet_keys_view_model.dart';
|
||||||
import 'package:cake_wallet/view_model/wallet_list/wallet_list_view_model.dart';
|
import 'package:cake_wallet/view_model/wallet_list/wallet_list_view_model.dart';
|
||||||
import 'package:cake_wallet/view_model/wallet_restore_view_model.dart';
|
import 'package:cake_wallet/view_model/wallet_restore_view_model.dart';
|
||||||
|
@ -192,8 +194,7 @@ Future setup(
|
||||||
_unspentCoinsInfoSource = unspentCoinsInfoSource;
|
_unspentCoinsInfoSource = unspentCoinsInfoSource;
|
||||||
|
|
||||||
if (!_isSetupFinished) {
|
if (!_isSetupFinished) {
|
||||||
getIt.registerSingletonAsync<SharedPreferences>(
|
getIt.registerSingletonAsync<SharedPreferences>(() => SharedPreferences.getInstance());
|
||||||
() => SharedPreferences.getInstance());
|
|
||||||
}
|
}
|
||||||
|
|
||||||
final isBitcoinBuyEnabled = (secrets.wyreSecretKey?.isNotEmpty ?? false) &&
|
final isBitcoinBuyEnabled = (secrets.wyreSecretKey?.isNotEmpty ?? false) &&
|
||||||
|
@ -219,73 +220,64 @@ Future setup(
|
||||||
walletList: getIt.get<WalletListStore>(),
|
walletList: getIt.get<WalletListStore>(),
|
||||||
settingsStore: getIt.get<SettingsStore>(),
|
settingsStore: getIt.get<SettingsStore>(),
|
||||||
nodeListStore: getIt.get<NodeListStore>()));
|
nodeListStore: getIt.get<NodeListStore>()));
|
||||||
getIt.registerSingleton<TradesStore>(TradesStore(
|
getIt.registerSingleton<TradesStore>(
|
||||||
tradesSource: _tradesSource, settingsStore: getIt.get<SettingsStore>()));
|
TradesStore(tradesSource: _tradesSource, settingsStore: getIt.get<SettingsStore>()));
|
||||||
getIt.registerSingleton<OrdersStore>(OrdersStore(
|
getIt.registerSingleton<OrdersStore>(
|
||||||
ordersSource: _ordersSource, settingsStore: getIt.get<SettingsStore>()));
|
OrdersStore(ordersSource: _ordersSource, settingsStore: getIt.get<SettingsStore>()));
|
||||||
getIt.registerSingleton<TradeFilterStore>(TradeFilterStore());
|
getIt.registerSingleton<TradeFilterStore>(TradeFilterStore());
|
||||||
getIt.registerSingleton<TransactionFilterStore>(TransactionFilterStore());
|
getIt.registerSingleton<TransactionFilterStore>(TransactionFilterStore());
|
||||||
getIt.registerSingleton<FiatConversionStore>(FiatConversionStore());
|
getIt.registerSingleton<FiatConversionStore>(FiatConversionStore());
|
||||||
getIt.registerSingleton<SendTemplateStore>(
|
getIt.registerSingleton<SendTemplateStore>(SendTemplateStore(templateSource: _templates));
|
||||||
SendTemplateStore(templateSource: _templates));
|
|
||||||
getIt.registerSingleton<ExchangeTemplateStore>(
|
getIt.registerSingleton<ExchangeTemplateStore>(
|
||||||
ExchangeTemplateStore(templateSource: _exchangeTemplates));
|
ExchangeTemplateStore(templateSource: _exchangeTemplates));
|
||||||
getIt.registerSingleton<YatStore>(YatStore(
|
getIt.registerSingleton<YatStore>(
|
||||||
appStore: getIt.get<AppStore>(),
|
YatStore(appStore: getIt.get<AppStore>(), secureStorage: getIt.get<FlutterSecureStorage>())
|
||||||
secureStorage: getIt.get<FlutterSecureStorage>())
|
..init());
|
||||||
..init());
|
|
||||||
|
|
||||||
final secretStore =
|
final secretStore = await SecretStoreBase.load(getIt.get<FlutterSecureStorage>());
|
||||||
await SecretStoreBase.load(getIt.get<FlutterSecureStorage>());
|
|
||||||
|
|
||||||
getIt.registerSingleton<SecretStore>(secretStore);
|
getIt.registerSingleton<SecretStore>(secretStore);
|
||||||
|
|
||||||
getIt.registerFactory<KeyService>(
|
getIt.registerFactory<KeyService>(() => KeyService(getIt.get<FlutterSecureStorage>()));
|
||||||
() => KeyService(getIt.get<FlutterSecureStorage>()));
|
|
||||||
|
|
||||||
getIt.registerFactoryParam<WalletCreationService, WalletType, void>(
|
getIt.registerFactoryParam<WalletCreationService, WalletType, void>((type, _) =>
|
||||||
(type, _) => WalletCreationService(
|
WalletCreationService(
|
||||||
initialType: type,
|
initialType: type,
|
||||||
keyService: getIt.get<KeyService>(),
|
keyService: getIt.get<KeyService>(),
|
||||||
secureStorage: getIt.get<FlutterSecureStorage>(),
|
secureStorage: getIt.get<FlutterSecureStorage>(),
|
||||||
sharedPreferences: getIt.get<SharedPreferences>(),
|
sharedPreferences: getIt.get<SharedPreferences>(),
|
||||||
walletInfoSource: _walletInfoSource));
|
walletInfoSource: _walletInfoSource));
|
||||||
|
|
||||||
getIt.registerFactory<WalletLoadingService>(
|
getIt.registerFactory<WalletLoadingService>(() => WalletLoadingService(
|
||||||
() => WalletLoadingService(
|
|
||||||
getIt.get<SharedPreferences>(),
|
getIt.get<SharedPreferences>(),
|
||||||
getIt.get<KeyService>(),
|
getIt.get<KeyService>(),
|
||||||
(WalletType type) => getIt.get<WalletService>(param1: type)));
|
(WalletType type) => getIt.get<WalletService>(param1: type)));
|
||||||
|
|
||||||
getIt.registerFactoryParam<WalletNewVM, WalletType, void>((type, _) =>
|
getIt.registerFactoryParam<WalletNewVM, WalletType, void>((type, _) => WalletNewVM(
|
||||||
WalletNewVM(getIt.get<AppStore>(),
|
getIt.get<AppStore>(), getIt.get<WalletCreationService>(param1: type), _walletInfoSource,
|
||||||
getIt.get<WalletCreationService>(param1: type), _walletInfoSource,
|
type: type));
|
||||||
type: type));
|
|
||||||
|
|
||||||
getIt
|
getIt.registerFactoryParam<WalletRestorationFromSeedVM, List, void>((args, _) {
|
||||||
.registerFactoryParam<WalletRestorationFromSeedVM, List, void>((args, _) {
|
|
||||||
final type = args.first as WalletType;
|
final type = args.first as WalletType;
|
||||||
final language = args[1] as String;
|
final language = args[1] as String;
|
||||||
final mnemonic = args[2] as String;
|
final mnemonic = args[2] as String;
|
||||||
|
|
||||||
return WalletRestorationFromSeedVM(getIt.get<AppStore>(),
|
return WalletRestorationFromSeedVM(
|
||||||
getIt.get<WalletCreationService>(param1: type), _walletInfoSource,
|
getIt.get<AppStore>(), getIt.get<WalletCreationService>(param1: type), _walletInfoSource,
|
||||||
type: type, language: language, seed: mnemonic);
|
type: type, language: language, seed: mnemonic);
|
||||||
});
|
});
|
||||||
|
|
||||||
getIt
|
getIt.registerFactoryParam<WalletRestorationFromKeysVM, List, void>((args, _) {
|
||||||
.registerFactoryParam<WalletRestorationFromKeysVM, List, void>((args, _) {
|
|
||||||
final type = args.first as WalletType;
|
final type = args.first as WalletType;
|
||||||
final language = args[1] as String;
|
final language = args[1] as String;
|
||||||
|
|
||||||
return WalletRestorationFromKeysVM(getIt.get<AppStore>(),
|
return WalletRestorationFromKeysVM(
|
||||||
getIt.get<WalletCreationService>(param1: type), _walletInfoSource,
|
getIt.get<AppStore>(), getIt.get<WalletCreationService>(param1: type), _walletInfoSource,
|
||||||
type: type, language: language);
|
type: type, language: language);
|
||||||
});
|
});
|
||||||
|
|
||||||
getIt.registerFactory<WalletAddressListViewModel>(() =>
|
getIt.registerFactory<WalletAddressListViewModel>(() =>
|
||||||
WalletAddressListViewModel(
|
WalletAddressListViewModel(appStore: getIt.get<AppStore>(), yatStore: getIt.get<YatStore>()));
|
||||||
appStore: getIt.get<AppStore>(), yatStore: getIt.get<YatStore>()));
|
|
||||||
|
|
||||||
getIt.registerFactory(() => BalanceViewModel(
|
getIt.registerFactory(() => BalanceViewModel(
|
||||||
appStore: getIt.get<AppStore>(),
|
appStore: getIt.get<AppStore>(),
|
||||||
|
@ -306,15 +298,12 @@ Future setup(
|
||||||
secureStorage: getIt.get<FlutterSecureStorage>(),
|
secureStorage: getIt.get<FlutterSecureStorage>(),
|
||||||
sharedPreferences: getIt.get<SharedPreferences>()));
|
sharedPreferences: getIt.get<SharedPreferences>()));
|
||||||
|
|
||||||
getIt.registerFactory<AuthViewModel>(() => AuthViewModel(
|
getIt.registerFactory<AuthViewModel>(() => AuthViewModel(getIt.get<AuthService>(),
|
||||||
getIt.get<AuthService>(),
|
getIt.get<SharedPreferences>(), getIt.get<SettingsStore>(), BiometricAuth()));
|
||||||
getIt.get<SharedPreferences>(),
|
|
||||||
getIt.get<SettingsStore>(),
|
|
||||||
BiometricAuth()));
|
|
||||||
|
|
||||||
getIt.registerFactory<AuthPage>(
|
getIt.registerFactory<AuthPage>(
|
||||||
() => AuthPage(getIt.get<AuthViewModel>(), onAuthenticationFinished:
|
() => AuthPage(getIt.get<AuthViewModel>(),
|
||||||
(isAuthenticated, AuthPageState authPageState) {
|
onAuthenticationFinished: (isAuthenticated, AuthPageState authPageState) {
|
||||||
if (!isAuthenticated) {
|
if (!isAuthenticated) {
|
||||||
return;
|
return;
|
||||||
}
|
}
|
||||||
|
@ -329,8 +318,7 @@ Future setup(
|
||||||
authPageState.changeProcessText('Loading the wallet');
|
authPageState.changeProcessText('Loading the wallet');
|
||||||
|
|
||||||
if (loginError != null) {
|
if (loginError != null) {
|
||||||
authPageState
|
authPageState.changeProcessText('ERROR: ${loginError.toString()}');
|
||||||
.changeProcessText('ERROR: ${loginError.toString()}');
|
|
||||||
}
|
}
|
||||||
|
|
||||||
ReactionDisposer? _reaction;
|
ReactionDisposer? _reaction;
|
||||||
|
@ -341,28 +329,29 @@ Future setup(
|
||||||
}, closable: false),
|
}, closable: false),
|
||||||
instanceName: 'login');
|
instanceName: 'login');
|
||||||
|
|
||||||
getIt
|
getIt.registerFactoryParam<AuthPage, void Function(bool, AuthPageState), bool>(
|
||||||
.registerFactoryParam<AuthPage, void Function(bool, AuthPageState), bool>(
|
(onAuthFinished, closable) => AuthPage(getIt.get<AuthViewModel>(),
|
||||||
(onAuthFinished, closable) => AuthPage(getIt.get<AuthViewModel>(),
|
onAuthenticationFinished: onAuthFinished, closable: closable ?? false));
|
||||||
onAuthenticationFinished: onAuthFinished,
|
|
||||||
closable: closable ?? false));
|
|
||||||
|
|
||||||
getIt.registerFactory(() =>
|
getIt.registerFactory(() => BalancePage(
|
||||||
BalancePage(dashboardViewModel: getIt.get<DashboardViewModel>(), settingsStore: getIt.get<SettingsStore>()));
|
dashboardViewModel: getIt.get<DashboardViewModel>(),
|
||||||
|
settingsStore: getIt.get<SettingsStore>()));
|
||||||
|
|
||||||
getIt.registerFactory<DashboardPage>(() => DashboardPage( balancePage: getIt.get<BalancePage>(), walletViewModel: getIt.get<DashboardViewModel>(), addressListViewModel: getIt.get<WalletAddressListViewModel>()));
|
getIt.registerFactory<DashboardPage>(() => DashboardPage(
|
||||||
getIt.registerFactory<ReceivePage>(() => ReceivePage(
|
balancePage: getIt.get<BalancePage>(),
|
||||||
|
walletViewModel: getIt.get<DashboardViewModel>(),
|
||||||
addressListViewModel: getIt.get<WalletAddressListViewModel>()));
|
addressListViewModel: getIt.get<WalletAddressListViewModel>()));
|
||||||
|
getIt.registerFactory<ReceivePage>(
|
||||||
|
() => ReceivePage(addressListViewModel: getIt.get<WalletAddressListViewModel>()));
|
||||||
getIt.registerFactory<AddressPage>(() => AddressPage(
|
getIt.registerFactory<AddressPage>(() => AddressPage(
|
||||||
addressListViewModel: getIt.get<WalletAddressListViewModel>(),
|
addressListViewModel: getIt.get<WalletAddressListViewModel>(),
|
||||||
walletViewModel: getIt.get<DashboardViewModel>()));
|
walletViewModel: getIt.get<DashboardViewModel>()));
|
||||||
|
|
||||||
getIt.registerFactoryParam<WalletAddressEditOrCreateViewModel, dynamic, void>(
|
getIt.registerFactoryParam<WalletAddressEditOrCreateViewModel, dynamic, void>((dynamic item, _) =>
|
||||||
(dynamic item, _) => WalletAddressEditOrCreateViewModel(
|
WalletAddressEditOrCreateViewModel(wallet: getIt.get<AppStore>().wallet!, item: item));
|
||||||
wallet: getIt.get<AppStore>().wallet!, item: item));
|
|
||||||
|
|
||||||
getIt.registerFactoryParam<AddressEditOrCreatePage, dynamic, void>(
|
getIt.registerFactoryParam<AddressEditOrCreatePage, dynamic, void>((dynamic item, _) =>
|
||||||
(dynamic item, _) => AddressEditOrCreatePage(
|
AddressEditOrCreatePage(
|
||||||
addressEditOrCreateViewModel:
|
addressEditOrCreateViewModel:
|
||||||
getIt.get<WalletAddressEditOrCreateViewModel>(param1: item)));
|
getIt.get<WalletAddressEditOrCreateViewModel>(param1: item)));
|
||||||
|
|
||||||
|
@ -380,20 +369,16 @@ Future setup(
|
||||||
getIt.get<BalanceViewModel>(),
|
getIt.get<BalanceViewModel>(),
|
||||||
_transactionDescriptionBox));
|
_transactionDescriptionBox));
|
||||||
|
|
||||||
getIt.registerFactory(
|
getIt.registerFactory(() => SendPage(sendViewModel: getIt.get<SendViewModel>()));
|
||||||
() => SendPage(sendViewModel: getIt.get<SendViewModel>(),
|
|
||||||
settingsViewModel: getIt.get<SettingsViewModel>()));
|
|
||||||
|
|
||||||
getIt.registerFactory(() => SendTemplatePage(
|
getIt.registerFactory(
|
||||||
sendTemplateViewModel: getIt.get<SendTemplateViewModel>()));
|
() => SendTemplatePage(sendTemplateViewModel: getIt.get<SendTemplateViewModel>()));
|
||||||
|
|
||||||
getIt.registerFactory(() => WalletListViewModel(
|
getIt.registerFactory(() => WalletListViewModel(
|
||||||
_walletInfoSource,
|
_walletInfoSource, getIt.get<AppStore>(), getIt.get<WalletLoadingService>()));
|
||||||
getIt.get<AppStore>(),
|
|
||||||
getIt.get<WalletLoadingService>()));
|
|
||||||
|
|
||||||
getIt.registerFactory(() =>
|
getIt
|
||||||
WalletListPage(walletListViewModel: getIt.get<WalletListViewModel>()));
|
.registerFactory(() => WalletListPage(walletListViewModel: getIt.get<WalletListViewModel>()));
|
||||||
|
|
||||||
getIt.registerFactory(() {
|
getIt.registerFactory(() {
|
||||||
final wallet = getIt.get<AppStore>().wallet!;
|
final wallet = getIt.get<AppStore>().wallet!;
|
||||||
|
@ -402,11 +387,12 @@ Future setup(
|
||||||
return MoneroAccountListViewModel(wallet);
|
return MoneroAccountListViewModel(wallet);
|
||||||
}
|
}
|
||||||
|
|
||||||
throw Exception('Unexpected wallet type: ${wallet.type} for generate MoneroAccountListViewModel');
|
throw Exception(
|
||||||
|
'Unexpected wallet type: ${wallet.type} for generate MoneroAccountListViewModel');
|
||||||
});
|
});
|
||||||
|
|
||||||
getIt.registerFactory(() => MoneroAccountListPage(
|
getIt.registerFactory(
|
||||||
accountListViewModel: getIt.get<MoneroAccountListViewModel>()));
|
() => MoneroAccountListPage(accountListViewModel: getIt.get<MoneroAccountListViewModel>()));
|
||||||
|
|
||||||
/*getIt.registerFactory(() {
|
/*getIt.registerFactory(() {
|
||||||
final wallet = getIt.get<AppStore>().wallet;
|
final wallet = getIt.get<AppStore>().wallet;
|
||||||
|
@ -423,92 +409,86 @@ Future setup(
|
||||||
moneroAccountCreationViewModel:
|
moneroAccountCreationViewModel:
|
||||||
getIt.get<MoneroAccountEditOrCreateViewModel>()));*/
|
getIt.get<MoneroAccountEditOrCreateViewModel>()));*/
|
||||||
|
|
||||||
getIt.registerFactoryParam<MoneroAccountEditOrCreateViewModel,
|
getIt.registerFactoryParam<MoneroAccountEditOrCreateViewModel, AccountListItem?, void>(
|
||||||
AccountListItem?, void>(
|
|
||||||
(AccountListItem? account, _) => MoneroAccountEditOrCreateViewModel(
|
(AccountListItem? account, _) => MoneroAccountEditOrCreateViewModel(
|
||||||
monero!.getAccountList(getIt.get<AppStore>().wallet!),
|
monero!.getAccountList(getIt.get<AppStore>().wallet!),
|
||||||
haven?.getAccountList(getIt.get<AppStore>().wallet!),
|
haven?.getAccountList(getIt.get<AppStore>().wallet!),
|
||||||
wallet: getIt.get<AppStore>().wallet!,
|
wallet: getIt.get<AppStore>().wallet!,
|
||||||
accountListItem: account));
|
accountListItem: account));
|
||||||
|
|
||||||
getIt.registerFactoryParam<MoneroAccountEditOrCreatePage, AccountListItem?,
|
getIt.registerFactoryParam<MoneroAccountEditOrCreatePage, AccountListItem?, void>(
|
||||||
void>(
|
|
||||||
(AccountListItem? account, _) => MoneroAccountEditOrCreatePage(
|
(AccountListItem? account, _) => MoneroAccountEditOrCreatePage(
|
||||||
moneroAccountCreationViewModel:
|
moneroAccountCreationViewModel:
|
||||||
getIt.get<MoneroAccountEditOrCreateViewModel>(param1: account)));
|
getIt.get<MoneroAccountEditOrCreateViewModel>(param1: account)));
|
||||||
|
|
||||||
getIt.registerFactory(() {
|
getIt.registerFactory(() {
|
||||||
final appStore = getIt.get<AppStore>();
|
return DisplaySettingsViewModel(getIt.get<SettingsStore>());
|
||||||
final yatStore = getIt.get<YatStore>();
|
|
||||||
final authService = getIt.get<AuthService>();
|
|
||||||
return SettingsViewModel(appStore.settingsStore, yatStore, authService, appStore.wallet!);
|
|
||||||
});
|
});
|
||||||
|
|
||||||
getIt
|
getIt.registerFactory(() {
|
||||||
.registerFactory(() => WalletSeedViewModel(getIt.get<AppStore>().wallet!));
|
return PrivacySettingsViewModel(getIt.get<SettingsStore>());
|
||||||
|
});
|
||||||
|
|
||||||
getIt.registerFactoryParam<WalletSeedPage, bool, void>(
|
getIt.registerFactory(() {
|
||||||
(bool isWalletCreated, _) => WalletSeedPage(
|
return OtherSettingsViewModel(getIt.get<SettingsStore>(), getIt.get<AppStore>().wallet!);
|
||||||
getIt.get<WalletSeedViewModel>(),
|
});
|
||||||
isNewWalletCreated: isWalletCreated));
|
|
||||||
|
|
||||||
getIt
|
getIt.registerFactory(() {
|
||||||
.registerFactory(() => WalletKeysViewModel(getIt.get<AppStore>().wallet!));
|
return SecuritySettingsViewModel(getIt.get<SettingsStore>());
|
||||||
|
});
|
||||||
|
|
||||||
|
getIt.registerFactory(() => WalletSeedViewModel(getIt.get<AppStore>().wallet!));
|
||||||
|
|
||||||
|
getIt.registerFactoryParam<WalletSeedPage, bool, void>((bool isWalletCreated, _) =>
|
||||||
|
WalletSeedPage(getIt.get<WalletSeedViewModel>(), isNewWalletCreated: isWalletCreated));
|
||||||
|
|
||||||
|
getIt.registerFactory(() => WalletKeysViewModel(getIt.get<AppStore>().wallet!));
|
||||||
|
|
||||||
getIt.registerFactory(() => WalletKeysPage(getIt.get<WalletKeysViewModel>()));
|
getIt.registerFactory(() => WalletKeysPage(getIt.get<WalletKeysViewModel>()));
|
||||||
|
|
||||||
getIt.registerFactoryParam<ContactViewModel, ContactRecord?, void>(
|
getIt.registerFactoryParam<ContactViewModel, ContactRecord?, void>(
|
||||||
(ContactRecord? contact, _) =>
|
(ContactRecord? contact, _) => ContactViewModel(_contactSource, contact: contact));
|
||||||
ContactViewModel(_contactSource, contact: contact));
|
|
||||||
|
|
||||||
getIt.registerFactory(
|
getIt.registerFactory(() => ContactListViewModel(_contactSource, _walletInfoSource));
|
||||||
() => ContactListViewModel(_contactSource, _walletInfoSource));
|
|
||||||
|
|
||||||
getIt.registerFactoryParam<ContactListPage, bool, void>(
|
getIt.registerFactoryParam<ContactListPage, bool, void>((bool isEditable, _) =>
|
||||||
(bool isEditable, _) => ContactListPage(getIt.get<ContactListViewModel>(),
|
ContactListPage(getIt.get<ContactListViewModel>(), isEditable: isEditable));
|
||||||
isEditable: isEditable));
|
|
||||||
|
|
||||||
getIt.registerFactoryParam<ContactPage, ContactRecord?, void>(
|
getIt.registerFactoryParam<ContactPage, ContactRecord?, void>(
|
||||||
(ContactRecord? contact, _) =>
|
(ContactRecord? contact, _) => ContactPage(getIt.get<ContactViewModel>(param1: contact)));
|
||||||
ContactPage(getIt.get<ContactViewModel>(param1: contact)));
|
|
||||||
|
|
||||||
getIt.registerFactory(() {
|
getIt.registerFactory(() {
|
||||||
final appStore = getIt.get<AppStore>();
|
final appStore = getIt.get<AppStore>();
|
||||||
return NodeListViewModel(
|
return NodeListViewModel(_nodeSource, appStore.wallet!, appStore.settingsStore);
|
||||||
_nodeSource, appStore.wallet!, appStore.settingsStore);
|
|
||||||
});
|
});
|
||||||
|
|
||||||
getIt.registerFactory(() => NodeListPage(getIt.get<NodeListViewModel>()));
|
|
||||||
|
|
||||||
getIt.registerFactory(() => ConnectionSyncPage(getIt.get<NodeListViewModel>(), getIt.get<DashboardViewModel>()));
|
|
||||||
|
|
||||||
getIt.registerFactory(() => SecurityBackupPage(getIt.get<SettingsViewModel>()));
|
|
||||||
|
|
||||||
getIt.registerFactory(() => PrivacyPage(getIt.get<SettingsViewModel>()));
|
|
||||||
|
|
||||||
getIt.registerFactory(() => DisplaySettingsPage(getIt.get<SettingsViewModel>()));
|
|
||||||
|
|
||||||
getIt.registerFactory(() => OtherSettingsPage(getIt.get<SettingsViewModel>()));
|
|
||||||
|
|
||||||
getIt.registerFactory(() =>
|
|
||||||
NodeCreateOrEditViewModel(_nodeSource, getIt.get<AppStore>().wallet!));
|
|
||||||
|
|
||||||
getIt.registerFactory(
|
getIt.registerFactory(
|
||||||
() => NodeCreateOrEditPage(getIt.get<NodeCreateOrEditViewModel>()));
|
() => ConnectionSyncPage(getIt.get<NodeListViewModel>(), getIt.get<DashboardViewModel>()));
|
||||||
|
|
||||||
|
getIt.registerFactory(() => SecurityBackupPage(getIt.get<SecuritySettingsViewModel>()));
|
||||||
|
|
||||||
|
getIt.registerFactory(() => PrivacyPage(getIt.get<PrivacySettingsViewModel>()));
|
||||||
|
|
||||||
|
getIt.registerFactory(() => DisplaySettingsPage(getIt.get<DisplaySettingsViewModel>()));
|
||||||
|
|
||||||
|
getIt.registerFactory(() => OtherSettingsPage(getIt.get<OtherSettingsViewModel>()));
|
||||||
|
|
||||||
|
getIt
|
||||||
|
.registerFactory(() => NodeCreateOrEditViewModel(_nodeSource, getIt.get<AppStore>().wallet!));
|
||||||
|
|
||||||
|
getIt.registerFactory(() => NodeCreateOrEditPage(getIt.get<NodeCreateOrEditViewModel>()));
|
||||||
|
|
||||||
getIt.registerFactory(() => OnRamperPage(
|
getIt.registerFactory(() => OnRamperPage(
|
||||||
settingsStore: getIt.get<AppStore>().settingsStore,
|
settingsStore: getIt.get<AppStore>().settingsStore, wallet: getIt.get<AppStore>().wallet!));
|
||||||
wallet: getIt.get<AppStore>().wallet!));
|
|
||||||
|
|
||||||
getIt.registerFactory(() => ExchangeViewModel(
|
getIt.registerFactory(() => ExchangeViewModel(
|
||||||
getIt.get<AppStore>().wallet!,
|
getIt.get<AppStore>().wallet!,
|
||||||
_tradesSource,
|
_tradesSource,
|
||||||
getIt.get<ExchangeTemplateStore>(),
|
getIt.get<ExchangeTemplateStore>(),
|
||||||
getIt.get<TradesStore>(),
|
getIt.get<TradesStore>(),
|
||||||
getIt.get<AppStore>().settingsStore,
|
getIt.get<AppStore>().settingsStore,
|
||||||
getIt.get<SharedPreferences>(),
|
getIt.get<SharedPreferences>(),
|
||||||
getIt.get<SettingsViewModel>(),
|
));
|
||||||
));
|
|
||||||
|
|
||||||
getIt.registerFactory(() => ExchangeTradeViewModel(
|
getIt.registerFactory(() => ExchangeTradeViewModel(
|
||||||
wallet: getIt.get<AppStore>().wallet!,
|
wallet: getIt.get<AppStore>().wallet!,
|
||||||
|
@ -518,40 +498,34 @@ Future setup(
|
||||||
|
|
||||||
getIt.registerFactory(() => ExchangePage(getIt.get<ExchangeViewModel>()));
|
getIt.registerFactory(() => ExchangePage(getIt.get<ExchangeViewModel>()));
|
||||||
|
|
||||||
getIt.registerFactory(
|
getIt.registerFactory(() => ExchangeConfirmPage(tradesStore: getIt.get<TradesStore>()));
|
||||||
() => ExchangeConfirmPage(tradesStore: getIt.get<TradesStore>()));
|
|
||||||
|
|
||||||
getIt.registerFactory(() => ExchangeTradePage(
|
|
||||||
exchangeTradeViewModel: getIt.get<ExchangeTradeViewModel>()));
|
|
||||||
|
|
||||||
getIt.registerFactory(
|
getIt.registerFactory(
|
||||||
() => ExchangeTemplatePage(getIt.get<ExchangeViewModel>()));
|
() => ExchangeTradePage(exchangeTradeViewModel: getIt.get<ExchangeTradeViewModel>()));
|
||||||
|
|
||||||
getIt.registerFactoryParam<WalletService, WalletType, void>(
|
getIt.registerFactory(() => ExchangeTemplatePage(getIt.get<ExchangeViewModel>()));
|
||||||
(WalletType param1, __) {
|
|
||||||
|
getIt.registerFactoryParam<WalletService, WalletType, void>((WalletType param1, __) {
|
||||||
switch (param1) {
|
switch (param1) {
|
||||||
case WalletType.haven:
|
case WalletType.haven:
|
||||||
return haven!.createHavenWalletService(_walletInfoSource);
|
return haven!.createHavenWalletService(_walletInfoSource);
|
||||||
case WalletType.monero:
|
case WalletType.monero:
|
||||||
return monero!.createMoneroWalletService(_walletInfoSource);
|
return monero!.createMoneroWalletService(_walletInfoSource);
|
||||||
case WalletType.bitcoin:
|
case WalletType.bitcoin:
|
||||||
return bitcoin!.createBitcoinWalletService(
|
return bitcoin!.createBitcoinWalletService(_walletInfoSource, _unspentCoinsInfoSource!);
|
||||||
_walletInfoSource, _unspentCoinsInfoSource!);
|
|
||||||
case WalletType.litecoin:
|
case WalletType.litecoin:
|
||||||
return bitcoin!.createLitecoinWalletService(
|
return bitcoin!.createLitecoinWalletService(_walletInfoSource, _unspentCoinsInfoSource!);
|
||||||
_walletInfoSource, _unspentCoinsInfoSource!);
|
|
||||||
default:
|
default:
|
||||||
throw Exception('Unexpected token: ${param1.toString()} for generating of WalletService');
|
throw Exception('Unexpected token: ${param1.toString()} for generating of WalletService');
|
||||||
}
|
}
|
||||||
});
|
});
|
||||||
|
|
||||||
getIt.registerFactory<SetupPinCodeViewModel>(() => SetupPinCodeViewModel(
|
getIt.registerFactory<SetupPinCodeViewModel>(
|
||||||
getIt.get<AuthService>(), getIt.get<SettingsStore>()));
|
() => SetupPinCodeViewModel(getIt.get<AuthService>(), getIt.get<SettingsStore>()));
|
||||||
|
|
||||||
getIt.registerFactoryParam<SetupPinCodePage,
|
getIt.registerFactoryParam<SetupPinCodePage, void Function(PinCodeState<PinCodeWidget>, String),
|
||||||
void Function(PinCodeState<PinCodeWidget>, String), void>(
|
void>(
|
||||||
(onSuccessfulPinSetup, _) => SetupPinCodePage(
|
(onSuccessfulPinSetup, _) => SetupPinCodePage(getIt.get<SetupPinCodeViewModel>(),
|
||||||
getIt.get<SetupPinCodeViewModel>(),
|
|
||||||
onSuccessfulPinSetup: onSuccessfulPinSetup));
|
onSuccessfulPinSetup: onSuccessfulPinSetup));
|
||||||
|
|
||||||
getIt.registerFactory(() => RescanViewModel(getIt.get<AppStore>().wallet!));
|
getIt.registerFactory(() => RescanViewModel(getIt.get<AppStore>().wallet!));
|
||||||
|
@ -560,17 +534,16 @@ Future setup(
|
||||||
|
|
||||||
getIt.registerFactory(() => FaqPage(getIt.get<SettingsStore>()));
|
getIt.registerFactory(() => FaqPage(getIt.get<SettingsStore>()));
|
||||||
|
|
||||||
getIt.registerFactoryParam<WalletRestoreViewModel, WalletType, void>(
|
getIt.registerFactoryParam<WalletRestoreViewModel, WalletType, void>((type, _) =>
|
||||||
(type, _) => WalletRestoreViewModel(getIt.get<AppStore>(),
|
WalletRestoreViewModel(
|
||||||
getIt.get<WalletCreationService>(param1: type), _walletInfoSource,
|
getIt.get<AppStore>(), getIt.get<WalletCreationService>(param1: type), _walletInfoSource,
|
||||||
type: type));
|
type: type));
|
||||||
|
|
||||||
getIt.registerFactoryParam<WalletRestorePage, WalletType, void>((type, _) =>
|
getIt.registerFactoryParam<WalletRestorePage, WalletType, void>(
|
||||||
WalletRestorePage(getIt.get<WalletRestoreViewModel>(param1: type)));
|
(type, _) => WalletRestorePage(getIt.get<WalletRestoreViewModel>(param1: type)));
|
||||||
|
|
||||||
getIt
|
getIt.registerFactoryParam<TransactionDetailsViewModel, TransactionInfo, void>(
|
||||||
.registerFactoryParam<TransactionDetailsViewModel, TransactionInfo, void>(
|
(TransactionInfo transactionInfo, _) {
|
||||||
(TransactionInfo transactionInfo, _) {
|
|
||||||
final wallet = getIt.get<AppStore>().wallet!;
|
final wallet = getIt.get<AppStore>().wallet!;
|
||||||
return TransactionDetailsViewModel(
|
return TransactionDetailsViewModel(
|
||||||
transactionInfo: transactionInfo,
|
transactionInfo: transactionInfo,
|
||||||
|
@ -584,52 +557,47 @@ Future setup(
|
||||||
transactionDetailsViewModel:
|
transactionDetailsViewModel:
|
||||||
getIt.get<TransactionDetailsViewModel>(param1: transactionInfo)));
|
getIt.get<TransactionDetailsViewModel>(param1: transactionInfo)));
|
||||||
|
|
||||||
getIt.registerFactoryParam<NewWalletTypePage,
|
getIt.registerFactoryParam<NewWalletTypePage, void Function(BuildContext, WalletType), void>(
|
||||||
void Function(BuildContext, WalletType), void>(
|
|
||||||
(param1, _) => NewWalletTypePage(onTypeSelected: param1));
|
(param1, _) => NewWalletTypePage(onTypeSelected: param1));
|
||||||
|
|
||||||
getIt.registerFactoryParam<PreSeedPage, WalletType, void>(
|
getIt.registerFactoryParam<PreSeedPage, WalletType, void>(
|
||||||
(WalletType type, _) => PreSeedPage(type));
|
(WalletType type, _) => PreSeedPage(type));
|
||||||
|
|
||||||
getIt.registerFactoryParam<TradeDetailsViewModel, Trade, void>((trade, _) =>
|
getIt.registerFactoryParam<TradeDetailsViewModel, Trade, void>((trade, _) =>
|
||||||
TradeDetailsViewModel(tradeForDetails: trade, trades: _tradesSource,
|
TradeDetailsViewModel(
|
||||||
|
tradeForDetails: trade,
|
||||||
|
trades: _tradesSource,
|
||||||
settingsStore: getIt.get<SettingsStore>()));
|
settingsStore: getIt.get<SettingsStore>()));
|
||||||
|
|
||||||
getIt.registerFactory(() => BackupService(
|
getIt.registerFactory(() => BackupService(getIt.get<FlutterSecureStorage>(), _walletInfoSource,
|
||||||
getIt.get<FlutterSecureStorage>(),
|
getIt.get<KeyService>(), getIt.get<SharedPreferences>()));
|
||||||
_walletInfoSource,
|
|
||||||
getIt.get<KeyService>(),
|
|
||||||
getIt.get<SharedPreferences>()));
|
|
||||||
|
|
||||||
getIt.registerFactory(() => BackupViewModel(getIt.get<FlutterSecureStorage>(),
|
getIt.registerFactory(() => BackupViewModel(
|
||||||
getIt.get<SecretStore>(), getIt.get<BackupService>()));
|
getIt.get<FlutterSecureStorage>(), getIt.get<SecretStore>(), getIt.get<BackupService>()));
|
||||||
|
|
||||||
getIt.registerFactory(() => BackupPage(getIt.get<BackupViewModel>()));
|
getIt.registerFactory(() => BackupPage(getIt.get<BackupViewModel>()));
|
||||||
|
|
||||||
getIt.registerFactory(
|
getIt.registerFactory(() =>
|
||||||
() => EditBackupPasswordViewModel(getIt.get<FlutterSecureStorage>(), getIt.get<SecretStore>()));
|
EditBackupPasswordViewModel(getIt.get<FlutterSecureStorage>(), getIt.get<SecretStore>()));
|
||||||
|
|
||||||
getIt.registerFactory(
|
getIt.registerFactory(() => EditBackupPasswordPage(getIt.get<EditBackupPasswordViewModel>()));
|
||||||
() => EditBackupPasswordPage(getIt.get<EditBackupPasswordViewModel>()));
|
|
||||||
|
|
||||||
getIt.registerFactory(() => RestoreOptionsPage());
|
getIt.registerFactory(() => RestoreOptionsPage());
|
||||||
|
|
||||||
getIt.registerFactory(
|
getIt.registerFactory(() => RestoreFromBackupViewModel(getIt.get<BackupService>()));
|
||||||
() => RestoreFromBackupViewModel(getIt.get<BackupService>()));
|
|
||||||
|
|
||||||
getIt.registerFactory(
|
getIt.registerFactory(() => RestoreFromBackupPage(getIt.get<RestoreFromBackupViewModel>()));
|
||||||
() => RestoreFromBackupPage(getIt.get<RestoreFromBackupViewModel>()));
|
|
||||||
|
|
||||||
getIt.registerFactoryParam<TradeDetailsPage, Trade, void>((Trade trade, _) =>
|
getIt.registerFactoryParam<TradeDetailsPage, Trade, void>(
|
||||||
TradeDetailsPage(getIt.get<TradeDetailsViewModel>(param1: trade)));
|
(Trade trade, _) => TradeDetailsPage(getIt.get<TradeDetailsViewModel>(param1: trade)));
|
||||||
|
|
||||||
getIt.registerFactory(() => BuyAmountViewModel());
|
getIt.registerFactory(() => BuyAmountViewModel());
|
||||||
|
|
||||||
getIt.registerFactory(() {
|
getIt.registerFactory(() {
|
||||||
final wallet = getIt.get<AppStore>().wallet;
|
final wallet = getIt.get<AppStore>().wallet;
|
||||||
|
|
||||||
return BuyViewModel(_ordersSource, getIt.get<OrdersStore>(),
|
return BuyViewModel(_ordersSource, getIt.get<OrdersStore>(), getIt.get<SettingsStore>(),
|
||||||
getIt.get<SettingsStore>(), getIt.get<BuyAmountViewModel>(),
|
getIt.get<BuyAmountViewModel>(),
|
||||||
wallet: wallet!);
|
wallet: wallet!);
|
||||||
});
|
});
|
||||||
|
|
||||||
|
@ -641,7 +609,8 @@ Future setup(
|
||||||
final url = args.first as String;
|
final url = args.first as String;
|
||||||
final buyViewModel = args[1] as BuyViewModel;
|
final buyViewModel = args[1] as BuyViewModel;
|
||||||
|
|
||||||
return BuyWebViewPage(buyViewModel: buyViewModel, ordersStore: getIt.get<OrdersStore>(), url: url);
|
return BuyWebViewPage(
|
||||||
|
buyViewModel: buyViewModel, ordersStore: getIt.get<OrdersStore>(), url: url);
|
||||||
});
|
});
|
||||||
|
|
||||||
getIt.registerFactoryParam<OrderDetailsViewModel, Order, void>((order, _) {
|
getIt.registerFactoryParam<OrderDetailsViewModel, Order, void>((order, _) {
|
||||||
|
@ -650,8 +619,8 @@ Future setup(
|
||||||
return OrderDetailsViewModel(wallet: wallet!, orderForDetails: order);
|
return OrderDetailsViewModel(wallet: wallet!, orderForDetails: order);
|
||||||
});
|
});
|
||||||
|
|
||||||
getIt.registerFactoryParam<OrderDetailsPage, Order, void>((Order order, _) =>
|
getIt.registerFactoryParam<OrderDetailsPage, Order, void>(
|
||||||
OrderDetailsPage(getIt.get<OrderDetailsViewModel>(param1: order)));
|
(Order order, _) => OrderDetailsPage(getIt.get<OrderDetailsViewModel>(param1: order)));
|
||||||
|
|
||||||
getIt.registerFactory(() => SupportViewModel());
|
getIt.registerFactory(() => SupportViewModel());
|
||||||
|
|
||||||
|
@ -660,20 +629,18 @@ Future setup(
|
||||||
getIt.registerFactory(() {
|
getIt.registerFactory(() {
|
||||||
final wallet = getIt.get<AppStore>().wallet;
|
final wallet = getIt.get<AppStore>().wallet;
|
||||||
|
|
||||||
return UnspentCoinsListViewModel(
|
return UnspentCoinsListViewModel(wallet: wallet!, unspentCoinsInfo: _unspentCoinsInfoSource!);
|
||||||
wallet: wallet!, unspentCoinsInfo: _unspentCoinsInfoSource!);
|
|
||||||
});
|
});
|
||||||
|
|
||||||
getIt.registerFactory(() => UnspentCoinsListPage(
|
getIt.registerFactory(() =>
|
||||||
unspentCoinsListViewModel: getIt.get<UnspentCoinsListViewModel>()));
|
UnspentCoinsListPage(unspentCoinsListViewModel: getIt.get<UnspentCoinsListViewModel>()));
|
||||||
|
|
||||||
getIt.registerFactoryParam<UnspentCoinsDetailsViewModel, UnspentCoinsItem,
|
getIt.registerFactoryParam<UnspentCoinsDetailsViewModel, UnspentCoinsItem,
|
||||||
UnspentCoinsListViewModel>(
|
UnspentCoinsListViewModel>(
|
||||||
(item, model) => UnspentCoinsDetailsViewModel(
|
(item, model) =>
|
||||||
unspentCoinsItem: item, unspentCoinsListViewModel: model));
|
UnspentCoinsDetailsViewModel(unspentCoinsItem: item, unspentCoinsListViewModel: model));
|
||||||
|
|
||||||
getIt.registerFactoryParam<UnspentCoinsDetailsPage, List, void>(
|
getIt.registerFactoryParam<UnspentCoinsDetailsPage, List, void>((List args, _) {
|
||||||
(List args, _) {
|
|
||||||
final item = args.first as UnspentCoinsItem;
|
final item = args.first as UnspentCoinsItem;
|
||||||
final unspentCoinsListViewModel = args[1] as UnspentCoinsListViewModel;
|
final unspentCoinsListViewModel = args[1] as UnspentCoinsListViewModel;
|
||||||
|
|
||||||
|
@ -686,11 +653,14 @@ Future setup(
|
||||||
|
|
||||||
getIt.registerFactory(() => YatService());
|
getIt.registerFactory(() => YatService());
|
||||||
|
|
||||||
getIt.registerFactory(() => AddressResolver(yatService: getIt.get<YatService>(),
|
getIt.registerFactory(() => AddressResolver(
|
||||||
walletType: getIt.get<AppStore>().wallet!.type));
|
yatService: getIt.get<YatService>(), walletType: getIt.get<AppStore>().wallet!.type));
|
||||||
|
|
||||||
getIt.registerFactoryParam<FullscreenQRPage, String, bool>(
|
getIt.registerFactoryParam<FullscreenQRPage, String, bool>(
|
||||||
(String qrData, bool isLight) => FullscreenQRPage(qrData: qrData, isLight: isLight,));
|
(String qrData, bool isLight) => FullscreenQRPage(
|
||||||
|
qrData: qrData,
|
||||||
|
isLight: isLight,
|
||||||
|
));
|
||||||
|
|
||||||
getIt.registerFactory(() => IoniaApi());
|
getIt.registerFactory(() => IoniaApi());
|
||||||
|
|
||||||
|
@ -699,26 +669,24 @@ Future setup(
|
||||||
getIt.registerFactory<IoniaService>(
|
getIt.registerFactory<IoniaService>(
|
||||||
() => IoniaService(getIt.get<FlutterSecureStorage>(), getIt.get<IoniaApi>()));
|
() => IoniaService(getIt.get<FlutterSecureStorage>(), getIt.get<IoniaApi>()));
|
||||||
|
|
||||||
getIt.registerFactory<IoniaAnyPay>(
|
getIt.registerFactory<IoniaAnyPay>(() => IoniaAnyPay(
|
||||||
() => IoniaAnyPay(
|
getIt.get<IoniaService>(), getIt.get<AnyPayApi>(), getIt.get<AppStore>().wallet!));
|
||||||
getIt.get<IoniaService>(),
|
|
||||||
getIt.get<AnyPayApi>(),
|
|
||||||
getIt.get<AppStore>().wallet!));
|
|
||||||
|
|
||||||
getIt.registerFactory(() => IoniaGiftCardsListViewModel(ioniaService: getIt.get<IoniaService>()));
|
getIt.registerFactory(() => IoniaGiftCardsListViewModel(ioniaService: getIt.get<IoniaService>()));
|
||||||
|
|
||||||
getIt.registerFactory(() => IoniaAuthViewModel(ioniaService: getIt.get<IoniaService>()));
|
getIt.registerFactory(() => IoniaAuthViewModel(ioniaService: getIt.get<IoniaService>()));
|
||||||
|
|
||||||
getIt.registerFactoryParam<IoniaMerchPurchaseViewModel, double, IoniaMerchant>((double amount, merchant) {
|
getIt.registerFactoryParam<IoniaMerchPurchaseViewModel, double, IoniaMerchant>(
|
||||||
|
(double amount, merchant) {
|
||||||
return IoniaMerchPurchaseViewModel(
|
return IoniaMerchPurchaseViewModel(
|
||||||
ioniaAnyPayService: getIt.get<IoniaAnyPay>(),
|
ioniaAnyPayService: getIt.get<IoniaAnyPay>(),
|
||||||
amount: amount,
|
amount: amount,
|
||||||
ioniaMerchant: merchant,
|
ioniaMerchant: merchant,
|
||||||
sendViewModel: getIt.get<SendViewModel>()
|
sendViewModel: getIt.get<SendViewModel>());
|
||||||
);
|
|
||||||
});
|
});
|
||||||
|
|
||||||
getIt.registerFactoryParam<IoniaBuyCardViewModel, IoniaMerchant, void>((IoniaMerchant merchant, _) {
|
getIt.registerFactoryParam<IoniaBuyCardViewModel, IoniaMerchant, void>(
|
||||||
|
(IoniaMerchant merchant, _) {
|
||||||
return IoniaBuyCardViewModel(ioniaMerchant: merchant);
|
return IoniaBuyCardViewModel(ioniaMerchant: merchant);
|
||||||
});
|
});
|
||||||
|
|
||||||
|
@ -746,42 +714,44 @@ Future setup(
|
||||||
getIt.registerFactoryParam<IoniaBuyGiftCardDetailPage, List, void>((List args, _) {
|
getIt.registerFactoryParam<IoniaBuyGiftCardDetailPage, List, void>((List args, _) {
|
||||||
final amount = args.first as double;
|
final amount = args.first as double;
|
||||||
final merchant = args.last as IoniaMerchant;
|
final merchant = args.last as IoniaMerchant;
|
||||||
return IoniaBuyGiftCardDetailPage(getIt.get<IoniaMerchPurchaseViewModel>(param1: amount, param2: merchant));
|
return IoniaBuyGiftCardDetailPage(
|
||||||
|
getIt.get<IoniaMerchPurchaseViewModel>(param1: amount, param2: merchant));
|
||||||
});
|
});
|
||||||
|
|
||||||
getIt.registerFactoryParam<IoniaGiftCardDetailsViewModel, IoniaGiftCard, void>((IoniaGiftCard giftCard, _) {
|
getIt.registerFactoryParam<IoniaGiftCardDetailsViewModel, IoniaGiftCard, void>(
|
||||||
return IoniaGiftCardDetailsViewModel(
|
(IoniaGiftCard giftCard, _) {
|
||||||
ioniaService: getIt.get<IoniaService>(),
|
return IoniaGiftCardDetailsViewModel(
|
||||||
giftCard: giftCard);
|
ioniaService: getIt.get<IoniaService>(), giftCard: giftCard);
|
||||||
});
|
});
|
||||||
|
|
||||||
getIt.registerFactoryParam<IoniaCustomTipViewModel, List, void>((List args, _) {
|
getIt.registerFactoryParam<IoniaCustomTipViewModel, List, void>((List args, _) {
|
||||||
final amount = args[0] as double;
|
final amount = args[0] as double;
|
||||||
final merchant = args[1] as IoniaMerchant;
|
final merchant = args[1] as IoniaMerchant;
|
||||||
final tip = args[2] as IoniaTip;
|
final tip = args[2] as IoniaTip;
|
||||||
|
|
||||||
return IoniaCustomTipViewModel(amount: amount, tip: tip, ioniaMerchant: merchant);
|
return IoniaCustomTipViewModel(amount: amount, tip: tip, ioniaMerchant: merchant);
|
||||||
});
|
});
|
||||||
|
|
||||||
getIt.registerFactoryParam<IoniaGiftCardDetailPage, IoniaGiftCard, void>((IoniaGiftCard giftCard, _) {
|
getIt.registerFactoryParam<IoniaGiftCardDetailPage, IoniaGiftCard, void>(
|
||||||
return IoniaGiftCardDetailPage(getIt.get<IoniaGiftCardDetailsViewModel>(param1: giftCard));
|
(IoniaGiftCard giftCard, _) {
|
||||||
|
return IoniaGiftCardDetailPage(getIt.get<IoniaGiftCardDetailsViewModel>(param1: giftCard));
|
||||||
});
|
});
|
||||||
|
|
||||||
getIt.registerFactoryParam<IoniaMoreOptionsPage, List, void>((List args, _){
|
getIt.registerFactoryParam<IoniaMoreOptionsPage, List, void>((List args, _) {
|
||||||
final giftCard = args.first as IoniaGiftCard;
|
final giftCard = args.first as IoniaGiftCard;
|
||||||
|
|
||||||
return IoniaMoreOptionsPage(giftCard);
|
return IoniaMoreOptionsPage(giftCard);
|
||||||
});
|
});
|
||||||
|
|
||||||
getIt.registerFactoryParam<IoniaCustomRedeemViewModel, IoniaGiftCard, void>((IoniaGiftCard giftCard, _) => IoniaCustomRedeemViewModel(giftCard));
|
getIt.registerFactoryParam<IoniaCustomRedeemViewModel, IoniaGiftCard, void>(
|
||||||
|
(IoniaGiftCard giftCard, _) => IoniaCustomRedeemViewModel(giftCard));
|
||||||
|
|
||||||
getIt.registerFactoryParam<IoniaCustomRedeemPage, List, void>((List args, _){
|
getIt.registerFactoryParam<IoniaCustomRedeemPage, List, void>((List args, _) {
|
||||||
final giftCard = args.first as IoniaGiftCard;
|
final giftCard = args.first as IoniaGiftCard;
|
||||||
|
|
||||||
return IoniaCustomRedeemPage(getIt.get<IoniaCustomRedeemViewModel>(param1: giftCard) );
|
return IoniaCustomRedeemPage(getIt.get<IoniaCustomRedeemViewModel>(param1: giftCard));
|
||||||
});
|
});
|
||||||
|
|
||||||
|
|
||||||
getIt.registerFactoryParam<IoniaCustomTipPage, List, void>((List args, _) {
|
getIt.registerFactoryParam<IoniaCustomTipPage, List, void>((List args, _) {
|
||||||
return IoniaCustomTipPage(getIt.get<IoniaCustomTipViewModel>(param1: args));
|
return IoniaCustomTipPage(getIt.get<IoniaCustomTipViewModel>(param1: args));
|
||||||
});
|
});
|
||||||
|
@ -796,16 +766,17 @@ Future setup(
|
||||||
|
|
||||||
getIt.registerFactory(() => IoniaAccountCardsPage(getIt.get<IoniaAccountViewModel>()));
|
getIt.registerFactory(() => IoniaAccountCardsPage(getIt.get<IoniaAccountViewModel>()));
|
||||||
|
|
||||||
getIt.registerFactoryParam<IoniaPaymentStatusViewModel, IoniaAnyPayPaymentInfo, AnyPayPaymentCommittedInfo>(
|
getIt.registerFactoryParam<IoniaPaymentStatusViewModel, IoniaAnyPayPaymentInfo,
|
||||||
(IoniaAnyPayPaymentInfo paymentInfo, AnyPayPaymentCommittedInfo committedInfo)
|
AnyPayPaymentCommittedInfo>(
|
||||||
=> IoniaPaymentStatusViewModel(
|
(IoniaAnyPayPaymentInfo paymentInfo, AnyPayPaymentCommittedInfo committedInfo) =>
|
||||||
getIt.get<IoniaService>(),
|
IoniaPaymentStatusViewModel(getIt.get<IoniaService>(),
|
||||||
paymentInfo: paymentInfo,
|
paymentInfo: paymentInfo, committedInfo: committedInfo));
|
||||||
committedInfo: committedInfo));
|
|
||||||
|
|
||||||
getIt.registerFactoryParam<IoniaPaymentStatusPage, IoniaAnyPayPaymentInfo, AnyPayPaymentCommittedInfo>(
|
getIt.registerFactoryParam<IoniaPaymentStatusPage, IoniaAnyPayPaymentInfo,
|
||||||
(IoniaAnyPayPaymentInfo paymentInfo, AnyPayPaymentCommittedInfo committedInfo)
|
AnyPayPaymentCommittedInfo>(
|
||||||
=> IoniaPaymentStatusPage(getIt.get<IoniaPaymentStatusViewModel>(param1: paymentInfo, param2: committedInfo)));
|
(IoniaAnyPayPaymentInfo paymentInfo, AnyPayPaymentCommittedInfo committedInfo) =>
|
||||||
|
IoniaPaymentStatusPage(
|
||||||
|
getIt.get<IoniaPaymentStatusViewModel>(param1: paymentInfo, param2: committedInfo)));
|
||||||
|
|
||||||
_isSetupFinished = true;
|
_isSetupFinished = true;
|
||||||
}
|
}
|
||||||
|
|
|
@ -69,6 +69,8 @@ Future defaultSettingsMigration(
|
||||||
sharedPreferences: sharedPreferences, nodes: nodes);
|
sharedPreferences: sharedPreferences, nodes: nodes);
|
||||||
await changeLitecoinCurrentElectrumServerToDefault(
|
await changeLitecoinCurrentElectrumServerToDefault(
|
||||||
sharedPreferences: sharedPreferences, nodes: nodes);
|
sharedPreferences: sharedPreferences, nodes: nodes);
|
||||||
|
await changeHavenCurrentNodeToDefault(
|
||||||
|
sharedPreferences: sharedPreferences, nodes: nodes);
|
||||||
|
|
||||||
break;
|
break;
|
||||||
case 2:
|
case 2:
|
||||||
|
@ -133,19 +135,32 @@ Future defaultSettingsMigration(
|
||||||
await changeDefaultHavenNode(nodes);
|
await changeDefaultHavenNode(nodes);
|
||||||
break;
|
break;
|
||||||
|
|
||||||
|
case 18:
|
||||||
|
await addOnionNode(nodes);
|
||||||
|
break;
|
||||||
|
|
||||||
default:
|
default:
|
||||||
break;
|
break;
|
||||||
}
|
}
|
||||||
|
|
||||||
await sharedPreferences.setInt(
|
await sharedPreferences.setInt(
|
||||||
'current_default_settings_migration_version', version);
|
PreferencesKey.currentDefaultSettingsMigrationVersion, version);
|
||||||
} catch (e) {
|
} catch (e) {
|
||||||
print('Migration error: ${e.toString()}');
|
print('Migration error: ${e.toString()}');
|
||||||
}
|
}
|
||||||
});
|
});
|
||||||
|
|
||||||
await sharedPreferences.setInt(
|
await sharedPreferences.setInt(
|
||||||
'current_default_settings_migration_version', version);
|
PreferencesKey.currentDefaultSettingsMigrationVersion, version);
|
||||||
|
}
|
||||||
|
|
||||||
|
Future<void> addOnionNode(Box<Node> nodes) async {
|
||||||
|
final onionNodeUri = "cakexmrl7bonq7ovjka5kuwuyd3f7qnkz6z6s6dmsy3uckwra7bvggyd.onion:18081";
|
||||||
|
|
||||||
|
// check if the user has this node before (added it manually)
|
||||||
|
if (nodes.values.firstWhereOrNull((element) => element.uriRaw == onionNodeUri) == null) {
|
||||||
|
await nodes.add(Node(uri: onionNodeUri, type: WalletType.monero));
|
||||||
|
}
|
||||||
}
|
}
|
||||||
|
|
||||||
Future<void> replaceNodesMigration({required Box<Node> nodes}) async {
|
Future<void> replaceNodesMigration({required Box<Node> nodes}) async {
|
||||||
|
@ -176,7 +191,7 @@ Future<void> changeMoneroCurrentNodeToDefault(
|
||||||
final node = getMoneroDefaultNode(nodes: nodes);
|
final node = getMoneroDefaultNode(nodes: nodes);
|
||||||
final nodeId = node?.key as int ?? 0; // 0 - England
|
final nodeId = node?.key as int ?? 0; // 0 - England
|
||||||
|
|
||||||
await sharedPreferences.setInt('current_node_id', nodeId);
|
await sharedPreferences.setInt(PreferencesKey.currentNodeIdKey, nodeId);
|
||||||
}
|
}
|
||||||
|
|
||||||
Node? getBitcoinDefaultElectrumServer({required Box<Node> nodes}) {
|
Node? getBitcoinDefaultElectrumServer({required Box<Node> nodes}) {
|
||||||
|
@ -223,7 +238,7 @@ Future<void> changeBitcoinCurrentElectrumServerToDefault(
|
||||||
final server = getBitcoinDefaultElectrumServer(nodes: nodes);
|
final server = getBitcoinDefaultElectrumServer(nodes: nodes);
|
||||||
final serverId = server?.key as int ?? 0;
|
final serverId = server?.key as int ?? 0;
|
||||||
|
|
||||||
await sharedPreferences.setInt('current_node_id_btc', serverId);
|
await sharedPreferences.setInt(PreferencesKey.currentBitcoinElectrumSererIdKey, serverId);
|
||||||
}
|
}
|
||||||
|
|
||||||
Future<void> changeLitecoinCurrentElectrumServerToDefault(
|
Future<void> changeLitecoinCurrentElectrumServerToDefault(
|
||||||
|
@ -232,7 +247,7 @@ Future<void> changeLitecoinCurrentElectrumServerToDefault(
|
||||||
final server = getLitecoinDefaultElectrumServer(nodes: nodes);
|
final server = getLitecoinDefaultElectrumServer(nodes: nodes);
|
||||||
final serverId = server?.key as int ?? 0;
|
final serverId = server?.key as int ?? 0;
|
||||||
|
|
||||||
await sharedPreferences.setInt('current_node_id_ltc', serverId);
|
await sharedPreferences.setInt(PreferencesKey.currentLitecoinElectrumSererIdKey, serverId);
|
||||||
}
|
}
|
||||||
|
|
||||||
Future<void> changeHavenCurrentNodeToDefault(
|
Future<void> changeHavenCurrentNodeToDefault(
|
||||||
|
@ -252,7 +267,7 @@ Future<void> replaceDefaultNode(
|
||||||
'eu-node.cakewallet.io:18081',
|
'eu-node.cakewallet.io:18081',
|
||||||
'node.cakewallet.io:18081'
|
'node.cakewallet.io:18081'
|
||||||
];
|
];
|
||||||
final currentNodeId = sharedPreferences.getInt('current_node_id');
|
final currentNodeId = sharedPreferences.getInt(PreferencesKey.currentNodeIdKey);
|
||||||
final currentNode =
|
final currentNode =
|
||||||
nodes.values.firstWhereOrNull((Node node) => node.key == currentNodeId);
|
nodes.values.firstWhereOrNull((Node node) => node.key == currentNodeId);
|
||||||
final needToReplace =
|
final needToReplace =
|
||||||
|
@ -277,17 +292,29 @@ Future<void> updateNodeTypes({required Box<Node> nodes}) async {
|
||||||
|
|
||||||
Future<void> addBitcoinElectrumServerList({required Box<Node> nodes}) async {
|
Future<void> addBitcoinElectrumServerList({required Box<Node> nodes}) async {
|
||||||
final serverList = await loadBitcoinElectrumServerList();
|
final serverList = await loadBitcoinElectrumServerList();
|
||||||
await nodes.addAll(serverList);
|
for (var node in serverList) {
|
||||||
|
if (nodes.values.firstWhereOrNull((element) => element.uriRaw == node.uriRaw) == null) {
|
||||||
|
await nodes.add(node);
|
||||||
|
}
|
||||||
|
}
|
||||||
}
|
}
|
||||||
|
|
||||||
Future<void> addLitecoinElectrumServerList({required Box<Node> nodes}) async {
|
Future<void> addLitecoinElectrumServerList({required Box<Node> nodes}) async {
|
||||||
final serverList = await loadLitecoinElectrumServerList();
|
final serverList = await loadLitecoinElectrumServerList();
|
||||||
await nodes.addAll(serverList);
|
for (var node in serverList) {
|
||||||
|
if (nodes.values.firstWhereOrNull((element) => element.uriRaw == node.uriRaw) == null) {
|
||||||
|
await nodes.add(node);
|
||||||
|
}
|
||||||
|
}
|
||||||
}
|
}
|
||||||
|
|
||||||
Future<void> addHavenNodeList({required Box<Node> nodes}) async {
|
Future<void> addHavenNodeList({required Box<Node> nodes}) async {
|
||||||
final nodeList = await loadDefaultHavenNodes();
|
final nodeList = await loadDefaultHavenNodes();
|
||||||
await nodes.addAll(nodeList);
|
for (var node in nodeList) {
|
||||||
|
if (nodes.values.firstWhereOrNull((element) => element.uriRaw == node.uriRaw) == null) {
|
||||||
|
await nodes.add(node);
|
||||||
|
}
|
||||||
|
}
|
||||||
}
|
}
|
||||||
|
|
||||||
Future<void> addAddressesForMoneroWallets(
|
Future<void> addAddressesForMoneroWallets(
|
||||||
|
@ -431,7 +458,7 @@ Future<void> resetBitcoinElectrumServer(
|
||||||
final oldElectrumServer = nodeSource.values.firstWhereOrNull(
|
final oldElectrumServer = nodeSource.values.firstWhereOrNull(
|
||||||
(node) => node.uri.toString().contains('electrumx.cakewallet.com'));
|
(node) => node.uri.toString().contains('electrumx.cakewallet.com'));
|
||||||
var cakeWalletNode = nodeSource.values.firstWhereOrNull(
|
var cakeWalletNode = nodeSource.values.firstWhereOrNull(
|
||||||
(node) => node.uri.toString() == cakeWalletBitcoinElectrumUri);
|
(node) => node.uriRaw.toString() == cakeWalletBitcoinElectrumUri);
|
||||||
|
|
||||||
if (cakeWalletNode == null) {
|
if (cakeWalletNode == null) {
|
||||||
cakeWalletNode =
|
cakeWalletNode =
|
||||||
|
|
21
lib/entities/priority_for_wallet_type.dart
Normal file
21
lib/entities/priority_for_wallet_type.dart
Normal file
|
@ -0,0 +1,21 @@
|
||||||
|
import 'package:cake_wallet/bitcoin/bitcoin.dart';
|
||||||
|
import 'package:cake_wallet/haven/haven.dart';
|
||||||
|
import 'package:cake_wallet/monero/monero.dart';
|
||||||
|
import 'package:cw_core/transaction_priority.dart';
|
||||||
|
import 'package:cw_core/wallet_type.dart';
|
||||||
|
|
||||||
|
List<TransactionPriority> priorityForWalletType(WalletType type) {
|
||||||
|
switch (type) {
|
||||||
|
case WalletType.monero:
|
||||||
|
return monero!.getTransactionPriorities();
|
||||||
|
case WalletType.bitcoin:
|
||||||
|
return bitcoin!.getTransactionPriorities();
|
||||||
|
case WalletType.litecoin:
|
||||||
|
return bitcoin!.getLitecoinTransactionPriorities();
|
||||||
|
case WalletType.haven:
|
||||||
|
return haven!.getTransactionPriorities();
|
||||||
|
default:
|
||||||
|
return [];
|
||||||
|
}
|
||||||
|
}
|
||||||
|
|
|
@ -130,7 +130,7 @@ class ChangeNowExchangeProvider extends ExchangeProvider {
|
||||||
final id = responseJSON['id'] as String;
|
final id = responseJSON['id'] as String;
|
||||||
final inputAddress = responseJSON['payinAddress'] as String;
|
final inputAddress = responseJSON['payinAddress'] as String;
|
||||||
final refundAddress = responseJSON['refundAddress'] as String;
|
final refundAddress = responseJSON['refundAddress'] as String;
|
||||||
final extraId = responseJSON['payinExtraId'] as String;
|
final extraId = responseJSON['payinExtraId'] as String?;
|
||||||
|
|
||||||
return Trade(
|
return Trade(
|
||||||
id: id,
|
id: id,
|
||||||
|
|
|
@ -128,7 +128,7 @@ Future<void> main() async {
|
||||||
exchangeTemplates: exchangeTemplates,
|
exchangeTemplates: exchangeTemplates,
|
||||||
transactionDescriptions: transactionDescriptions,
|
transactionDescriptions: transactionDescriptions,
|
||||||
secureStorage: secureStorage,
|
secureStorage: secureStorage,
|
||||||
initialMigrationVersion: 17);
|
initialMigrationVersion: 18);
|
||||||
runApp(App());
|
runApp(App());
|
||||||
} catch (e, stacktrace) {
|
} catch (e, stacktrace) {
|
||||||
runApp(MaterialApp(
|
runApp(MaterialApp(
|
||||||
|
|
|
@ -41,7 +41,6 @@ import 'package:cake_wallet/src/screens/dashboard/dashboard_page.dart';
|
||||||
import 'package:cake_wallet/src/screens/seed/wallet_seed_page.dart';
|
import 'package:cake_wallet/src/screens/seed/wallet_seed_page.dart';
|
||||||
import 'package:cake_wallet/src/screens/auth/auth_page.dart';
|
import 'package:cake_wallet/src/screens/auth/auth_page.dart';
|
||||||
import 'package:cake_wallet/src/screens/nodes/node_create_or_edit_page.dart';
|
import 'package:cake_wallet/src/screens/nodes/node_create_or_edit_page.dart';
|
||||||
import 'package:cake_wallet/src/screens/nodes/nodes_list_page.dart';
|
|
||||||
import 'package:cake_wallet/src/screens/receive/receive_page.dart';
|
import 'package:cake_wallet/src/screens/receive/receive_page.dart';
|
||||||
import 'package:cake_wallet/src/screens/subaddress/address_edit_or_create_page.dart';
|
import 'package:cake_wallet/src/screens/subaddress/address_edit_or_create_page.dart';
|
||||||
import 'package:cake_wallet/src/screens/wallet_list/wallet_list_page.dart';
|
import 'package:cake_wallet/src/screens/wallet_list/wallet_list_page.dart';
|
||||||
|
@ -278,10 +277,6 @@ Route<dynamic> createRoute(RouteSettings settings) {
|
||||||
param2: false),
|
param2: false),
|
||||||
onWillPop: () async => false));
|
onWillPop: () async => false));
|
||||||
|
|
||||||
case Routes.nodeList:
|
|
||||||
return CupertinoPageRoute<void>(
|
|
||||||
builder: (_) => getIt.get<NodeListPage>());
|
|
||||||
|
|
||||||
case Routes.connectionSync:
|
case Routes.connectionSync:
|
||||||
return CupertinoPageRoute<void>(
|
return CupertinoPageRoute<void>(
|
||||||
builder: (_) => getIt.get<ConnectionSyncPage>());
|
builder: (_) => getIt.get<ConnectionSyncPage>());
|
||||||
|
|
|
@ -21,7 +21,6 @@ class Routes {
|
||||||
static const seedLanguage = '/seed_language';
|
static const seedLanguage = '/seed_language';
|
||||||
static const walletList = '/view_model.wallet_list';
|
static const walletList = '/view_model.wallet_list';
|
||||||
static const auth = '/auth';
|
static const auth = '/auth';
|
||||||
static const nodeList = '/node_list';
|
|
||||||
static const newNode = '/new_node_list';
|
static const newNode = '/new_node_list';
|
||||||
static const login = '/login';
|
static const login = '/login';
|
||||||
static const splash = '/splash';
|
static const splash = '/splash';
|
||||||
|
|
|
@ -118,7 +118,7 @@ class IoniaManageCardsPage extends BasePage {
|
||||||
width: 32,
|
width: 32,
|
||||||
padding: EdgeInsets.all(8),
|
padding: EdgeInsets.all(8),
|
||||||
decoration: BoxDecoration(
|
decoration: BoxDecoration(
|
||||||
color: Colors.white.withOpacity(0.15),
|
color: Theme.of(context).textTheme!.headline6!.backgroundColor!,
|
||||||
border: Border.all(
|
border: Border.all(
|
||||||
color: Colors.white.withOpacity(0.2),
|
color: Colors.white.withOpacity(0.2),
|
||||||
),
|
),
|
||||||
|
|
|
@ -20,7 +20,7 @@ class IoniaFilterModal extends StatelessWidget {
|
||||||
padding: EdgeInsets.all(10),
|
padding: EdgeInsets.all(10),
|
||||||
child: Image.asset(
|
child: Image.asset(
|
||||||
'assets/images/mini_search_icon.png',
|
'assets/images/mini_search_icon.png',
|
||||||
color: Theme.of(context).accentColor,
|
color: Theme.of(context).textTheme.subtitle2!.color!,
|
||||||
),
|
),
|
||||||
);
|
);
|
||||||
return Scaffold(
|
return Scaffold(
|
||||||
|
@ -53,7 +53,7 @@ class IoniaFilterModal extends StatelessWidget {
|
||||||
prefixIcon: searchIcon,
|
prefixIcon: searchIcon,
|
||||||
hintText: S.of(context).search_category,
|
hintText: S.of(context).search_category,
|
||||||
contentPadding: EdgeInsets.only(bottom: 5),
|
contentPadding: EdgeInsets.only(bottom: 5),
|
||||||
fillColor: Theme.of(context).textTheme!.subtitle1!.backgroundColor!,
|
fillColor: Theme.of(context).primaryTextTheme!.caption!.decorationColor!.withOpacity(0.5),
|
||||||
border: OutlineInputBorder(
|
border: OutlineInputBorder(
|
||||||
borderSide: BorderSide.none,
|
borderSide: BorderSide.none,
|
||||||
borderRadius: BorderRadius.circular(8),
|
borderRadius: BorderRadius.circular(8),
|
||||||
|
|
|
@ -174,7 +174,22 @@ class NodeCreateOrEditPage extends BasePage {
|
||||||
caption: S.of(context).use_ssl,
|
caption: S.of(context).use_ssl,
|
||||||
))
|
))
|
||||||
],
|
],
|
||||||
))
|
)),
|
||||||
|
Padding(
|
||||||
|
padding: EdgeInsets.only(top: 20),
|
||||||
|
child: Row(
|
||||||
|
mainAxisAlignment: MainAxisAlignment.start,
|
||||||
|
mainAxisSize: MainAxisSize.max,
|
||||||
|
children: [
|
||||||
|
Observer(
|
||||||
|
builder: (_) => StandardCheckbox(
|
||||||
|
value: nodeCreateOrEditViewModel.trusted,
|
||||||
|
onChanged: (value) =>
|
||||||
|
nodeCreateOrEditViewModel.trusted = value,
|
||||||
|
caption: S.of(context).trusted,
|
||||||
|
))
|
||||||
|
],
|
||||||
|
)),
|
||||||
]
|
]
|
||||||
],
|
],
|
||||||
)),
|
)),
|
||||||
|
|
|
@ -1,166 +0,0 @@
|
||||||
import 'package:cake_wallet/utils/show_pop_up.dart';
|
|
||||||
import 'package:cw_core/node.dart';
|
|
||||||
import 'package:flutter/material.dart';
|
|
||||||
import 'package:flutter/cupertino.dart';
|
|
||||||
import 'package:flutter_mobx/flutter_mobx.dart';
|
|
||||||
import 'package:cake_wallet/routes.dart';
|
|
||||||
import 'package:cake_wallet/palette.dart';
|
|
||||||
import 'package:cake_wallet/generated/i18n.dart';
|
|
||||||
import 'package:cake_wallet/src/screens/base_page.dart';
|
|
||||||
import 'package:cake_wallet/src/screens/nodes/widgets/node_list_row.dart';
|
|
||||||
import 'package:cake_wallet/src/widgets/standard_list.dart';
|
|
||||||
import 'package:cake_wallet/src/widgets/alert_with_two_actions.dart';
|
|
||||||
import 'package:cake_wallet/view_model/node_list/node_list_view_model.dart';
|
|
||||||
import 'package:flutter_slidable/flutter_slidable.dart';
|
|
||||||
|
|
||||||
class NodeListPage extends BasePage {
|
|
||||||
NodeListPage(this.nodeListViewModel);
|
|
||||||
|
|
||||||
@override
|
|
||||||
String get title => S.current.nodes;
|
|
||||||
|
|
||||||
final NodeListViewModel nodeListViewModel;
|
|
||||||
|
|
||||||
@override
|
|
||||||
Widget trailing(context) {
|
|
||||||
return Container(
|
|
||||||
height: 32,
|
|
||||||
decoration: BoxDecoration(
|
|
||||||
borderRadius: BorderRadius.all(Radius.circular(16)),
|
|
||||||
color: Theme.of(context).accentTextTheme.caption!.color!),
|
|
||||||
child: ButtonTheme(
|
|
||||||
minWidth: double.minPositive,
|
|
||||||
child: TextButton(
|
|
||||||
onPressed: () async {
|
|
||||||
await showPopUp<void>(
|
|
||||||
context: context,
|
|
||||||
builder: (BuildContext context) {
|
|
||||||
return AlertWithTwoActions(
|
|
||||||
alertTitle: S.of(context).node_reset_settings_title,
|
|
||||||
alertContent:
|
|
||||||
S.of(context).nodes_list_reset_to_default_message,
|
|
||||||
rightButtonText: S.of(context).reset,
|
|
||||||
leftButtonText: S.of(context).cancel,
|
|
||||||
actionRightButton: () async {
|
|
||||||
Navigator.of(context).pop();
|
|
||||||
await nodeListViewModel.reset();
|
|
||||||
},
|
|
||||||
actionLeftButton: () => Navigator.of(context).pop());
|
|
||||||
});
|
|
||||||
},
|
|
||||||
child: Text(
|
|
||||||
S.of(context).reset,
|
|
||||||
textAlign: TextAlign.center,
|
|
||||||
style: TextStyle(
|
|
||||||
fontSize: 14.0,
|
|
||||||
fontWeight: FontWeight.w600,
|
|
||||||
color: Palette.blueCraiola),
|
|
||||||
)),
|
|
||||||
),
|
|
||||||
);
|
|
||||||
}
|
|
||||||
|
|
||||||
@override
|
|
||||||
Widget body(BuildContext context) {
|
|
||||||
return Container(
|
|
||||||
padding: EdgeInsets.only(top: 10),
|
|
||||||
child: Observer(
|
|
||||||
builder: (BuildContext context) {
|
|
||||||
return SectionStandardList(
|
|
||||||
sectionCount: 2,
|
|
||||||
context: context,
|
|
||||||
itemCounter: (int sectionIndex) {
|
|
||||||
if (sectionIndex == 0) {
|
|
||||||
return 1;
|
|
||||||
}
|
|
||||||
|
|
||||||
return nodeListViewModel.nodes.length;
|
|
||||||
},
|
|
||||||
itemBuilder: (_, sectionIndex, index) {
|
|
||||||
if (sectionIndex == 0) {
|
|
||||||
return NodeHeaderListRow(
|
|
||||||
title: S.of(context).add_new_node,
|
|
||||||
onTap: (_) async => await Navigator.of(context)
|
|
||||||
.pushNamed(Routes.newNode));
|
|
||||||
}
|
|
||||||
|
|
||||||
final node = nodeListViewModel.nodes[index];
|
|
||||||
final isSelected =
|
|
||||||
node.keyIndex == nodeListViewModel.currentNode.keyIndex;
|
|
||||||
final nodeListRow = NodeListRow(
|
|
||||||
title: node.uriRaw,
|
|
||||||
isSelected: isSelected,
|
|
||||||
isAlive: node.requestNode(),
|
|
||||||
onTap: (_) async {
|
|
||||||
if (isSelected) {
|
|
||||||
return;
|
|
||||||
}
|
|
||||||
|
|
||||||
await showPopUp<void>(
|
|
||||||
context: context,
|
|
||||||
builder: (BuildContext context) {
|
|
||||||
return AlertWithTwoActions(
|
|
||||||
alertTitle:
|
|
||||||
S.of(context).change_current_node_title,
|
|
||||||
alertContent: S
|
|
||||||
.of(context)
|
|
||||||
.change_current_node(node.uriRaw),
|
|
||||||
leftButtonText: S.of(context).cancel,
|
|
||||||
rightButtonText: S.of(context).change,
|
|
||||||
actionLeftButton: () =>
|
|
||||||
Navigator.of(context).pop(),
|
|
||||||
actionRightButton: () async {
|
|
||||||
await nodeListViewModel.setAsCurrent(node);
|
|
||||||
Navigator.of(context).pop();
|
|
||||||
});
|
|
||||||
});
|
|
||||||
});
|
|
||||||
|
|
||||||
final dismissibleRow = Slidable(
|
|
||||||
key: Key('${node.keyIndex}'),
|
|
||||||
startActionPane: _actionPane(context, node),
|
|
||||||
endActionPane: _actionPane(context, node),
|
|
||||||
child: nodeListRow,
|
|
||||||
);
|
|
||||||
|
|
||||||
return isSelected ? nodeListRow : dismissibleRow;
|
|
||||||
});
|
|
||||||
},
|
|
||||||
),
|
|
||||||
);
|
|
||||||
}
|
|
||||||
|
|
||||||
ActionPane _actionPane(BuildContext context, Node node) => ActionPane(
|
|
||||||
motion: const ScrollMotion(),
|
|
||||||
extentRatio: 0.3,
|
|
||||||
children: [
|
|
||||||
SlidableAction(
|
|
||||||
onPressed: (context) async {
|
|
||||||
final confirmed = await showPopUp<bool>(
|
|
||||||
context: context,
|
|
||||||
builder: (BuildContext context) {
|
|
||||||
return AlertWithTwoActions(
|
|
||||||
alertTitle: S.of(context).remove_node,
|
|
||||||
alertContent:
|
|
||||||
S.of(context).remove_node_message,
|
|
||||||
rightButtonText: S.of(context).remove,
|
|
||||||
leftButtonText: S.of(context).cancel,
|
|
||||||
actionRightButton: () =>
|
|
||||||
Navigator.pop(context, true),
|
|
||||||
actionLeftButton: () =>
|
|
||||||
Navigator.pop(context, false));
|
|
||||||
}) ??
|
|
||||||
false;
|
|
||||||
|
|
||||||
if (confirmed) {
|
|
||||||
await nodeListViewModel.delete(node);
|
|
||||||
}
|
|
||||||
},
|
|
||||||
backgroundColor: Colors.red,
|
|
||||||
foregroundColor: Colors.white,
|
|
||||||
icon: CupertinoIcons.delete,
|
|
||||||
label: S.of(context).delete,
|
|
||||||
),
|
|
||||||
],
|
|
||||||
);
|
|
||||||
}
|
|
|
@ -1,4 +1,3 @@
|
||||||
import 'dart:ui';
|
|
||||||
import 'package:cake_wallet/entities/fiat_currency.dart';
|
import 'package:cake_wallet/entities/fiat_currency.dart';
|
||||||
import 'package:cake_wallet/src/screens/dashboard/widgets/sync_indicator_icon.dart';
|
import 'package:cake_wallet/src/screens/dashboard/widgets/sync_indicator_icon.dart';
|
||||||
import 'package:cake_wallet/src/screens/send/widgets/send_card.dart';
|
import 'package:cake_wallet/src/screens/send/widgets/send_card.dart';
|
||||||
|
@ -6,8 +5,6 @@ import 'package:cake_wallet/src/widgets/alert_with_two_actions.dart';
|
||||||
import 'package:cake_wallet/src/widgets/picker.dart';
|
import 'package:cake_wallet/src/widgets/picker.dart';
|
||||||
import 'package:cake_wallet/src/widgets/template_tile.dart';
|
import 'package:cake_wallet/src/widgets/template_tile.dart';
|
||||||
import 'package:cake_wallet/view_model/send/output.dart';
|
import 'package:cake_wallet/view_model/send/output.dart';
|
||||||
import 'package:cake_wallet/view_model/settings/settings_view_model.dart';
|
|
||||||
import 'package:flutter/cupertino.dart';
|
|
||||||
import 'package:flutter/material.dart';
|
import 'package:flutter/material.dart';
|
||||||
import 'package:flutter_mobx/flutter_mobx.dart';
|
import 'package:flutter_mobx/flutter_mobx.dart';
|
||||||
import 'package:mobx/mobx.dart';
|
import 'package:mobx/mobx.dart';
|
||||||
|
@ -28,13 +25,11 @@ import 'package:smooth_page_indicator/smooth_page_indicator.dart';
|
||||||
import 'package:cw_core/crypto_currency.dart';
|
import 'package:cw_core/crypto_currency.dart';
|
||||||
|
|
||||||
class SendPage extends BasePage {
|
class SendPage extends BasePage {
|
||||||
SendPage({required this.sendViewModel,required this.settingsViewModel }) : _formKey = GlobalKey<FormState>(),fiatFromSettings = settingsViewModel.fiatCurrency;
|
SendPage({required this.sendViewModel}) : _formKey = GlobalKey<FormState>();
|
||||||
|
|
||||||
final SendViewModel sendViewModel;
|
final SendViewModel sendViewModel;
|
||||||
final SettingsViewModel settingsViewModel;
|
|
||||||
final GlobalKey<FormState> _formKey;
|
final GlobalKey<FormState> _formKey;
|
||||||
final controller = PageController(initialPage: 0);
|
final controller = PageController(initialPage: 0);
|
||||||
final FiatCurrency fiatFromSettings ;
|
|
||||||
|
|
||||||
bool _effectsInstalled = false;
|
bool _effectsInstalled = false;
|
||||||
|
|
||||||
|
@ -55,7 +50,7 @@ class SendPage extends BasePage {
|
||||||
|
|
||||||
@override
|
@override
|
||||||
void onClose(BuildContext context) {
|
void onClose(BuildContext context) {
|
||||||
settingsViewModel.setFiatCurrency(fiatFromSettings);
|
sendViewModel.onClose();
|
||||||
Navigator.of(context).pop();
|
Navigator.of(context).pop();
|
||||||
}
|
}
|
||||||
|
|
||||||
|
@ -236,7 +231,7 @@ class SendPage extends BasePage {
|
||||||
if(template.isCurrencySelected){
|
if(template.isCurrencySelected){
|
||||||
output.setCryptoAmount(template.amount);
|
output.setCryptoAmount(template.amount);
|
||||||
}else{
|
}else{
|
||||||
settingsViewModel.setFiatCurrency(fiatFromTemplate);
|
sendViewModel.setFiatCurrency(fiatFromTemplate);
|
||||||
output.setFiatAmount(template.amountFiat);
|
output.setFiatAmount(template.amountFiat);
|
||||||
}
|
}
|
||||||
output.resetParsedAddress();
|
output.resetParsedAddress();
|
||||||
|
|
|
@ -1,11 +1,10 @@
|
||||||
import 'dart:ui';
|
import 'package:cake_wallet/entities/priority_for_wallet_type.dart';
|
||||||
import 'package:cake_wallet/utils/payment_request.dart';
|
import 'package:cake_wallet/utils/payment_request.dart';
|
||||||
import 'package:cw_core/transaction_priority.dart';
|
import 'package:cw_core/transaction_priority.dart';
|
||||||
import 'package:cake_wallet/routes.dart';
|
import 'package:cake_wallet/routes.dart';
|
||||||
import 'package:cake_wallet/src/widgets/keyboard_done_button.dart';
|
import 'package:cake_wallet/src/widgets/keyboard_done_button.dart';
|
||||||
import 'package:cake_wallet/src/widgets/picker.dart';
|
import 'package:cake_wallet/src/widgets/picker.dart';
|
||||||
import 'package:cake_wallet/view_model/send/output.dart';
|
import 'package:cake_wallet/view_model/send/output.dart';
|
||||||
import 'package:cake_wallet/view_model/settings/settings_view_model.dart';
|
|
||||||
import 'package:flutter/material.dart';
|
import 'package:flutter/material.dart';
|
||||||
import 'package:flutter/services.dart';
|
import 'package:flutter/services.dart';
|
||||||
import 'package:flutter_mobx/flutter_mobx.dart';
|
import 'package:flutter_mobx/flutter_mobx.dart';
|
||||||
|
|
|
@ -8,18 +8,18 @@ import 'package:cake_wallet/src/screens/settings/widgets/settings_switcher_cell.
|
||||||
import 'package:cake_wallet/themes/theme_base.dart';
|
import 'package:cake_wallet/themes/theme_base.dart';
|
||||||
import 'package:cake_wallet/themes/theme_list.dart';
|
import 'package:cake_wallet/themes/theme_list.dart';
|
||||||
import 'package:cake_wallet/view_model/settings/choices_list_item.dart';
|
import 'package:cake_wallet/view_model/settings/choices_list_item.dart';
|
||||||
import 'package:cake_wallet/view_model/settings/settings_view_model.dart';
|
import 'package:cake_wallet/view_model/settings/display_settings_view_model.dart';
|
||||||
import 'package:cake_wallet/wallet_type_utils.dart';
|
import 'package:cake_wallet/wallet_type_utils.dart';
|
||||||
import 'package:flutter/material.dart';
|
import 'package:flutter/material.dart';
|
||||||
import 'package:flutter_mobx/flutter_mobx.dart';
|
import 'package:flutter_mobx/flutter_mobx.dart';
|
||||||
|
|
||||||
class DisplaySettingsPage extends BasePage {
|
class DisplaySettingsPage extends BasePage {
|
||||||
DisplaySettingsPage(this.settingsViewModel);
|
DisplaySettingsPage(this._displaySettingsViewModel);
|
||||||
|
|
||||||
@override
|
@override
|
||||||
String get title => S.current.display_settings;
|
String get title => S.current.display_settings;
|
||||||
|
|
||||||
final SettingsViewModel settingsViewModel;
|
final DisplaySettingsViewModel _displaySettingsViewModel;
|
||||||
|
|
||||||
@override
|
@override
|
||||||
Widget body(BuildContext context) {
|
Widget body(BuildContext context) {
|
||||||
|
@ -30,17 +30,17 @@ class DisplaySettingsPage extends BasePage {
|
||||||
children: [
|
children: [
|
||||||
SettingsSwitcherCell(
|
SettingsSwitcherCell(
|
||||||
title: S.current.settings_display_balance,
|
title: S.current.settings_display_balance,
|
||||||
value: settingsViewModel.shouldDisplayBalance,
|
value: _displaySettingsViewModel.shouldDisplayBalance,
|
||||||
onValueChange: (_, bool value) {
|
onValueChange: (_, bool value) {
|
||||||
settingsViewModel.setShouldDisplayBalance(value);
|
_displaySettingsViewModel.setShouldDisplayBalance(value);
|
||||||
}),
|
}),
|
||||||
if (!isHaven)
|
if (!isHaven)
|
||||||
SettingsPickerCell<FiatCurrency>(
|
SettingsPickerCell<FiatCurrency>(
|
||||||
title: S.current.settings_currency,
|
title: S.current.settings_currency,
|
||||||
searchHintText: S.current.search_currency,
|
searchHintText: S.current.search_currency,
|
||||||
items: FiatCurrency.all,
|
items: FiatCurrency.all,
|
||||||
selectedItem: settingsViewModel.fiatCurrency,
|
selectedItem: _displaySettingsViewModel.fiatCurrency,
|
||||||
onItemSelected: (FiatCurrency currency) => settingsViewModel.setFiatCurrency(currency),
|
onItemSelected: (FiatCurrency currency) => _displaySettingsViewModel.setFiatCurrency(currency),
|
||||||
images: FiatCurrency.all.map((e) => Image.asset("assets/images/flags/${e.countryCode}.png")).toList(),
|
images: FiatCurrency.all.map((e) => Image.asset("assets/images/flags/${e.countryCode}.png")).toList(),
|
||||||
isGridView: true,
|
isGridView: true,
|
||||||
matchingCriteria: (FiatCurrency currency, String searchText) {
|
matchingCriteria: (FiatCurrency currency, String searchText) {
|
||||||
|
@ -55,8 +55,8 @@ class DisplaySettingsPage extends BasePage {
|
||||||
displayItem: (dynamic code) {
|
displayItem: (dynamic code) {
|
||||||
return LanguageService.list[code] ?? '';
|
return LanguageService.list[code] ?? '';
|
||||||
},
|
},
|
||||||
selectedItem: settingsViewModel.languageCode,
|
selectedItem: _displaySettingsViewModel.languageCode,
|
||||||
onItemSelected: settingsViewModel.onLanguageSelected,
|
onItemSelected: _displaySettingsViewModel.onLanguageSelected,
|
||||||
images: LanguageService.list.keys
|
images: LanguageService.list.keys
|
||||||
.map((e) => Image.asset("assets/images/flags/${LanguageService.localeCountryCode[e]}.png"))
|
.map((e) => Image.asset("assets/images/flags/${LanguageService.localeCountryCode[e]}.png"))
|
||||||
.toList(),
|
.toList(),
|
||||||
|
@ -68,8 +68,8 @@ class DisplaySettingsPage extends BasePage {
|
||||||
ChoicesListItem<ThemeBase>(
|
ChoicesListItem<ThemeBase>(
|
||||||
title: S.current.color_theme,
|
title: S.current.color_theme,
|
||||||
items: ThemeList.all,
|
items: ThemeList.all,
|
||||||
selectedItem: settingsViewModel.theme,
|
selectedItem: _displaySettingsViewModel.theme,
|
||||||
onItemSelected: (ThemeBase theme) => settingsViewModel.setTheme(theme),
|
onItemSelected: (ThemeBase theme) => _displaySettingsViewModel.setTheme(theme),
|
||||||
),
|
),
|
||||||
),
|
),
|
||||||
],
|
],
|
||||||
|
|
|
@ -1,3 +1,4 @@
|
||||||
|
import 'package:cake_wallet/entities/priority_for_wallet_type.dart';
|
||||||
import 'package:cake_wallet/generated/i18n.dart';
|
import 'package:cake_wallet/generated/i18n.dart';
|
||||||
import 'package:cake_wallet/routes.dart';
|
import 'package:cake_wallet/routes.dart';
|
||||||
import 'package:cake_wallet/src/screens/base_page.dart';
|
import 'package:cake_wallet/src/screens/base_page.dart';
|
||||||
|
@ -5,18 +6,17 @@ import 'package:cake_wallet/src/screens/settings/widgets/settings_cell_with_arro
|
||||||
import 'package:cake_wallet/src/screens/settings/widgets/settings_picker_cell.dart';
|
import 'package:cake_wallet/src/screens/settings/widgets/settings_picker_cell.dart';
|
||||||
import 'package:cake_wallet/src/screens/settings/widgets/settings_version_cell.dart';
|
import 'package:cake_wallet/src/screens/settings/widgets/settings_version_cell.dart';
|
||||||
import 'package:cake_wallet/src/widgets/standard_list.dart';
|
import 'package:cake_wallet/src/widgets/standard_list.dart';
|
||||||
import 'package:cake_wallet/view_model/settings/settings_view_model.dart';
|
import 'package:cake_wallet/view_model/settings/other_settings_view_model.dart';
|
||||||
import 'package:cw_core/transaction_priority.dart';
|
|
||||||
import 'package:flutter/material.dart';
|
import 'package:flutter/material.dart';
|
||||||
import 'package:flutter_mobx/flutter_mobx.dart';
|
import 'package:flutter_mobx/flutter_mobx.dart';
|
||||||
|
|
||||||
class OtherSettingsPage extends BasePage {
|
class OtherSettingsPage extends BasePage {
|
||||||
OtherSettingsPage(this._settingsViewModel);
|
OtherSettingsPage(this._otherSettingsViewModel);
|
||||||
|
|
||||||
@override
|
@override
|
||||||
String get title => S.current.other_settings;
|
String get title => S.current.other_settings;
|
||||||
|
|
||||||
final SettingsViewModel _settingsViewModel;
|
final OtherSettingsViewModel _otherSettingsViewModel;
|
||||||
|
|
||||||
@override
|
@override
|
||||||
Widget body(BuildContext context) {
|
Widget body(BuildContext context) {
|
||||||
|
@ -26,10 +26,10 @@ class OtherSettingsPage extends BasePage {
|
||||||
child: Column(children: [
|
child: Column(children: [
|
||||||
SettingsPickerCell(
|
SettingsPickerCell(
|
||||||
title: S.current.settings_fee_priority,
|
title: S.current.settings_fee_priority,
|
||||||
items: priorityForWalletType(_settingsViewModel.walletType),
|
items: priorityForWalletType(_otherSettingsViewModel.walletType),
|
||||||
displayItem: _settingsViewModel.getDisplayPriority,
|
displayItem: _otherSettingsViewModel.getDisplayPriority,
|
||||||
selectedItem: _settingsViewModel.transactionPriority,
|
selectedItem: _otherSettingsViewModel.transactionPriority,
|
||||||
onItemSelected: _settingsViewModel.onDisplayPrioritySelected,
|
onItemSelected: _otherSettingsViewModel.onDisplayPrioritySelected,
|
||||||
),
|
),
|
||||||
SettingsCellWithArrow(
|
SettingsCellWithArrow(
|
||||||
title: S.current.settings_terms_and_conditions,
|
title: S.current.settings_terms_and_conditions,
|
||||||
|
@ -37,7 +37,7 @@ class OtherSettingsPage extends BasePage {
|
||||||
),
|
),
|
||||||
StandardListSeparator(padding: EdgeInsets.symmetric(horizontal: 24)),
|
StandardListSeparator(padding: EdgeInsets.symmetric(horizontal: 24)),
|
||||||
Spacer(),
|
Spacer(),
|
||||||
SettingsVersionCell(title: S.of(context).version(_settingsViewModel.currentVersion))
|
SettingsVersionCell(title: S.of(context).version(_otherSettingsViewModel.currentVersion))
|
||||||
]),
|
]),
|
||||||
);
|
);
|
||||||
});
|
});
|
||||||
|
|
|
@ -1,29 +1,42 @@
|
||||||
import 'package:cake_wallet/generated/i18n.dart';
|
import 'package:cake_wallet/generated/i18n.dart';
|
||||||
import 'package:cake_wallet/src/screens/base_page.dart';
|
import 'package:cake_wallet/src/screens/base_page.dart';
|
||||||
import 'package:cake_wallet/src/screens/settings/widgets/settings_switcher_cell.dart';
|
import 'package:cake_wallet/src/screens/settings/widgets/settings_switcher_cell.dart';
|
||||||
import 'package:cake_wallet/view_model/settings/settings_view_model.dart';
|
import 'package:cake_wallet/view_model/settings/privacy_settings_view_model.dart';
|
||||||
import 'package:flutter/material.dart';
|
import 'package:flutter/material.dart';
|
||||||
import 'package:flutter_mobx/flutter_mobx.dart';
|
import 'package:flutter_mobx/flutter_mobx.dart';
|
||||||
|
|
||||||
class PrivacyPage extends BasePage {
|
class PrivacyPage extends BasePage {
|
||||||
PrivacyPage(this.settingsViewModel);
|
PrivacyPage(this._privacySettingsViewModel);
|
||||||
|
|
||||||
@override
|
@override
|
||||||
String get title => S.current.privacy_settings;
|
String get title => S.current.privacy_settings;
|
||||||
|
|
||||||
final SettingsViewModel settingsViewModel;
|
final PrivacySettingsViewModel _privacySettingsViewModel;
|
||||||
|
|
||||||
@override
|
@override
|
||||||
Widget body(BuildContext context) {
|
Widget body(BuildContext context) {
|
||||||
return Container(
|
return Container(
|
||||||
padding: EdgeInsets.only(top: 10),
|
padding: EdgeInsets.only(top: 10),
|
||||||
child: Observer(builder: (_) {
|
child: Observer(builder: (_) {
|
||||||
return SettingsSwitcherCell(
|
return Observer(builder: (_) {
|
||||||
title: S.current.settings_save_recipient_address,
|
return Column(
|
||||||
value: settingsViewModel.shouldSaveRecipientAddress,
|
mainAxisSize: MainAxisSize.min,
|
||||||
onValueChange: (BuildContext _, bool value) {
|
children: [
|
||||||
settingsViewModel.setShouldSaveRecipientAddress(value);
|
SettingsSwitcherCell(
|
||||||
});
|
title: S.current.disable_exchange,
|
||||||
|
value: _privacySettingsViewModel.disableExchange,
|
||||||
|
onValueChange: (BuildContext context, bool value) {
|
||||||
|
_privacySettingsViewModel.setEnableExchange(value);
|
||||||
|
}),
|
||||||
|
SettingsSwitcherCell(
|
||||||
|
title: S.current.settings_save_recipient_address,
|
||||||
|
value: _privacySettingsViewModel.shouldSaveRecipientAddress,
|
||||||
|
onValueChange: (BuildContext _, bool value) {
|
||||||
|
_privacySettingsViewModel.setShouldSaveRecipientAddress(value);
|
||||||
|
})
|
||||||
|
],
|
||||||
|
);
|
||||||
|
});
|
||||||
}),
|
}),
|
||||||
);
|
);
|
||||||
}
|
}
|
||||||
|
|
|
@ -8,42 +8,45 @@ import 'package:cake_wallet/src/screens/settings/widgets/settings_cell_with_arro
|
||||||
import 'package:cake_wallet/src/screens/settings/widgets/settings_picker_cell.dart';
|
import 'package:cake_wallet/src/screens/settings/widgets/settings_picker_cell.dart';
|
||||||
import 'package:cake_wallet/src/screens/settings/widgets/settings_switcher_cell.dart';
|
import 'package:cake_wallet/src/screens/settings/widgets/settings_switcher_cell.dart';
|
||||||
import 'package:cake_wallet/src/widgets/standard_list.dart';
|
import 'package:cake_wallet/src/widgets/standard_list.dart';
|
||||||
import 'package:cake_wallet/view_model/settings/settings_view_model.dart';
|
import 'package:cake_wallet/view_model/settings/security_settings_view_model.dart';
|
||||||
import 'package:flutter/material.dart';
|
import 'package:flutter/material.dart';
|
||||||
import 'package:flutter_mobx/flutter_mobx.dart';
|
import 'package:flutter_mobx/flutter_mobx.dart';
|
||||||
|
|
||||||
class SecurityBackupPage extends BasePage {
|
class SecurityBackupPage extends BasePage {
|
||||||
SecurityBackupPage(this.settingsViewModel);
|
SecurityBackupPage(this._securitySettingsViewModel);
|
||||||
|
|
||||||
@override
|
@override
|
||||||
String get title => S.current.security_and_backup;
|
String get title => S.current.security_and_backup;
|
||||||
|
|
||||||
final SettingsViewModel settingsViewModel;
|
final SecuritySettingsViewModel _securitySettingsViewModel;
|
||||||
|
|
||||||
@override
|
@override
|
||||||
Widget body(BuildContext context) {
|
Widget body(BuildContext context) {
|
||||||
|
|
||||||
return Container(
|
return Container(
|
||||||
padding: EdgeInsets.only(top: 10),
|
padding: EdgeInsets.only(top: 10),
|
||||||
child: Column(mainAxisSize: MainAxisSize.min, children: [
|
child: Column(mainAxisSize: MainAxisSize.min, children: [
|
||||||
SettingsCellWithArrow(
|
SettingsCellWithArrow(
|
||||||
title: S.current.show_keys,
|
title: S.current.show_keys,
|
||||||
handler: (_) => settingsViewModel.checkPinCodeRiquired() ? Navigator.of(context).pushNamed(Routes.auth,
|
handler: (_) => _securitySettingsViewModel.checkPinCodeRiquired()
|
||||||
arguments: (bool isAuthenticatedSuccessfully, AuthPageState auth) {
|
? Navigator.of(context).pushNamed(Routes.auth,
|
||||||
if (isAuthenticatedSuccessfully) {
|
arguments: (bool isAuthenticatedSuccessfully, AuthPageState auth) {
|
||||||
auth.close(route: Routes.showKeys);
|
if (isAuthenticatedSuccessfully) {
|
||||||
}
|
auth.close(route: Routes.showKeys);
|
||||||
}) : Navigator.of(context).pushNamed(Routes.showKeys),
|
}
|
||||||
|
})
|
||||||
|
: Navigator.of(context).pushNamed(Routes.showKeys),
|
||||||
),
|
),
|
||||||
StandardListSeparator(padding: EdgeInsets.symmetric(horizontal: 24)),
|
StandardListSeparator(padding: EdgeInsets.symmetric(horizontal: 24)),
|
||||||
SettingsCellWithArrow(
|
SettingsCellWithArrow(
|
||||||
title: S.current.create_backup,
|
title: S.current.create_backup,
|
||||||
handler: (_) => settingsViewModel.checkPinCodeRiquired() ? Navigator.of(context).pushNamed(Routes.auth,
|
handler: (_) => _securitySettingsViewModel.checkPinCodeRiquired()
|
||||||
arguments: (bool isAuthenticatedSuccessfully, AuthPageState auth) {
|
? Navigator.of(context).pushNamed(Routes.auth,
|
||||||
if (isAuthenticatedSuccessfully) {
|
arguments: (bool isAuthenticatedSuccessfully, AuthPageState auth) {
|
||||||
auth.close(route: Routes.backup);
|
if (isAuthenticatedSuccessfully) {
|
||||||
}
|
auth.close(route: Routes.backup);
|
||||||
}) : Navigator.of(context).pushNamed(Routes.backup),
|
}
|
||||||
|
})
|
||||||
|
: Navigator.of(context).pushNamed(Routes.backup),
|
||||||
),
|
),
|
||||||
StandardListSeparator(padding: EdgeInsets.symmetric(horizontal: 24)),
|
StandardListSeparator(padding: EdgeInsets.symmetric(horizontal: 24)),
|
||||||
SettingsCellWithArrow(
|
SettingsCellWithArrow(
|
||||||
|
@ -63,37 +66,38 @@ class SecurityBackupPage extends BasePage {
|
||||||
children: [
|
children: [
|
||||||
SettingsSwitcherCell(
|
SettingsSwitcherCell(
|
||||||
title: S.current.settings_allow_biometrical_authentication,
|
title: S.current.settings_allow_biometrical_authentication,
|
||||||
value: settingsViewModel.allowBiometricalAuthentication,
|
value: _securitySettingsViewModel.allowBiometricalAuthentication,
|
||||||
onValueChange: (BuildContext context, bool value) {
|
onValueChange: (BuildContext context, bool value) {
|
||||||
if (value) {
|
if (value) {
|
||||||
Navigator.of(context).pushNamed(Routes.auth,
|
Navigator.of(context).pushNamed(Routes.auth,
|
||||||
arguments: (bool isAuthenticatedSuccessfully, AuthPageState auth) async {
|
arguments: (bool isAuthenticatedSuccessfully, AuthPageState auth) async {
|
||||||
if (isAuthenticatedSuccessfully) {
|
if (isAuthenticatedSuccessfully) {
|
||||||
if (await settingsViewModel.biometricAuthenticated()) {
|
if (await _securitySettingsViewModel.biometricAuthenticated()) {
|
||||||
settingsViewModel.setAllowBiometricalAuthentication(isAuthenticatedSuccessfully);
|
_securitySettingsViewModel
|
||||||
|
.setAllowBiometricalAuthentication(isAuthenticatedSuccessfully);
|
||||||
}
|
}
|
||||||
} else {
|
} else {
|
||||||
settingsViewModel.setAllowBiometricalAuthentication(isAuthenticatedSuccessfully);
|
_securitySettingsViewModel
|
||||||
|
.setAllowBiometricalAuthentication(isAuthenticatedSuccessfully);
|
||||||
}
|
}
|
||||||
|
|
||||||
auth.close();
|
auth.close();
|
||||||
});
|
});
|
||||||
} else {
|
} else {
|
||||||
settingsViewModel.setAllowBiometricalAuthentication(value);
|
_securitySettingsViewModel.setAllowBiometricalAuthentication(value);
|
||||||
}
|
}
|
||||||
}),
|
}),
|
||||||
SettingsPickerCell<PinCodeRequiredDuration>(
|
SettingsPickerCell<PinCodeRequiredDuration>(
|
||||||
title: S.current.require_pin_after,
|
title: S.current.require_pin_after,
|
||||||
items: PinCodeRequiredDuration.values,
|
items: PinCodeRequiredDuration.values,
|
||||||
selectedItem: settingsViewModel.pinCodeRequiredDuration,
|
selectedItem: _securitySettingsViewModel.pinCodeRequiredDuration,
|
||||||
onItemSelected: (PinCodeRequiredDuration code) {
|
onItemSelected: (PinCodeRequiredDuration code) {
|
||||||
settingsViewModel.setPinCodeRequiredDuration(code);
|
_securitySettingsViewModel.setPinCodeRequiredDuration(code);
|
||||||
},
|
},
|
||||||
),
|
),
|
||||||
],
|
],
|
||||||
);
|
);
|
||||||
}),
|
}),
|
||||||
|
|
||||||
]),
|
]),
|
||||||
);
|
);
|
||||||
}
|
}
|
||||||
|
|
|
@ -6,8 +6,8 @@ import 'package:cake_wallet/entities/preferences_key.dart';
|
||||||
import 'package:cake_wallet/exchange/sideshift/sideshift_exchange_provider.dart';
|
import 'package:cake_wallet/exchange/sideshift/sideshift_exchange_provider.dart';
|
||||||
import 'package:cake_wallet/exchange/sideshift/sideshift_request.dart';
|
import 'package:cake_wallet/exchange/sideshift/sideshift_request.dart';
|
||||||
import 'package:cake_wallet/exchange/simpleswap/simpleswap_exchange_provider.dart';
|
import 'package:cake_wallet/exchange/simpleswap/simpleswap_exchange_provider.dart';
|
||||||
import 'package:cake_wallet/view_model/settings/settings_view_model.dart';
|
|
||||||
import 'package:cake_wallet/exchange/simpleswap/simpleswap_request.dart';
|
import 'package:cake_wallet/exchange/simpleswap/simpleswap_request.dart';
|
||||||
|
import 'package:cw_core/transaction_priority.dart';
|
||||||
import 'package:cw_core/wallet_base.dart';
|
import 'package:cw_core/wallet_base.dart';
|
||||||
import 'package:cw_core/crypto_currency.dart';
|
import 'package:cw_core/crypto_currency.dart';
|
||||||
import 'package:cw_core/sync_status.dart';
|
import 'package:cw_core/sync_status.dart';
|
||||||
|
@ -42,7 +42,7 @@ class ExchangeViewModel = ExchangeViewModelBase with _$ExchangeViewModel;
|
||||||
|
|
||||||
abstract class ExchangeViewModelBase with Store {
|
abstract class ExchangeViewModelBase with Store {
|
||||||
ExchangeViewModelBase(this.wallet, this.trades, this._exchangeTemplateStore,
|
ExchangeViewModelBase(this.wallet, this.trades, this._exchangeTemplateStore,
|
||||||
this.tradesStore, this._settingsStore, this.sharedPreferences, this._settingsViewModel)
|
this.tradesStore, this._settingsStore, this.sharedPreferences)
|
||||||
: _cryptoNumberFormat = NumberFormat(),
|
: _cryptoNumberFormat = NumberFormat(),
|
||||||
isReverse = false,
|
isReverse = false,
|
||||||
isFixedRateMode = false,
|
isFixedRateMode = false,
|
||||||
|
@ -189,6 +189,19 @@ abstract class ExchangeViewModelBase with Store {
|
||||||
ObservableList<ExchangeTemplate> get templates =>
|
ObservableList<ExchangeTemplate> get templates =>
|
||||||
_exchangeTemplateStore.templates;
|
_exchangeTemplateStore.templates;
|
||||||
|
|
||||||
|
|
||||||
|
@computed
|
||||||
|
TransactionPriority get transactionPriority {
|
||||||
|
final priority = _settingsStore.priority[wallet.type];
|
||||||
|
|
||||||
|
if (priority == null) {
|
||||||
|
throw Exception('Unexpected type ${wallet.type.toString()}');
|
||||||
|
}
|
||||||
|
|
||||||
|
return priority;
|
||||||
|
}
|
||||||
|
|
||||||
|
|
||||||
bool get hasAllAmount =>
|
bool get hasAllAmount =>
|
||||||
wallet.type == WalletType.bitcoin && depositCurrency == wallet.currency;
|
wallet.type == WalletType.bitcoin && depositCurrency == wallet.currency;
|
||||||
|
|
||||||
|
@ -198,11 +211,11 @@ abstract class ExchangeViewModelBase with Store {
|
||||||
switch (wallet.type) {
|
switch (wallet.type) {
|
||||||
case WalletType.monero:
|
case WalletType.monero:
|
||||||
case WalletType.haven:
|
case WalletType.haven:
|
||||||
return _settingsViewModel.transactionPriority == monero!.getMoneroTransactionPrioritySlow();
|
return transactionPriority == monero!.getMoneroTransactionPrioritySlow();
|
||||||
case WalletType.bitcoin:
|
case WalletType.bitcoin:
|
||||||
return _settingsViewModel.transactionPriority == bitcoin!.getBitcoinTransactionPrioritySlow();
|
return transactionPriority == bitcoin!.getBitcoinTransactionPrioritySlow();
|
||||||
case WalletType.litecoin:
|
case WalletType.litecoin:
|
||||||
return _settingsViewModel.transactionPriority == bitcoin!.getLitecoinTransactionPrioritySlow();
|
return transactionPriority == bitcoin!.getLitecoinTransactionPrioritySlow();
|
||||||
default:
|
default:
|
||||||
return false;
|
return false;
|
||||||
}
|
}
|
||||||
|
@ -220,8 +233,6 @@ abstract class ExchangeViewModelBase with Store {
|
||||||
|
|
||||||
final SettingsStore _settingsStore;
|
final SettingsStore _settingsStore;
|
||||||
|
|
||||||
final SettingsViewModel _settingsViewModel;
|
|
||||||
|
|
||||||
double _bestRate = 0.0;
|
double _bestRate = 0.0;
|
||||||
|
|
||||||
late Timer bestRateSync;
|
late Timer bestRateSync;
|
||||||
|
@ -296,12 +307,14 @@ abstract class ExchangeViewModelBase with Store {
|
||||||
}
|
}
|
||||||
|
|
||||||
Future<void> _calculateBestRate() async {
|
Future<void> _calculateBestRate() async {
|
||||||
|
final amount = double.tryParse(isFixedRateMode ? receiveAmount : depositAmount) ?? 1;
|
||||||
|
|
||||||
final result = await Future.wait<double>(
|
final result = await Future.wait<double>(
|
||||||
_tradeAvailableProviders
|
_tradeAvailableProviders
|
||||||
.map((element) => element.calculateAmount(
|
.map((element) => element.calculateAmount(
|
||||||
from: depositCurrency,
|
from: depositCurrency,
|
||||||
to: receiveCurrency,
|
to: receiveCurrency,
|
||||||
amount: 1,
|
amount: amount,
|
||||||
isFixedRateMode: isFixedRateMode,
|
isFixedRateMode: isFixedRateMode,
|
||||||
isReceiveAmount: false))
|
isReceiveAmount: false))
|
||||||
);
|
);
|
||||||
|
@ -311,7 +324,7 @@ abstract class ExchangeViewModelBase with Store {
|
||||||
for (int i=0;i<result.length;i++) {
|
for (int i=0;i<result.length;i++) {
|
||||||
if (result[i] != 0) {
|
if (result[i] != 0) {
|
||||||
/// add this provider as its valid for this trade
|
/// add this provider as its valid for this trade
|
||||||
_sortedAvailableProviders[result[i]] = _tradeAvailableProviders[i];
|
_sortedAvailableProviders[result[i] / amount] = _tradeAvailableProviders[i];
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
if (_sortedAvailableProviders.isNotEmpty) {
|
if (_sortedAvailableProviders.isNotEmpty) {
|
||||||
|
@ -334,7 +347,7 @@ abstract class ExchangeViewModelBase with Store {
|
||||||
? depositCurrency
|
? depositCurrency
|
||||||
: receiveCurrency;
|
: receiveCurrency;
|
||||||
|
|
||||||
double lowestMin = double.maxFinite;
|
double? lowestMin = double.maxFinite;
|
||||||
double? highestMax = 0.0;
|
double? highestMax = 0.0;
|
||||||
|
|
||||||
for (var provider in selectedProviders) {
|
for (var provider in selectedProviders) {
|
||||||
|
@ -349,8 +362,8 @@ abstract class ExchangeViewModelBase with Store {
|
||||||
to: to,
|
to: to,
|
||||||
isFixedRateMode: isFixedRateMode);
|
isFixedRateMode: isFixedRateMode);
|
||||||
|
|
||||||
if (tempLimits.min != null && tempLimits.min! < lowestMin) {
|
if (lowestMin != null && (tempLimits.min ?? -1) < lowestMin) {
|
||||||
lowestMin = tempLimits.min!;
|
lowestMin = tempLimits.min;
|
||||||
}
|
}
|
||||||
if (highestMax != null && (tempLimits.max ?? double.maxFinite) > highestMax) {
|
if (highestMax != null && (tempLimits.max ?? double.maxFinite) > highestMax) {
|
||||||
highestMax = tempLimits.max;
|
highestMax = tempLimits.max;
|
||||||
|
@ -360,7 +373,7 @@ abstract class ExchangeViewModelBase with Store {
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
|
||||||
if (lowestMin < double.maxFinite) {
|
if (lowestMin != double.maxFinite) {
|
||||||
limits = Limits(min: lowestMin, max: highestMax);
|
limits = Limits(min: lowestMin, max: highestMax);
|
||||||
|
|
||||||
limitsState = LimitsLoadedSuccessfully(limits: limits);
|
limitsState = LimitsLoadedSuccessfully(limits: limits);
|
||||||
|
|
|
@ -18,7 +18,8 @@ abstract class NodeCreateOrEditViewModelBase with Store {
|
||||||
address = '',
|
address = '',
|
||||||
port = '',
|
port = '',
|
||||||
login = '',
|
login = '',
|
||||||
password = '';
|
password = '',
|
||||||
|
trusted = false;
|
||||||
|
|
||||||
@observable
|
@observable
|
||||||
ExecutionState state;
|
ExecutionState state;
|
||||||
|
@ -41,6 +42,9 @@ abstract class NodeCreateOrEditViewModelBase with Store {
|
||||||
@observable
|
@observable
|
||||||
bool useSSL;
|
bool useSSL;
|
||||||
|
|
||||||
|
@observable
|
||||||
|
bool trusted;
|
||||||
|
|
||||||
@computed
|
@computed
|
||||||
bool get isReady =>
|
bool get isReady =>
|
||||||
address.isNotEmpty && port.isNotEmpty;
|
address.isNotEmpty && port.isNotEmpty;
|
||||||
|
@ -68,6 +72,7 @@ abstract class NodeCreateOrEditViewModelBase with Store {
|
||||||
login = '';
|
login = '';
|
||||||
password = '';
|
password = '';
|
||||||
useSSL = false;
|
useSSL = false;
|
||||||
|
trusted = false;
|
||||||
}
|
}
|
||||||
|
|
||||||
@action
|
@action
|
||||||
|
@ -76,7 +81,7 @@ abstract class NodeCreateOrEditViewModelBase with Store {
|
||||||
state = IsExecutingState();
|
state = IsExecutingState();
|
||||||
final node =
|
final node =
|
||||||
Node(uri: uri, type: _wallet.type, login: login, password: password,
|
Node(uri: uri, type: _wallet.type, login: login, password: password,
|
||||||
useSSL: useSSL);
|
useSSL: useSSL, trusted: trusted);
|
||||||
await _nodeSource.add(node);
|
await _nodeSource.add(node);
|
||||||
state = ExecutedSuccessfullyState();
|
state = ExecutedSuccessfullyState();
|
||||||
} catch (e) {
|
} catch (e) {
|
||||||
|
|
|
@ -1,10 +1,10 @@
|
||||||
import 'package:cake_wallet/entities/balance_display_mode.dart';
|
import 'package:cake_wallet/entities/balance_display_mode.dart';
|
||||||
|
import 'package:cake_wallet/entities/priority_for_wallet_type.dart';
|
||||||
import 'package:cake_wallet/entities/transaction_description.dart';
|
import 'package:cake_wallet/entities/transaction_description.dart';
|
||||||
import 'package:cake_wallet/view_model/dashboard/balance_view_model.dart';
|
import 'package:cake_wallet/view_model/dashboard/balance_view_model.dart';
|
||||||
import 'package:cw_core/transaction_priority.dart';
|
import 'package:cw_core/transaction_priority.dart';
|
||||||
import 'package:cake_wallet/view_model/send/output.dart';
|
import 'package:cake_wallet/view_model/send/output.dart';
|
||||||
import 'package:cake_wallet/view_model/send/send_template_view_model.dart';
|
import 'package:cake_wallet/view_model/send/send_template_view_model.dart';
|
||||||
import 'package:cake_wallet/view_model/settings/settings_view_model.dart';
|
|
||||||
import 'package:hive/hive.dart';
|
import 'package:hive/hive.dart';
|
||||||
import 'package:mobx/mobx.dart';
|
import 'package:mobx/mobx.dart';
|
||||||
import 'package:cake_wallet/entities/template.dart';
|
import 'package:cake_wallet/entities/template.dart';
|
||||||
|
@ -42,7 +42,8 @@ abstract class SendViewModelBase with Store {
|
||||||
: state = InitialExecutionState(),
|
: state = InitialExecutionState(),
|
||||||
currencies = _wallet.balance.keys.toList(),
|
currencies = _wallet.balance.keys.toList(),
|
||||||
selectedCryptoCurrency = _wallet.currency,
|
selectedCryptoCurrency = _wallet.currency,
|
||||||
outputs = ObservableList<Output>() {
|
outputs = ObservableList<Output>(),
|
||||||
|
fiatFromSettings = _settingsStore.fiatCurrency {
|
||||||
final priority = _settingsStore.priority[_wallet.type];
|
final priority = _settingsStore.priority[_wallet.type];
|
||||||
final priorities = priorityForWalletType(_wallet.type);
|
final priorities = priorityForWalletType(_wallet.type);
|
||||||
|
|
||||||
|
@ -133,11 +134,13 @@ abstract class SendViewModelBase with Store {
|
||||||
|
|
||||||
Validator get textValidator => TextValidator();
|
Validator get textValidator => TextValidator();
|
||||||
|
|
||||||
|
final FiatCurrency fiatFromSettings;
|
||||||
|
|
||||||
@observable
|
@observable
|
||||||
PendingTransaction? pendingTransaction;
|
PendingTransaction? pendingTransaction;
|
||||||
|
|
||||||
@computed
|
@computed
|
||||||
String get balance => balanceViewModel.availableBalance ?? '0.0';
|
String get balance => balanceViewModel.availableBalance;
|
||||||
|
|
||||||
@computed
|
@computed
|
||||||
bool get isReadyForSend => _wallet.syncStatus is SyncedSyncStatus;
|
bool get isReadyForSend => _wallet.syncStatus is SyncedSyncStatus;
|
||||||
|
@ -166,6 +169,9 @@ abstract class SendViewModelBase with Store {
|
||||||
|
|
||||||
bool get hasCurrecyChanger => walletType == WalletType.haven;
|
bool get hasCurrecyChanger => walletType == WalletType.haven;
|
||||||
|
|
||||||
|
@computed
|
||||||
|
FiatCurrency get fiatCurrency => _settingsStore.fiatCurrency;
|
||||||
|
|
||||||
final WalletBase _wallet;
|
final WalletBase _wallet;
|
||||||
final SettingsStore _settingsStore;
|
final SettingsStore _settingsStore;
|
||||||
final SendTemplateViewModel sendTemplateViewModel;
|
final SendTemplateViewModel sendTemplateViewModel;
|
||||||
|
@ -208,7 +214,7 @@ abstract class SendViewModelBase with Store {
|
||||||
state = TransactionCommitting();
|
state = TransactionCommitting();
|
||||||
await pendingTransaction!.commit();
|
await pendingTransaction!.commit();
|
||||||
|
|
||||||
if (pendingTransaction!.id?.isNotEmpty ?? false) {
|
if (pendingTransaction!.id.isNotEmpty) {
|
||||||
_settingsStore.shouldSaveRecipientAddress
|
_settingsStore.shouldSaveRecipientAddress
|
||||||
? await transactionDescriptionBox.add(TransactionDescription(
|
? await transactionDescriptionBox.add(TransactionDescription(
|
||||||
id: pendingTransaction!.id,
|
id: pendingTransaction!.id,
|
||||||
|
@ -283,4 +289,12 @@ abstract class SendViewModelBase with Store {
|
||||||
|
|
||||||
bool _isEqualCurrency(String currency) =>
|
bool _isEqualCurrency(String currency) =>
|
||||||
currency.toLowerCase() == _wallet.currency.title.toLowerCase();
|
currency.toLowerCase() == _wallet.currency.title.toLowerCase();
|
||||||
|
|
||||||
|
@action
|
||||||
|
void onClose() =>
|
||||||
|
_settingsStore.fiatCurrency = fiatFromSettings;
|
||||||
|
|
||||||
|
@action
|
||||||
|
void setFiatCurrency(FiatCurrency fiat) =>
|
||||||
|
_settingsStore.fiatCurrency = fiat;
|
||||||
}
|
}
|
||||||
|
|
57
lib/view_model/settings/display_settings_view_model.dart
Normal file
57
lib/view_model/settings/display_settings_view_model.dart
Normal file
|
@ -0,0 +1,57 @@
|
||||||
|
import 'package:cake_wallet/entities/balance_display_mode.dart';
|
||||||
|
import 'package:cake_wallet/entities/fiat_currency.dart';
|
||||||
|
import 'package:cake_wallet/store/settings_store.dart';
|
||||||
|
import 'package:cake_wallet/themes/theme_base.dart';
|
||||||
|
import 'package:mobx/mobx.dart';
|
||||||
|
|
||||||
|
part 'display_settings_view_model.g.dart';
|
||||||
|
|
||||||
|
class DisplaySettingsViewModel = DisplaySettingsViewModelBase with _$DisplaySettingsViewModel;
|
||||||
|
|
||||||
|
abstract class DisplaySettingsViewModelBase with Store {
|
||||||
|
DisplaySettingsViewModelBase(
|
||||||
|
this._settingsStore,
|
||||||
|
);
|
||||||
|
|
||||||
|
final SettingsStore _settingsStore;
|
||||||
|
|
||||||
|
@computed
|
||||||
|
FiatCurrency get fiatCurrency => _settingsStore.fiatCurrency;
|
||||||
|
|
||||||
|
@computed
|
||||||
|
String get languageCode => _settingsStore.languageCode;
|
||||||
|
|
||||||
|
@computed
|
||||||
|
BalanceDisplayMode get balanceDisplayMode => _settingsStore.balanceDisplayMode;
|
||||||
|
|
||||||
|
@computed
|
||||||
|
bool get shouldDisplayBalance => balanceDisplayMode == BalanceDisplayMode.displayableBalance;
|
||||||
|
|
||||||
|
@computed
|
||||||
|
ThemeBase get theme => _settingsStore.currentTheme;
|
||||||
|
|
||||||
|
@action
|
||||||
|
void setBalanceDisplayMode(BalanceDisplayMode value) => _settingsStore.balanceDisplayMode = value;
|
||||||
|
|
||||||
|
@action
|
||||||
|
void setShouldDisplayBalance(bool value) {
|
||||||
|
if (value) {
|
||||||
|
_settingsStore.balanceDisplayMode = BalanceDisplayMode.displayableBalance;
|
||||||
|
} else {
|
||||||
|
_settingsStore.balanceDisplayMode = BalanceDisplayMode.hiddenBalance;
|
||||||
|
}
|
||||||
|
}
|
||||||
|
|
||||||
|
@action
|
||||||
|
void onLanguageSelected(String code) {
|
||||||
|
_settingsStore.languageCode = code;
|
||||||
|
}
|
||||||
|
|
||||||
|
@action
|
||||||
|
void setTheme(ThemeBase newTheme) {
|
||||||
|
_settingsStore.currentTheme = newTheme;
|
||||||
|
}
|
||||||
|
|
||||||
|
@action
|
||||||
|
void setFiatCurrency(FiatCurrency value) => _settingsStore.fiatCurrency = value;
|
||||||
|
}
|
64
lib/view_model/settings/other_settings_view_model.dart
Normal file
64
lib/view_model/settings/other_settings_view_model.dart
Normal file
|
@ -0,0 +1,64 @@
|
||||||
|
import 'package:cake_wallet/bitcoin/bitcoin.dart';
|
||||||
|
import 'package:cake_wallet/entities/priority_for_wallet_type.dart';
|
||||||
|
import 'package:cake_wallet/store/settings_store.dart';
|
||||||
|
import 'package:cw_core/balance.dart';
|
||||||
|
import 'package:cw_core/transaction_history.dart';
|
||||||
|
import 'package:cw_core/transaction_info.dart';
|
||||||
|
import 'package:cw_core/transaction_priority.dart';
|
||||||
|
import 'package:cw_core/wallet_base.dart';
|
||||||
|
import 'package:cw_core/wallet_type.dart';
|
||||||
|
import 'package:mobx/mobx.dart';
|
||||||
|
import 'package:package_info/package_info.dart';
|
||||||
|
|
||||||
|
part 'other_settings_view_model.g.dart';
|
||||||
|
|
||||||
|
class OtherSettingsViewModel = OtherSettingsViewModelBase with _$OtherSettingsViewModel;
|
||||||
|
|
||||||
|
abstract class OtherSettingsViewModelBase with Store {
|
||||||
|
OtherSettingsViewModelBase(this._settingsStore, this._wallet)
|
||||||
|
: walletType = _wallet.type,
|
||||||
|
currentVersion = '' {
|
||||||
|
PackageInfo.fromPlatform()
|
||||||
|
.then((PackageInfo packageInfo) => currentVersion = packageInfo.version);
|
||||||
|
|
||||||
|
final priority = _settingsStore.priority[_wallet.type];
|
||||||
|
final priorities = priorityForWalletType(_wallet.type);
|
||||||
|
|
||||||
|
if (!priorities.contains(priority)) {
|
||||||
|
_settingsStore.priority[_wallet.type] = priorities.first;
|
||||||
|
}
|
||||||
|
}
|
||||||
|
|
||||||
|
final WalletType walletType;
|
||||||
|
final WalletBase<Balance, TransactionHistoryBase<TransactionInfo>, TransactionInfo> _wallet;
|
||||||
|
|
||||||
|
@observable
|
||||||
|
String currentVersion;
|
||||||
|
|
||||||
|
final SettingsStore _settingsStore;
|
||||||
|
|
||||||
|
@computed
|
||||||
|
TransactionPriority get transactionPriority {
|
||||||
|
final priority = _settingsStore.priority[walletType];
|
||||||
|
|
||||||
|
if (priority == null) {
|
||||||
|
throw Exception('Unexpected type ${walletType.toString()}');
|
||||||
|
}
|
||||||
|
|
||||||
|
return priority;
|
||||||
|
}
|
||||||
|
|
||||||
|
String getDisplayPriority(dynamic priority) {
|
||||||
|
final _priority = priority as TransactionPriority;
|
||||||
|
|
||||||
|
if (_wallet.type == WalletType.bitcoin || _wallet.type == WalletType.litecoin) {
|
||||||
|
final rate = bitcoin!.getFeeRate(_wallet, _priority);
|
||||||
|
return bitcoin!.bitcoinTransactionPriorityWithLabel(_priority, rate);
|
||||||
|
}
|
||||||
|
|
||||||
|
return priority.toString();
|
||||||
|
}
|
||||||
|
|
||||||
|
void onDisplayPrioritySelected(TransactionPriority priority) =>
|
||||||
|
_settingsStore.priority[_wallet.type] = priority;
|
||||||
|
}
|
24
lib/view_model/settings/privacy_settings_view_model.dart
Normal file
24
lib/view_model/settings/privacy_settings_view_model.dart
Normal file
|
@ -0,0 +1,24 @@
|
||||||
|
import 'package:cake_wallet/store/settings_store.dart';
|
||||||
|
import 'package:mobx/mobx.dart';
|
||||||
|
|
||||||
|
part 'privacy_settings_view_model.g.dart';
|
||||||
|
|
||||||
|
class PrivacySettingsViewModel = PrivacySettingsViewModelBase with _$PrivacySettingsViewModel;
|
||||||
|
|
||||||
|
abstract class PrivacySettingsViewModelBase with Store {
|
||||||
|
PrivacySettingsViewModelBase(this._settingsStore);
|
||||||
|
|
||||||
|
final SettingsStore _settingsStore;
|
||||||
|
|
||||||
|
@computed
|
||||||
|
bool get disableExchange => _settingsStore.disableExchange;
|
||||||
|
|
||||||
|
@computed
|
||||||
|
bool get shouldSaveRecipientAddress => _settingsStore.shouldSaveRecipientAddress;
|
||||||
|
|
||||||
|
@action
|
||||||
|
void setShouldSaveRecipientAddress(bool value) => _settingsStore.shouldSaveRecipientAddress = value;
|
||||||
|
|
||||||
|
@action
|
||||||
|
void setEnableExchange(bool value) => _settingsStore.disableExchange = value;
|
||||||
|
}
|
25
lib/view_model/settings/security_settings_view_model.dart
Normal file
25
lib/view_model/settings/security_settings_view_model.dart
Normal file
|
@ -0,0 +1,25 @@
|
||||||
|
import 'package:cake_wallet/entities/biometric_auth.dart';
|
||||||
|
import 'package:cake_wallet/store/settings_store.dart';
|
||||||
|
import 'package:mobx/mobx.dart';
|
||||||
|
|
||||||
|
part 'security_settings_view_model.g.dart';
|
||||||
|
|
||||||
|
class SecuritySettingsViewModel = SecuritySettingsViewModelBase with _$SecuritySettingsViewModel;
|
||||||
|
|
||||||
|
abstract class SecuritySettingsViewModelBase with Store {
|
||||||
|
SecuritySettingsViewModelBase(this._settingsStore) : _biometricAuth = BiometricAuth();
|
||||||
|
|
||||||
|
final BiometricAuth _biometricAuth;
|
||||||
|
final SettingsStore _settingsStore;
|
||||||
|
|
||||||
|
@computed
|
||||||
|
bool get allowBiometricalAuthentication => _settingsStore.allowBiometricalAuthentication;
|
||||||
|
|
||||||
|
@action
|
||||||
|
Future<bool> biometricAuthenticated() async {
|
||||||
|
return await _biometricAuth.canCheckBiometrics() && await _biometricAuth.isAuthenticated();
|
||||||
|
}
|
||||||
|
|
||||||
|
@action
|
||||||
|
void setAllowBiometricalAuthentication(bool value) => _settingsStore.allowBiometricalAuthentication = value;
|
||||||
|
}
|
|
@ -1,239 +0,0 @@
|
||||||
import 'package:cake_wallet/core/auth_service.dart';
|
|
||||||
import 'package:cake_wallet/entities/pin_code_required_duration.dart';
|
|
||||||
import 'package:cake_wallet/store/yat/yat_store.dart';
|
|
||||||
import 'package:mobx/mobx.dart';
|
|
||||||
import 'package:package_info/package_info.dart';
|
|
||||||
import 'package:cw_core/wallet_base.dart';
|
|
||||||
import 'package:cake_wallet/store/settings_store.dart';
|
|
||||||
import 'package:cake_wallet/entities/biometric_auth.dart';
|
|
||||||
import 'package:cw_core/wallet_type.dart';
|
|
||||||
import 'package:cake_wallet/entities/balance_display_mode.dart';
|
|
||||||
import 'package:cake_wallet/entities/fiat_currency.dart';
|
|
||||||
import 'package:cw_core/node.dart';
|
|
||||||
import 'package:cake_wallet/monero/monero.dart';
|
|
||||||
import 'package:cake_wallet/haven/haven.dart';
|
|
||||||
import 'package:cake_wallet/entities/action_list_display_mode.dart';
|
|
||||||
import 'package:cake_wallet/bitcoin/bitcoin.dart';
|
|
||||||
import 'package:cw_core/transaction_history.dart';
|
|
||||||
import 'package:cw_core/balance.dart';
|
|
||||||
import 'package:cw_core/transaction_info.dart';
|
|
||||||
import 'package:cw_core/transaction_priority.dart';
|
|
||||||
import 'package:cake_wallet/themes/theme_base.dart';
|
|
||||||
|
|
||||||
part 'settings_view_model.g.dart';
|
|
||||||
|
|
||||||
class SettingsViewModel = SettingsViewModelBase with _$SettingsViewModel;
|
|
||||||
|
|
||||||
List<TransactionPriority> priorityForWalletType(WalletType type) {
|
|
||||||
switch (type) {
|
|
||||||
case WalletType.monero:
|
|
||||||
return monero!.getTransactionPriorities();
|
|
||||||
case WalletType.bitcoin:
|
|
||||||
return bitcoin!.getTransactionPriorities();
|
|
||||||
case WalletType.litecoin:
|
|
||||||
return bitcoin!.getLitecoinTransactionPriorities();
|
|
||||||
case WalletType.haven:
|
|
||||||
return haven!.getTransactionPriorities();
|
|
||||||
default:
|
|
||||||
return [];
|
|
||||||
}
|
|
||||||
}
|
|
||||||
|
|
||||||
abstract class SettingsViewModelBase with Store {
|
|
||||||
SettingsViewModelBase(
|
|
||||||
this._settingsStore,
|
|
||||||
this._yatStore,
|
|
||||||
this._authService,
|
|
||||||
WalletBase<Balance, TransactionHistoryBase<TransactionInfo>,
|
|
||||||
TransactionInfo>
|
|
||||||
wallet)
|
|
||||||
: itemHeaders = {},
|
|
||||||
walletType = wallet.type,
|
|
||||||
_wallet = wallet,
|
|
||||||
_biometricAuth = BiometricAuth(),
|
|
||||||
currentVersion = '' {
|
|
||||||
PackageInfo.fromPlatform().then(
|
|
||||||
(PackageInfo packageInfo) => currentVersion = packageInfo.version);
|
|
||||||
|
|
||||||
final priority = _settingsStore.priority[wallet.type];
|
|
||||||
final priorities = priorityForWalletType(wallet.type);
|
|
||||||
|
|
||||||
if (!priorities.contains(priority)) {
|
|
||||||
_settingsStore.priority[wallet.type] = priorities.first;
|
|
||||||
}
|
|
||||||
|
|
||||||
//var connectYatUrl = YatLink.baseUrl + YatLink.signInSuffix;
|
|
||||||
//final connectYatUrlParameters =
|
|
||||||
// _yatStore.defineQueryParameters();
|
|
||||||
|
|
||||||
//if (connectYatUrlParameters.isNotEmpty) {
|
|
||||||
// connectYatUrl += YatLink.queryParameter + connectYatUrlParameters;
|
|
||||||
//}
|
|
||||||
|
|
||||||
//var manageYatUrl = YatLink.baseUrl + YatLink.managePath;
|
|
||||||
//final manageYatUrlParameters =
|
|
||||||
// _yatStore.defineQueryParameters();
|
|
||||||
|
|
||||||
//if (manageYatUrlParameters.isNotEmpty) {
|
|
||||||
// manageYatUrl += YatLink.queryParameter + manageYatUrlParameters;
|
|
||||||
//}
|
|
||||||
|
|
||||||
//var createNewYatUrl = YatLink.startFlowUrl;
|
|
||||||
//final createNewYatUrlParameters =
|
|
||||||
// _yatStore.defineQueryParameters();
|
|
||||||
|
|
||||||
//if (createNewYatUrlParameters.isNotEmpty) {
|
|
||||||
// createNewYatUrl += '?sub1=' + createNewYatUrlParameters;
|
|
||||||
//}
|
|
||||||
|
|
||||||
}
|
|
||||||
|
|
||||||
@observable
|
|
||||||
String currentVersion;
|
|
||||||
|
|
||||||
@computed
|
|
||||||
Node get node => _settingsStore.getCurrentNode(walletType);
|
|
||||||
|
|
||||||
@computed
|
|
||||||
FiatCurrency get fiatCurrency => _settingsStore.fiatCurrency;
|
|
||||||
|
|
||||||
@computed
|
|
||||||
PinCodeRequiredDuration get pinCodeRequiredDuration =>
|
|
||||||
_settingsStore.pinTimeOutDuration;
|
|
||||||
|
|
||||||
@computed
|
|
||||||
String get languageCode => _settingsStore.languageCode;
|
|
||||||
|
|
||||||
@computed
|
|
||||||
ObservableList<ActionListDisplayMode> get actionlistDisplayMode =>
|
|
||||||
_settingsStore.actionlistDisplayMode;
|
|
||||||
|
|
||||||
@computed
|
|
||||||
TransactionPriority get transactionPriority {
|
|
||||||
final priority = _settingsStore.priority[walletType];
|
|
||||||
|
|
||||||
if (priority == null) {
|
|
||||||
throw Exception('Unexpected type ${walletType.toString()}');
|
|
||||||
}
|
|
||||||
|
|
||||||
return priority;
|
|
||||||
}
|
|
||||||
|
|
||||||
@computed
|
|
||||||
BalanceDisplayMode get balanceDisplayMode =>
|
|
||||||
_settingsStore.balanceDisplayMode;
|
|
||||||
|
|
||||||
@computed
|
|
||||||
bool get shouldDisplayBalance => balanceDisplayMode == BalanceDisplayMode.displayableBalance;
|
|
||||||
|
|
||||||
@computed
|
|
||||||
bool get shouldSaveRecipientAddress =>
|
|
||||||
_settingsStore.shouldSaveRecipientAddress;
|
|
||||||
|
|
||||||
@computed
|
|
||||||
bool get allowBiometricalAuthentication =>
|
|
||||||
_settingsStore.allowBiometricalAuthentication;
|
|
||||||
|
|
||||||
@computed
|
|
||||||
ThemeBase get theme => _settingsStore.currentTheme;
|
|
||||||
|
|
||||||
bool get isBitcoinBuyEnabled => _settingsStore.isBitcoinBuyEnabled;
|
|
||||||
|
|
||||||
final Map<String, String> itemHeaders;
|
|
||||||
final SettingsStore _settingsStore;
|
|
||||||
final YatStore _yatStore;
|
|
||||||
final AuthService _authService;
|
|
||||||
final WalletType walletType;
|
|
||||||
final BiometricAuth _biometricAuth;
|
|
||||||
final WalletBase<Balance, TransactionHistoryBase<TransactionInfo>,
|
|
||||||
TransactionInfo> _wallet;
|
|
||||||
|
|
||||||
@action
|
|
||||||
void setBalanceDisplayMode(BalanceDisplayMode value) =>
|
|
||||||
_settingsStore.balanceDisplayMode = value;
|
|
||||||
|
|
||||||
@action
|
|
||||||
void setFiatCurrency(FiatCurrency value) =>
|
|
||||||
_settingsStore.fiatCurrency = value;
|
|
||||||
|
|
||||||
@action
|
|
||||||
void setShouldSaveRecipientAddress(bool value) =>
|
|
||||||
_settingsStore.shouldSaveRecipientAddress = value;
|
|
||||||
|
|
||||||
@action
|
|
||||||
void setAllowBiometricalAuthentication(bool value) =>
|
|
||||||
_settingsStore.allowBiometricalAuthentication = value;
|
|
||||||
|
|
||||||
@action
|
|
||||||
void toggleTransactionsDisplay() =>
|
|
||||||
actionlistDisplayMode.contains(ActionListDisplayMode.transactions)
|
|
||||||
? _hideTransaction()
|
|
||||||
: _showTransaction();
|
|
||||||
|
|
||||||
@action
|
|
||||||
void toggleTradesDisplay() =>
|
|
||||||
actionlistDisplayMode.contains(ActionListDisplayMode.trades)
|
|
||||||
? _hideTrades()
|
|
||||||
: _showTrades();
|
|
||||||
|
|
||||||
@action
|
|
||||||
void _hideTransaction() =>
|
|
||||||
actionlistDisplayMode.remove(ActionListDisplayMode.transactions);
|
|
||||||
|
|
||||||
@action
|
|
||||||
void _hideTrades() =>
|
|
||||||
actionlistDisplayMode.remove(ActionListDisplayMode.trades);
|
|
||||||
|
|
||||||
@action
|
|
||||||
void _showTransaction() =>
|
|
||||||
actionlistDisplayMode.add(ActionListDisplayMode.transactions);
|
|
||||||
|
|
||||||
@action
|
|
||||||
void _showTrades() => actionlistDisplayMode.add(ActionListDisplayMode.trades);
|
|
||||||
|
|
||||||
@action
|
|
||||||
Future<bool> biometricAuthenticated()async{
|
|
||||||
return await _biometricAuth.canCheckBiometrics() && await _biometricAuth.isAuthenticated();
|
|
||||||
}
|
|
||||||
|
|
||||||
@action
|
|
||||||
void onLanguageSelected (String code) {
|
|
||||||
_settingsStore.languageCode = code;
|
|
||||||
}
|
|
||||||
|
|
||||||
@action
|
|
||||||
void setTheme(ThemeBase newTheme){
|
|
||||||
_settingsStore.currentTheme = newTheme;
|
|
||||||
}
|
|
||||||
|
|
||||||
@action
|
|
||||||
void setShouldDisplayBalance(bool value){
|
|
||||||
if (value) {
|
|
||||||
_settingsStore.balanceDisplayMode = BalanceDisplayMode.displayableBalance;
|
|
||||||
} else {
|
|
||||||
_settingsStore.balanceDisplayMode = BalanceDisplayMode.hiddenBalance;
|
|
||||||
}
|
|
||||||
}
|
|
||||||
|
|
||||||
@action
|
|
||||||
setPinCodeRequiredDuration(PinCodeRequiredDuration duration) =>
|
|
||||||
_settingsStore.pinTimeOutDuration = duration;
|
|
||||||
|
|
||||||
String getDisplayPriority(dynamic priority) {
|
|
||||||
final _priority = priority as TransactionPriority;
|
|
||||||
|
|
||||||
if (_wallet.type == WalletType.bitcoin
|
|
||||||
|| _wallet.type == WalletType.litecoin) {
|
|
||||||
final rate = bitcoin!.getFeeRate(_wallet, _priority);
|
|
||||||
return bitcoin!.bitcoinTransactionPriorityWithLabel(_priority, rate);
|
|
||||||
}
|
|
||||||
|
|
||||||
return priority.toString();
|
|
||||||
}
|
|
||||||
|
|
||||||
void onDisplayPrioritySelected(TransactionPriority priority) =>
|
|
||||||
_settingsStore.priority[_wallet.type] = priority;
|
|
||||||
|
|
||||||
bool checkPinCodeRiquired() => _authService.requireAuth();
|
|
||||||
|
|
||||||
}
|
|
|
@ -184,7 +184,7 @@ abstract class TransactionDetailsViewModelBase with Store {
|
||||||
case WalletType.monero:
|
case WalletType.monero:
|
||||||
return 'https://monero.com/tx/${txId}';
|
return 'https://monero.com/tx/${txId}';
|
||||||
case WalletType.bitcoin:
|
case WalletType.bitcoin:
|
||||||
return 'https://www.blockchain.com/btc/tx/${txId}';
|
return 'https://mempool.space/tx/${txId}';
|
||||||
case WalletType.litecoin:
|
case WalletType.litecoin:
|
||||||
return 'https://blockchair.com/litecoin/transaction/${txId}';
|
return 'https://blockchair.com/litecoin/transaction/${txId}';
|
||||||
case WalletType.haven:
|
case WalletType.haven:
|
||||||
|
@ -199,7 +199,7 @@ abstract class TransactionDetailsViewModelBase with Store {
|
||||||
case WalletType.monero:
|
case WalletType.monero:
|
||||||
return S.current.view_transaction_on + 'Monero.com';
|
return S.current.view_transaction_on + 'Monero.com';
|
||||||
case WalletType.bitcoin:
|
case WalletType.bitcoin:
|
||||||
return S.current.view_transaction_on + 'Blockchain.com';
|
return S.current.view_transaction_on + 'mempool.space';
|
||||||
case WalletType.litecoin:
|
case WalletType.litecoin:
|
||||||
return S.current.view_transaction_on + 'Blockchair.com';
|
return S.current.view_transaction_on + 'Blockchair.com';
|
||||||
case WalletType.haven:
|
case WalletType.haven:
|
||||||
|
|
5
model_generator.sh
Normal file
5
model_generator.sh
Normal file
|
@ -0,0 +1,5 @@
|
||||||
|
cd cw_core && flutter pub get && flutter packages pub run build_runner build --delete-conflicting-outputs && cd ..
|
||||||
|
cd cw_monero && flutter pub get && flutter packages pub run build_runner build --delete-conflicting-outputs && cd ..
|
||||||
|
cd cw_bitcoin && flutter pub get && flutter packages pub run build_runner build --delete-conflicting-outputs && cd ..
|
||||||
|
cd cw_haven && flutter pub get && flutter packages pub run build_runner build --delete-conflicting-outputs && cd ..
|
||||||
|
flutter packages pub run build_runner build --delete-conflicting-outputs
|
|
@ -356,6 +356,7 @@
|
||||||
"sync_status_failed_connect" : "GETRENNT",
|
"sync_status_failed_connect" : "GETRENNT",
|
||||||
"sync_status_connecting" : "VERBINDEN",
|
"sync_status_connecting" : "VERBINDEN",
|
||||||
"sync_status_connected" : "VERBUNDEN",
|
"sync_status_connected" : "VERBUNDEN",
|
||||||
|
"sync_status_attempting_sync" : "SYNC VERSUCHEN",
|
||||||
|
|
||||||
|
|
||||||
"transaction_priority_slow" : "Langsam",
|
"transaction_priority_slow" : "Langsam",
|
||||||
|
@ -436,6 +437,7 @@
|
||||||
"provider_error" : "${provider}-Fehler",
|
"provider_error" : "${provider}-Fehler",
|
||||||
|
|
||||||
"use_ssl" : "SSL verwenden",
|
"use_ssl" : "SSL verwenden",
|
||||||
|
"trusted" : "Vertrauenswürdige",
|
||||||
|
|
||||||
"color_theme" : "Farbthema",
|
"color_theme" : "Farbthema",
|
||||||
"light_theme" : "Hell",
|
"light_theme" : "Hell",
|
||||||
|
@ -652,6 +654,9 @@
|
||||||
"use_suggested": "Vorgeschlagen verwenden",
|
"use_suggested": "Vorgeschlagen verwenden",
|
||||||
"do_not_share_warning_text" : "Teilen Sie diese nicht mit anderen, einschließlich des Supports.\n\nSie werden Ihr Geld stehlen!",
|
"do_not_share_warning_text" : "Teilen Sie diese nicht mit anderen, einschließlich des Supports.\n\nSie werden Ihr Geld stehlen!",
|
||||||
"help": "hilfe",
|
"help": "hilfe",
|
||||||
|
"connection_sync": "Verbindung und Synchronisierung",
|
||||||
|
"security_and_backup": "Sicherheit und Datensicherung",
|
||||||
|
"create_backup": "Backup erstellen",
|
||||||
"privacy_settings": "Datenschutzeinstellungen",
|
"privacy_settings": "Datenschutzeinstellungen",
|
||||||
"privacy": "Datenschutz",
|
"privacy": "Datenschutz",
|
||||||
"display_settings": "Anzeigeeinstellungen",
|
"display_settings": "Anzeigeeinstellungen",
|
||||||
|
|
|
@ -356,6 +356,7 @@
|
||||||
"sync_status_failed_connect" : "DISCONNECTED",
|
"sync_status_failed_connect" : "DISCONNECTED",
|
||||||
"sync_status_connecting" : "CONNECTING",
|
"sync_status_connecting" : "CONNECTING",
|
||||||
"sync_status_connected" : "CONNECTED",
|
"sync_status_connected" : "CONNECTED",
|
||||||
|
"sync_status_attempting_sync" : "ATTEMPTING SYNC",
|
||||||
|
|
||||||
|
|
||||||
"transaction_priority_slow" : "Slow",
|
"transaction_priority_slow" : "Slow",
|
||||||
|
@ -436,6 +437,7 @@
|
||||||
"provider_error" : "${provider} error",
|
"provider_error" : "${provider} error",
|
||||||
|
|
||||||
"use_ssl" : "Use SSL",
|
"use_ssl" : "Use SSL",
|
||||||
|
"trusted" : "Trusted",
|
||||||
|
|
||||||
"color_theme" : "Color theme",
|
"color_theme" : "Color theme",
|
||||||
"light_theme" : "Light",
|
"light_theme" : "Light",
|
||||||
|
|
|
@ -356,6 +356,7 @@
|
||||||
"sync_status_failed_connect" : "DESCONECTADO",
|
"sync_status_failed_connect" : "DESCONECTADO",
|
||||||
"sync_status_connecting" : "CONECTANDO",
|
"sync_status_connecting" : "CONECTANDO",
|
||||||
"sync_status_connected" : "CONECTADO",
|
"sync_status_connected" : "CONECTADO",
|
||||||
|
"sync_status_attempting_sync" : "INTENTAR SINCRONIZAR",
|
||||||
|
|
||||||
|
|
||||||
"transaction_priority_slow" : "Lento",
|
"transaction_priority_slow" : "Lento",
|
||||||
|
@ -436,6 +437,7 @@
|
||||||
"provider_error" : "${provider} error",
|
"provider_error" : "${provider} error",
|
||||||
|
|
||||||
"use_ssl" : "Utilice SSL",
|
"use_ssl" : "Utilice SSL",
|
||||||
|
"trusted" : "de confianza",
|
||||||
|
|
||||||
"color_theme" : "Tema de color",
|
"color_theme" : "Tema de color",
|
||||||
"light_theme" : "Ligera",
|
"light_theme" : "Ligera",
|
||||||
|
@ -652,6 +654,9 @@
|
||||||
"use_suggested": "Usar sugerido",
|
"use_suggested": "Usar sugerido",
|
||||||
"do_not_share_warning_text" : "No comparta estos con nadie más, incluido el soporte.\n\n¡Te robarán tu dinero!",
|
"do_not_share_warning_text" : "No comparta estos con nadie más, incluido el soporte.\n\n¡Te robarán tu dinero!",
|
||||||
"help": "ayuda",
|
"help": "ayuda",
|
||||||
|
"connection_sync": "Conexión y sincronización",
|
||||||
|
"security_and_backup": "Seguridad y respaldo",
|
||||||
|
"create_backup": "Crear copia de seguridad",
|
||||||
"privacy_settings": "Configuración de privacidad",
|
"privacy_settings": "Configuración de privacidad",
|
||||||
"privacy": "Privacidad",
|
"privacy": "Privacidad",
|
||||||
"display_settings": "Configuración de pantalla",
|
"display_settings": "Configuración de pantalla",
|
||||||
|
|
|
@ -354,6 +354,7 @@
|
||||||
"sync_status_failed_connect" : "DÉCONNECTÉ",
|
"sync_status_failed_connect" : "DÉCONNECTÉ",
|
||||||
"sync_status_connecting" : "CONNEXION EN COURS",
|
"sync_status_connecting" : "CONNEXION EN COURS",
|
||||||
"sync_status_connected" : "CONNECTÉ",
|
"sync_status_connected" : "CONNECTÉ",
|
||||||
|
"sync_status_attempting_sync" : "TENTATIVE DE SYNCHRONISATION",
|
||||||
|
|
||||||
|
|
||||||
"transaction_priority_slow" : "Lent",
|
"transaction_priority_slow" : "Lent",
|
||||||
|
@ -434,6 +435,7 @@
|
||||||
"provider_error" : "Erreur de ${provider}",
|
"provider_error" : "Erreur de ${provider}",
|
||||||
|
|
||||||
"use_ssl" : "Utiliser SSL",
|
"use_ssl" : "Utiliser SSL",
|
||||||
|
"trusted" : "de confiance",
|
||||||
|
|
||||||
"color_theme" : "Thème",
|
"color_theme" : "Thème",
|
||||||
"light_theme" : "Clair",
|
"light_theme" : "Clair",
|
||||||
|
@ -650,6 +652,9 @@
|
||||||
"use_suggested": "Utilisation suggérée",
|
"use_suggested": "Utilisation suggérée",
|
||||||
"do_not_share_warning_text" : "Ne les partagez avec personne d'autre, y compris avec l'assistance.\n\nIls vont voler votre argent!",
|
"do_not_share_warning_text" : "Ne les partagez avec personne d'autre, y compris avec l'assistance.\n\nIls vont voler votre argent!",
|
||||||
"help": "aider",
|
"help": "aider",
|
||||||
|
"connection_sync": "Connexion et synchronisation",
|
||||||
|
"security_and_backup": "Sécurité et sauvegarde",
|
||||||
|
"create_backup": "Créer une sauvegarde",
|
||||||
"privacy_settings": "Paramètres de confidentialité",
|
"privacy_settings": "Paramètres de confidentialité",
|
||||||
"privacy": "Confidentialité",
|
"privacy": "Confidentialité",
|
||||||
"display_settings": "Paramètres d'affichage",
|
"display_settings": "Paramètres d'affichage",
|
||||||
|
|
|
@ -356,6 +356,7 @@
|
||||||
"sync_status_failed_connect" : "डिस्कनेक्ट किया गया",
|
"sync_status_failed_connect" : "डिस्कनेक्ट किया गया",
|
||||||
"sync_status_connecting" : "कनेक्ट",
|
"sync_status_connecting" : "कनेक्ट",
|
||||||
"sync_status_connected" : "जुड़े हुए",
|
"sync_status_connected" : "जुड़े हुए",
|
||||||
|
"sync_status_attempting_sync" : "सिंक करने का प्रयास",
|
||||||
|
|
||||||
|
|
||||||
"transaction_priority_slow" : "धीरे",
|
"transaction_priority_slow" : "धीरे",
|
||||||
|
@ -436,6 +437,7 @@
|
||||||
"provider_error" : "${provider} त्रुटि",
|
"provider_error" : "${provider} त्रुटि",
|
||||||
|
|
||||||
"use_ssl" : "उपयोग SSL",
|
"use_ssl" : "उपयोग SSL",
|
||||||
|
"trusted" : "भरोसा",
|
||||||
|
|
||||||
"color_theme" : "रंग विषय",
|
"color_theme" : "रंग विषय",
|
||||||
"light_theme" : "रोशनी",
|
"light_theme" : "रोशनी",
|
||||||
|
@ -652,6 +654,9 @@
|
||||||
"use_suggested": "सुझाए गए का प्रयोग करें",
|
"use_suggested": "सुझाए गए का प्रयोग करें",
|
||||||
"do_not_share_warning_text" : "इन्हें समर्थन सहित किसी और के साथ साझा न करें।\n\nवे आपका पैसा चुरा लेंगे!",
|
"do_not_share_warning_text" : "इन्हें समर्थन सहित किसी और के साथ साझा न करें।\n\nवे आपका पैसा चुरा लेंगे!",
|
||||||
"help": "मदद करना",
|
"help": "मदद करना",
|
||||||
|
"connection_sync": "कनेक्शन और सिंक",
|
||||||
|
"security_and_backup": "सुरक्षा और बैकअप",
|
||||||
|
"create_backup": "बैकअप बनाएँ",
|
||||||
"privacy_settings": "गोपनीयता सेटिंग्स",
|
"privacy_settings": "गोपनीयता सेटिंग्स",
|
||||||
"privacy": "गोपनीयता",
|
"privacy": "गोपनीयता",
|
||||||
"display_settings": "प्रदर्शन सेटिंग्स",
|
"display_settings": "प्रदर्शन सेटिंग्स",
|
||||||
|
|
|
@ -356,6 +356,7 @@
|
||||||
"sync_status_failed_connect" : "ISKLJUČENO",
|
"sync_status_failed_connect" : "ISKLJUČENO",
|
||||||
"sync_status_connecting" : "SPAJANJE",
|
"sync_status_connecting" : "SPAJANJE",
|
||||||
"sync_status_connected" : "SPOJENO",
|
"sync_status_connected" : "SPOJENO",
|
||||||
|
"sync_status_attempting_sync" : "POKUŠAJ SINKRONIZACIJE",
|
||||||
|
|
||||||
|
|
||||||
"transaction_priority_slow" : "Sporo",
|
"transaction_priority_slow" : "Sporo",
|
||||||
|
@ -436,6 +437,7 @@
|
||||||
"provider_error" : "${provider} greška",
|
"provider_error" : "${provider} greška",
|
||||||
|
|
||||||
"use_ssl" : "Koristi SSL",
|
"use_ssl" : "Koristi SSL",
|
||||||
|
"trusted" : "vjerovao",
|
||||||
|
|
||||||
"color_theme" : "Shema boja",
|
"color_theme" : "Shema boja",
|
||||||
"light_theme" : "Svijetla",
|
"light_theme" : "Svijetla",
|
||||||
|
@ -652,6 +654,9 @@
|
||||||
"use_suggested": "Koristite predloženo",
|
"use_suggested": "Koristite predloženo",
|
||||||
"do_not_share_warning_text" : "Nemojte ih dijeliti ni s kim, uključujući podršku.\n\nUkrast će vam novac!",
|
"do_not_share_warning_text" : "Nemojte ih dijeliti ni s kim, uključujući podršku.\n\nUkrast će vam novac!",
|
||||||
"help": "pomozite",
|
"help": "pomozite",
|
||||||
|
"connection_sync": "Povezivanje i sinkronizacija",
|
||||||
|
"security_and_backup": "Sigurnost i sigurnosna kopija",
|
||||||
|
"create_backup": "Stvori sigurnosnu kopiju",
|
||||||
"privacy_settings": "Postavke privatnosti",
|
"privacy_settings": "Postavke privatnosti",
|
||||||
"privacy": "Privatnost",
|
"privacy": "Privatnost",
|
||||||
"display_settings": "Postavke zaslona",
|
"display_settings": "Postavke zaslona",
|
||||||
|
|
|
@ -356,6 +356,7 @@
|
||||||
"sync_status_failed_connect" : "DISCONNESSO",
|
"sync_status_failed_connect" : "DISCONNESSO",
|
||||||
"sync_status_connecting" : "CONNESSIONE",
|
"sync_status_connecting" : "CONNESSIONE",
|
||||||
"sync_status_connected" : "CONNESSO",
|
"sync_status_connected" : "CONNESSO",
|
||||||
|
"sync_status_attempting_sync" : "TENTATIVO DI SINCRONIZZAZIONE",
|
||||||
|
|
||||||
|
|
||||||
"transaction_priority_slow" : "Bassa",
|
"transaction_priority_slow" : "Bassa",
|
||||||
|
@ -436,6 +437,7 @@
|
||||||
"provider_error" : "${provider} errore",
|
"provider_error" : "${provider} errore",
|
||||||
|
|
||||||
"use_ssl" : "Usa SSL",
|
"use_ssl" : "Usa SSL",
|
||||||
|
"trusted" : "di fiducia",
|
||||||
|
|
||||||
"color_theme" : "Colore tema",
|
"color_theme" : "Colore tema",
|
||||||
"light_theme" : "Bianco",
|
"light_theme" : "Bianco",
|
||||||
|
@ -652,6 +654,9 @@
|
||||||
"use_suggested": "Usa suggerito",
|
"use_suggested": "Usa suggerito",
|
||||||
"do_not_share_warning_text" : "Non condividerli con nessun altro, incluso il supporto.\n\nTi ruberanno i soldi!",
|
"do_not_share_warning_text" : "Non condividerli con nessun altro, incluso il supporto.\n\nTi ruberanno i soldi!",
|
||||||
"help": "aiuto",
|
"help": "aiuto",
|
||||||
|
"connection_sync": "Connessione e sincronizzazione",
|
||||||
|
"security_and_backup": "Sicurezza e backup",
|
||||||
|
"create_backup": "Crea backup",
|
||||||
"privacy_settings": "Impostazioni privacy",
|
"privacy_settings": "Impostazioni privacy",
|
||||||
"privacy": "Privacy",
|
"privacy": "Privacy",
|
||||||
"display_settings": "Impostazioni di visualizzazione",
|
"display_settings": "Impostazioni di visualizzazione",
|
||||||
|
|
|
@ -356,6 +356,7 @@
|
||||||
"sync_status_failed_connect" : "切断されました",
|
"sync_status_failed_connect" : "切断されました",
|
||||||
"sync_status_connecting" : "接続中",
|
"sync_status_connecting" : "接続中",
|
||||||
"sync_status_connected" : "接続済み",
|
"sync_status_connected" : "接続済み",
|
||||||
|
"sync_status_attempting_sync" : "同期を試みています",
|
||||||
|
|
||||||
|
|
||||||
"transaction_priority_slow" : "スロー",
|
"transaction_priority_slow" : "スロー",
|
||||||
|
@ -436,6 +437,7 @@
|
||||||
"provider_error" : "${provider} エラー",
|
"provider_error" : "${provider} エラー",
|
||||||
|
|
||||||
"use_ssl" : "SSLを使用する",
|
"use_ssl" : "SSLを使用する",
|
||||||
|
"trusted" : "信頼できる",
|
||||||
|
|
||||||
"color_theme" : "カラーテーマ",
|
"color_theme" : "カラーテーマ",
|
||||||
"light_theme" : "光",
|
"light_theme" : "光",
|
||||||
|
@ -652,6 +654,9 @@
|
||||||
"use_suggested": "推奨を使用",
|
"use_suggested": "推奨を使用",
|
||||||
"do_not_share_warning_text" : "サポートを含め、これらを他の誰とも共有しないでください。\n\n彼らはあなたのお金を盗みます!",
|
"do_not_share_warning_text" : "サポートを含め、これらを他の誰とも共有しないでください。\n\n彼らはあなたのお金を盗みます!",
|
||||||
"help": "ヘルプ",
|
"help": "ヘルプ",
|
||||||
|
"connection_sync": "接続と同期",
|
||||||
|
"security_and_backup": "セキュリティとバックアップ",
|
||||||
|
"create_backup": "バックアップを作成",
|
||||||
"privacy_settings": "プライバシー設定",
|
"privacy_settings": "プライバシー設定",
|
||||||
"privacy": "プライバシー",
|
"privacy": "プライバシー",
|
||||||
"display_settings": "表示設定",
|
"display_settings": "表示設定",
|
||||||
|
|
|
@ -356,6 +356,7 @@
|
||||||
"sync_status_failed_connect" : "연결 해제",
|
"sync_status_failed_connect" : "연결 해제",
|
||||||
"sync_status_connecting" : "연결 중",
|
"sync_status_connecting" : "연결 중",
|
||||||
"sync_status_connected" : "연결됨",
|
"sync_status_connected" : "연결됨",
|
||||||
|
"sync_status_attempting_sync" : "동기화 시도 중",
|
||||||
|
|
||||||
|
|
||||||
"transaction_priority_slow" : "느린",
|
"transaction_priority_slow" : "느린",
|
||||||
|
@ -436,6 +437,7 @@
|
||||||
"provider_error" : "${provider} 오류",
|
"provider_error" : "${provider} 오류",
|
||||||
|
|
||||||
"use_ssl" : "SSL 사용",
|
"use_ssl" : "SSL 사용",
|
||||||
|
"trusted" : "신뢰할 수 있는",
|
||||||
|
|
||||||
"color_theme" : "색상 테마",
|
"color_theme" : "색상 테마",
|
||||||
"light_theme" : "빛",
|
"light_theme" : "빛",
|
||||||
|
@ -652,6 +654,9 @@
|
||||||
"use_suggested": "추천 사용",
|
"use_suggested": "추천 사용",
|
||||||
"do_not_share_warning_text" : "지원을 포함하여 다른 사람과 이러한 정보를 공유하지 마십시오.\n\n그들은 당신의 돈을 훔칠 것입니다!",
|
"do_not_share_warning_text" : "지원을 포함하여 다른 사람과 이러한 정보를 공유하지 마십시오.\n\n그들은 당신의 돈을 훔칠 것입니다!",
|
||||||
"help": "돕다",
|
"help": "돕다",
|
||||||
|
"connection_sync": "연결 및 동기화",
|
||||||
|
"security_and_backup": "보안 및 백업",
|
||||||
|
"create_backup": "백업 생성",
|
||||||
"privacy_settings": "개인정보 설정",
|
"privacy_settings": "개인정보 설정",
|
||||||
"privacy": "프라이버시",
|
"privacy": "프라이버시",
|
||||||
"display_settings": "디스플레이 설정",
|
"display_settings": "디스플레이 설정",
|
||||||
|
|
|
@ -356,6 +356,7 @@
|
||||||
"sync_status_failed_connect" : "LOSGEKOPPELD",
|
"sync_status_failed_connect" : "LOSGEKOPPELD",
|
||||||
"sync_status_connecting" : "AANSLUITING",
|
"sync_status_connecting" : "AANSLUITING",
|
||||||
"sync_status_connected" : "VERBONDEN",
|
"sync_status_connected" : "VERBONDEN",
|
||||||
|
"sync_status_attempting_sync" : "SYNCHRONISATIE PROBEREN",
|
||||||
|
|
||||||
|
|
||||||
"transaction_priority_slow" : "Langzaam",
|
"transaction_priority_slow" : "Langzaam",
|
||||||
|
@ -436,6 +437,7 @@
|
||||||
"provider_error" : "${provider} fout",
|
"provider_error" : "${provider} fout",
|
||||||
|
|
||||||
"use_ssl" : "Gebruik SSL",
|
"use_ssl" : "Gebruik SSL",
|
||||||
|
"trusted" : "vertrouwd",
|
||||||
|
|
||||||
"color_theme" : "Kleur thema",
|
"color_theme" : "Kleur thema",
|
||||||
"light_theme" : "Licht",
|
"light_theme" : "Licht",
|
||||||
|
@ -652,6 +654,9 @@
|
||||||
"use_suggested": "Gebruik aanbevolen",
|
"use_suggested": "Gebruik aanbevolen",
|
||||||
"do_not_share_warning_text" : "Deel deze met niemand anders, ook niet met support.\n\nZe zullen je geld stelen!",
|
"do_not_share_warning_text" : "Deel deze met niemand anders, ook niet met support.\n\nZe zullen je geld stelen!",
|
||||||
"help": "helpen",
|
"help": "helpen",
|
||||||
|
"connection_sync": "Verbinding en synchronisatie",
|
||||||
|
"security_and_backup": "Beveiliging en back-up",
|
||||||
|
"create_backup": "Maak een back-up",
|
||||||
"privacy_settings": "Privacy-instellingen",
|
"privacy_settings": "Privacy-instellingen",
|
||||||
"privacy": "Privacy",
|
"privacy": "Privacy",
|
||||||
"display_settings": "Weergave-instellingen",
|
"display_settings": "Weergave-instellingen",
|
||||||
|
|
|
@ -356,6 +356,7 @@
|
||||||
"sync_status_failed_connect" : "NIEPOWIĄZANY",
|
"sync_status_failed_connect" : "NIEPOWIĄZANY",
|
||||||
"sync_status_connecting" : "ZŁĄCZONY",
|
"sync_status_connecting" : "ZŁĄCZONY",
|
||||||
"sync_status_connected" : "POŁĄCZONY",
|
"sync_status_connected" : "POŁĄCZONY",
|
||||||
|
"sync_status_attempting_sync" : "PRÓBA SYNCHRONIZACJI",
|
||||||
|
|
||||||
|
|
||||||
"transaction_priority_slow" : "Powolny",
|
"transaction_priority_slow" : "Powolny",
|
||||||
|
@ -436,6 +437,7 @@
|
||||||
"provider_error" : "${provider} pomyłka",
|
"provider_error" : "${provider} pomyłka",
|
||||||
|
|
||||||
"use_ssl" : "Użyj SSL",
|
"use_ssl" : "Użyj SSL",
|
||||||
|
"trusted" : "zaufany",
|
||||||
|
|
||||||
"color_theme" : "Motyw kolorystyczny",
|
"color_theme" : "Motyw kolorystyczny",
|
||||||
"light_theme" : "Lekki",
|
"light_theme" : "Lekki",
|
||||||
|
@ -652,6 +654,9 @@
|
||||||
"use_suggested": "Użyj sugerowane",
|
"use_suggested": "Użyj sugerowane",
|
||||||
"do_not_share_warning_text" : "Nie udostępniaj ich nikomu innemu, w tym wsparcia.\n\nUkradną twoje pieniądze!",
|
"do_not_share_warning_text" : "Nie udostępniaj ich nikomu innemu, w tym wsparcia.\n\nUkradną twoje pieniądze!",
|
||||||
"help": "pomoc",
|
"help": "pomoc",
|
||||||
|
"connection_sync": "Połączenie i synchronizacja",
|
||||||
|
"security_and_backup": "Bezpieczeństwo i kopia zapasowa",
|
||||||
|
"create_backup": "Utwórz kopię zapasową",
|
||||||
"privacy_settings": "Ustawienia prywatności",
|
"privacy_settings": "Ustawienia prywatności",
|
||||||
"privacy": "Prywatność",
|
"privacy": "Prywatność",
|
||||||
"display_settings": "Ustawienia wyświetlania",
|
"display_settings": "Ustawienia wyświetlania",
|
||||||
|
|
|
@ -356,6 +356,7 @@
|
||||||
"sync_status_failed_connect" : "DESCONECTADO",
|
"sync_status_failed_connect" : "DESCONECTADO",
|
||||||
"sync_status_connecting" : "CONECTANDO",
|
"sync_status_connecting" : "CONECTANDO",
|
||||||
"sync_status_connected" : "CONECTADO",
|
"sync_status_connected" : "CONECTADO",
|
||||||
|
"sync_status_attempting_sync" : "TENTANDO SINCRONIZAR",
|
||||||
|
|
||||||
|
|
||||||
"transaction_priority_slow" : "Lenta",
|
"transaction_priority_slow" : "Lenta",
|
||||||
|
@ -436,6 +437,7 @@
|
||||||
"provider_error" : "${provider} erro",
|
"provider_error" : "${provider} erro",
|
||||||
|
|
||||||
"use_ssl" : "Use SSL",
|
"use_ssl" : "Use SSL",
|
||||||
|
"trusted" : "confiável",
|
||||||
|
|
||||||
"color_theme" : "Tema de cor",
|
"color_theme" : "Tema de cor",
|
||||||
"light_theme" : "Luz",
|
"light_theme" : "Luz",
|
||||||
|
@ -544,7 +546,6 @@
|
||||||
"create_account": "Criar conta",
|
"create_account": "Criar conta",
|
||||||
"privacy_policy": "Política de privacidade",
|
"privacy_policy": "Política de privacidade",
|
||||||
"welcome_to_cakepay": "Bem-vindo ao Cake Pay!",
|
"welcome_to_cakepay": "Bem-vindo ao Cake Pay!",
|
||||||
"create_account": "Registar-se",
|
|
||||||
"forgot_password": "Esqueci a senha",
|
"forgot_password": "Esqueci a senha",
|
||||||
"reset_password": "Redefinir senha",
|
"reset_password": "Redefinir senha",
|
||||||
"gift_cards": "Cartões de presente",
|
"gift_cards": "Cartões de presente",
|
||||||
|
@ -652,6 +653,9 @@
|
||||||
"use_suggested": "Uso sugerido",
|
"use_suggested": "Uso sugerido",
|
||||||
"do_not_share_warning_text" : "Não os compartilhe com mais ninguém, incluindo suporte.\n\nEles vão roubar seu dinheiro!",
|
"do_not_share_warning_text" : "Não os compartilhe com mais ninguém, incluindo suporte.\n\nEles vão roubar seu dinheiro!",
|
||||||
"help": "ajuda",
|
"help": "ajuda",
|
||||||
|
"connection_sync": "Conexão e sincronização",
|
||||||
|
"security_and_backup": "Segurança e backup",
|
||||||
|
"create_backup": "Criar backup",
|
||||||
"privacy_settings": "Configurações de privacidade",
|
"privacy_settings": "Configurações de privacidade",
|
||||||
"privacy": "Privacidade",
|
"privacy": "Privacidade",
|
||||||
"display_settings": "Configurações de exibição",
|
"display_settings": "Configurações de exibição",
|
||||||
|
|
|
@ -356,6 +356,7 @@
|
||||||
"sync_status_failed_connect" : "ОТКЛЮЧЕНО",
|
"sync_status_failed_connect" : "ОТКЛЮЧЕНО",
|
||||||
"sync_status_connecting" : "ПОДКЛЮЧЕНИЕ",
|
"sync_status_connecting" : "ПОДКЛЮЧЕНИЕ",
|
||||||
"sync_status_connected" : "ПОДКЛЮЧЕНО",
|
"sync_status_connected" : "ПОДКЛЮЧЕНО",
|
||||||
|
"sync_status_attempting_sync" : "ПОПЫТКА СИНХРОНИЗАЦИИ",
|
||||||
|
|
||||||
|
|
||||||
"transaction_priority_slow" : "Медленный",
|
"transaction_priority_slow" : "Медленный",
|
||||||
|
@ -436,6 +437,7 @@
|
||||||
"provider_error" : "${provider} ошибка",
|
"provider_error" : "${provider} ошибка",
|
||||||
|
|
||||||
"use_ssl" : "Использовать SSL",
|
"use_ssl" : "Использовать SSL",
|
||||||
|
"trusted" : "доверенный",
|
||||||
|
|
||||||
"color_theme" : "Цветовая тема",
|
"color_theme" : "Цветовая тема",
|
||||||
"light_theme" : "Светлая",
|
"light_theme" : "Светлая",
|
||||||
|
@ -652,6 +654,9 @@
|
||||||
"use_suggested": "Использовать предложенный",
|
"use_suggested": "Использовать предложенный",
|
||||||
"do_not_share_warning_text" : "Не делитесь ими с кем-либо еще, в том числе со службой поддержки.\n\nОни украдут ваши деньги!",
|
"do_not_share_warning_text" : "Не делитесь ими с кем-либо еще, в том числе со службой поддержки.\n\nОни украдут ваши деньги!",
|
||||||
"help": "помощь",
|
"help": "помощь",
|
||||||
|
"connection_sync": "Подключение и синхронизация",
|
||||||
|
"security_and_backup": "Безопасность и резервное копирование",
|
||||||
|
"create_backup": "Создать резервную копию",
|
||||||
"privacy_settings": "Настройки конфиденциальности",
|
"privacy_settings": "Настройки конфиденциальности",
|
||||||
"privacy": "Конфиденциальность",
|
"privacy": "Конфиденциальность",
|
||||||
"display_settings": "Настройки отображения",
|
"display_settings": "Настройки отображения",
|
||||||
|
|
|
@ -355,6 +355,7 @@
|
||||||
"sync_status_failed_connect" : "ВІДКЛЮЧЕНО",
|
"sync_status_failed_connect" : "ВІДКЛЮЧЕНО",
|
||||||
"sync_status_connecting" : "ПІДКЛЮЧЕННЯ",
|
"sync_status_connecting" : "ПІДКЛЮЧЕННЯ",
|
||||||
"sync_status_connected" : "ПІДКЛЮЧЕНО",
|
"sync_status_connected" : "ПІДКЛЮЧЕНО",
|
||||||
|
"sync_status_attempting_sync" : "СПРОБА СИНХРОНІЗАЦІЇ",
|
||||||
|
|
||||||
|
|
||||||
"transaction_priority_slow" : "Повільний",
|
"transaction_priority_slow" : "Повільний",
|
||||||
|
@ -435,6 +436,7 @@
|
||||||
"provider_error" : "${provider} помилка",
|
"provider_error" : "${provider} помилка",
|
||||||
|
|
||||||
"use_ssl" : "Використати SSL",
|
"use_ssl" : "Використати SSL",
|
||||||
|
"trusted" : "довіряють",
|
||||||
|
|
||||||
"color_theme" : "Кольорова тема",
|
"color_theme" : "Кольорова тема",
|
||||||
"light_theme" : "Світла",
|
"light_theme" : "Світла",
|
||||||
|
@ -651,6 +653,9 @@
|
||||||
"use_suggested": "Використати запропоноване",
|
"use_suggested": "Використати запропоноване",
|
||||||
"do_not_share_warning_text" : "Не повідомляйте їх нікому, включно зі службою підтримки.\n\nВони вкрадуть ваші гроші!",
|
"do_not_share_warning_text" : "Не повідомляйте їх нікому, включно зі службою підтримки.\n\nВони вкрадуть ваші гроші!",
|
||||||
"help": "допомога",
|
"help": "допомога",
|
||||||
|
"connection_sync": "Підключення та синхронізація",
|
||||||
|
"security_and_backup": "Безпека та резервне копіювання",
|
||||||
|
"create_backup": "Створити резервну копію",
|
||||||
"privacy_settings": "Налаштування конфіденційності",
|
"privacy_settings": "Налаштування конфіденційності",
|
||||||
"privacy": "Конфіденційність",
|
"privacy": "Конфіденційність",
|
||||||
"display_settings": "Налаштування дисплея",
|
"display_settings": "Налаштування дисплея",
|
||||||
|
|
|
@ -356,6 +356,7 @@
|
||||||
"sync_status_failed_connect" : "断线",
|
"sync_status_failed_connect" : "断线",
|
||||||
"sync_status_connecting" : "连接中",
|
"sync_status_connecting" : "连接中",
|
||||||
"sync_status_connected" : "已连接",
|
"sync_status_connected" : "已连接",
|
||||||
|
"sync_status_attempting_sync" : "嘗試同步",
|
||||||
|
|
||||||
|
|
||||||
"transaction_priority_slow" : "慢速",
|
"transaction_priority_slow" : "慢速",
|
||||||
|
@ -435,6 +436,7 @@
|
||||||
"provider_error" : "${provider} 错误",
|
"provider_error" : "${provider} 错误",
|
||||||
|
|
||||||
"use_ssl" : "使用SSL",
|
"use_ssl" : "使用SSL",
|
||||||
|
"trusted" : "值得信赖",
|
||||||
|
|
||||||
"color_theme" : "主题",
|
"color_theme" : "主题",
|
||||||
"light_theme" : "艳丽",
|
"light_theme" : "艳丽",
|
||||||
|
@ -650,6 +652,9 @@
|
||||||
"use_suggested": "使用建议",
|
"use_suggested": "使用建议",
|
||||||
"do_not_share_warning_text" : "不要與其他任何人分享這些內容,包括支持。\n\n他們會偷你的錢!",
|
"do_not_share_warning_text" : "不要與其他任何人分享這些內容,包括支持。\n\n他們會偷你的錢!",
|
||||||
"help": "帮助",
|
"help": "帮助",
|
||||||
|
"connection_sync": "连接和同步",
|
||||||
|
"security_and_backup": "安全和备份",
|
||||||
|
"create_backup": "创建备份",
|
||||||
"privacy_settings": "隐私设置",
|
"privacy_settings": "隐私设置",
|
||||||
"privacy":"隐私",
|
"privacy":"隐私",
|
||||||
"display_settings": "显示设置",
|
"display_settings": "显示设置",
|
||||||
|
|
Loading…
Reference in a new issue