2021-09-06 08:19:13 +00:00
|
|
|
import 'dart:async';
|
2023-03-24 15:26:42 +00:00
|
|
|
import 'package:cake_wallet/anonpay/anonpay_invoice_info.dart';
|
2022-12-13 15:19:31 +00:00
|
|
|
import 'package:cake_wallet/core/auth_service.dart';
|
2024-05-08 20:23:27 +00:00
|
|
|
import 'package:cake_wallet/core/secure_storage.dart';
|
2021-03-24 16:52:30 +00:00
|
|
|
import 'package:cake_wallet/entities/language_service.dart';
|
2021-04-12 18:22:22 +00:00
|
|
|
import 'package:cake_wallet/buy/order.dart';
|
2023-05-25 17:30:21 +00:00
|
|
|
import 'package:cake_wallet/locales/locale.dart';
|
2023-11-03 05:42:18 +00:00
|
|
|
import 'package:cake_wallet/utils/device_info.dart';
|
2023-02-01 15:37:18 +00:00
|
|
|
import 'package:cake_wallet/utils/exception_handler.dart';
|
2024-05-08 00:00:01 +00:00
|
|
|
import 'package:cake_wallet/view_model/link_view_model.dart';
|
2023-08-29 16:11:51 +00:00
|
|
|
import 'package:cw_core/address_info.dart';
|
2023-06-13 23:04:52 +00:00
|
|
|
import 'package:cake_wallet/utils/responsive_layout_util.dart';
|
2023-08-15 00:47:25 +00:00
|
|
|
import 'package:cw_core/hive_type_ids.dart';
|
2021-09-06 08:19:13 +00:00
|
|
|
import 'package:flutter/foundation.dart';
|
2020-09-28 15:47:43 +00:00
|
|
|
import 'package:flutter/material.dart';
|
|
|
|
import 'package:flutter/services.dart';
|
|
|
|
import 'package:hive/hive.dart';
|
2020-06-20 07:10:00 +00:00
|
|
|
import 'package:cake_wallet/di.dart';
|
2020-01-04 19:31:52 +00:00
|
|
|
import 'package:path_provider/path_provider.dart';
|
|
|
|
import 'package:shared_preferences/shared_preferences.dart';
|
2020-09-28 15:47:43 +00:00
|
|
|
import 'package:flutter_mobx/flutter_mobx.dart';
|
2021-01-15 17:41:30 +00:00
|
|
|
import 'package:cake_wallet/themes/theme_base.dart';
|
2020-10-19 11:20:24 +00:00
|
|
|
import 'package:cake_wallet/router.dart' as Router;
|
2020-09-28 15:47:43 +00:00
|
|
|
import 'package:cake_wallet/routes.dart';
|
|
|
|
import 'package:cake_wallet/generated/i18n.dart';
|
|
|
|
import 'package:cake_wallet/reactions/bootstrap.dart';
|
|
|
|
import 'package:cake_wallet/store/app_store.dart';
|
|
|
|
import 'package:cake_wallet/store/authentication_store.dart';
|
|
|
|
import 'package:cake_wallet/entities/transaction_description.dart';
|
2020-09-21 11:50:26 +00:00
|
|
|
import 'package:cake_wallet/entities/get_encryption_key.dart';
|
|
|
|
import 'package:cake_wallet/entities/contact.dart';
|
2021-12-24 12:37:24 +00:00
|
|
|
import 'package:cw_core/node.dart';
|
|
|
|
import 'package:cw_core/wallet_info.dart';
|
2020-09-21 11:50:26 +00:00
|
|
|
import 'package:cake_wallet/entities/default_settings_migration.dart';
|
2021-12-24 12:37:24 +00:00
|
|
|
import 'package:cw_core/wallet_type.dart';
|
2020-09-21 11:50:26 +00:00
|
|
|
import 'package:cake_wallet/entities/template.dart';
|
2020-09-28 15:47:43 +00:00
|
|
|
import 'package:cake_wallet/exchange/trade.dart';
|
2020-09-21 11:50:26 +00:00
|
|
|
import 'package:cake_wallet/exchange/exchange_template.dart';
|
2020-09-28 15:47:43 +00:00
|
|
|
import 'package:cake_wallet/src/screens/root/root.dart';
|
2021-12-24 12:37:24 +00:00
|
|
|
import 'package:cw_core/unspent_coins_info.dart';
|
|
|
|
import 'package:cake_wallet/monero/monero.dart';
|
2023-08-15 00:47:25 +00:00
|
|
|
import 'package:cw_core/cake_hive.dart';
|
2024-05-06 19:14:43 +00:00
|
|
|
import 'package:cw_core/window_size.dart';
|
2020-08-20 17:43:54 +00:00
|
|
|
|
2020-09-14 12:08:33 +00:00
|
|
|
final navigatorKey = GlobalKey<NavigatorState>();
|
2021-11-02 09:17:24 +00:00
|
|
|
final rootKey = GlobalKey<RootState>();
|
2024-05-13 20:59:11 +00:00
|
|
|
final RouteObserver<PageRoute<dynamic>> routeObserver = RouteObserver<PageRoute<dynamic>>();
|
2020-09-14 12:08:33 +00:00
|
|
|
|
2021-01-15 17:41:30 +00:00
|
|
|
Future<void> main() async {
|
2024-05-14 01:27:16 +00:00
|
|
|
bool isAppRunning = false;
|
2022-11-23 16:06:09 +00:00
|
|
|
await runZonedGuarded(() async {
|
2020-11-08 20:44:09 +00:00
|
|
|
WidgetsFlutterBinding.ensureInitialized();
|
2020-01-04 19:31:52 +00:00
|
|
|
|
2023-02-01 15:37:18 +00:00
|
|
|
FlutterError.onError = ExceptionHandler.onError;
|
2022-11-25 16:59:47 +00:00
|
|
|
|
|
|
|
/// A callback that is invoked when an unhandled error occurs in the root
|
|
|
|
/// isolate.
|
2022-11-23 21:02:18 +00:00
|
|
|
PlatformDispatcher.instance.onError = (error, stack) {
|
2023-02-01 15:37:18 +00:00
|
|
|
ExceptionHandler.onError(FlutterErrorDetails(exception: error, stack: stack));
|
2023-01-06 17:42:37 +00:00
|
|
|
|
2022-11-23 21:02:18 +00:00
|
|
|
return true;
|
|
|
|
};
|
|
|
|
|
2024-05-06 19:14:43 +00:00
|
|
|
await setDefaultMinimumWindowSize();
|
2024-05-13 20:59:11 +00:00
|
|
|
|
2023-08-15 00:47:25 +00:00
|
|
|
await CakeHive.close();
|
2021-01-15 17:41:30 +00:00
|
|
|
|
2023-08-04 17:55:56 +00:00
|
|
|
await initializeAppConfigs();
|
2021-01-15 17:41:30 +00:00
|
|
|
|
2023-08-04 17:55:56 +00:00
|
|
|
runApp(App());
|
2024-05-14 01:27:16 +00:00
|
|
|
|
|
|
|
isAppRunning = true;
|
2023-08-04 17:55:56 +00:00
|
|
|
}, (error, stackTrace) async {
|
2024-05-14 01:27:16 +00:00
|
|
|
if (!isAppRunning) {
|
|
|
|
runApp(
|
|
|
|
MaterialApp(
|
|
|
|
debugShowCheckedModeBanner: false,
|
|
|
|
home: Scaffold(
|
|
|
|
body: SingleChildScrollView(
|
|
|
|
child: Container(
|
|
|
|
margin: EdgeInsets.only(top: 50, left: 20, right: 20, bottom: 20),
|
|
|
|
child: Column(
|
|
|
|
children: [
|
|
|
|
Text(
|
|
|
|
'Error:\n${error.toString()}',
|
|
|
|
style: TextStyle(fontSize: 22),
|
|
|
|
),
|
|
|
|
Text(
|
|
|
|
'Stack trace:\n${stackTrace.toString()}',
|
|
|
|
style: TextStyle(fontSize: 16),
|
|
|
|
),
|
|
|
|
],
|
|
|
|
),
|
2024-05-13 20:59:11 +00:00
|
|
|
),
|
|
|
|
),
|
|
|
|
),
|
|
|
|
),
|
2024-05-14 01:27:16 +00:00
|
|
|
);
|
|
|
|
}
|
2024-05-13 20:59:11 +00:00
|
|
|
|
2023-08-04 17:55:56 +00:00
|
|
|
ExceptionHandler.onError(FlutterErrorDetails(exception: error, stack: stackTrace));
|
|
|
|
});
|
|
|
|
}
|
2021-01-15 17:41:30 +00:00
|
|
|
|
2023-08-04 17:55:56 +00:00
|
|
|
Future<void> initializeAppConfigs() async {
|
|
|
|
final appDir = await getApplicationDocumentsDirectory();
|
2023-08-15 00:47:25 +00:00
|
|
|
CakeHive.init(appDir.path);
|
2021-01-15 17:41:30 +00:00
|
|
|
|
2023-08-15 00:47:25 +00:00
|
|
|
if (!CakeHive.isAdapterRegistered(Contact.typeId)) {
|
|
|
|
CakeHive.registerAdapter(ContactAdapter());
|
2023-08-04 17:55:56 +00:00
|
|
|
}
|
2021-01-15 17:41:30 +00:00
|
|
|
|
2023-08-15 00:47:25 +00:00
|
|
|
if (!CakeHive.isAdapterRegistered(Node.typeId)) {
|
|
|
|
CakeHive.registerAdapter(NodeAdapter());
|
2023-08-04 17:55:56 +00:00
|
|
|
}
|
2021-01-15 17:41:30 +00:00
|
|
|
|
2023-08-15 00:47:25 +00:00
|
|
|
if (!CakeHive.isAdapterRegistered(TransactionDescription.typeId)) {
|
|
|
|
CakeHive.registerAdapter(TransactionDescriptionAdapter());
|
2023-08-04 17:55:56 +00:00
|
|
|
}
|
2021-01-15 17:41:30 +00:00
|
|
|
|
2023-08-15 00:47:25 +00:00
|
|
|
if (!CakeHive.isAdapterRegistered(Trade.typeId)) {
|
|
|
|
CakeHive.registerAdapter(TradeAdapter());
|
2023-08-04 17:55:56 +00:00
|
|
|
}
|
2021-01-15 17:41:30 +00:00
|
|
|
|
2023-08-29 16:11:51 +00:00
|
|
|
if (!CakeHive.isAdapterRegistered(AddressInfo.typeId)) {
|
|
|
|
CakeHive.registerAdapter(AddressInfoAdapter());
|
|
|
|
}
|
|
|
|
|
2023-08-15 00:47:25 +00:00
|
|
|
if (!CakeHive.isAdapterRegistered(WalletInfo.typeId)) {
|
|
|
|
CakeHive.registerAdapter(WalletInfoAdapter());
|
2023-08-04 17:55:56 +00:00
|
|
|
}
|
2021-01-15 17:41:30 +00:00
|
|
|
|
2023-10-13 11:49:00 +00:00
|
|
|
if (!CakeHive.isAdapterRegistered(DERIVATION_TYPE_TYPE_ID)) {
|
2023-10-05 01:09:07 +00:00
|
|
|
CakeHive.registerAdapter(DerivationTypeAdapter());
|
|
|
|
}
|
2023-10-13 11:49:00 +00:00
|
|
|
|
Bitcoin derivations (#1089)
* - Update and Fix Conflicts with main
* Add Balances for ERC20 tokens
* Fix conflicts with main
* Add erc20 abi json
* Add send erc20 tokens initial function
* add missing getHeightByDate in Haven [skip ci]
* Allow contacts and wallets from the same tag
* Add Shiba Inu icon
* Add send ERC-20 tokens initial flow
* Add missing import in generated file
* Add initial approach for transaction sending for ERC-20 tokens
* Refactor signing/sending transactions
* Add initial flow for transactions subscription
* Refactor signing/sending transactions
* Add home settings icon
* Fix conflicts with main
* Initial flow for home settings
* Add logic flow for adding erc20 tokens
* Fix initial UI
* Finalize UI for Tokens
* Integrate UI with Ethereum flow
* Add "Enable/Disable" feature for ERC20 tokens
* Add initial Erc20 tokens
* Add Sorting and Pin Native Token features
* Fix price sorting
* Sort tokens list as well when Sort criteria changes
* - Improve sorting balances flow
- Add initial add token from search bar flow
* Fix Accounts Popup UI
* Fix Pin native token
* Fix Enabling/Disabling tokens
Fix sorting by fiat once app is opened
Improve token availability mechanism
* Fix deleting token
Fix renaming tokens
* Fix issue with search
* Add more tokens
* - Fix scroll issue
- Add ERC20 tokens placeholder image in picker
* - Separate and organize default erc20 tokens
- Fix scrolling
- Add token placeholder images in picker
- Sort disabled tokens alphabetically
* Change BNB token initial availability [skip ci]
* Fix Conflicts with main
* Fix Conflicts with main
* Add Verse ERC20 token to the initial tokens list
* Add rename wallet to Ethereum
* Integrate EtherScan API for fetching address transactions
Generate Ethereum specific secrets in Ethereum package
* Adjust transactions fiat price for ERC20 tokens
* Free Up GitHub Actions Ubuntu Runner Disk Space
* Free Up GitHub Actions Ubuntu Runner Disk space (trial 2)
* Fix Transaction Fee display
* Save transaction history
* Enhance loading time for erc20 tokens transactions
* Minor Fixes and Enhancements
* Fix sending erc20
fix block explorer issue
* Fix int overflow
* Fix transaction amount conversions
* Minor: `slow` -> `Slow` [skip-ci]
* initial changes
* more base config stuff
* config changes
* successfully builds!
* save
* successfully add nano wallet
* save
* seed generation
* receive screen + node screen working
* tx history working and fiat fixes
* balance working
* derivation updates
* nano-unfinished
* sends working
* remove fees from send screen, send and receive transactions working
* fixes + auto receive incoming txs
* fix for scanning QR codes
* save
* update translations
* fixes
* more fixes
* more strings
* small fix
* fix github actions workflow
* potential fix
* potential fix
* ci/cd fix
* change rep working
* seed generation fixes
* fixes
* save
* change rep screen functional
* save
* banano changes
* fixes, start adding ui for PoW
* pow node changes
* update translations
* fix
* account changing barely working
* save
* disable account generation
* small fix
* save
* UI work
* save
* fixes after merge main
* fixes
* remove monero stuff, work on derivation ui
* lots of fixes + finish up seed derivation
* last minute fixes
* node related fixes
* more fixes
* small fix
* more fixes
* fixes
* pretty big refactor for pow, still some bugs
* finally works!
* get transactions after send
* fix
* merge conflict fixes
* save
* fix pow node showing up twice
* done
* initial changes
* small fix
* more merge fixes
* fixes
* more fixes
* fix
* save
* fix manage pow nodes setting appearing on other wallets
* fix contact bug
* fixes
* fiat fixes
* save
* save
* save
* save
* updates
* cleanup
* restore fix
* fixes
* remove deprecated alert
* fix
* small fix
* remove outdated warning
* electrum restore fixes
* fixes
* fixes
* fix
* derivation fixes
* nano fixes pt.1
* nano fixes pt.2
* bip39 fixes
* pownode refactor
* nodes pages fixes
* observer fix
* ssl fix
* remove old references
* remove unused imports
* code cleanup
* small fix
* small potential fix
* save
* derivation fixes
* deterministic fix
* fix pt.2
* derivation class fixes
* review fixes from nano that also apply here
* formatting
* stuff that should've stayed deleted
* post merge fixes
* remove problematic imports and duplicate changes
* Delete lib/nano/nano.dart
* move wallet restore page proxy code to the view model
* fix dashboard page indicators being the same color
* debatably better refactoring of derivationInfo, migration needed
* additional refactor improvements
* blanket comment some stuff out to narrow down this issue
* refactor fixes
* fix nano exchange
* fix , bug, i.e. replace , with . when making a nano transaction
* fix nano sending, update restore page wording, and other minor fixes
* write migration for existing bitcoin and nano wallets
* merge fixes
* minor fixes
* use default derivation type when restoring from qr code
* fixes for restoring
* fixes
* fixes
* merge fix
* Fix issues with Creating Electrum and Restoring Bip39
* updates & fixes
* Add missing case for no transactions BIP39 wallet restore
* Make the default BIP39 the 84 derivation path
* Add Samourai Deposit
* litecoin mnemonic error fix
* Bip39 passphrase support (#1412)
* save
* passphrase working
* fix for when loading wallets + translation update
* minor fix
* Fix Nano
* minor fix [skip ci]
---------
Co-authored-by: OmarHatem <omarh.ismail1@gmail.com>
* change error state seed conditions into throwables [skip ci]
* litecoin fixes
* Bip39 minor enhancements (#1416)
* minor enhancements
* rename bitcoin_derivations -> electrum_derivations
* Remove duplicate derivations
handle default case
* minor fix
* Enable passphrase for Litecoin
* obscure text of passphrase
---------
Co-authored-by: OmarHatem <omarh.ismail1@gmail.com>
Co-authored-by: Justin Ehrenhofer <justin.ehrenhofer@gmail.com>
Co-authored-by: fossephate <fosse@book.local>
2024-04-30 00:49:56 +00:00
|
|
|
if (!CakeHive.isAdapterRegistered(DERIVATION_INFO_TYPE_ID)) {
|
|
|
|
CakeHive.registerAdapter(DerivationInfoAdapter());
|
|
|
|
}
|
2024-05-05 01:44:50 +00:00
|
|
|
|
|
|
|
if (!CakeHive.isAdapterRegistered(HARDWARE_WALLET_TYPE_TYPE_ID)) {
|
|
|
|
CakeHive.registerAdapter(HardwareWalletTypeAdapter());
|
|
|
|
}
|
|
|
|
|
2023-08-15 00:47:25 +00:00
|
|
|
if (!CakeHive.isAdapterRegistered(WALLET_TYPE_TYPE_ID)) {
|
|
|
|
CakeHive.registerAdapter(WalletTypeAdapter());
|
2023-08-04 17:55:56 +00:00
|
|
|
}
|
2021-03-12 19:04:37 +00:00
|
|
|
|
2023-08-15 00:47:25 +00:00
|
|
|
if (!CakeHive.isAdapterRegistered(Template.typeId)) {
|
|
|
|
CakeHive.registerAdapter(TemplateAdapter());
|
2023-08-04 17:55:56 +00:00
|
|
|
}
|
2022-01-08 14:33:17 +00:00
|
|
|
|
2023-08-15 00:47:25 +00:00
|
|
|
if (!CakeHive.isAdapterRegistered(ExchangeTemplate.typeId)) {
|
|
|
|
CakeHive.registerAdapter(ExchangeTemplateAdapter());
|
2023-08-04 17:55:56 +00:00
|
|
|
}
|
2023-03-24 15:26:42 +00:00
|
|
|
|
2023-08-15 00:47:25 +00:00
|
|
|
if (!CakeHive.isAdapterRegistered(Order.typeId)) {
|
|
|
|
CakeHive.registerAdapter(OrderAdapter());
|
2023-08-04 17:55:56 +00:00
|
|
|
}
|
2023-05-19 14:33:16 +00:00
|
|
|
|
2023-09-14 19:14:16 +00:00
|
|
|
if (!CakeHive.isAdapterRegistered(UnspentCoinsInfo.typeId)) {
|
2023-08-15 00:47:25 +00:00
|
|
|
CakeHive.registerAdapter(UnspentCoinsInfoAdapter());
|
2023-08-04 17:55:56 +00:00
|
|
|
}
|
|
|
|
|
2023-08-15 00:47:25 +00:00
|
|
|
if (!CakeHive.isAdapterRegistered(AnonpayInvoiceInfo.typeId)) {
|
|
|
|
CakeHive.registerAdapter(AnonpayInvoiceInfoAdapter());
|
2023-08-04 17:55:56 +00:00
|
|
|
}
|
|
|
|
|
2024-05-08 20:23:27 +00:00
|
|
|
final secureStorage = secureStorageShared;
|
|
|
|
|
2023-08-04 17:55:56 +00:00
|
|
|
final transactionDescriptionsBoxKey =
|
|
|
|
await getEncryptionKey(secureStorage: secureStorage, forKey: TransactionDescription.boxKey);
|
|
|
|
final tradesBoxKey = await getEncryptionKey(secureStorage: secureStorage, forKey: Trade.boxKey);
|
|
|
|
final ordersBoxKey = await getEncryptionKey(secureStorage: secureStorage, forKey: Order.boxKey);
|
2023-08-15 00:47:25 +00:00
|
|
|
final contacts = await CakeHive.openBox<Contact>(Contact.boxName);
|
|
|
|
final nodes = await CakeHive.openBox<Node>(Node.boxName);
|
2023-10-13 11:49:00 +00:00
|
|
|
final powNodes =
|
|
|
|
await CakeHive.openBox<Node>(Node.boxName + "pow"); // must be different from Node.boxName
|
2023-08-15 00:47:25 +00:00
|
|
|
final transactionDescriptions = await CakeHive.openBox<TransactionDescription>(
|
2023-08-04 17:55:56 +00:00
|
|
|
TransactionDescription.boxName,
|
|
|
|
encryptionKey: transactionDescriptionsBoxKey);
|
2023-08-15 00:47:25 +00:00
|
|
|
final trades = await CakeHive.openBox<Trade>(Trade.boxName, encryptionKey: tradesBoxKey);
|
|
|
|
final orders = await CakeHive.openBox<Order>(Order.boxName, encryptionKey: ordersBoxKey);
|
|
|
|
final walletInfoSource = await CakeHive.openBox<WalletInfo>(WalletInfo.boxName);
|
|
|
|
final templates = await CakeHive.openBox<Template>(Template.boxName);
|
|
|
|
final exchangeTemplates = await CakeHive.openBox<ExchangeTemplate>(ExchangeTemplate.boxName);
|
|
|
|
final anonpayInvoiceInfo = await CakeHive.openBox<AnonpayInvoiceInfo>(AnonpayInvoiceInfo.boxName);
|
2023-08-24 13:54:05 +00:00
|
|
|
final unspentCoinsInfoSource = await CakeHive.openBox<UnspentCoinsInfo>(UnspentCoinsInfo.boxName);
|
2023-08-04 17:55:56 +00:00
|
|
|
|
|
|
|
await initialSetup(
|
2024-04-02 18:02:28 +00:00
|
|
|
sharedPreferences: await SharedPreferences.getInstance(),
|
|
|
|
nodes: nodes,
|
|
|
|
powNodes: powNodes,
|
|
|
|
walletInfoSource: walletInfoSource,
|
|
|
|
contactSource: contacts,
|
|
|
|
tradesSource: trades,
|
|
|
|
ordersSource: orders,
|
|
|
|
unspentCoinsInfoSource: unspentCoinsInfoSource,
|
|
|
|
// fiatConvertationService: fiatConvertationService,
|
|
|
|
templates: templates,
|
|
|
|
exchangeTemplates: exchangeTemplates,
|
|
|
|
transactionDescriptions: transactionDescriptions,
|
|
|
|
secureStorage: secureStorage,
|
|
|
|
anonpayInvoiceInfo: anonpayInvoiceInfo,
|
2024-06-18 05:08:03 +00:00
|
|
|
initialMigrationVersion: 37,
|
2024-04-02 18:02:28 +00:00
|
|
|
);
|
2023-10-17 15:59:41 +00:00
|
|
|
}
|
2020-01-04 19:31:52 +00:00
|
|
|
|
2021-01-15 17:41:30 +00:00
|
|
|
Future<void> initialSetup(
|
2024-04-02 18:02:28 +00:00
|
|
|
{required SharedPreferences sharedPreferences,
|
2022-10-12 17:09:57 +00:00
|
|
|
required Box<Node> nodes,
|
2023-10-05 01:09:07 +00:00
|
|
|
required Box<Node> powNodes,
|
2022-10-12 17:09:57 +00:00
|
|
|
required Box<WalletInfo> walletInfoSource,
|
|
|
|
required Box<Contact> contactSource,
|
|
|
|
required Box<Trade> tradesSource,
|
|
|
|
required Box<Order> ordersSource,
|
|
|
|
// required FiatConvertationService fiatConvertationService,
|
|
|
|
required Box<Template> templates,
|
|
|
|
required Box<ExchangeTemplate> exchangeTemplates,
|
|
|
|
required Box<TransactionDescription> transactionDescriptions,
|
2024-05-08 20:23:27 +00:00
|
|
|
required SecureStorage secureStorage,
|
2023-03-24 15:26:42 +00:00
|
|
|
required Box<AnonpayInvoiceInfo> anonpayInvoiceInfo,
|
2023-08-24 13:54:05 +00:00
|
|
|
required Box<UnspentCoinsInfo> unspentCoinsInfoSource,
|
2021-05-07 07:36:38 +00:00
|
|
|
int initialMigrationVersion = 15}) async {
|
2021-03-24 16:52:30 +00:00
|
|
|
LanguageService.loadLocaleList();
|
2020-01-04 19:31:52 +00:00
|
|
|
await defaultSettingsMigration(
|
2021-01-15 17:41:30 +00:00
|
|
|
secureStorage: secureStorage,
|
2020-01-04 19:31:52 +00:00
|
|
|
version: initialMigrationVersion,
|
|
|
|
sharedPreferences: sharedPreferences,
|
2020-09-23 18:26:10 +00:00
|
|
|
walletInfoSource: walletInfoSource,
|
|
|
|
contactSource: contactSource,
|
|
|
|
tradeSource: tradesSource,
|
2023-10-05 01:09:07 +00:00
|
|
|
nodes: nodes,
|
|
|
|
powNodes: powNodes);
|
2020-07-06 20:09:03 +00:00
|
|
|
await setup(
|
2024-05-08 00:00:01 +00:00
|
|
|
walletInfoSource: walletInfoSource,
|
|
|
|
nodeSource: nodes,
|
|
|
|
powNodeSource: powNodes,
|
|
|
|
contactSource: contactSource,
|
|
|
|
tradesSource: tradesSource,
|
|
|
|
templates: templates,
|
|
|
|
exchangeTemplates: exchangeTemplates,
|
|
|
|
transactionDescriptionBox: transactionDescriptions,
|
|
|
|
ordersSource: ordersSource,
|
|
|
|
anonpayInvoiceInfoSource: anonpayInvoiceInfo,
|
|
|
|
unspentCoinsInfoSource: unspentCoinsInfoSource,
|
|
|
|
secureStorage: secureStorage,
|
|
|
|
navigatorKey: navigatorKey,
|
|
|
|
);
|
2021-01-15 17:41:30 +00:00
|
|
|
await bootstrap(navigatorKey);
|
2021-12-24 12:37:24 +00:00
|
|
|
monero?.onStartup();
|
2020-01-04 19:31:52 +00:00
|
|
|
}
|
|
|
|
|
2021-09-06 08:19:13 +00:00
|
|
|
class App extends StatefulWidget {
|
|
|
|
@override
|
|
|
|
AppState createState() => AppState();
|
|
|
|
}
|
|
|
|
|
|
|
|
class AppState extends State<App> with SingleTickerProviderStateMixin {
|
|
|
|
@override
|
|
|
|
Widget build(BuildContext context) {
|
|
|
|
return Observer(builder: (BuildContext context) {
|
2022-10-12 17:09:57 +00:00
|
|
|
final appStore = getIt.get<AppStore>();
|
2022-12-13 15:19:31 +00:00
|
|
|
final authService = getIt.get<AuthService>();
|
2024-05-08 00:00:01 +00:00
|
|
|
final linkViewModel = getIt.get<LinkViewModel>();
|
2022-10-12 17:09:57 +00:00
|
|
|
final settingsStore = appStore.settingsStore;
|
2021-09-06 08:19:13 +00:00
|
|
|
final statusBarColor = Colors.transparent;
|
|
|
|
final authenticationStore = getIt.get<AuthenticationStore>();
|
2023-05-19 14:33:16 +00:00
|
|
|
final initialRoute = authenticationStore.state == AuthenticationState.uninitialized
|
2021-09-06 08:19:13 +00:00
|
|
|
? Routes.disclaimer
|
|
|
|
: Routes.login;
|
|
|
|
final currentTheme = settingsStore.currentTheme;
|
2023-05-19 14:33:16 +00:00
|
|
|
final statusBarBrightness =
|
|
|
|
currentTheme.type == ThemeType.dark ? Brightness.light : Brightness.dark;
|
|
|
|
final statusBarIconBrightness =
|
|
|
|
currentTheme.type == ThemeType.dark ? Brightness.light : Brightness.dark;
|
2021-09-06 08:19:13 +00:00
|
|
|
SystemChrome.setSystemUIOverlayStyle(SystemUiOverlayStyle(
|
|
|
|
statusBarColor: statusBarColor,
|
|
|
|
statusBarBrightness: statusBarBrightness,
|
|
|
|
statusBarIconBrightness: statusBarIconBrightness));
|
|
|
|
|
|
|
|
return Root(
|
2021-11-02 09:17:24 +00:00
|
|
|
key: rootKey,
|
2022-10-12 17:09:57 +00:00
|
|
|
appStore: appStore,
|
2021-09-06 08:19:13 +00:00
|
|
|
authenticationStore: authenticationStore,
|
|
|
|
navigatorKey: navigatorKey,
|
2022-12-13 15:19:31 +00:00
|
|
|
authService: authService,
|
2024-05-08 00:00:01 +00:00
|
|
|
linkViewModel: linkViewModel,
|
2021-09-06 08:19:13 +00:00
|
|
|
child: MaterialApp(
|
2022-11-08 15:49:51 +00:00
|
|
|
navigatorObservers: [routeObserver],
|
2021-09-06 08:19:13 +00:00
|
|
|
navigatorKey: navigatorKey,
|
|
|
|
debugShowCheckedModeBanner: false,
|
|
|
|
theme: settingsStore.theme,
|
2023-05-25 17:30:21 +00:00
|
|
|
localizationsDelegates: localizationDelegates,
|
2021-09-06 08:19:13 +00:00
|
|
|
supportedLocales: S.delegate.supportedLocales,
|
|
|
|
locale: Locale(settingsStore.languageCode),
|
|
|
|
onGenerateRoute: (settings) => Router.createRoute(settings),
|
|
|
|
initialRoute: initialRoute,
|
2023-07-13 13:05:52 +00:00
|
|
|
home: _Home(),
|
2021-09-06 08:19:13 +00:00
|
|
|
));
|
|
|
|
});
|
|
|
|
}
|
|
|
|
}
|
2023-07-13 13:05:52 +00:00
|
|
|
|
|
|
|
class _Home extends StatefulWidget {
|
|
|
|
const _Home();
|
|
|
|
|
|
|
|
@override
|
|
|
|
State<_Home> createState() => _HomeState();
|
|
|
|
}
|
|
|
|
|
|
|
|
class _HomeState extends State<_Home> {
|
2023-10-03 14:56:10 +00:00
|
|
|
@override
|
2023-07-13 13:05:52 +00:00
|
|
|
void didChangeDependencies() {
|
2023-11-03 05:42:18 +00:00
|
|
|
_setOrientation(context);
|
|
|
|
|
2023-07-13 13:05:52 +00:00
|
|
|
super.didChangeDependencies();
|
|
|
|
}
|
|
|
|
|
2023-10-03 14:56:10 +00:00
|
|
|
void _setOrientation(BuildContext context) {
|
2023-11-03 05:42:18 +00:00
|
|
|
if (!DeviceInfo.instance.isDesktop) {
|
|
|
|
if (responsiveLayoutUtil.shouldRenderMobileUI) {
|
|
|
|
SystemChrome.setPreferredOrientations(
|
|
|
|
[DeviceOrientation.portraitUp, DeviceOrientation.portraitDown]);
|
|
|
|
} else {
|
|
|
|
SystemChrome.setPreferredOrientations(
|
|
|
|
[DeviceOrientation.landscapeLeft, DeviceOrientation.landscapeRight]);
|
|
|
|
}
|
2023-07-13 13:05:52 +00:00
|
|
|
}
|
2023-10-03 14:56:10 +00:00
|
|
|
}
|
2023-08-04 17:55:56 +00:00
|
|
|
|
2023-07-13 13:05:52 +00:00
|
|
|
@override
|
|
|
|
Widget build(BuildContext context) {
|
|
|
|
return const SizedBox.shrink();
|
|
|
|
}
|
|
|
|
}
|