import 'package:flutter/material.dart'; import 'dart:async'; import 'package:gecko/globals.dart'; import 'package:gecko/models/chest_data.dart'; import 'package:gecko/models/wallet_data.dart'; import 'package:gecko/providers/substrate_sdk.dart'; import 'package:provider/provider.dart'; class MyWalletsProvider with ChangeNotifier { List listWallets = []; late String pinCode; late String mnemonic; int? pinLenght; int? getCurrentChest() { if (configBox.get('currentChest') == null) { configBox.put('currentChest', 0); } return configBox.get('currentChest'); } bool checkIfWalletExist() { // configBox.delete('endpoint'); if (!configBox.containsKey('endpoint') || configBox.get('endpoint') == '') { log.d('No endpoint, configure...'); // configBox.put('endpoint', 'wss://gdev.librelois.fr/ws'); configBox.put('endpoint', 'ws://127.0.0.1:9944'); } if (chestBox.isEmpty) { log.i('No wallets detected'); return false; } else { return true; } } List readAllWallets(int? _chest) { listWallets.clear(); walletBox.toMap().forEach((key, value) { if (value.chest == _chest) { listWallets.add(value); } }); return listWallets; } WalletData? getWalletData(List _id) { if (_id.isEmpty) return WalletData(); int? _chest = _id[0]; int? _nbr = _id[1]; WalletData? _targetedWallet; walletBox.toMap().forEach((key, value) { if (value.chest == _chest && value.number == _nbr) { _targetedWallet = value; return; } }); return _targetedWallet; } WalletData? getDefaultWallet(int? chest) { if (chestBox.isEmpty) { return WalletData(chest: 0, number: 0); } else { int? defaultWalletNumber = chestBox.get(chest)!.defaultWallet; return getWalletData([chest, defaultWalletNumber]); } } Future deleteAllWallet(context) async { SubstrateSdk _sub = Provider.of(context, listen: false); try { log.w('DELETE ALL WALLETS ?'); final bool? _answer = await (_confirmDeletingAllWallets(context)); if (_answer!) { await walletBox.clear(); await chestBox.clear(); await configBox.delete('defaultWallet'); await _sub.deleteAllAccounts(); await Navigator.of(context).pushNamedAndRemoveUntil( '/', ModalRoute.withName('/'), ); } return 0; } catch (e) { return 1; } } Future _confirmDeletingAllWallets(context) async { return showDialog( context: context, barrierDismissible: true, // user must tap button! builder: (BuildContext context) { return AlertDialog( backgroundColor: backgroundColor, content: const Text( 'Êtes-vous sûr de vouloir oublier tous vos coffres ?', textAlign: TextAlign.center, style: TextStyle(fontSize: 18, fontWeight: FontWeight.w500), ), actions: [ Row( mainAxisAlignment: MainAxisAlignment.center, children: [ TextButton( key: const Key('confirmDeletingAllWallets'), child: const Text( "Oui", style: TextStyle( fontSize: 20, color: Color(0xffD80000), ), ), onPressed: () { Navigator.pop(context, true); }, ), const SizedBox(width: 20), TextButton( child: const Text( "Non", style: TextStyle(fontSize: 20), ), onPressed: () { Navigator.pop(context, false); }, ), const SizedBox(height: 120) ], ) ], ); }, ); } Future generateNewDerivation(context, String _name) async { int _newDerivationNbr; int _newWalletNbr; int? _chest = getCurrentChest(); List _walletConfig = readAllWallets(_chest); if (_walletConfig.isEmpty) { _newDerivationNbr = 2; _newWalletNbr = 0; } else { _newDerivationNbr = _walletConfig.last.derivation! + 2; _newWalletNbr = _walletConfig.last.number! + 1; } MyWalletsProvider myWalletProvider = Provider.of(context, listen: false); SubstrateSdk _sub = Provider.of(context, listen: false); final int? _currentChestNumber = myWalletProvider.getCurrentChest(); final ChestData _currentChest = chestBox.get(_currentChestNumber)!; final address = await _sub.derive( context, _currentChest.address!, _newDerivationNbr, pinCode); WalletData newWallet = WalletData( version: dataVersion, chest: _chest, address: address, number: _newWalletNbr, name: _name, derivation: _newDerivationNbr, imageName: '${_newWalletNbr % 4}.png'); await walletBox.add(newWallet); notifyListeners(); } void rebuildWidget() { notifyListeners(); } }