script generated app_config.g.dart file

This commit is contained in:
julian 2024-05-22 13:38:49 -06:00
parent bc785e13fc
commit cc7b958c5a
52 changed files with 462 additions and 358 deletions

1
.gitignore vendored
View file

@ -63,3 +63,4 @@ libtor_ffi.dll
flutter_libsparkmobile.dll flutter_libsparkmobile.dll
secp256k1.dll secp256k1.dll
/libisar.so /libisar.so
/lib/app_config.g.dart

View file

@ -1,34 +1,43 @@
import 'package:stackwallet/wallets/crypto_currency/crypto_currency.dart'; import 'package:stackwallet/wallets/crypto_currency/crypto_currency.dart';
import 'package:stackwallet/wallets/crypto_currency/intermediate/frost_currency.dart';
part 'app_config.g.dart';
abstract class AppConfig { abstract class AppConfig {
static const appName = prefix + _separator + suffix; static const appName = _prefix + _separator + suffix;
static const prefix = "Stack"; static const prefix = _prefix;
static const suffix = _suffix;
static const _separator = " "; static List<CryptoCurrency> get coins => _supportedCoins;
static const suffix = "Wallet"; static CryptoCurrency getCryptoCurrencyFor(String coinIdentifier) =>
coins.firstWhere(
(e) => e.identifier == coinIdentifier,
);
// comment out coins to disable them static CryptoCurrency getCryptoCurrencyForTicker(
static const supportedCoins = [ final String ticker, {
Bitcoin, bool caseInsensitive = true,
BitcoinFrost, }) {
Litecoin, final _ticker = caseInsensitive ? ticker.toLowerCase() : ticker;
Bitcoincash, return coins.firstWhere(
Dogecoin, caseInsensitive
Epiccash, ? (e) => e.ticker.toLowerCase() == _ticker && e is! FrostCurrency
Ecash, : (e) => e.ticker == _ticker && e is! FrostCurrency,
Ethereum, );
Firo, }
Monero,
Particl, /// Fuzzy logic. Use with caution!!
Peercoin, @Deprecated("dangerous")
Solana, static CryptoCurrency getCryptoCurrencyByPrettyName(final String prettyName) {
Stellar, final name = prettyName.replaceAll(" ", "").toLowerCase();
Tezos, try {
Wownero, return coins.firstWhere(
Namecoin, (e) => e.identifier.toLowerCase() == name || e.prettyName == prettyName,
Nano, );
Banano, } catch (_) {
]; throw Exception("getCryptoCurrencyByPrettyName($prettyName) failed!");
}
}
} }

View file

@ -10,6 +10,7 @@
import 'package:hive/hive.dart'; import 'package:hive/hive.dart';
import 'package:isar/isar.dart'; import 'package:isar/isar.dart';
import 'package:stackwallet/app_config.dart';
import 'package:stackwallet/db/hive/db.dart'; import 'package:stackwallet/db/hive/db.dart';
import 'package:stackwallet/db/isar/main_db.dart'; import 'package:stackwallet/db/isar/main_db.dart';
import 'package:stackwallet/db/migrate_wallets_to_isar.dart'; import 'package:stackwallet/db/migrate_wallets_to_isar.dart';
@ -26,15 +27,11 @@ import 'package:stackwallet/models/node_model.dart';
import 'package:stackwallet/services/mixins/wallet_db.dart'; import 'package:stackwallet/services/mixins/wallet_db.dart';
import 'package:stackwallet/services/node_service.dart'; import 'package:stackwallet/services/node_service.dart';
import 'package:stackwallet/services/wallets_service.dart'; import 'package:stackwallet/services/wallets_service.dart';
import 'package:stackwallet/supported_coins.dart';
import 'package:stackwallet/utilities/amount/amount.dart'; import 'package:stackwallet/utilities/amount/amount.dart';
import 'package:stackwallet/utilities/constants.dart'; import 'package:stackwallet/utilities/constants.dart';
import 'package:stackwallet/utilities/flutter_secure_storage_interface.dart'; import 'package:stackwallet/utilities/flutter_secure_storage_interface.dart';
import 'package:stackwallet/utilities/logger.dart'; import 'package:stackwallet/utilities/logger.dart';
import 'package:stackwallet/utilities/prefs.dart'; import 'package:stackwallet/utilities/prefs.dart';
import 'package:stackwallet/wallets/crypto_currency/coins/bitcoincash.dart';
import 'package:stackwallet/wallets/crypto_currency/coins/epiccash.dart';
import 'package:stackwallet/wallets/crypto_currency/coins/firo.dart';
import 'package:stackwallet/wallets/crypto_currency/crypto_currency.dart'; import 'package:stackwallet/wallets/crypto_currency/crypto_currency.dart';
import 'package:tuple/tuple.dart'; import 'package:tuple/tuple.dart';
@ -560,7 +557,7 @@ class DbVersionMigrator with WalletDB {
final count = await MainDB.instance.getTransactions(walletId).count(); final count = await MainDB.instance.getTransactions(walletId).count();
final crypto = Coins.getCryptoCurrencyFor(info.coinIdentifier); final crypto = AppConfig.getCryptoCurrencyFor(info.coinIdentifier);
for (var i = 0; i < count; i += 50) { for (var i = 0; i < count; i += 50) {
final txns = await MainDB.instance final txns = await MainDB.instance

View file

@ -13,14 +13,13 @@ import 'dart:isolate';
import 'package:cw_core/wallet_info.dart' as xmr; import 'package:cw_core/wallet_info.dart' as xmr;
import 'package:hive/hive.dart'; import 'package:hive/hive.dart';
import 'package:mutex/mutex.dart'; import 'package:mutex/mutex.dart';
import 'package:stackwallet/app_config.dart';
import 'package:stackwallet/models/exchange/response_objects/trade.dart'; import 'package:stackwallet/models/exchange/response_objects/trade.dart';
import 'package:stackwallet/models/node_model.dart'; import 'package:stackwallet/models/node_model.dart';
import 'package:stackwallet/models/notification_model.dart'; import 'package:stackwallet/models/notification_model.dart';
import 'package:stackwallet/models/trade_wallet_lookup.dart'; import 'package:stackwallet/models/trade_wallet_lookup.dart';
import 'package:stackwallet/services/wallets_service.dart'; import 'package:stackwallet/services/wallets_service.dart';
import 'package:stackwallet/supported_coins.dart';
import 'package:stackwallet/utilities/logger.dart'; import 'package:stackwallet/utilities/logger.dart';
import 'package:stackwallet/wallets/crypto_currency/coins/firo.dart';
import 'package:stackwallet/wallets/crypto_currency/crypto_currency.dart'; import 'package:stackwallet/wallets/crypto_currency/crypto_currency.dart';
class DB { class DB {
@ -164,7 +163,7 @@ class DB {
names.removeWhere((name, dyn) { names.removeWhere((name, dyn) {
final jsonObject = Map<String, dynamic>.from(dyn as Map); final jsonObject = Map<String, dynamic>.from(dyn as Map);
try { try {
Coins.getCryptoCurrencyFor(jsonObject["coin"] as String); AppConfig.getCryptoCurrencyFor(jsonObject["coin"] as String);
return false; return false;
} catch (e, s) { } catch (e, s) {
Logging.instance.log( Logging.instance.log(

View file

@ -2,16 +2,12 @@ import 'dart:convert';
import 'package:hive_flutter/hive_flutter.dart'; import 'package:hive_flutter/hive_flutter.dart';
import 'package:isar/isar.dart'; import 'package:isar/isar.dart';
import 'package:stackwallet/app_config.dart';
import 'package:stackwallet/db/hive/db.dart'; import 'package:stackwallet/db/hive/db.dart';
import 'package:stackwallet/db/isar/main_db.dart'; import 'package:stackwallet/db/isar/main_db.dart';
import 'package:stackwallet/models/isar/models/blockchain_data/v2/transaction_v2.dart'; import 'package:stackwallet/models/isar/models/blockchain_data/v2/transaction_v2.dart';
import 'package:stackwallet/models/isar/models/isar_models.dart'; import 'package:stackwallet/models/isar/models/isar_models.dart';
import 'package:stackwallet/supported_coins.dart';
import 'package:stackwallet/utilities/flutter_secure_storage_interface.dart'; import 'package:stackwallet/utilities/flutter_secure_storage_interface.dart';
import 'package:stackwallet/wallets/crypto_currency/coins/epiccash.dart';
import 'package:stackwallet/wallets/crypto_currency/coins/firo.dart';
import 'package:stackwallet/wallets/crypto_currency/coins/stellar.dart';
import 'package:stackwallet/wallets/crypto_currency/coins/tezos.dart';
import 'package:stackwallet/wallets/crypto_currency/crypto_currency.dart'; import 'package:stackwallet/wallets/crypto_currency/crypto_currency.dart';
import 'package:stackwallet/wallets/isar/models/token_wallet_info.dart'; import 'package:stackwallet/wallets/isar/models/token_wallet_info.dart';
import 'package:stackwallet/wallets/isar/models/wallet_info.dart'; import 'package:stackwallet/wallets/isar/models/wallet_info.dart';
@ -171,8 +167,8 @@ Future<void> migrateWalletsToIsar({
coinName: old.coinIdentifier, coinName: old.coinIdentifier,
walletId: old.walletId, walletId: old.walletId,
name: old.name, name: old.name,
mainAddressType: Coins.getCryptoCurrencyFor(old.coinIdentifier) mainAddressType:
.primaryAddressType, AppConfig.getCryptoCurrencyFor(old.coinIdentifier).primaryAddressType,
favouriteOrderIndex: favourites.indexOf(old.walletId), favouriteOrderIndex: favourites.indexOf(old.walletId),
cachedChainHeight: walletBox.get( cachedChainHeight: walletBox.get(
DBKeys.storedChainHeight, DBKeys.storedChainHeight,

View file

@ -10,7 +10,7 @@
import 'dart:convert'; import 'dart:convert';
import 'package:stackwallet/supported_coins.dart'; import 'package:stackwallet/app_config.dart';
import 'package:stackwallet/wallets/crypto_currency/crypto_currency.dart'; import 'package:stackwallet/wallets/crypto_currency/crypto_currency.dart';
@Deprecated("Use lib/models/isar/models/contact_entry.dart instead") @Deprecated("Use lib/models/isar/models/contact_entry.dart instead")
@ -43,7 +43,7 @@ class ContactAddressEntry {
factory ContactAddressEntry.fromJson(Map<String, dynamic> jsonObject) { factory ContactAddressEntry.fromJson(Map<String, dynamic> jsonObject) {
return ContactAddressEntry( return ContactAddressEntry(
coin: Coins.getCryptoCurrencyFor(jsonObject["coin"] as String), coin: AppConfig.getCryptoCurrencyFor(jsonObject["coin"] as String),
address: jsonObject["address"] as String, address: jsonObject["address"] as String,
label: jsonObject["label"] as String, label: jsonObject["label"] as String,
other: jsonObject["other"] as String?, other: jsonObject["other"] as String?,

View file

@ -9,8 +9,8 @@
*/ */
import 'package:isar/isar.dart'; import 'package:isar/isar.dart';
import 'package:stackwallet/app_config.dart';
import 'package:stackwallet/models/isar/exchange_cache/pair.dart'; import 'package:stackwallet/models/isar/exchange_cache/pair.dart';
import 'package:stackwallet/supported_coins.dart';
part 'currency.g.dart'; part 'currency.g.dart';
@ -161,7 +161,7 @@ class Currency {
static bool checkIsStackCoin(String ticker) { static bool checkIsStackCoin(String ticker) {
try { try {
Coins.getCryptoCurrencyForTicker(ticker); AppConfig.getCryptoCurrencyForTicker(ticker);
return true; return true;
} catch (_) { } catch (_) {
return false; return false;

View file

@ -9,7 +9,7 @@
*/ */
import 'package:isar/isar.dart'; import 'package:isar/isar.dart';
import 'package:stackwallet/supported_coins.dart'; import 'package:stackwallet/app_config.dart';
import 'package:stackwallet/wallets/crypto_currency/crypto_currency.dart'; import 'package:stackwallet/wallets/crypto_currency/crypto_currency.dart';
part 'block_explorer.g.dart'; part 'block_explorer.g.dart';
@ -31,7 +31,7 @@ class TransactionBlockExplorer {
@ignore @ignore
CryptoCurrency? get coin { CryptoCurrency? get coin {
try { try {
return Coins.getCryptoCurrencyForTicker(ticker); return AppConfig.getCryptoCurrencyForTicker(ticker);
} catch (_) { } catch (_) {
return null; return null;
} }

View file

@ -9,7 +9,7 @@
*/ */
import 'package:isar/isar.dart'; import 'package:isar/isar.dart';
import 'package:stackwallet/supported_coins.dart'; import 'package:stackwallet/app_config.dart';
import 'package:stackwallet/wallets/crypto_currency/crypto_currency.dart'; import 'package:stackwallet/wallets/crypto_currency/crypto_currency.dart';
part 'contact_entry.g.dart'; part 'contact_entry.g.dart';
@ -37,7 +37,7 @@ class ContactEntry {
@ignore @ignore
List<ContactAddressEntry> get addressesSorted { List<ContactAddressEntry> get addressesSorted {
final List<ContactAddressEntry> sorted = []; final List<ContactAddressEntry> sorted = [];
for (final coin in Coins.enabled) { for (final coin in AppConfig.coins) {
final slice = addresses.where((e) => e.coin == coin).toList(); final slice = addresses.where((e) => e.coin == coin).toList();
if (slice.isNotEmpty) { if (slice.isNotEmpty) {
slice.sort( slice.sort(
@ -102,7 +102,7 @@ class ContactAddressEntry {
late final String? other; late final String? other;
@ignore @ignore
CryptoCurrency get coin => Coins.getCryptoCurrencyFor(coinName); CryptoCurrency get coin => AppConfig.getCryptoCurrencyFor(coinName);
ContactAddressEntry(); ContactAddressEntry();

View file

@ -13,7 +13,7 @@ import 'dart:io';
import 'package:flutter/material.dart'; import 'package:flutter/material.dart';
import 'package:isar/isar.dart'; import 'package:isar/isar.dart';
import 'package:stackwallet/supported_coins.dart'; import 'package:stackwallet/app_config.dart';
import 'package:stackwallet/utilities/extensions/impl/box_shadow.dart'; import 'package:stackwallet/utilities/extensions/impl/box_shadow.dart';
import 'package:stackwallet/utilities/extensions/impl/gradient.dart'; import 'package:stackwallet/utilities/extensions/impl/gradient.dart';
import 'package:stackwallet/utilities/extensions/impl/string.dart'; import 'package:stackwallet/utilities/extensions/impl/string.dart';
@ -1878,7 +1878,7 @@ class StackTheme {
final Map<String, Color> result = {}; final Map<String, Color> result = {};
for (final mainNetId in Coins.enabled.map((e) => e.mainNetId)) { for (final mainNetId in AppConfig.coins.map((e) => e.mainNetId)) {
if (map[mainNetId] is String) { if (map[mainNetId] is String) {
result[mainNetId] = Color( result[mainNetId] = Color(
(map[mainNetId] as String).toBigIntFromHex.toInt(), (map[mainNetId] as String).toBigIntFromHex.toInt(),
@ -2196,7 +2196,7 @@ class ThemeAssetsV2 implements IThemeAssets {
final Map<String, String> result = {}; final Map<String, String> result = {};
for (final coin in Coins.enabled) { for (final coin in AppConfig.coins) {
result[coin.mainNetId] = map[coin.mainNetId] as String? ?? placeHolder; result[coin.mainNetId] = map[coin.mainNetId] as String? ?? placeHolder;
} }
@ -2531,7 +2531,7 @@ class ThemeAssetsV3 implements IThemeAssets {
final Map<String, String> result = {}; final Map<String, String> result = {};
for (final coin in Coins.enabled) { for (final coin in AppConfig.coins) {
result[coin.mainNetId] = map[coin.mainNetId] as String? ?? placeHolder; result[coin.mainNetId] = map[coin.mainNetId] as String? ?? placeHolder;
result[coin.mainNetId] = prependIfNeeded(result[coin.mainNetId]!); result[coin.mainNetId] = prependIfNeeded(result[coin.mainNetId]!);
} }

View file

@ -13,9 +13,9 @@ import 'dart:io';
import 'package:flutter/material.dart'; import 'package:flutter/material.dart';
import 'package:flutter_riverpod/flutter_riverpod.dart'; import 'package:flutter_riverpod/flutter_riverpod.dart';
import 'package:flutter_svg/svg.dart'; import 'package:flutter_svg/svg.dart';
import 'package:stackwallet/app_config.dart';
import 'package:stackwallet/models/isar/stack_theme.dart'; import 'package:stackwallet/models/isar/stack_theme.dart';
import 'package:stackwallet/models/notification_model.dart'; import 'package:stackwallet/models/notification_model.dart';
import 'package:stackwallet/supported_coins.dart';
import 'package:stackwallet/themes/coin_icon_provider.dart'; import 'package:stackwallet/themes/coin_icon_provider.dart';
import 'package:stackwallet/themes/stack_colors.dart'; import 'package:stackwallet/themes/stack_colors.dart';
import 'package:stackwallet/themes/theme_providers.dart'; import 'package:stackwallet/themes/theme_providers.dart';
@ -44,7 +44,8 @@ class NotificationCard extends ConsumerWidget {
String coinIconPath(IThemeAssets assets, WidgetRef ref) { String coinIconPath(IThemeAssets assets, WidgetRef ref) {
try { try {
final coin = Coins.getCryptoCurrencyByPrettyName(notification.coinName); final coin =
AppConfig.getCryptoCurrencyByPrettyName(notification.coinName);
return ref.read(coinIconProvider(coin)); return ref.read(coinIconProvider(coin));
} catch (_) { } catch (_) {
return notification.iconAssetName; return notification.iconAssetName;

View file

@ -28,7 +28,7 @@ import 'package:stackwallet/pages/add_wallet_views/add_wallet_view/sub_widgets/e
import 'package:stackwallet/pages/add_wallet_views/add_wallet_view/sub_widgets/next_button.dart'; import 'package:stackwallet/pages/add_wallet_views/add_wallet_view/sub_widgets/next_button.dart';
import 'package:stackwallet/pages_desktop_specific/my_stack_view/exit_to_my_stack_button.dart'; import 'package:stackwallet/pages_desktop_specific/my_stack_view/exit_to_my_stack_button.dart';
import 'package:stackwallet/providers/providers.dart'; import 'package:stackwallet/providers/providers.dart';
import 'package:stackwallet/supported_coins.dart'; import 'package:stackwallet/app_config.dart';
import 'package:stackwallet/themes/stack_colors.dart'; import 'package:stackwallet/themes/stack_colors.dart';
import 'package:stackwallet/utilities/assets.dart'; import 'package:stackwallet/utilities/assets.dart';
import 'package:stackwallet/utilities/constants.dart'; import 'package:stackwallet/utilities/constants.dart';
@ -63,10 +63,10 @@ class _AddWalletViewState extends ConsumerState<AddWalletView> {
String _searchTerm = ""; String _searchTerm = "";
final _coinsTestnet = [ final _coinsTestnet = [
...Coins.enabled.where((e) => e.network == CryptoCurrencyNetwork.test), ...AppConfig.coins.where((e) => e.network == CryptoCurrencyNetwork.test),
]; ];
final _coins = [ final _coins = [
...Coins.enabled.where((e) => e.network == CryptoCurrencyNetwork.main), ...AppConfig.coins.where((e) => e.network == CryptoCurrencyNetwork.main),
]; ];
final List<AddWalletListEntity> coinEntities = []; final List<AddWalletListEntity> coinEntities = [];
final List<EthTokenEntity> tokenEntities = []; final List<EthTokenEntity> tokenEntities = [];
@ -147,7 +147,7 @@ class _AddWalletViewState extends ConsumerState<AddWalletView> {
coinEntities.addAll(_coinsTestnet.map((e) => CoinEntity(e))); coinEntities.addAll(_coinsTestnet.map((e) => CoinEntity(e)));
} }
if (Coins.enabled.whereType<Ethereum>().isNotEmpty) { if (AppConfig.coins.whereType<Ethereum>().isNotEmpty) {
final contracts = final contracts =
MainDB.instance.getEthContracts().sortByName().findAllSync(); MainDB.instance.getEthContracts().sortByName().findAllSync();

View file

@ -20,7 +20,7 @@ import 'package:stackwallet/providers/db/main_db_provider.dart';
import 'package:stackwallet/providers/global/address_book_service_provider.dart'; import 'package:stackwallet/providers/global/address_book_service_provider.dart';
import 'package:stackwallet/providers/providers.dart'; import 'package:stackwallet/providers/providers.dart';
import 'package:stackwallet/providers/ui/address_book_providers/address_book_filter_provider.dart'; import 'package:stackwallet/providers/ui/address_book_providers/address_book_filter_provider.dart';
import 'package:stackwallet/supported_coins.dart'; import 'package:stackwallet/app_config.dart';
import 'package:stackwallet/themes/stack_colors.dart'; import 'package:stackwallet/themes/stack_colors.dart';
import 'package:stackwallet/utilities/assets.dart'; import 'package:stackwallet/utilities/assets.dart';
import 'package:stackwallet/utilities/constants.dart'; import 'package:stackwallet/utilities/constants.dart';
@ -66,7 +66,7 @@ class _AddressBookViewState extends ConsumerState<AddressBookView> {
ref.refresh(addressBookFilterProvider); ref.refresh(addressBookFilterProvider);
if (widget.coin == null) { if (widget.coin == null) {
final coins = [...Coins.enabled]; final coins = [...AppConfig.coins];
coins.removeWhere( coins.removeWhere(
(e) => e is Firo && e.network == CryptoCurrencyNetwork.test, (e) => e is Firo && e.network == CryptoCurrencyNetwork.test,
); );

View file

@ -12,7 +12,7 @@ import 'package:flutter/material.dart';
import 'package:flutter_riverpod/flutter_riverpod.dart'; import 'package:flutter_riverpod/flutter_riverpod.dart';
import 'package:stackwallet/providers/global/prefs_provider.dart'; import 'package:stackwallet/providers/global/prefs_provider.dart';
import 'package:stackwallet/providers/ui/address_book_providers/address_book_filter_provider.dart'; import 'package:stackwallet/providers/ui/address_book_providers/address_book_filter_provider.dart';
import 'package:stackwallet/supported_coins.dart'; import 'package:stackwallet/app_config.dart';
import 'package:stackwallet/themes/stack_colors.dart'; import 'package:stackwallet/themes/stack_colors.dart';
import 'package:stackwallet/utilities/text_styles.dart'; import 'package:stackwallet/utilities/text_styles.dart';
import 'package:stackwallet/utilities/util.dart'; import 'package:stackwallet/utilities/util.dart';
@ -40,7 +40,7 @@ class _AddressBookFilterViewState extends ConsumerState<AddressBookFilterView> {
@override @override
void initState() { void initState() {
final coins = [...Coins.enabled]; final coins = [...AppConfig.coins];
coins.removeWhere( coins.removeWhere(
(e) => e is Firo && e.network == CryptoCurrencyNetwork.test, (e) => e is Firo && e.network == CryptoCurrencyNetwork.test,
); );

View file

@ -14,7 +14,7 @@ import 'package:flutter/material.dart';
import 'package:flutter_riverpod/flutter_riverpod.dart'; import 'package:flutter_riverpod/flutter_riverpod.dart';
import 'package:flutter_svg/svg.dart'; import 'package:flutter_svg/svg.dart';
import 'package:stackwallet/providers/global/prefs_provider.dart'; import 'package:stackwallet/providers/global/prefs_provider.dart';
import 'package:stackwallet/supported_coins.dart'; import 'package:stackwallet/app_config.dart';
import 'package:stackwallet/themes/coin_image_provider.dart'; import 'package:stackwallet/themes/coin_image_provider.dart';
import 'package:stackwallet/themes/stack_colors.dart'; import 'package:stackwallet/themes/stack_colors.dart';
import 'package:stackwallet/utilities/constants.dart'; import 'package:stackwallet/utilities/constants.dart';
@ -27,7 +27,7 @@ class CoinSelectSheet extends StatelessWidget {
@override @override
Widget build(BuildContext context) { Widget build(BuildContext context) {
final maxHeight = MediaQuery.of(context).size.height * 0.60; final maxHeight = MediaQuery.of(context).size.height * 0.60;
final coins_ = [...Coins.enabled]; final coins_ = [...AppConfig.coins];
coins_.removeWhere( coins_.removeWhere(
(e) => e is Firo && e.network == CryptoCurrencyNetwork.test, (e) => e is Firo && e.network == CryptoCurrencyNetwork.test,
); );

View file

@ -19,7 +19,7 @@ import 'package:stackwallet/pages/address_book_views/subviews/coin_select_sheet.
import 'package:stackwallet/providers/providers.dart'; import 'package:stackwallet/providers/providers.dart';
// import 'package:stackwallet/providers/global/should_show_lockscreen_on_resume_state_provider.dart'; // import 'package:stackwallet/providers/global/should_show_lockscreen_on_resume_state_provider.dart';
import 'package:stackwallet/providers/ui/address_book_providers/address_entry_data_provider.dart'; import 'package:stackwallet/providers/ui/address_book_providers/address_entry_data_provider.dart';
import 'package:stackwallet/supported_coins.dart'; import 'package:stackwallet/app_config.dart';
import 'package:stackwallet/themes/coin_icon_provider.dart'; import 'package:stackwallet/themes/coin_icon_provider.dart';
import 'package:stackwallet/themes/stack_colors.dart'; import 'package:stackwallet/themes/stack_colors.dart';
import 'package:stackwallet/utilities/address_utils.dart'; import 'package:stackwallet/utilities/address_utils.dart';
@ -73,7 +73,7 @@ class _NewContactAddressEntryFormState
..text = ref.read(addressEntryDataProvider(widget.id)).address ?? ""; ..text = ref.read(addressEntryDataProvider(widget.id)).address ?? "";
addressLabelFocusNode = FocusNode(); addressLabelFocusNode = FocusNode();
addressFocusNode = FocusNode(); addressFocusNode = FocusNode();
coins = [...Coins.enabled]; coins = [...AppConfig.coins];
super.initState(); super.initState();
} }
@ -90,7 +90,7 @@ class _NewContactAddressEntryFormState
Widget build(BuildContext context) { Widget build(BuildContext context) {
final isDesktop = Util.isDesktop; final isDesktop = Util.isDesktop;
if (isDesktop) { if (isDesktop) {
coins = [...Coins.enabled]; coins = [...AppConfig.coins];
coins.removeWhere( coins.removeWhere(
(e) => e is Firo && e.network == CryptoCurrencyNetwork.test, (e) => e is Firo && e.network == CryptoCurrencyNetwork.test,
); );

View file

@ -16,6 +16,7 @@ import 'package:flutter/services.dart';
import 'package:flutter_riverpod/flutter_riverpod.dart'; import 'package:flutter_riverpod/flutter_riverpod.dart';
import 'package:flutter_svg/svg.dart'; import 'package:flutter_svg/svg.dart';
import 'package:intl/intl.dart'; import 'package:intl/intl.dart';
import 'package:stackwallet/app_config.dart';
import 'package:stackwallet/models/buy/response_objects/crypto.dart'; import 'package:stackwallet/models/buy/response_objects/crypto.dart';
import 'package:stackwallet/models/buy/response_objects/fiat.dart'; import 'package:stackwallet/models/buy/response_objects/fiat.dart';
import 'package:stackwallet/models/buy/response_objects/quote.dart'; import 'package:stackwallet/models/buy/response_objects/quote.dart';
@ -30,7 +31,6 @@ import 'package:stackwallet/pages_desktop_specific/my_stack_view/wallet_view/sub
import 'package:stackwallet/providers/providers.dart'; import 'package:stackwallet/providers/providers.dart';
import 'package:stackwallet/services/buy/buy_response.dart'; import 'package:stackwallet/services/buy/buy_response.dart';
import 'package:stackwallet/services/buy/simplex/simplex_api.dart'; import 'package:stackwallet/services/buy/simplex/simplex_api.dart';
import 'package:stackwallet/supported_coins.dart';
import 'package:stackwallet/themes/stack_colors.dart'; import 'package:stackwallet/themes/stack_colors.dart';
import 'package:stackwallet/utilities/address_utils.dart'; import 'package:stackwallet/utilities/address_utils.dart';
import 'package:stackwallet/utilities/assets.dart'; import 'package:stackwallet/utilities/assets.dart';
@ -413,7 +413,7 @@ class _BuyFormState extends ConsumerState<BuyForm> {
if (ticker == null) return false; if (ticker == null) return false;
try { try {
Coins.getCryptoCurrencyForTicker(ticker); AppConfig.getCryptoCurrencyForTicker(ticker);
return true; return true;
} on ArgumentError catch (_) { } on ArgumentError catch (_) {
return false; return false;
@ -1168,7 +1168,7 @@ class _BuyFormState extends ConsumerState<BuyForm> {
text: "Choose from Stack", text: "Choose from Stack",
onTap: () { onTap: () {
try { try {
final coin = Coins.getCryptoCurrencyForTicker( final coin = AppConfig.getCryptoCurrencyForTicker(
selectedCrypto!.ticker, selectedCrypto!.ticker,
); );
Navigator.of(context) Navigator.of(context)
@ -1331,7 +1331,7 @@ class _BuyFormState extends ConsumerState<BuyForm> {
), ),
Expanded( Expanded(
child: AddressBookAddressChooser( child: AddressBookAddressChooser(
coin: Coins.enabled.firstWhere( coin: AppConfig.coins.firstWhere(
(e) => (e) =>
e.ticker.toLowerCase() == e.ticker.toLowerCase() ==
selectedCrypto!.ticker selectedCrypto!.ticker

View file

@ -13,8 +13,8 @@ import 'dart:io';
import 'package:flutter/material.dart'; import 'package:flutter/material.dart';
import 'package:flutter_riverpod/flutter_riverpod.dart'; import 'package:flutter_riverpod/flutter_riverpod.dart';
import 'package:flutter_svg/svg.dart'; import 'package:flutter_svg/svg.dart';
import 'package:stackwallet/app_config.dart';
import 'package:stackwallet/models/buy/response_objects/crypto.dart'; import 'package:stackwallet/models/buy/response_objects/crypto.dart';
import 'package:stackwallet/supported_coins.dart';
import 'package:stackwallet/themes/coin_icon_provider.dart'; import 'package:stackwallet/themes/coin_icon_provider.dart';
import 'package:stackwallet/themes/stack_colors.dart'; import 'package:stackwallet/themes/stack_colors.dart';
import 'package:stackwallet/utilities/assets.dart'; import 'package:stackwallet/utilities/assets.dart';
@ -70,7 +70,7 @@ class _CryptoSelectionViewState extends ConsumerState<CryptoSelectionView> {
coins.sort( coins.sort(
(a, b) => a.ticker.toLowerCase().compareTo(b.ticker.toLowerCase()), (a, b) => a.ticker.toLowerCase().compareTo(b.ticker.toLowerCase()),
); );
for (final coin in Coins.enabled.reversed) { for (final coin in AppConfig.coins.reversed) {
final index = coins.indexWhere( final index = coins.indexWhere(
(element) => element.ticker.toLowerCase() == coin.ticker.toLowerCase(), (element) => element.ticker.toLowerCase() == coin.ticker.toLowerCase(),
); );
@ -270,7 +270,7 @@ bool isStackCoin(String? ticker) {
if (ticker == null) return false; if (ticker == null) return false;
try { try {
Coins.getCryptoCurrencyForTicker(ticker); AppConfig.getCryptoCurrencyForTicker(ticker);
return true; return true;
} on ArgumentError catch (_) { } on ArgumentError catch (_) {
return false; return false;
@ -305,7 +305,7 @@ class CoinIconForTicker extends ConsumerWidget {
@override @override
Widget build(BuildContext context, WidgetRef ref) { Widget build(BuildContext context, WidgetRef ref) {
try { try {
final coin = Coins.getCryptoCurrencyForTicker(ticker); final coin = AppConfig.getCryptoCurrencyForTicker(ticker);
return SvgPicture.file( return SvgPicture.file(
File( File(
ref.watch(coinIconProvider(coin)), ref.watch(coinIconProvider(coin)),
@ -326,7 +326,7 @@ class CoinIconForTicker extends ConsumerWidget {
// }) { // }) {
// String? iconAsset = /*isStackCoin(ticker) // String? iconAsset = /*isStackCoin(ticker)
// ?*/ // ?*/
// Assets.svg.iconFor(coin: SupportedCoins.getCryptoCurrencyForTicker(ticker)); // Assets.svg.iconFor(coin: SupportedAppConfig.getCryptoCurrencyForTicker(ticker));
// // : Assets.svg.buyIconFor(ticker); // // : Assets.svg.buyIconFor(ticker);
// return (iconAsset != null) // return (iconAsset != null)
// ? SvgPicture.asset(iconAsset, height: size, width: size) // ? SvgPicture.asset(iconAsset, height: size, width: size)

View file

@ -22,7 +22,7 @@ import 'package:stackwallet/services/exchange/exchange.dart';
import 'package:stackwallet/services/exchange/exchange_data_loading_service.dart'; import 'package:stackwallet/services/exchange/exchange_data_loading_service.dart';
import 'package:stackwallet/services/exchange/majestic_bank/majestic_bank_exchange.dart'; import 'package:stackwallet/services/exchange/majestic_bank/majestic_bank_exchange.dart';
import 'package:stackwallet/services/exchange/trocador/trocador_exchange.dart'; import 'package:stackwallet/services/exchange/trocador/trocador_exchange.dart';
import 'package:stackwallet/supported_coins.dart'; import 'package:stackwallet/app_config.dart';
import 'package:stackwallet/themes/stack_colors.dart'; import 'package:stackwallet/themes/stack_colors.dart';
import 'package:stackwallet/utilities/assets.dart'; import 'package:stackwallet/utilities/assets.dart';
import 'package:stackwallet/utilities/constants.dart'; import 'package:stackwallet/utilities/constants.dart';
@ -365,7 +365,7 @@ class _ExchangeCurrencySelectionViewState
Flexible( Flexible(
child: Builder( child: Builder(
builder: (context) { builder: (context) {
final coins = Coins.enabled.where( final coins = AppConfig.coins.where(
(e) => (e) =>
e.ticker.toLowerCase() != e.ticker.toLowerCase() !=
widget.pairedTicker?.toLowerCase(), widget.pairedTicker?.toLowerCase(),

View file

@ -11,6 +11,7 @@
import 'package:flutter/material.dart'; import 'package:flutter/material.dart';
import 'package:flutter/services.dart'; import 'package:flutter/services.dart';
import 'package:flutter_riverpod/flutter_riverpod.dart'; import 'package:flutter_riverpod/flutter_riverpod.dart';
import 'package:stackwallet/app_config.dart';
import 'package:stackwallet/models/exchange/incomplete_exchange.dart'; import 'package:stackwallet/models/exchange/incomplete_exchange.dart';
import 'package:stackwallet/pages/address_book_views/address_book_view.dart'; import 'package:stackwallet/pages/address_book_views/address_book_view.dart';
import 'package:stackwallet/pages/address_book_views/subviews/contact_popup.dart'; import 'package:stackwallet/pages/address_book_views/subviews/contact_popup.dart';
@ -19,7 +20,6 @@ import 'package:stackwallet/pages/exchange_view/exchange_step_views/step_3_view.
import 'package:stackwallet/pages/exchange_view/sub_widgets/step_row.dart'; import 'package:stackwallet/pages/exchange_view/sub_widgets/step_row.dart';
import 'package:stackwallet/providers/providers.dart'; import 'package:stackwallet/providers/providers.dart';
import 'package:stackwallet/services/exchange/majestic_bank/majestic_bank_exchange.dart'; import 'package:stackwallet/services/exchange/majestic_bank/majestic_bank_exchange.dart';
import 'package:stackwallet/supported_coins.dart';
import 'package:stackwallet/themes/stack_colors.dart'; import 'package:stackwallet/themes/stack_colors.dart';
import 'package:stackwallet/utilities/address_utils.dart'; import 'package:stackwallet/utilities/address_utils.dart';
import 'package:stackwallet/utilities/barcode_scanner_interface.dart'; import 'package:stackwallet/utilities/barcode_scanner_interface.dart';
@ -72,7 +72,7 @@ class _Step2ViewState extends ConsumerState<Step2View> {
bool isStackCoin(String ticker) { bool isStackCoin(String ticker) {
try { try {
Coins.getCryptoCurrencyForTicker(ticker); AppConfig.getCryptoCurrencyForTicker(ticker);
return true; return true;
} on ArgumentError catch (_) { } on ArgumentError catch (_) {
return false; return false;
@ -207,7 +207,7 @@ class _Step2ViewState extends ConsumerState<Step2View> {
text: "Choose from Stack", text: "Choose from Stack",
onTap: () { onTap: () {
try { try {
final coin = Coins.enabled.firstWhere( final coin = AppConfig.coins.firstWhere(
(e) => (e) =>
e.ticker.toLowerCase() == e.ticker.toLowerCase() ==
model.receiveTicker.toLowerCase(), model.receiveTicker.toLowerCase(),
@ -493,7 +493,7 @@ class _Step2ViewState extends ConsumerState<Step2View> {
text: "Choose from Stack", text: "Choose from Stack",
onTap: () { onTap: () {
try { try {
final coin = Coins.enabled.firstWhere( final coin = AppConfig.coins.firstWhere(
(e) => (e) =>
e.ticker.toLowerCase() == e.ticker.toLowerCase() ==
model.sendTicker.toLowerCase(), model.sendTicker.toLowerCase(),

View file

@ -26,7 +26,6 @@ import 'package:stackwallet/pages/send_view/sub_widgets/building_transaction_dia
import 'package:stackwallet/pages/wallet_view/wallet_view.dart'; import 'package:stackwallet/pages/wallet_view/wallet_view.dart';
import 'package:stackwallet/providers/providers.dart'; import 'package:stackwallet/providers/providers.dart';
import 'package:stackwallet/route_generator.dart'; import 'package:stackwallet/route_generator.dart';
import 'package:stackwallet/supported_coins.dart';
import 'package:stackwallet/themes/stack_colors.dart'; import 'package:stackwallet/themes/stack_colors.dart';
import 'package:stackwallet/utilities/amount/amount.dart'; import 'package:stackwallet/utilities/amount/amount.dart';
import 'package:stackwallet/utilities/amount/amount_formatter.dart'; import 'package:stackwallet/utilities/amount/amount_formatter.dart';
@ -73,7 +72,7 @@ class _Step4ViewState extends ConsumerState<Step4View> {
bool _isWalletCoinAndHasWallet(String ticker, WidgetRef ref) { bool _isWalletCoinAndHasWallet(String ticker, WidgetRef ref) {
try { try {
final coin = Coins.getCryptoCurrencyForTicker(ticker); final coin = AppConfig.getCryptoCurrencyForTicker(ticker);
return ref return ref
.read(pWallets) .read(pWallets)
.wallets .wallets
@ -851,8 +850,8 @@ class _Step4ViewState extends ConsumerState<Step4View> {
.useMaterialPageRoute, .useMaterialPageRoute,
builder: builder:
(BuildContext context) { (BuildContext context) {
final coin = final coin = AppConfig.coins
Coins.enabled.firstWhere( .firstWhere(
(e) => (e) =>
e.ticker e.ticker
.toLowerCase() == .toLowerCase() ==

View file

@ -12,11 +12,11 @@ import 'package:decimal/decimal.dart';
import 'package:flutter/material.dart'; import 'package:flutter/material.dart';
import 'package:flutter_riverpod/flutter_riverpod.dart'; import 'package:flutter_riverpod/flutter_riverpod.dart';
import 'package:flutter_svg/svg.dart'; import 'package:flutter_svg/svg.dart';
import 'package:stackwallet/app_config.dart';
import 'package:stackwallet/models/exchange/response_objects/estimate.dart'; import 'package:stackwallet/models/exchange/response_objects/estimate.dart';
import 'package:stackwallet/providers/exchange/exchange_form_state_provider.dart'; import 'package:stackwallet/providers/exchange/exchange_form_state_provider.dart';
import 'package:stackwallet/providers/global/locale_provider.dart'; import 'package:stackwallet/providers/global/locale_provider.dart';
import 'package:stackwallet/services/exchange/exchange.dart'; import 'package:stackwallet/services/exchange/exchange.dart';
import 'package:stackwallet/supported_coins.dart';
import 'package:stackwallet/themes/stack_colors.dart'; import 'package:stackwallet/themes/stack_colors.dart';
import 'package:stackwallet/utilities/amount/amount.dart'; import 'package:stackwallet/utilities/amount/amount.dart';
import 'package:stackwallet/utilities/amount/amount_formatter.dart'; import 'package:stackwallet/utilities/amount/amount_formatter.dart';
@ -26,7 +26,6 @@ import 'package:stackwallet/utilities/enums/exchange_rate_type_enum.dart';
import 'package:stackwallet/utilities/logger.dart'; import 'package:stackwallet/utilities/logger.dart';
import 'package:stackwallet/utilities/text_styles.dart'; import 'package:stackwallet/utilities/text_styles.dart';
import 'package:stackwallet/utilities/util.dart'; import 'package:stackwallet/utilities/util.dart';
import 'package:stackwallet/wallets/crypto_currency/coins/bitcoin.dart';
import 'package:stackwallet/wallets/crypto_currency/crypto_currency.dart'; import 'package:stackwallet/wallets/crypto_currency/crypto_currency.dart';
import 'package:stackwallet/widgets/animated_text.dart'; import 'package:stackwallet/widgets/animated_text.dart';
import 'package:stackwallet/widgets/conditional_parent.dart'; import 'package:stackwallet/widgets/conditional_parent.dart';
@ -94,7 +93,7 @@ class _ExchangeOptionState extends ConsumerState<ExchangeOption> {
int decimals; int decimals;
try { try {
decimals = Coins.getCryptoCurrencyForTicker( decimals = AppConfig.getCryptoCurrencyForTicker(
receivingCurrency.ticker, receivingCurrency.ticker,
).fractionDigits; ).fractionDigits;
} catch (_) { } catch (_) {
@ -113,7 +112,7 @@ class _ExchangeOptionState extends ConsumerState<ExchangeOption> {
CryptoCurrency? coin; CryptoCurrency? coin;
try { try {
coin = Coins.getCryptoCurrencyForTicker( coin = AppConfig.getCryptoCurrencyForTicker(
receivingCurrency.ticker, receivingCurrency.ticker,
); );
} catch (_) { } catch (_) {

View file

@ -17,6 +17,7 @@ import 'package:flutter/services.dart';
import 'package:flutter_riverpod/flutter_riverpod.dart'; import 'package:flutter_riverpod/flutter_riverpod.dart';
import 'package:flutter_svg/svg.dart'; import 'package:flutter_svg/svg.dart';
import 'package:qr_flutter/qr_flutter.dart'; import 'package:qr_flutter/qr_flutter.dart';
import 'package:stackwallet/app_config.dart';
import 'package:stackwallet/models/exchange/change_now/exchange_transaction_status.dart'; import 'package:stackwallet/models/exchange/change_now/exchange_transaction_status.dart';
import 'package:stackwallet/models/isar/models/blockchain_data/transaction.dart'; import 'package:stackwallet/models/isar/models/blockchain_data/transaction.dart';
import 'package:stackwallet/models/isar/stack_theme.dart'; import 'package:stackwallet/models/isar/stack_theme.dart';
@ -33,7 +34,6 @@ import 'package:stackwallet/services/exchange/exchange.dart';
import 'package:stackwallet/services/exchange/majestic_bank/majestic_bank_exchange.dart'; import 'package:stackwallet/services/exchange/majestic_bank/majestic_bank_exchange.dart';
import 'package:stackwallet/services/exchange/simpleswap/simpleswap_exchange.dart'; import 'package:stackwallet/services/exchange/simpleswap/simpleswap_exchange.dart';
import 'package:stackwallet/services/exchange/trocador/trocador_exchange.dart'; import 'package:stackwallet/services/exchange/trocador/trocador_exchange.dart';
import 'package:stackwallet/supported_coins.dart';
import 'package:stackwallet/themes/stack_colors.dart'; import 'package:stackwallet/themes/stack_colors.dart';
import 'package:stackwallet/themes/theme_providers.dart'; import 'package:stackwallet/themes/theme_providers.dart';
import 'package:stackwallet/utilities/amount/amount.dart'; import 'package:stackwallet/utilities/amount/amount.dart';
@ -88,9 +88,9 @@ class _TradeDetailsViewState extends ConsumerState<TradeDetailsView> {
bool isStackCoin(String ticker) { bool isStackCoin(String ticker) {
try { try {
try { try {
Coins.getCryptoCurrencyForTicker(ticker); AppConfig.getCryptoCurrencyForTicker(ticker);
} catch (_) {} } catch (_) {}
Coins.getCryptoCurrencyByPrettyName(ticker); AppConfig.getCryptoCurrencyByPrettyName(ticker);
return true; return true;
} on ArgumentError catch (_) { } on ArgumentError catch (_) {
return false; return false;
@ -279,11 +279,11 @@ class _TradeDetailsViewState extends ConsumerState<TradeDetailsView> {
onPressed: () { onPressed: () {
CryptoCurrency coin; CryptoCurrency coin;
try { try {
coin = Coins.getCryptoCurrencyForTicker( coin = AppConfig.getCryptoCurrencyForTicker(
trade.payInCurrency, trade.payInCurrency,
); );
} catch (_) { } catch (_) {
coin = Coins.getCryptoCurrencyByPrettyName( coin = AppConfig.getCryptoCurrencyByPrettyName(
trade.payInCurrency, trade.payInCurrency,
); );
} }
@ -379,7 +379,8 @@ class _TradeDetailsViewState extends ConsumerState<TradeDetailsView> {
builder: (context) { builder: (context) {
String text; String text;
try { try {
final coin = Coins.getCryptoCurrencyForTicker( final coin =
AppConfig.getCryptoCurrencyForTicker(
trade.payInCurrency, trade.payInCurrency,
); );
final amount = sendAmount.toAmount( final amount = sendAmount.toAmount(
@ -628,7 +629,7 @@ class _TradeDetailsViewState extends ConsumerState<TradeDetailsView> {
text: "View transaction", text: "View transaction",
onTap: () { onTap: () {
final CryptoCurrency coin = final CryptoCurrency coin =
Coins.getCryptoCurrencyForTicker( AppConfig.getCryptoCurrencyForTicker(
trade.payInCurrency, trade.payInCurrency,
); );
@ -1381,11 +1382,11 @@ class _TradeDetailsViewState extends ConsumerState<TradeDetailsView> {
onPressed: () { onPressed: () {
CryptoCurrency coin; CryptoCurrency coin;
try { try {
coin = Coins.getCryptoCurrencyForTicker( coin = AppConfig.getCryptoCurrencyForTicker(
trade.payInCurrency, trade.payInCurrency,
); );
} catch (_) { } catch (_) {
coin = Coins.getCryptoCurrencyByPrettyName( coin = AppConfig.getCryptoCurrencyByPrettyName(
trade.payInCurrency, trade.payInCurrency,
); );
} }

View file

@ -5,7 +5,7 @@ import 'package:flutter_riverpod/flutter_riverpod.dart';
import 'package:flutter_svg/svg.dart'; import 'package:flutter_svg/svg.dart';
import 'package:stackwallet/pages/settings_views/global_settings_view/advanced_views/manage_coin_units/edit_coin_units_view.dart'; import 'package:stackwallet/pages/settings_views/global_settings_view/advanced_views/manage_coin_units/edit_coin_units_view.dart';
import 'package:stackwallet/providers/global/prefs_provider.dart'; import 'package:stackwallet/providers/global/prefs_provider.dart';
import 'package:stackwallet/supported_coins.dart'; import 'package:stackwallet/app_config.dart';
import 'package:stackwallet/themes/coin_icon_provider.dart'; import 'package:stackwallet/themes/coin_icon_provider.dart';
import 'package:stackwallet/themes/stack_colors.dart'; import 'package:stackwallet/themes/stack_colors.dart';
import 'package:stackwallet/utilities/assets.dart'; import 'package:stackwallet/utilities/assets.dart';
@ -44,7 +44,7 @@ class ManageCoinUnitsView extends ConsumerWidget {
prefsChangeNotifierProvider.select((value) => value.showTestNetCoins), prefsChangeNotifierProvider.select((value) => value.showTestNetCoins),
); );
final _coins = Coins.enabled final _coins = AppConfig.coins
.where((e) => e is! Firo && e.network != CryptoCurrencyNetwork.test) .where((e) => e is! Firo && e.network != CryptoCurrencyNetwork.test)
.toList(); .toList();

View file

@ -15,7 +15,7 @@ import 'package:flutter_riverpod/flutter_riverpod.dart';
import 'package:flutter_svg/svg.dart'; import 'package:flutter_svg/svg.dart';
import 'package:stackwallet/pages/settings_views/global_settings_view/manage_nodes_views/coin_nodes_view.dart'; import 'package:stackwallet/pages/settings_views/global_settings_view/manage_nodes_views/coin_nodes_view.dart';
import 'package:stackwallet/providers/providers.dart'; import 'package:stackwallet/providers/providers.dart';
import 'package:stackwallet/supported_coins.dart'; import 'package:stackwallet/app_config.dart';
import 'package:stackwallet/themes/coin_icon_provider.dart'; import 'package:stackwallet/themes/coin_icon_provider.dart';
import 'package:stackwallet/themes/stack_colors.dart'; import 'package:stackwallet/themes/stack_colors.dart';
import 'package:stackwallet/utilities/constants.dart'; import 'package:stackwallet/utilities/constants.dart';
@ -37,7 +37,7 @@ class ManageNodesView extends ConsumerStatefulWidget {
} }
class _ManageNodesViewState extends ConsumerState<ManageNodesView> { class _ManageNodesViewState extends ConsumerState<ManageNodesView> {
List<CryptoCurrency> _coins = [...Coins.enabled]; List<CryptoCurrency> _coins = [...AppConfig.coins];
@override @override
void initState() { void initState() {

View file

@ -16,6 +16,7 @@ import 'dart:typed_data';
import 'package:frostdart/frostdart.dart' as frost; import 'package:frostdart/frostdart.dart' as frost;
import 'package:isar/isar.dart'; import 'package:isar/isar.dart';
import 'package:stack_wallet_backup/stack_wallet_backup.dart'; import 'package:stack_wallet_backup/stack_wallet_backup.dart';
import 'package:stackwallet/app_config.dart';
import 'package:stackwallet/db/hive/db.dart'; import 'package:stackwallet/db/hive/db.dart';
import 'package:stackwallet/db/isar/main_db.dart'; import 'package:stackwallet/db/isar/main_db.dart';
import 'package:stackwallet/models/exchange/change_now/exchange_transaction.dart'; import 'package:stackwallet/models/exchange/change_now/exchange_transaction.dart';
@ -33,7 +34,6 @@ import 'package:stackwallet/services/trade_notes_service.dart';
import 'package:stackwallet/services/trade_sent_from_stack_service.dart'; import 'package:stackwallet/services/trade_sent_from_stack_service.dart';
import 'package:stackwallet/services/trade_service.dart'; import 'package:stackwallet/services/trade_service.dart';
import 'package:stackwallet/services/wallets.dart'; import 'package:stackwallet/services/wallets.dart';
import 'package:stackwallet/supported_coins.dart';
import 'package:stackwallet/utilities/enums/backup_frequency_type.dart'; import 'package:stackwallet/utilities/enums/backup_frequency_type.dart';
import 'package:stackwallet/utilities/enums/stack_restoring_status.dart'; import 'package:stackwallet/utilities/enums/stack_restoring_status.dart';
import 'package:stackwallet/utilities/enums/sync_type_enum.dart'; import 'package:stackwallet/utilities/enums/sync_type_enum.dart';
@ -774,7 +774,7 @@ abstract class SWB {
return false; return false;
} }
final coin = Coins.getCryptoCurrencyFor( final coin = AppConfig.getCryptoCurrencyFor(
walletbackup['coinName'] as String, walletbackup['coinName'] as String,
); );
@ -1036,7 +1036,7 @@ abstract class SWB {
for (final node in primaryNodes) { for (final node in primaryNodes) {
try { try {
await nodeService.setPrimaryNodeFor( await nodeService.setPrimaryNodeFor(
coin: Coins.getCryptoCurrencyByPrettyName( coin: AppConfig.getCryptoCurrencyByPrettyName(
node['coinName'] as String, node['coinName'] as String,
), ),
node: nodeService.getNodeById(id: node['id'] as String)!, node: nodeService.getNodeById(id: node['id'] as String)!,
@ -1226,7 +1226,7 @@ abstract class SWB {
for (final node in primaryNodes) { for (final node in primaryNodes) {
try { try {
await nodeService.setPrimaryNodeFor( await nodeService.setPrimaryNodeFor(
coin: Coins.getCryptoCurrencyByPrettyName( coin: AppConfig.getCryptoCurrencyByPrettyName(
node['coinName'] as String, node['coinName'] as String,
), ),
node: nodeService.getNodeById(id: node['id'] as String)!, node: nodeService.getNodeById(id: node['id'] as String)!,

View file

@ -22,7 +22,7 @@ import 'package:stackwallet/providers/db/main_db_provider.dart';
import 'package:stackwallet/providers/global/address_book_service_provider.dart'; import 'package:stackwallet/providers/global/address_book_service_provider.dart';
import 'package:stackwallet/providers/providers.dart'; import 'package:stackwallet/providers/providers.dart';
import 'package:stackwallet/providers/ui/address_book_providers/address_book_filter_provider.dart'; import 'package:stackwallet/providers/ui/address_book_providers/address_book_filter_provider.dart';
import 'package:stackwallet/supported_coins.dart'; import 'package:stackwallet/app_config.dart';
import 'package:stackwallet/themes/stack_colors.dart'; import 'package:stackwallet/themes/stack_colors.dart';
import 'package:stackwallet/utilities/assets.dart'; import 'package:stackwallet/utilities/assets.dart';
import 'package:stackwallet/utilities/constants.dart'; import 'package:stackwallet/utilities/constants.dart';
@ -98,7 +98,7 @@ class _DesktopAddressBook extends ConsumerState<DesktopAddressBook> {
ref.refresh(addressBookFilterProvider); ref.refresh(addressBookFilterProvider);
// if (widget.coin == null) { // if (widget.coin == null) {
final coins = Coins.enabled.toList(); final coins = AppConfig.coins.toList();
coins.removeWhere( coins.removeWhere(
(e) => e is Firo && e.network == CryptoCurrencyNetwork.test, (e) => e is Firo && e.network == CryptoCurrencyNetwork.test,
); );

View file

@ -28,7 +28,6 @@ import 'package:stackwallet/providers/global/trades_service_provider.dart';
import 'package:stackwallet/route_generator.dart'; import 'package:stackwallet/route_generator.dart';
import 'package:stackwallet/services/exchange/exchange_response.dart'; import 'package:stackwallet/services/exchange/exchange_response.dart';
import 'package:stackwallet/services/notifications_api.dart'; import 'package:stackwallet/services/notifications_api.dart';
import 'package:stackwallet/supported_coins.dart';
import 'package:stackwallet/themes/stack_colors.dart'; import 'package:stackwallet/themes/stack_colors.dart';
import 'package:stackwallet/utilities/amount/amount.dart'; import 'package:stackwallet/utilities/amount/amount.dart';
import 'package:stackwallet/utilities/assets.dart'; import 'package:stackwallet/utilities/assets.dart';
@ -194,7 +193,7 @@ class _StepScaffoldState extends ConsumerState<StepScaffold> {
void sendFromStack() { void sendFromStack() {
final trade = ref.read(desktopExchangeModelProvider)!.trade!; final trade = ref.read(desktopExchangeModelProvider)!.trade!;
final address = trade.payInAddress; final address = trade.payInAddress;
final coin = Coins.getCryptoCurrencyForTicker(trade.payInCurrency); final coin = AppConfig.getCryptoCurrencyForTicker(trade.payInCurrency);
final amount = Decimal.parse(trade.payInAmount).toAmount( final amount = Decimal.parse(trade.payInAmount).toAmount(
fractionDigits: coin.fractionDigits, fractionDigits: coin.fractionDigits,
); );

View file

@ -11,13 +11,13 @@
import 'package:flutter/material.dart'; import 'package:flutter/material.dart';
import 'package:flutter/services.dart'; import 'package:flutter/services.dart';
import 'package:flutter_riverpod/flutter_riverpod.dart'; import 'package:flutter_riverpod/flutter_riverpod.dart';
import 'package:stackwallet/app_config.dart';
import 'package:stackwallet/models/contact_address_entry.dart'; import 'package:stackwallet/models/contact_address_entry.dart';
import 'package:stackwallet/pages_desktop_specific/desktop_exchange/exchange_steps/step_scaffold.dart'; import 'package:stackwallet/pages_desktop_specific/desktop_exchange/exchange_steps/step_scaffold.dart';
import 'package:stackwallet/pages_desktop_specific/desktop_exchange/subwidgets/desktop_choose_from_stack.dart'; import 'package:stackwallet/pages_desktop_specific/desktop_exchange/subwidgets/desktop_choose_from_stack.dart';
import 'package:stackwallet/pages_desktop_specific/my_stack_view/wallet_view/sub_widgets/address_book_address_chooser/address_book_address_chooser.dart'; import 'package:stackwallet/pages_desktop_specific/my_stack_view/wallet_view/sub_widgets/address_book_address_chooser/address_book_address_chooser.dart';
import 'package:stackwallet/providers/exchange/exchange_send_from_wallet_id_provider.dart'; import 'package:stackwallet/providers/exchange/exchange_send_from_wallet_id_provider.dart';
import 'package:stackwallet/providers/global/wallets_provider.dart'; import 'package:stackwallet/providers/global/wallets_provider.dart';
import 'package:stackwallet/supported_coins.dart';
import 'package:stackwallet/themes/stack_colors.dart'; import 'package:stackwallet/themes/stack_colors.dart';
import 'package:stackwallet/utilities/clipboard_interface.dart'; import 'package:stackwallet/utilities/clipboard_interface.dart';
import 'package:stackwallet/utilities/constants.dart'; import 'package:stackwallet/utilities/constants.dart';
@ -59,7 +59,7 @@ class _DesktopStep2State extends ConsumerState<DesktopStep2> {
bool isStackCoin(String ticker) { bool isStackCoin(String ticker) {
try { try {
Coins.getCryptoCurrencyForTicker(ticker); AppConfig.getCryptoCurrencyForTicker(ticker);
return true; return true;
} on ArgumentError catch (_) { } on ArgumentError catch (_) {
return false; return false;
@ -68,7 +68,7 @@ class _DesktopStep2State extends ConsumerState<DesktopStep2> {
void selectRecipientAddressFromStack() async { void selectRecipientAddressFromStack() async {
try { try {
final coin = Coins.getCryptoCurrencyForTicker( final coin = AppConfig.getCryptoCurrencyForTicker(
ref.read(desktopExchangeModelProvider)!.receiveTicker, ref.read(desktopExchangeModelProvider)!.receiveTicker,
); );
@ -101,7 +101,7 @@ class _DesktopStep2State extends ConsumerState<DesktopStep2> {
void selectRefundAddressFromStack() async { void selectRefundAddressFromStack() async {
try { try {
final coin = Coins.getCryptoCurrencyForTicker( final coin = AppConfig.getCryptoCurrencyForTicker(
ref.read(desktopExchangeModelProvider)!.sendTicker, ref.read(desktopExchangeModelProvider)!.sendTicker,
); );
@ -131,7 +131,7 @@ class _DesktopStep2State extends ConsumerState<DesktopStep2> {
} }
void selectRecipientFromAddressBook() async { void selectRecipientFromAddressBook() async {
final coin = Coins.getCryptoCurrencyForTicker( final coin = AppConfig.getCryptoCurrencyForTicker(
ref.read(desktopExchangeModelProvider)!.receiveTicker, ref.read(desktopExchangeModelProvider)!.receiveTicker,
); );
@ -178,7 +178,7 @@ class _DesktopStep2State extends ConsumerState<DesktopStep2> {
} }
void selectRefundFromAddressBook() async { void selectRefundFromAddressBook() async {
final coin = Coins.getCryptoCurrencyForTicker( final coin = AppConfig.getCryptoCurrencyForTicker(
ref.read(desktopExchangeModelProvider)!.sendTicker, ref.read(desktopExchangeModelProvider)!.sendTicker,
); );

View file

@ -12,10 +12,10 @@ import 'dart:async';
import 'package:flutter/material.dart'; import 'package:flutter/material.dart';
import 'package:flutter_riverpod/flutter_riverpod.dart'; import 'package:flutter_riverpod/flutter_riverpod.dart';
import 'package:stackwallet/app_config.dart';
import 'package:stackwallet/pages_desktop_specific/desktop_exchange/exchange_steps/step_scaffold.dart'; import 'package:stackwallet/pages_desktop_specific/desktop_exchange/exchange_steps/step_scaffold.dart';
import 'package:stackwallet/pages_desktop_specific/desktop_exchange/exchange_steps/subwidgets/desktop_step_item.dart'; import 'package:stackwallet/pages_desktop_specific/desktop_exchange/exchange_steps/subwidgets/desktop_step_item.dart';
import 'package:stackwallet/providers/providers.dart'; import 'package:stackwallet/providers/providers.dart';
import 'package:stackwallet/supported_coins.dart';
import 'package:stackwallet/themes/stack_colors.dart'; import 'package:stackwallet/themes/stack_colors.dart';
import 'package:stackwallet/utilities/text_styles.dart'; import 'package:stackwallet/utilities/text_styles.dart';
import 'package:stackwallet/widgets/rounded_container.dart'; import 'package:stackwallet/widgets/rounded_container.dart';
@ -37,7 +37,7 @@ class _DesktopStep4State extends ConsumerState<DesktopStep4> {
bool _isWalletCoinAndHasWallet(String ticker) { bool _isWalletCoinAndHasWallet(String ticker) {
try { try {
final coin = Coins.getCryptoCurrencyForTicker(ticker); final coin = AppConfig.getCryptoCurrencyForTicker(ticker);
return ref return ref
.read(pWallets) .read(pWallets)
.wallets .wallets

View file

@ -14,7 +14,7 @@ import 'package:flutter/material.dart';
import 'package:flutter_riverpod/flutter_riverpod.dart'; import 'package:flutter_riverpod/flutter_riverpod.dart';
import 'package:flutter_svg/svg.dart'; import 'package:flutter_svg/svg.dart';
import 'package:stackwallet/providers/global/prefs_provider.dart'; import 'package:stackwallet/providers/global/prefs_provider.dart';
import 'package:stackwallet/supported_coins.dart'; import 'package:stackwallet/app_config.dart';
import 'package:stackwallet/themes/coin_icon_provider.dart'; import 'package:stackwallet/themes/coin_icon_provider.dart';
import 'package:stackwallet/themes/stack_colors.dart'; import 'package:stackwallet/themes/stack_colors.dart';
import 'package:stackwallet/utilities/assets.dart'; import 'package:stackwallet/utilities/assets.dart';
@ -39,7 +39,7 @@ class DesktopManageBlockExplorersDialog extends ConsumerWidget {
prefsChangeNotifierProvider.select((value) => value.showTestNetCoins), prefsChangeNotifierProvider.select((value) => value.showTestNetCoins),
); );
final coins = Coins.enabled final coins = AppConfig.coins
.where( .where(
(e) => showTestNet || e.network == CryptoCurrencyNetwork.main, (e) => showTestNet || e.network == CryptoCurrencyNetwork.main,
) )

View file

@ -16,7 +16,7 @@ import 'package:flutter_svg/svg.dart';
import 'package:stackwallet/pages/settings_views/global_settings_view/manage_nodes_views/coin_nodes_view.dart'; import 'package:stackwallet/pages/settings_views/global_settings_view/manage_nodes_views/coin_nodes_view.dart';
import 'package:stackwallet/providers/providers.dart'; import 'package:stackwallet/providers/providers.dart';
import 'package:stackwallet/route_generator.dart'; import 'package:stackwallet/route_generator.dart';
import 'package:stackwallet/supported_coins.dart'; import 'package:stackwallet/app_config.dart';
import 'package:stackwallet/themes/coin_icon_provider.dart'; import 'package:stackwallet/themes/coin_icon_provider.dart';
import 'package:stackwallet/themes/stack_colors.dart'; import 'package:stackwallet/themes/stack_colors.dart';
import 'package:stackwallet/utilities/assets.dart'; import 'package:stackwallet/utilities/assets.dart';
@ -39,7 +39,7 @@ class NodesSettings extends ConsumerStatefulWidget {
} }
class _NodesSettings extends ConsumerState<NodesSettings> { class _NodesSettings extends ConsumerState<NodesSettings> {
List<CryptoCurrency> _coins = [...Coins.enabled]; List<CryptoCurrency> _coins = [...AppConfig.coins];
late final TextEditingController searchNodeController; late final TextEditingController searchNodeController;
late final FocusNode searchNodeFocusNode; late final FocusNode searchNodeFocusNode;

View file

@ -12,6 +12,7 @@ import 'dart:async';
import 'dart:convert'; import 'dart:convert';
import 'package:decimal/decimal.dart'; import 'package:decimal/decimal.dart';
import 'package:stackwallet/app_config.dart';
import 'package:stackwallet/models/buy/response_objects/crypto.dart'; import 'package:stackwallet/models/buy/response_objects/crypto.dart';
import 'package:stackwallet/models/buy/response_objects/fiat.dart'; import 'package:stackwallet/models/buy/response_objects/fiat.dart';
import 'package:stackwallet/models/buy/response_objects/order.dart'; import 'package:stackwallet/models/buy/response_objects/order.dart';
@ -19,7 +20,6 @@ import 'package:stackwallet/models/buy/response_objects/quote.dart';
import 'package:stackwallet/networking/http.dart'; import 'package:stackwallet/networking/http.dart';
import 'package:stackwallet/services/buy/buy_response.dart'; import 'package:stackwallet/services/buy/buy_response.dart';
import 'package:stackwallet/services/tor_service.dart'; import 'package:stackwallet/services/tor_service.dart';
import 'package:stackwallet/supported_coins.dart';
import 'package:stackwallet/utilities/enums/fiat_enum.dart'; import 'package:stackwallet/utilities/enums/fiat_enum.dart';
import 'package:stackwallet/utilities/logger.dart'; import 'package:stackwallet/utilities/logger.dart';
import 'package:stackwallet/utilities/prefs.dart'; import 'package:stackwallet/utilities/prefs.dart';
@ -405,7 +405,7 @@ bool isStackCoin(String? ticker) {
if (ticker == null) return false; if (ticker == null) return false;
try { try {
Coins.getCryptoCurrencyForTicker(ticker); AppConfig.getCryptoCurrencyForTicker(ticker);
return true; return true;
} on ArgumentError catch (_) { } on ArgumentError catch (_) {
return false; return false;

View file

@ -12,9 +12,9 @@ import 'dart:convert';
import 'package:flutter/material.dart'; import 'package:flutter/material.dart';
import 'package:http/http.dart'; import 'package:http/http.dart';
import 'package:stackwallet/app_config.dart';
import 'package:stackwallet/db/hive/db.dart'; import 'package:stackwallet/db/hive/db.dart';
import 'package:stackwallet/models/node_model.dart'; import 'package:stackwallet/models/node_model.dart';
import 'package:stackwallet/supported_coins.dart';
import 'package:stackwallet/utilities/default_nodes.dart'; import 'package:stackwallet/utilities/default_nodes.dart';
import 'package:stackwallet/utilities/flutter_secure_storage_interface.dart'; import 'package:stackwallet/utilities/flutter_secure_storage_interface.dart';
import 'package:stackwallet/utilities/logger.dart'; import 'package:stackwallet/utilities/logger.dart';
@ -31,7 +31,7 @@ class NodeService extends ChangeNotifier {
}); });
Future<void> updateDefaults() async { Future<void> updateDefaults() async {
for (final defaultNode in Coins.enabled.map( for (final defaultNode in AppConfig.coins.map(
(e) => e.defaultNode, (e) => e.defaultNode,
)) { )) {
final savedNode = DB.instance final savedNode = DB.instance
@ -39,7 +39,7 @@ class NodeService extends ChangeNotifier {
if (savedNode == null) { if (savedNode == null) {
// save the default node to hive only if no other nodes for the specific coin exist // save the default node to hive only if no other nodes for the specific coin exist
if (getNodesFor( if (getNodesFor(
Coins.getCryptoCurrencyByPrettyName( AppConfig.getCryptoCurrencyByPrettyName(
defaultNode.coinName, defaultNode.coinName,
), ),
).isEmpty) { ).isEmpty) {
@ -64,7 +64,8 @@ class NodeService extends ChangeNotifier {
// check if a default node is the primary node for the crypto currency // check if a default node is the primary node for the crypto currency
// and update it if needed // and update it if needed
final coin = Coins.getCryptoCurrencyByPrettyName(defaultNode.coinName); final coin =
AppConfig.getCryptoCurrencyByPrettyName(defaultNode.coinName);
final primaryNode = getPrimaryNodeFor(currency: coin); final primaryNode = getPrimaryNodeFor(currency: coin);
if (primaryNode != null && primaryNode.id == defaultNode.id) { if (primaryNode != null && primaryNode.id == defaultNode.id) {
await setPrimaryNodeFor( await setPrimaryNodeFor(
@ -205,7 +206,7 @@ class NodeService extends ChangeNotifier {
bool shouldNotifyListeners, bool shouldNotifyListeners,
) async { ) async {
// check if the node being edited is the primary one; if it is, setPrimaryNodeFor coin // check if the node being edited is the primary one; if it is, setPrimaryNodeFor coin
final coin = Coins.getCryptoCurrencyByPrettyName(editedNode.coinName); final coin = AppConfig.getCryptoCurrencyByPrettyName(editedNode.coinName);
final primaryNode = getPrimaryNodeFor(currency: coin); final primaryNode = getPrimaryNodeFor(currency: coin);
if (primaryNode?.id == editedNode.id) { if (primaryNode?.id == editedNode.id) {
await setPrimaryNodeFor( await setPrimaryNodeFor(
@ -238,7 +239,7 @@ class NodeService extends ChangeNotifier {
final map = jsonDecode(result as String); final map = jsonDecode(result as String);
Logging.instance.log(map, level: LogLevel.Info); Logging.instance.log(map, level: LogLevel.Info);
for (final coin in Coins.enabled) { for (final coin in AppConfig.coins) {
final nodeList = List<Map<String, dynamic>>.from( final nodeList = List<Map<String, dynamic>>.from(
map["nodes"][coin.identifier] as List? ?? [], map["nodes"][coin.identifier] as List? ?? [],
); );

View file

@ -11,6 +11,7 @@
import 'dart:async'; import 'dart:async';
import 'package:flutter/foundation.dart'; import 'package:flutter/foundation.dart';
import 'package:stackwallet/app_config.dart';
import 'package:stackwallet/db/hive/db.dart'; import 'package:stackwallet/db/hive/db.dart';
import 'package:stackwallet/electrumx_rpc/electrumx_client.dart'; import 'package:stackwallet/electrumx_rpc/electrumx_client.dart';
import 'package:stackwallet/exceptions/electrumx/no_such_transaction.dart'; import 'package:stackwallet/exceptions/electrumx/no_such_transaction.dart';
@ -21,7 +22,6 @@ import 'package:stackwallet/services/node_service.dart';
import 'package:stackwallet/services/notifications_api.dart'; import 'package:stackwallet/services/notifications_api.dart';
import 'package:stackwallet/services/trade_service.dart'; import 'package:stackwallet/services/trade_service.dart';
import 'package:stackwallet/services/wallets.dart'; import 'package:stackwallet/services/wallets.dart';
import 'package:stackwallet/supported_coins.dart';
import 'package:stackwallet/utilities/logger.dart'; import 'package:stackwallet/utilities/logger.dart';
import 'package:stackwallet/utilities/prefs.dart'; import 'package:stackwallet/utilities/prefs.dart';
import 'package:stackwallet/wallets/crypto_currency/crypto_currency.dart'; import 'package:stackwallet/wallets/crypto_currency/crypto_currency.dart';
@ -129,7 +129,7 @@ class NotificationsService extends ChangeNotifier {
for (final notification in _watchedTransactionNotifications) { for (final notification in _watchedTransactionNotifications) {
try { try {
final CryptoCurrency coin = final CryptoCurrency coin =
Coins.getCryptoCurrencyByPrettyName(notification.coinName); AppConfig.getCryptoCurrencyByPrettyName(notification.coinName);
final txid = notification.txid!; final txid = notification.txid!;
final wallet = Wallets.sharedInstance.getWallet(notification.walletId); final wallet = Wallets.sharedInstance.getWallet(notification.walletId);

View file

@ -13,10 +13,10 @@ import 'dart:convert';
import 'package:decimal/decimal.dart'; import 'package:decimal/decimal.dart';
import 'package:flutter/foundation.dart'; import 'package:flutter/foundation.dart';
import 'package:stackwallet/app_config.dart';
import 'package:stackwallet/db/hive/db.dart'; import 'package:stackwallet/db/hive/db.dart';
import 'package:stackwallet/networking/http.dart'; import 'package:stackwallet/networking/http.dart';
import 'package:stackwallet/services/tor_service.dart'; import 'package:stackwallet/services/tor_service.dart';
import 'package:stackwallet/supported_coins.dart';
import 'package:stackwallet/utilities/logger.dart'; import 'package:stackwallet/utilities/logger.dart';
import 'package:stackwallet/utilities/prefs.dart'; import 'package:stackwallet/utilities/prefs.dart';
import 'package:stackwallet/wallets/crypto_currency/crypto_currency.dart'; import 'package:stackwallet/wallets/crypto_currency/crypto_currency.dart';
@ -48,7 +48,7 @@ class PriceAPI {
) async { ) async {
final Map<String, dynamic> map = {}; final Map<String, dynamic> map = {};
for (final coin in Coins.enabled) { for (final coin in AppConfig.coins) {
final entry = data[coin]; final entry = data[coin];
if (entry == null) { if (entry == null) {
map[coin.prettyName] = ["0", 0.0]; map[coin.prettyName] = ["0", 0.0];
@ -68,11 +68,11 @@ class PriceAPI {
{}; {};
// init with 0 // init with 0
final result = { final result = {
for (final coin in Coins.enabled) coin: Tuple2(Decimal.zero, 0.0), for (final coin in AppConfig.coins) coin: Tuple2(Decimal.zero, 0.0),
}; };
for (final entry in map.entries) { for (final entry in map.entries) {
result[Coins.getCryptoCurrencyByPrettyName( result[AppConfig.getCryptoCurrencyByPrettyName(
entry.key as String, entry.key as String,
)] = Tuple2( )] = Tuple2(
Decimal.parse(entry.value[0] as String), Decimal.parse(entry.value[0] as String),
@ -125,7 +125,7 @@ class PriceAPI {
for (final map in coinGeckoData) { for (final map in coinGeckoData) {
final String coinName = map["name"] as String; final String coinName = map["name"] as String;
final coin = Coins.getCryptoCurrencyByPrettyName(coinName); final coin = AppConfig.getCryptoCurrencyByPrettyName(coinName);
final price = Decimal.parse(map["current_price"].toString()); final price = Decimal.parse(map["current_price"].toString());
final change24h = map["price_change_percentage_24h"] != null final change24h = map["price_change_percentage_24h"] != null

View file

@ -17,7 +17,7 @@ import 'package:stackwallet/db/isar/main_db.dart';
import 'package:stackwallet/models/isar/models/isar_models.dart'; import 'package:stackwallet/models/isar/models/isar_models.dart';
import 'package:stackwallet/networking/http.dart'; import 'package:stackwallet/networking/http.dart';
import 'package:stackwallet/services/price.dart'; import 'package:stackwallet/services/price.dart';
import 'package:stackwallet/supported_coins.dart'; import 'package:stackwallet/app_config.dart';
import 'package:stackwallet/wallets/crypto_currency/crypto_currency.dart'; import 'package:stackwallet/wallets/crypto_currency/crypto_currency.dart';
import 'package:tuple/tuple.dart'; import 'package:tuple/tuple.dart';
@ -30,7 +30,7 @@ class PriceService extends ChangeNotifier {
Timer? _timer; Timer? _timer;
final Map<CryptoCurrency, Tuple2<Decimal, double>> _cachedPrices = { final Map<CryptoCurrency, Tuple2<Decimal, double>> _cachedPrices = {
for (final coin in Coins.enabled) coin: Tuple2(Decimal.zero, 0.0), for (final coin in AppConfig.coins) coin: Tuple2(Decimal.zero, 0.0),
}; };
final Map<String, Tuple2<Decimal, double>> _cachedTokenPrices = {}; final Map<String, Tuple2<Decimal, double>> _cachedTokenPrices = {};

View file

@ -18,7 +18,7 @@ import 'package:stackwallet/db/isar/main_db.dart';
import 'package:stackwallet/services/node_service.dart'; import 'package:stackwallet/services/node_service.dart';
import 'package:stackwallet/services/notifications_service.dart'; import 'package:stackwallet/services/notifications_service.dart';
import 'package:stackwallet/services/trade_sent_from_stack_service.dart'; import 'package:stackwallet/services/trade_sent_from_stack_service.dart';
import 'package:stackwallet/supported_coins.dart'; import 'package:stackwallet/app_config.dart';
import 'package:stackwallet/utilities/enums/sync_type_enum.dart'; import 'package:stackwallet/utilities/enums/sync_type_enum.dart';
import 'package:stackwallet/utilities/flutter_secure_storage_interface.dart'; import 'package:stackwallet/utilities/flutter_secure_storage_interface.dart';
import 'package:stackwallet/utilities/logger.dart'; import 'package:stackwallet/utilities/logger.dart';
@ -400,7 +400,7 @@ class Wallets {
.where() .where()
.filter() .filter()
.anyOf<String, CryptoCurrency>( .anyOf<String, CryptoCurrency>(
Coins.enabled.map((e) => e.identifier), AppConfig.coins.map((e) => e.identifier),
(q, element) => q.coinNameMatches(element), (q, element) => q.coinNameMatches(element),
) )
.findAll(); .findAll();

View file

@ -11,8 +11,8 @@
import 'dart:convert'; import 'dart:convert';
import 'package:flutter/material.dart'; import 'package:flutter/material.dart';
import 'package:stackwallet/app_config.dart';
import 'package:stackwallet/db/hive/db.dart'; import 'package:stackwallet/db/hive/db.dart';
import 'package:stackwallet/supported_coins.dart';
import 'package:stackwallet/utilities/logger.dart'; import 'package:stackwallet/utilities/logger.dart';
@Deprecated("Legacy support only. Do not use.") @Deprecated("Legacy support only. Do not use.")
@ -90,7 +90,7 @@ class WalletsService extends ChangeNotifier {
mapped.removeWhere((name, dyn) { mapped.removeWhere((name, dyn) {
final jsonObject = Map<String, dynamic>.from(dyn as Map); final jsonObject = Map<String, dynamic>.from(dyn as Map);
try { try {
Coins.getCryptoCurrencyFor(jsonObject["coin"] as String); AppConfig.getCryptoCurrencyFor(jsonObject["coin"] as String);
return false; return false;
} catch (e, s) { } catch (e, s) {
Logging.instance.log( Logging.instance.log(

View file

@ -1,73 +0,0 @@
import 'package:stackwallet/app_config.dart';
import 'package:stackwallet/wallets/crypto_currency/crypto_currency.dart';
import 'package:stackwallet/wallets/crypto_currency/intermediate/frost_currency.dart';
/// The supported coins. Eventually move away from the Coin enum
class Coins {
/// A List of enabled coins.
static List<CryptoCurrency> get enabled => all
.where(
(element) => AppConfig.supportedCoins.contains(element.runtimeType))
.toList();
/// A List of all implemented coins.
static final List<CryptoCurrency> all = [
Bitcoin(CryptoCurrencyNetwork.main),
BitcoinFrost(CryptoCurrencyNetwork.main),
Litecoin(CryptoCurrencyNetwork.main),
Bitcoincash(CryptoCurrencyNetwork.main),
Dogecoin(CryptoCurrencyNetwork.main),
Epiccash(CryptoCurrencyNetwork.main),
Ecash(CryptoCurrencyNetwork.main),
Ethereum(CryptoCurrencyNetwork.main),
Firo(CryptoCurrencyNetwork.main),
Monero(CryptoCurrencyNetwork.main),
Particl(CryptoCurrencyNetwork.main),
Peercoin(CryptoCurrencyNetwork.main),
Solana(CryptoCurrencyNetwork.main),
Stellar(CryptoCurrencyNetwork.main),
Tezos(CryptoCurrencyNetwork.main),
Wownero(CryptoCurrencyNetwork.main),
Namecoin(CryptoCurrencyNetwork.main),
Nano(CryptoCurrencyNetwork.main),
Banano(CryptoCurrencyNetwork.main),
Bitcoin(CryptoCurrencyNetwork.test),
BitcoinFrost(CryptoCurrencyNetwork.test),
Litecoin(CryptoCurrencyNetwork.test),
Bitcoincash(CryptoCurrencyNetwork.test),
Firo(CryptoCurrencyNetwork.test),
Dogecoin(CryptoCurrencyNetwork.test),
Stellar(CryptoCurrencyNetwork.test),
Peercoin(CryptoCurrencyNetwork.test),
];
static CryptoCurrency getCryptoCurrencyFor(String coinIdentifier) =>
all.firstWhere(
(e) => e.identifier == coinIdentifier,
);
static CryptoCurrency getCryptoCurrencyForTicker(
final String ticker, {
bool caseInsensitive = true,
}) {
final _ticker = caseInsensitive ? ticker.toLowerCase() : ticker;
return all.firstWhere(
caseInsensitive
? (e) => e.ticker.toLowerCase() == _ticker && e is! FrostCurrency
: (e) => e.ticker == _ticker && e is! FrostCurrency,
);
}
/// Fuzzy logic. Use with caution!!
@Deprecated("dangerous")
static CryptoCurrency getCryptoCurrencyByPrettyName(final String prettyName) {
final name = prettyName.replaceAll(" ", "").toLowerCase();
try {
return all.firstWhere(
(e) => e.identifier.toLowerCase() == name || e.prettyName == prettyName,
);
} catch (_) {
throw Exception("getCryptoCurrencyByPrettyName($prettyName) failed!");
}
}
}

View file

@ -14,7 +14,7 @@ import 'package:flutter/cupertino.dart';
import 'package:stackwallet/db/hive/db.dart'; import 'package:stackwallet/db/hive/db.dart';
import 'package:stackwallet/services/event_bus/events/global/tor_status_changed_event.dart'; import 'package:stackwallet/services/event_bus/events/global/tor_status_changed_event.dart';
import 'package:stackwallet/services/event_bus/global_event_bus.dart'; import 'package:stackwallet/services/event_bus/global_event_bus.dart';
import 'package:stackwallet/supported_coins.dart'; import 'package:stackwallet/app_config.dart';
import 'package:stackwallet/utilities/amount/amount_unit.dart'; import 'package:stackwallet/utilities/amount/amount_unit.dart';
import 'package:stackwallet/utilities/constants.dart'; import 'package:stackwallet/utilities/constants.dart';
import 'package:stackwallet/utilities/enums/backup_frequency_type.dart'; import 'package:stackwallet/utilities/enums/backup_frequency_type.dart';
@ -85,7 +85,8 @@ class Prefs extends ChangeNotifier {
DB.instance.put<dynamic>( DB.instance.put<dynamic>(
boxName: DB.boxNamePrefs, boxName: DB.boxNamePrefs,
key: "lastUnlockedTimeout", key: "lastUnlockedTimeout",
value: lastUnlockedTimeout,); value: lastUnlockedTimeout,
);
_lastUnlockedTimeout = lastUnlockedTimeout; _lastUnlockedTimeout = lastUnlockedTimeout;
notifyListeners(); notifyListeners();
} }
@ -93,7 +94,9 @@ class Prefs extends ChangeNotifier {
Future<int> _getLastUnlockedTimeout() async { Future<int> _getLastUnlockedTimeout() async {
return (DB.instance.get<dynamic>( return (DB.instance.get<dynamic>(
boxName: DB.boxNamePrefs, key: "lastUnlockedTimeout",)) as int? ?? boxName: DB.boxNamePrefs,
key: "lastUnlockedTimeout",
)) as int? ??
60; 60;
} }
@ -106,7 +109,10 @@ class Prefs extends ChangeNotifier {
set lastUnlocked(int lastUnlocked) { set lastUnlocked(int lastUnlocked) {
if (_lastUnlocked != lastUnlocked) { if (_lastUnlocked != lastUnlocked) {
DB.instance.put<dynamic>( DB.instance.put<dynamic>(
boxName: DB.boxNamePrefs, key: "lastUnlocked", value: lastUnlocked,); boxName: DB.boxNamePrefs,
key: "lastUnlocked",
value: lastUnlocked,
);
_lastUnlocked = lastUnlocked; _lastUnlocked = lastUnlocked;
notifyListeners(); notifyListeners();
} }
@ -114,7 +120,9 @@ class Prefs extends ChangeNotifier {
Future<int> _getLastUnlocked() async { Future<int> _getLastUnlocked() async {
return await DB.instance.get<dynamic>( return await DB.instance.get<dynamic>(
boxName: DB.boxNamePrefs, key: "lastUnlocked",) as int? ?? boxName: DB.boxNamePrefs,
key: "lastUnlocked",
) as int? ??
0; 0;
} }
@ -133,13 +141,16 @@ class Prefs extends ChangeNotifier {
await DB.instance.put<dynamic>( await DB.instance.put<dynamic>(
boxName: DB.boxNamePrefs, boxName: DB.boxNamePrefs,
key: "currentNotificationId", key: "currentNotificationId",
value: _currentNotificationId,); value: _currentNotificationId,
);
notifyListeners(); notifyListeners();
} }
Future<int> _getCurrentNotificationIndex() async { Future<int> _getCurrentNotificationIndex() async {
return await DB.instance.get<dynamic>( return await DB.instance.get<dynamic>(
boxName: DB.boxNamePrefs, key: "currentNotificationId",) as int? ?? boxName: DB.boxNamePrefs,
key: "currentNotificationId",
) as int? ??
0; 0;
} }
@ -154,7 +165,8 @@ class Prefs extends ChangeNotifier {
DB.instance.put<dynamic>( DB.instance.put<dynamic>(
boxName: DB.boxNamePrefs, boxName: DB.boxNamePrefs,
key: "walletIdsSyncOnStartup", key: "walletIdsSyncOnStartup",
value: walletIdsSyncOnStartup,); value: walletIdsSyncOnStartup,
);
_walletIdsSyncOnStartup = walletIdsSyncOnStartup; _walletIdsSyncOnStartup = walletIdsSyncOnStartup;
notifyListeners(); notifyListeners();
} }
@ -162,7 +174,9 @@ class Prefs extends ChangeNotifier {
Future<List<String>> _getWalletIdsSyncOnStartup() async { Future<List<String>> _getWalletIdsSyncOnStartup() async {
final list = await DB.instance.get<dynamic>( final list = await DB.instance.get<dynamic>(
boxName: DB.boxNamePrefs, key: "walletIdsSyncOnStartup",) as List? ?? boxName: DB.boxNamePrefs,
key: "walletIdsSyncOnStartup",
) as List? ??
[]; [];
return List<String>.from(list); return List<String>.from(list);
} }
@ -178,7 +192,8 @@ class Prefs extends ChangeNotifier {
DB.instance.put<dynamic>( DB.instance.put<dynamic>(
boxName: DB.boxNamePrefs, boxName: DB.boxNamePrefs,
key: "syncTypeIndex", key: "syncTypeIndex",
value: syncType.index,); value: syncType.index,
);
_syncType = syncType; _syncType = syncType;
notifyListeners(); notifyListeners();
} }
@ -186,7 +201,9 @@ class Prefs extends ChangeNotifier {
Future<SyncingType> _getSyncType() async { Future<SyncingType> _getSyncType() async {
final int index = await DB.instance.get<dynamic>( final int index = await DB.instance.get<dynamic>(
boxName: DB.boxNamePrefs, key: "syncTypeIndex",) as int? ?? boxName: DB.boxNamePrefs,
key: "syncTypeIndex",
) as int? ??
SyncingType.allWalletsOnStartup.index; SyncingType.allWalletsOnStartup.index;
return SyncingType.values[index]; return SyncingType.values[index];
} }
@ -200,7 +217,10 @@ class Prefs extends ChangeNotifier {
set wifiOnly(bool wifiOnly) { set wifiOnly(bool wifiOnly) {
if (_wifiOnly != wifiOnly) { if (_wifiOnly != wifiOnly) {
DB.instance.put<dynamic>( DB.instance.put<dynamic>(
boxName: DB.boxNamePrefs, key: "wifiOnly", value: wifiOnly,); boxName: DB.boxNamePrefs,
key: "wifiOnly",
value: wifiOnly,
);
_wifiOnly = wifiOnly; _wifiOnly = wifiOnly;
notifyListeners(); notifyListeners();
} }
@ -223,7 +243,8 @@ class Prefs extends ChangeNotifier {
DB.instance.put<dynamic>( DB.instance.put<dynamic>(
boxName: DB.boxNamePrefs, boxName: DB.boxNamePrefs,
key: "showFavoriteWallets", key: "showFavoriteWallets",
value: showFavoriteWallets,); value: showFavoriteWallets,
);
_showFavoriteWallets = showFavoriteWallets; _showFavoriteWallets = showFavoriteWallets;
notifyListeners(); notifyListeners();
} }
@ -231,7 +252,9 @@ class Prefs extends ChangeNotifier {
Future<bool> _getShowFavoriteWallets() async { Future<bool> _getShowFavoriteWallets() async {
return await DB.instance.get<dynamic>( return await DB.instance.get<dynamic>(
boxName: DB.boxNamePrefs, key: "showFavoriteWallets",) as bool? ?? boxName: DB.boxNamePrefs,
key: "showFavoriteWallets",
) as bool? ??
true; true;
} }
@ -244,7 +267,10 @@ class Prefs extends ChangeNotifier {
set language(String newLanguage) { set language(String newLanguage) {
if (_language != newLanguage) { if (_language != newLanguage) {
DB.instance.put<dynamic>( DB.instance.put<dynamic>(
boxName: DB.boxNamePrefs, key: "language", value: newLanguage,); boxName: DB.boxNamePrefs,
key: "language",
value: newLanguage,
);
_language = newLanguage; _language = newLanguage;
notifyListeners(); notifyListeners();
} }
@ -252,7 +278,9 @@ class Prefs extends ChangeNotifier {
Future<String> _getPreferredLanguage() async { Future<String> _getPreferredLanguage() async {
return await DB.instance.get<dynamic>( return await DB.instance.get<dynamic>(
boxName: DB.boxNamePrefs, key: "language",) as String? ?? boxName: DB.boxNamePrefs,
key: "language",
) as String? ??
Language.englishUS.description; Language.englishUS.description;
} }
@ -265,7 +293,10 @@ class Prefs extends ChangeNotifier {
set currency(String newCurrency) { set currency(String newCurrency) {
if (currency != newCurrency) { if (currency != newCurrency) {
DB.instance.put<dynamic>( DB.instance.put<dynamic>(
boxName: DB.boxNamePrefs, key: "currency", value: newCurrency,); boxName: DB.boxNamePrefs,
key: "currency",
value: newCurrency,
);
_currency = newCurrency; _currency = newCurrency;
notifyListeners(); notifyListeners();
} }
@ -273,7 +304,9 @@ class Prefs extends ChangeNotifier {
Future<String> _getPreferredCurrency() async { Future<String> _getPreferredCurrency() async {
return await DB.instance.get<dynamic>( return await DB.instance.get<dynamic>(
boxName: DB.boxNamePrefs, key: "currency",) as String? ?? boxName: DB.boxNamePrefs,
key: "currency",
) as String? ??
"USD"; "USD";
} }
@ -327,7 +360,10 @@ class Prefs extends ChangeNotifier {
set randomizePIN(bool randomizePIN) { set randomizePIN(bool randomizePIN) {
if (_randomizePIN != randomizePIN) { if (_randomizePIN != randomizePIN) {
DB.instance.put<dynamic>( DB.instance.put<dynamic>(
boxName: DB.boxNamePrefs, key: "randomizePIN", value: randomizePIN,); boxName: DB.boxNamePrefs,
key: "randomizePIN",
value: randomizePIN,
);
_randomizePIN = randomizePIN; _randomizePIN = randomizePIN;
notifyListeners(); notifyListeners();
} }
@ -335,7 +371,9 @@ class Prefs extends ChangeNotifier {
Future<bool> _getRandomizePIN() async { Future<bool> _getRandomizePIN() async {
return await DB.instance.get<dynamic>( return await DB.instance.get<dynamic>(
boxName: DB.boxNamePrefs, key: "randomizePIN",) as bool? ?? boxName: DB.boxNamePrefs,
key: "randomizePIN",
) as bool? ??
false; false;
} }
@ -348,7 +386,10 @@ class Prefs extends ChangeNotifier {
set useBiometrics(bool useBiometrics) { set useBiometrics(bool useBiometrics) {
if (_useBiometrics != useBiometrics) { if (_useBiometrics != useBiometrics) {
DB.instance.put<dynamic>( DB.instance.put<dynamic>(
boxName: DB.boxNamePrefs, key: "useBiometrics", value: useBiometrics,); boxName: DB.boxNamePrefs,
key: "useBiometrics",
value: useBiometrics,
);
_useBiometrics = useBiometrics; _useBiometrics = useBiometrics;
notifyListeners(); notifyListeners();
} }
@ -356,7 +397,9 @@ class Prefs extends ChangeNotifier {
Future<bool> _getUseBiometrics() async { Future<bool> _getUseBiometrics() async {
return await DB.instance.get<dynamic>( return await DB.instance.get<dynamic>(
boxName: DB.boxNamePrefs, key: "useBiometrics",) as bool? ?? boxName: DB.boxNamePrefs,
key: "useBiometrics",
) as bool? ??
false; false;
} }
@ -390,7 +433,10 @@ class Prefs extends ChangeNotifier {
set familiarity(int familiarity) { set familiarity(int familiarity) {
if (_familiarity != familiarity) { if (_familiarity != familiarity) {
DB.instance.put<dynamic>( DB.instance.put<dynamic>(
boxName: DB.boxNamePrefs, key: "familiarity", value: familiarity,); boxName: DB.boxNamePrefs,
key: "familiarity",
value: familiarity,
);
_familiarity = familiarity; _familiarity = familiarity;
notifyListeners(); notifyListeners();
} }
@ -398,7 +444,9 @@ class Prefs extends ChangeNotifier {
Future<int> _getHasFamiliarity() async { Future<int> _getHasFamiliarity() async {
return await DB.instance.get<dynamic>( return await DB.instance.get<dynamic>(
boxName: DB.boxNamePrefs, key: "familiarity",) as int? ?? boxName: DB.boxNamePrefs,
key: "familiarity",
) as int? ??
0; 0;
} }
@ -439,7 +487,8 @@ class Prefs extends ChangeNotifier {
DB.instance.put<dynamic>( DB.instance.put<dynamic>(
boxName: DB.boxNamePrefs, boxName: DB.boxNamePrefs,
key: "showTestNetCoins", key: "showTestNetCoins",
value: showTestNetCoins,); value: showTestNetCoins,
);
_showTestNetCoins = showTestNetCoins; _showTestNetCoins = showTestNetCoins;
notifyListeners(); notifyListeners();
} }
@ -447,7 +496,9 @@ class Prefs extends ChangeNotifier {
Future<bool> _getShowTestNetCoins() async { Future<bool> _getShowTestNetCoins() async {
return await DB.instance.get<dynamic>( return await DB.instance.get<dynamic>(
boxName: DB.boxNamePrefs, key: "showTestNetCoins",) as bool? ?? boxName: DB.boxNamePrefs,
key: "showTestNetCoins",
) as bool? ??
false; false;
} }
@ -463,7 +514,8 @@ class Prefs extends ChangeNotifier {
.put<dynamic>( .put<dynamic>(
boxName: DB.boxNamePrefs, boxName: DB.boxNamePrefs,
key: "isAutoBackupEnabled", key: "isAutoBackupEnabled",
value: isAutoBackupEnabled,) value: isAutoBackupEnabled,
)
.then((_) { .then((_) {
_isAutoBackupEnabled = isAutoBackupEnabled; _isAutoBackupEnabled = isAutoBackupEnabled;
notifyListeners(); notifyListeners();
@ -473,7 +525,9 @@ class Prefs extends ChangeNotifier {
Future<bool> _getIsAutoBackupEnabled() async { Future<bool> _getIsAutoBackupEnabled() async {
return await DB.instance.get<dynamic>( return await DB.instance.get<dynamic>(
boxName: DB.boxNamePrefs, key: "isAutoBackupEnabled",) as bool? ?? boxName: DB.boxNamePrefs,
key: "isAutoBackupEnabled",
) as bool? ??
false; false;
} }
@ -488,7 +542,8 @@ class Prefs extends ChangeNotifier {
DB.instance.put<dynamic>( DB.instance.put<dynamic>(
boxName: DB.boxNamePrefs, boxName: DB.boxNamePrefs,
key: "autoBackupLocation", key: "autoBackupLocation",
value: autoBackupLocation,); value: autoBackupLocation,
);
_autoBackupLocation = autoBackupLocation; _autoBackupLocation = autoBackupLocation;
notifyListeners(); notifyListeners();
} }
@ -496,7 +551,9 @@ class Prefs extends ChangeNotifier {
Future<String?> _getAutoBackupLocation() async { Future<String?> _getAutoBackupLocation() async {
return await DB.instance.get<dynamic>( return await DB.instance.get<dynamic>(
boxName: DB.boxNamePrefs, key: "autoBackupLocation",) as String?; boxName: DB.boxNamePrefs,
key: "autoBackupLocation",
) as String?;
} }
// auto backup frequency type // auto backup frequency type
@ -513,19 +570,22 @@ class Prefs extends ChangeNotifier {
DB.instance.put<dynamic>( DB.instance.put<dynamic>(
boxName: DB.boxNamePrefs, boxName: DB.boxNamePrefs,
key: "backupFrequencyType", key: "backupFrequencyType",
value: "10Min",); value: "10Min",
);
break; break;
case BackupFrequencyType.everyAppStart: case BackupFrequencyType.everyAppStart:
DB.instance.put<dynamic>( DB.instance.put<dynamic>(
boxName: DB.boxNamePrefs, boxName: DB.boxNamePrefs,
key: "backupFrequencyType", key: "backupFrequencyType",
value: "onStart",); value: "onStart",
);
break; break;
case BackupFrequencyType.afterClosingAWallet: case BackupFrequencyType.afterClosingAWallet:
DB.instance.put<dynamic>( DB.instance.put<dynamic>(
boxName: DB.boxNamePrefs, boxName: DB.boxNamePrefs,
key: "backupFrequencyType", key: "backupFrequencyType",
value: "onWalletClose",); value: "onWalletClose",
);
break; break;
} }
_backupFrequencyType = backupFrequencyType; _backupFrequencyType = backupFrequencyType;
@ -535,7 +595,9 @@ class Prefs extends ChangeNotifier {
Future<BackupFrequencyType> _getBackupFrequencyType() async { Future<BackupFrequencyType> _getBackupFrequencyType() async {
String? rate = await DB.instance.get<dynamic>( String? rate = await DB.instance.get<dynamic>(
boxName: DB.boxNamePrefs, key: "backupFrequencyType",) as String?; boxName: DB.boxNamePrefs,
key: "backupFrequencyType",
) as String?;
rate ??= "10Min"; rate ??= "10Min";
switch (rate) { switch (rate) {
case "10Min": case "10Min":
@ -560,7 +622,8 @@ class Prefs extends ChangeNotifier {
DB.instance.put<dynamic>( DB.instance.put<dynamic>(
boxName: DB.boxNamePrefs, boxName: DB.boxNamePrefs,
key: "lastAutoBackup", key: "lastAutoBackup",
value: lastAutoBackup,); value: lastAutoBackup,
);
_lastAutoBackup = lastAutoBackup; _lastAutoBackup = lastAutoBackup;
notifyListeners(); notifyListeners();
} }
@ -568,7 +631,9 @@ class Prefs extends ChangeNotifier {
Future<DateTime?> _getLastAutoBackup() async { Future<DateTime?> _getLastAutoBackup() async {
return await DB.instance.get<dynamic>( return await DB.instance.get<dynamic>(
boxName: DB.boxNamePrefs, key: "autoBackupFileUri",) as DateTime?; boxName: DB.boxNamePrefs,
key: "autoBackupFileUri",
) as DateTime?;
} }
// auto backup // auto backup
@ -583,7 +648,8 @@ class Prefs extends ChangeNotifier {
.put<dynamic>( .put<dynamic>(
boxName: DB.boxNamePrefs, boxName: DB.boxNamePrefs,
key: "hideBlockExplorerWarning", key: "hideBlockExplorerWarning",
value: hideBlockExplorerWarning,) value: hideBlockExplorerWarning,
)
.then((_) { .then((_) {
_hideBlockExplorerWarning = hideBlockExplorerWarning; _hideBlockExplorerWarning = hideBlockExplorerWarning;
notifyListeners(); notifyListeners();
@ -594,7 +660,8 @@ class Prefs extends ChangeNotifier {
Future<bool> _getHideBlockExplorerWarning() async { Future<bool> _getHideBlockExplorerWarning() async {
return await DB.instance.get<dynamic>( return await DB.instance.get<dynamic>(
boxName: DB.boxNamePrefs, boxName: DB.boxNamePrefs,
key: "hideBlockExplorerWarning",) as bool? ?? key: "hideBlockExplorerWarning",
) as bool? ??
false; false;
} }
@ -610,7 +677,8 @@ class Prefs extends ChangeNotifier {
.put<dynamic>( .put<dynamic>(
boxName: DB.boxNamePrefs, boxName: DB.boxNamePrefs,
key: "gotoWalletOnStartup", key: "gotoWalletOnStartup",
value: gotoWalletOnStartup,) value: gotoWalletOnStartup,
)
.then((_) { .then((_) {
_gotoWalletOnStartup = gotoWalletOnStartup; _gotoWalletOnStartup = gotoWalletOnStartup;
notifyListeners(); notifyListeners();
@ -620,7 +688,9 @@ class Prefs extends ChangeNotifier {
Future<bool> _getGotoWalletOnStartup() async { Future<bool> _getGotoWalletOnStartup() async {
return await DB.instance.get<dynamic>( return await DB.instance.get<dynamic>(
boxName: DB.boxNamePrefs, key: "gotoWalletOnStartup",) as bool? ?? boxName: DB.boxNamePrefs,
key: "gotoWalletOnStartup",
) as bool? ??
false; false;
} }
@ -635,7 +705,8 @@ class Prefs extends ChangeNotifier {
DB.instance.put<dynamic>( DB.instance.put<dynamic>(
boxName: DB.boxNamePrefs, boxName: DB.boxNamePrefs,
key: "startupWalletId", key: "startupWalletId",
value: startupWalletId,); value: startupWalletId,
);
_startupWalletId = startupWalletId; _startupWalletId = startupWalletId;
notifyListeners(); notifyListeners();
} }
@ -643,7 +714,9 @@ class Prefs extends ChangeNotifier {
Future<String?> _getStartupWalletId() async { Future<String?> _getStartupWalletId() async {
return await DB.instance.get<dynamic>( return await DB.instance.get<dynamic>(
boxName: DB.boxNamePrefs, key: "startupWalletId",) as String?; boxName: DB.boxNamePrefs,
key: "startupWalletId",
) as String?;
} }
// incognito mode off by default // incognito mode off by default
@ -658,7 +731,8 @@ class Prefs extends ChangeNotifier {
.put<dynamic>( .put<dynamic>(
boxName: DB.boxNamePrefs, boxName: DB.boxNamePrefs,
key: "externalCalls", key: "externalCalls",
value: externalCalls,) value: externalCalls,
)
.then((_) { .then((_) {
_externalCalls = externalCalls; _externalCalls = externalCalls;
notifyListeners(); notifyListeners();
@ -668,7 +742,9 @@ class Prefs extends ChangeNotifier {
Future<bool> _getHasExternalCalls() async { Future<bool> _getHasExternalCalls() async {
return await DB.instance.get<dynamic>( return await DB.instance.get<dynamic>(
boxName: DB.boxNamePrefs, key: "externalCalls",) as bool? ?? boxName: DB.boxNamePrefs,
key: "externalCalls",
) as bool? ??
true; true;
} }
@ -718,7 +794,10 @@ class Prefs extends ChangeNotifier {
Future<void> saveSignupEpoch(int signupEpoch) async { Future<void> saveSignupEpoch(int signupEpoch) async {
_signupEpoch = signupEpoch; _signupEpoch = signupEpoch;
await DB.instance.put<dynamic>( await DB.instance.put<dynamic>(
boxName: DB.boxNamePrefs, key: "signupEpoch", value: _signupEpoch,); boxName: DB.boxNamePrefs,
key: "signupEpoch",
value: _signupEpoch,
);
// notifyListeners(); // notifyListeners();
} }
@ -733,7 +812,8 @@ class Prefs extends ChangeNotifier {
DB.instance.put<dynamic>( DB.instance.put<dynamic>(
boxName: DB.boxNamePrefs, boxName: DB.boxNamePrefs,
key: "enableCoinControl", key: "enableCoinControl",
value: enableCoinControl,); value: enableCoinControl,
);
_enableCoinControl = enableCoinControl; _enableCoinControl = enableCoinControl;
notifyListeners(); notifyListeners();
} }
@ -741,7 +821,9 @@ class Prefs extends ChangeNotifier {
Future<bool> _getEnableCoinControl() async { Future<bool> _getEnableCoinControl() async {
return await DB.instance.get<dynamic>( return await DB.instance.get<dynamic>(
boxName: DB.boxNamePrefs, key: "enableCoinControl",) as bool? ?? boxName: DB.boxNamePrefs,
key: "enableCoinControl",
) as bool? ??
false; false;
} }
@ -756,7 +838,8 @@ class Prefs extends ChangeNotifier {
DB.instance.put<dynamic>( DB.instance.put<dynamic>(
boxName: DB.boxNamePrefs, boxName: DB.boxNamePrefs,
key: "enableSystemBrightness", key: "enableSystemBrightness",
value: enableSystemBrightness,); value: enableSystemBrightness,
);
_enableSystemBrightness = enableSystemBrightness; _enableSystemBrightness = enableSystemBrightness;
notifyListeners(); notifyListeners();
} }
@ -764,7 +847,9 @@ class Prefs extends ChangeNotifier {
Future<bool> _getEnableSystemBrightness() async { Future<bool> _getEnableSystemBrightness() async {
return await DB.instance.get<dynamic>( return await DB.instance.get<dynamic>(
boxName: DB.boxNamePrefs, key: "enableSystemBrightness",) as bool? ?? boxName: DB.boxNamePrefs,
key: "enableSystemBrightness",
) as bool? ??
false; false;
} }
@ -853,8 +938,10 @@ class Prefs extends ChangeNotifier {
AmountUnit amountUnit(CryptoCurrency coin) => AmountUnit amountUnit(CryptoCurrency coin) =>
_amountUnits[coin] ?? AmountUnit.normal; _amountUnits[coin] ?? AmountUnit.normal;
void updateAmountUnit( void updateAmountUnit({
{required CryptoCurrency coin, required AmountUnit amountUnit,}) { required CryptoCurrency coin,
required AmountUnit amountUnit,
}) {
if (this.amountUnit(coin) != amountUnit) { if (this.amountUnit(coin) != amountUnit) {
DB.instance.put<dynamic>( DB.instance.put<dynamic>(
boxName: DB.boxNamePrefs, boxName: DB.boxNamePrefs,
@ -867,7 +954,7 @@ class Prefs extends ChangeNotifier {
} }
Future<void> _setAmountUnits() async { Future<void> _setAmountUnits() async {
for (final coin in Coins.enabled) { for (final coin in AppConfig.coins) {
final unitIndex = await DB.instance.get<dynamic>( final unitIndex = await DB.instance.get<dynamic>(
boxName: DB.boxNamePrefs, boxName: DB.boxNamePrefs,
key: "amountUnitFor${coin.identifier}", key: "amountUnitFor${coin.identifier}",
@ -900,7 +987,7 @@ class Prefs extends ChangeNotifier {
} }
Future<void> _setMaxDecimals() async { Future<void> _setMaxDecimals() async {
for (final coin in Coins.enabled) { for (final coin in AppConfig.coins) {
final decimals = await DB.instance.get<dynamic>( final decimals = await DB.instance.get<dynamic>(
boxName: DB.boxNamePrefs, boxName: DB.boxNamePrefs,
key: "maxDecimalsFor${coin.identifier}", key: "maxDecimalsFor${coin.identifier}",

View file

@ -1,9 +1,9 @@
import 'dart:convert'; import 'dart:convert';
import 'package:isar/isar.dart'; import 'package:isar/isar.dart';
import 'package:stackwallet/app_config.dart';
import 'package:stackwallet/models/balance.dart'; import 'package:stackwallet/models/balance.dart';
import 'package:stackwallet/models/isar/models/blockchain_data/address.dart'; import 'package:stackwallet/models/isar/models/blockchain_data/address.dart';
import 'package:stackwallet/supported_coins.dart';
import 'package:stackwallet/wallets/crypto_currency/crypto_currency.dart'; import 'package:stackwallet/wallets/crypto_currency/crypto_currency.dart';
import 'package:stackwallet/wallets/isar/isar_id_interface.dart'; import 'package:stackwallet/wallets/isar/isar_id_interface.dart';
import 'package:stackwallet/wallets/isar/models/wallet_info_meta.dart'; import 'package:stackwallet/wallets/isar/models/wallet_info_meta.dart';
@ -96,7 +96,7 @@ class WalletInfo implements IsarId {
} }
@ignore @ignore
CryptoCurrency get coin => Coins.getCryptoCurrencyFor(coinName); CryptoCurrency get coin => AppConfig.getCryptoCurrencyFor(coinName);
@ignore @ignore
Balance get cachedBalance { Balance get cachedBalance {
@ -407,7 +407,7 @@ class WalletInfo implements IsarId {
this.cachedBalanceTertiaryString, this.cachedBalanceTertiaryString,
this.otherDataJsonString, this.otherDataJsonString,
}) : assert( }) : assert(
Coins.enabled.map((e) => e.identifier).contains(coinName), AppConfig.coins.map((e) => e.identifier).contains(coinName),
); );
WalletInfo copyWith({ WalletInfo copyWith({
@ -464,7 +464,7 @@ class WalletInfo implements IsarId {
Map<String, dynamic> jsonObject, Map<String, dynamic> jsonObject,
AddressType mainAddressType, AddressType mainAddressType,
) { ) {
final coin = Coins.getCryptoCurrencyFor( final coin = AppConfig.getCryptoCurrencyFor(
jsonObject["coin"] as String, jsonObject["coin"] as String,
); );
return WalletInfo( return WalletInfo(

View file

@ -4,7 +4,7 @@ import 'package:flutter/foundation.dart';
import 'package:flutter_riverpod/flutter_riverpod.dart'; import 'package:flutter_riverpod/flutter_riverpod.dart';
import 'package:isar/isar.dart'; import 'package:isar/isar.dart';
import 'package:stackwallet/providers/db/main_db_provider.dart'; import 'package:stackwallet/providers/db/main_db_provider.dart';
import 'package:stackwallet/supported_coins.dart'; import 'package:stackwallet/app_config.dart';
import 'package:stackwallet/wallets/crypto_currency/crypto_currency.dart'; import 'package:stackwallet/wallets/crypto_currency/crypto_currency.dart';
import 'package:stackwallet/wallets/isar/models/wallet_info.dart'; import 'package:stackwallet/wallets/isar/models/wallet_info.dart';
@ -27,7 +27,7 @@ final pAllWalletsInfoByCoin = Provider((ref) {
} }
final List<({CryptoCurrency coin, List<WalletInfo> wallets})> results = []; final List<({CryptoCurrency coin, List<WalletInfo> wallets})> results = [];
for (final coin in Coins.enabled) { for (final coin in AppConfig.coins) {
if (map[coin] != null) { if (map[coin] != null) {
results.add(map[coin]!); results.add(map[coin]!);
} }
@ -46,7 +46,7 @@ final _pAllWalletsInfo = ChangeNotifierProvider((ref) {
.where() .where()
.filter() .filter()
.anyOf<String, CryptoCurrency>( .anyOf<String, CryptoCurrency>(
Coins.enabled.map((e) => e.identifier), AppConfig.coins.map((e) => e.identifier),
(q, element) => q.coinNameMatches(element), (q, element) => q.coinNameMatches(element),
) )
.findAllSync(), .findAllSync(),
@ -71,7 +71,7 @@ class _WalletInfoWatcher extends ChangeNotifier {
.where() .where()
.filter() .filter()
.anyOf<String, CryptoCurrency>( .anyOf<String, CryptoCurrency>(
Coins.enabled.map((e) => e.identifier), AppConfig.coins.map((e) => e.identifier),
(q, element) => q.coinNameMatches(element), (q, element) => q.coinNameMatches(element),
) )
.findAll() .findAll()

View file

@ -4,7 +4,7 @@ import 'package:flutter/foundation.dart';
import 'package:flutter_riverpod/flutter_riverpod.dart'; import 'package:flutter_riverpod/flutter_riverpod.dart';
import 'package:isar/isar.dart'; import 'package:isar/isar.dart';
import 'package:stackwallet/providers/db/main_db_provider.dart'; import 'package:stackwallet/providers/db/main_db_provider.dart';
import 'package:stackwallet/supported_coins.dart'; import 'package:stackwallet/app_config.dart';
import 'package:stackwallet/wallets/crypto_currency/crypto_currency.dart'; import 'package:stackwallet/wallets/crypto_currency/crypto_currency.dart';
import 'package:stackwallet/wallets/isar/models/wallet_info.dart'; import 'package:stackwallet/wallets/isar/models/wallet_info.dart';
@ -20,7 +20,7 @@ class _Watcher extends ChangeNotifier {
_streamSubscription = isar.walletInfo _streamSubscription = isar.walletInfo
.filter() .filter()
.anyOf<String, CryptoCurrency>( .anyOf<String, CryptoCurrency>(
Coins.enabled.map((e) => e.identifier), AppConfig.coins.map((e) => e.identifier),
(q, element) => q.coinNameMatches(element), (q, element) => q.coinNameMatches(element),
) )
.isFavouriteEqualTo(isFavourite) .isFavouriteEqualTo(isFavourite)
@ -47,7 +47,7 @@ final _wiProvider = ChangeNotifierProvider.family<_Watcher, bool>(
isar.walletInfo isar.walletInfo
.filter() .filter()
.anyOf<String, CryptoCurrency>( .anyOf<String, CryptoCurrency>(
Coins.enabled.map((e) => e.identifier), AppConfig.coins.map((e) => e.identifier),
(q, element) => q.coinNameMatches(element), (q, element) => q.coinNameMatches(element),
) )
.isFavouriteEqualTo(isFavourite) .isFavouriteEqualTo(isFavourite)

View file

@ -16,7 +16,7 @@ import 'package:flutter_svg/svg.dart';
import 'package:stackwallet/models/isar/models/contact_entry.dart'; import 'package:stackwallet/models/isar/models/contact_entry.dart';
import 'package:stackwallet/pages/address_book_views/subviews/contact_popup.dart'; import 'package:stackwallet/pages/address_book_views/subviews/contact_popup.dart';
import 'package:stackwallet/providers/global/address_book_service_provider.dart'; import 'package:stackwallet/providers/global/address_book_service_provider.dart';
import 'package:stackwallet/supported_coins.dart'; import 'package:stackwallet/app_config.dart';
import 'package:stackwallet/themes/stack_colors.dart'; import 'package:stackwallet/themes/stack_colors.dart';
import 'package:stackwallet/themes/theme_providers.dart'; import 'package:stackwallet/themes/theme_providers.dart';
import 'package:stackwallet/utilities/assets.dart'; import 'package:stackwallet/utilities/assets.dart';
@ -72,7 +72,7 @@ class _AddressBookCardState extends ConsumerState<AddressBookCard> {
final List<CryptoCurrency> coins = []; final List<CryptoCurrency> coins = [];
for (final coin in Coins.enabled) { for (final coin in AppConfig.coins) {
if (contact.addresses.where((e) => e.coin == coin).isNotEmpty) { if (contact.addresses.where((e) => e.coin == coin).isNotEmpty) {
coins.add(coin); coins.add(coin);
} }

View file

@ -14,7 +14,7 @@ import 'package:flutter/material.dart';
import 'package:flutter_riverpod/flutter_riverpod.dart'; import 'package:flutter_riverpod/flutter_riverpod.dart';
import 'package:flutter_svg/svg.dart'; import 'package:flutter_svg/svg.dart';
import 'package:stackwallet/providers/providers.dart'; import 'package:stackwallet/providers/providers.dart';
import 'package:stackwallet/supported_coins.dart'; import 'package:stackwallet/app_config.dart';
import 'package:stackwallet/themes/coin_icon_provider.dart'; import 'package:stackwallet/themes/coin_icon_provider.dart';
import 'package:stackwallet/themes/stack_colors.dart'; import 'package:stackwallet/themes/stack_colors.dart';
import 'package:stackwallet/utilities/constants.dart'; import 'package:stackwallet/utilities/constants.dart';
@ -51,7 +51,7 @@ class ChooseCoinView extends ConsumerStatefulWidget {
} }
class _ChooseCoinViewState extends ConsumerState<ChooseCoinView> { class _ChooseCoinViewState extends ConsumerState<ChooseCoinView> {
List<CryptoCurrency> _coins = [...Coins.enabled]; List<CryptoCurrency> _coins = [...AppConfig.coins];
@override @override
void initState() { void initState() {

View file

@ -1,5 +1,5 @@
name: stackwallet name: PLACEHOLDER
description: Stack Wallet description: PLACEHOLDER
# The following defines the version and build number for your application. # The following defines the version and build number for your application.
# A version number is three numbers separated by dots, like 1.2.43 # A version number is three numbers separated by dots, like 1.2.43

View file

@ -1,25 +0,0 @@
#!/bin/bash
set -x -e
# Configure files for Duo.
ORIGINAL_PUBSPEC_NAME="stackwallet"
NEW_PUBSPEC_NAME="stackduo"
export ORIGINAL_NAME="Stack Wallet"
export ORIGINAL_APP_ID="com.cypherstack.stackwallet"
export NEW_NAME="Stack Duo"
export NEW_APP_ID="com.cypherstack.stackduo"
# String replacements.
if [[ "$(uname)" == 'Darwin' ]]; then
# macos specific sed
sed -i '' 's/Wallet/Duo/g' ../../lib/app_config.dart
sed -i '' "s/${ORIGINAL_NAME}/${NEW_NAME}/g" ../../pubspec.yaml
sed -i '' "s/${ORIGINAL_PUBSPEC_NAME}/${NEW_PUBSPEC_NAME}/g" ../../pubspec.yaml
else
sed -i 's/Wallet/Duo/g' ../../lib/app_config.dart
sed -i "s/${ORIGINAL_NAME}/${NEW_NAME}/g" ../../pubspec.yaml
sed -i "s/${ORIGINAL_PUBSPEC_NAME}/${NEW_PUBSPEC_NAME}/g" ../../pubspec.yaml
fi

View file

@ -0,0 +1,44 @@
#!/bin/bash
set -x -e
# Configure files for Duo.
export ORIGINAL_NAME="Stack Wallet"
export ORIGINAL_APP_ID="com.cypherstack.stackwallet"
export NEW_NAME="Stack Duo"
export NEW_APP_ID="com.cypherstack.stackduo"
PUBSPEC_FILE="${APP_PROJECT_ROOT_DIR}/pubspec.yaml"
PUBSPEC_NAME="stackduo"
PUBSPEC_DESC="Stack Duo"
# String replacements.
if [[ "$(uname)" == 'Darwin' ]]; then
# macos specific sed
sed -i '' "s/name: PLACEHOLDER/name: ${PUBSPEC_NAME}/g" "${PUBSPEC_FILE}"
sed -i '' "s/description: PLACEHOLDER/description: ${PUBSPEC_DESC}/g" "${PUBSPEC_FILE}"
else
sed -i "s/name: PLACEHOLDER/name: ${PUBSPEC_NAME}/g" "${PUBSPEC_FILE}"
sed -i "s/description: PLACEHOLDER/description: ${PUBSPEC_DESC}/g" "${PUBSPEC_FILE}"
fi
APP_CONFIG_DART_FILE="${APP_PROJECT_ROOT_DIR}/lib/app_config.g.dart"
rm -f "$APP_CONFIG_DART_FILE"
cat << EOF > "$APP_CONFIG_DART_FILE"
// GENERATED CODE - DO NOT MODIFY BY HAND
part of 'app_config.dart';
const _prefix = "Stack";
const _separator = " ";
const _suffix = "Duo";
final List<CryptoCurrency> _supportedCoins = List.unmodifiable([
Bitcoin(CryptoCurrencyNetwork.main),
Monero(CryptoCurrencyNetwork.main),
Bitcoin(CryptoCurrencyNetwork.test),
]);
EOF

View file

@ -0,0 +1,68 @@
#!/bin/bash
set -x -e
# Configure files for Stack Wallet.
# currently unused
#export APP_NAME="Stack Wallet"
#export APP_ID="com.cypherstack.stackwallet"
PUBSPEC_FILE="${APP_PROJECT_ROOT_DIR}/pubspec.yaml"
PUBSPEC_NAME="stackwallet"
PUBSPEC_DESC="Stack Wallet"
# String replacements.
if [[ "$(uname)" == 'Darwin' ]]; then
# macos specific sed
sed -i '' "s/name: PLACEHOLDER/name: ${PUBSPEC_NAME}/g" "${PUBSPEC_FILE}"
sed -i '' "s/description: PLACEHOLDER/description: ${PUBSPEC_DESC}/g" "${PUBSPEC_FILE}"
else
sed -i "s/name: PLACEHOLDER/name: ${PUBSPEC_NAME}/g" "${PUBSPEC_FILE}"
sed -i "s/description: PLACEHOLDER/description: ${PUBSPEC_DESC}/g" "${PUBSPEC_FILE}"
fi
APP_CONFIG_DART_FILE="${APP_PROJECT_ROOT_DIR}/lib/app_config.g.dart"
rm -f "$APP_CONFIG_DART_FILE"
cat << EOF > "$APP_CONFIG_DART_FILE"
// GENERATED CODE - DO NOT MODIFY BY HAND
part of 'app_config.dart';
const _prefix = "Stack";
const _separator = " ";
const _suffix = "Wallet";
final List<CryptoCurrency> _supportedCoins = List.unmodifiable([
Bitcoin(CryptoCurrencyNetwork.main),
BitcoinFrost(CryptoCurrencyNetwork.main),
Litecoin(CryptoCurrencyNetwork.main),
Bitcoincash(CryptoCurrencyNetwork.main),
Dogecoin(CryptoCurrencyNetwork.main),
Epiccash(CryptoCurrencyNetwork.main),
Ecash(CryptoCurrencyNetwork.main),
Ethereum(CryptoCurrencyNetwork.main),
Firo(CryptoCurrencyNetwork.main),
Monero(CryptoCurrencyNetwork.main),
Particl(CryptoCurrencyNetwork.main),
Peercoin(CryptoCurrencyNetwork.main),
Solana(CryptoCurrencyNetwork.main),
Stellar(CryptoCurrencyNetwork.main),
Tezos(CryptoCurrencyNetwork.main),
Wownero(CryptoCurrencyNetwork.main),
Namecoin(CryptoCurrencyNetwork.main),
Nano(CryptoCurrencyNetwork.main),
Banano(CryptoCurrencyNetwork.main),
Bitcoin(CryptoCurrencyNetwork.test),
BitcoinFrost(CryptoCurrencyNetwork.test),
Litecoin(CryptoCurrencyNetwork.test),
Bitcoincash(CryptoCurrencyNetwork.test),
Firo(CryptoCurrencyNetwork.test),
Dogecoin(CryptoCurrencyNetwork.test),
Stellar(CryptoCurrencyNetwork.test),
Peercoin(CryptoCurrencyNetwork.test),
]);
EOF

View file

@ -42,6 +42,8 @@ else
fi fi
if printf '%s\0' "${APP_NAMED_IDS[@]}" | grep -Fxqz -- "${APP_NAMED_ID}"; then if printf '%s\0' "${APP_NAMED_IDS[@]}" | grep -Fxqz -- "${APP_NAMED_ID}"; then
# shellcheck disable=SC1090
source "${APP_PROJECT_ROOT_DIR}/scripts/app_config/configure_${APP_NAMED_ID}.sh"
"${APP_PROJECT_ROOT_DIR}/scripts/app_config/update_version.sh" -v "${APP_VERSION_STRING}" -b "${APP_BUILD_NUMBER}" "${APP_PROJECT_ROOT_DIR}/scripts/app_config/update_version.sh" -v "${APP_VERSION_STRING}" -b "${APP_BUILD_NUMBER}"
"${APP_PROJECT_ROOT_DIR}/scripts/app_config/shared/link_assets.sh" "${APP_NAMED_ID}" "${APP_PROJECT_ROOT_DIR}/scripts/app_config/shared/link_assets.sh" "${APP_NAMED_ID}"
else else
@ -52,7 +54,6 @@ fi
if [[ "$APP_NAMED_ID" = "stack_wallet" ]]; then if [[ "$APP_NAMED_ID" = "stack_wallet" ]]; then
./build_all.sh ./build_all.sh
elif [[ "$APP_NAMED_ID" = "stack_duo" ]]; then elif [[ "$APP_NAMED_ID" = "stack_duo" ]]; then
"${APP_PROJECT_ROOT_DIR}/scripts/app_config/configure_duo.sh"
./build_all_duo.sh ./build_all_duo.sh
else else
echo "Invalid app id: ${APP_NAMED_ID}" echo "Invalid app id: ${APP_NAMED_ID}"

View file

@ -4,7 +4,7 @@ import 'package:hive_test/hive_test.dart';
import 'package:stackwallet/db/hive/db.dart'; import 'package:stackwallet/db/hive/db.dart';
import 'package:stackwallet/models/node_model.dart'; import 'package:stackwallet/models/node_model.dart';
import 'package:stackwallet/services/node_service.dart'; import 'package:stackwallet/services/node_service.dart';
import 'package:stackwallet/supported_coins.dart'; import 'package:stackwallet/app_config.dart';
import 'package:stackwallet/utilities/flutter_secure_storage_interface.dart'; import 'package:stackwallet/utilities/flutter_secure_storage_interface.dart';
import 'package:stackwallet/wallets/crypto_currency/crypto_currency.dart'; import 'package:stackwallet/wallets/crypto_currency/crypto_currency.dart';
@ -112,7 +112,7 @@ void main() {
await service.updateDefaults(); await service.updateDefaults();
expect( expect(
service.nodes.length, service.nodes.length,
Coins.enabled.map((e) => e.defaultNode).length, AppConfig.coins.map((e) => e.defaultNode).length,
); );
expect(fakeStore.interactions, 0); expect(fakeStore.interactions, 0);
}); });
@ -205,7 +205,7 @@ void main() {
final fakeStore = FakeSecureStorage(); final fakeStore = FakeSecureStorage();
final service = NodeService(secureStorageInterface: fakeStore); final service = NodeService(secureStorageInterface: fakeStore);
final nodes = service.nodes; final nodes = service.nodes;
final defaults = Coins.enabled.map((e) => e.defaultNode).toList(); final defaults = AppConfig.coins.map((e) => e.defaultNode).toList();
nodes.sort((a, b) => a.id.compareTo(b.id)); nodes.sort((a, b) => a.id.compareTo(b.id));
defaults.sort((a, b) => a.id.compareTo(b.id)); defaults.sort((a, b) => a.id.compareTo(b.id));
@ -221,7 +221,7 @@ void main() {
await service.add(nodeA, null, true); await service.add(nodeA, null, true);
expect( expect(
service.nodes.length, service.nodes.length,
Coins.enabled.map((e) => e.defaultNode).length + 1, AppConfig.coins.map((e) => e.defaultNode).length + 1,
); );
expect(fakeStore.interactions, 0); expect(fakeStore.interactions, 0);
}); });
@ -232,7 +232,7 @@ void main() {
await service.add(nodeA, "some password", true); await service.add(nodeA, "some password", true);
expect( expect(
service.nodes.length, service.nodes.length,
Coins.enabled.map((e) => e.defaultNode).length + 1, AppConfig.coins.map((e) => e.defaultNode).length + 1,
); );
expect(fakeStore.interactions, 1); expect(fakeStore.interactions, 1);
expect(fakeStore.writes, 1); expect(fakeStore.writes, 1);
@ -290,7 +290,7 @@ void main() {
expect( expect(
service.nodes.length, service.nodes.length,
Coins.enabled.map((e) => e.defaultNode).length + 2, AppConfig.coins.map((e) => e.defaultNode).length + 2,
); );
expect( expect(
service.nodes.where((element) => element.id == nodeB.id).length, service.nodes.where((element) => element.id == nodeB.id).length,