Skip to content
Snippets Groups Projects
Commit f39cafd3 authored by poka's avatar poka
Browse files

Big improve on Wallets Tiles; Review of wallets index format

parent d0e1bbba
No related branches found
No related tags found
1 merge request!9Add figma UX for wallet option screen - rework wallet list storage
Pipeline #11163 waiting for manual action
<svg width="96" height="117" viewBox="0 0 96 117" fill="none" xmlns="http://www.w3.org/2000/svg" xmlns:xlink="http://www.w3.org/1999/xlink">
<rect width="96" height="115.59" transform="matrix(-1 0 0 1 96 0.480713)" fill="url(#pattern0)"/>
<defs>
<pattern id="pattern0" patternContentUnits="objectBoundingBox" width="1" height="1">
<use xlink:href="#image0" transform="translate(-0.0160256) scale(0.00819088 0.00680272)"/>
</pattern>
<image id="image0" width="126" height="147" xlink:href=""/>
</defs>
</svg>
assets/chopp-gecko2.png

9.3 KiB

...@@ -3,6 +3,8 @@ import 'package:shared_preferences/shared_preferences.dart'; ...@@ -3,6 +3,8 @@ import 'package:shared_preferences/shared_preferences.dart';
Directory appPath; Directory appPath;
Directory walletsDirectory; Directory walletsDirectory;
File defaultWalletFile;
String defaultWallet;
String appVersion; String appVersion;
SharedPreferences prefs; SharedPreferences prefs;
String endPointGVA; String endPointGVA;
......
...@@ -25,8 +25,10 @@ Future<void> main() async { ...@@ -25,8 +25,10 @@ Future<void> main() async {
WidgetsFlutterBinding.ensureInitialized(); WidgetsFlutterBinding.ensureInitialized();
HomeProvider _homeProvider = HomeProvider(); HomeProvider _homeProvider = HomeProvider();
MyWalletsProvider _walletsProvider = MyWalletsProvider();
await _homeProvider.getAppPath(); await _homeProvider.getAppPath();
await _homeProvider.createDefaultAvatar(); await _homeProvider.createDefaultAvatar();
await _walletsProvider.getDefaultWallet();
appVersion = await _homeProvider.getAppVersion(); appVersion = await _homeProvider.getAppVersion();
prefs = await SharedPreferences.getInstance(); prefs = await SharedPreferences.getInstance();
final HiveStore _store = final HiveStore _store =
......
...@@ -39,50 +39,30 @@ class GenerateWalletsProvider with ChangeNotifier { ...@@ -39,50 +39,30 @@ class GenerateWalletsProvider with ChangeNotifier {
bool canImport = false; bool canImport = false;
bool isPinChanged = false; bool isPinChanged = false;
Future storeWallet(NewWallet wallet, String _name, BuildContext context, Future storeHDWallet(
{bool isHD = false}) async { NewWallet _wallet, String _name, BuildContext context) async {
int nbrWallet; // Directory walletDirectory;
if (isHD) {
nbrWallet = 0;
} else {
nbrWallet = 1;
}
Directory walletNbrDirectory;
do {
nbrWallet++;
walletNbrDirectory = Directory('${walletsDirectory.path}/$nbrWallet');
} while (await walletNbrDirectory.exists());
final walletFile = File('${walletNbrDirectory.path}/wallet.dewif');
await walletNbrDirectory.create(); final Directory hdDirectory = Directory('${walletsDirectory.path}/0');
await walletFile.writeAsString(wallet.dewif); await hdDirectory.create();
final configFile = File('${walletNbrDirectory.path}/config.txt'); final configFile = File('${hdDirectory.path}/config.txt');
final dewifFile = File('${hdDirectory.path}/wallet.dewif');
if (isHD) { // List<String> _lastConfig = [];
final int _derivationNbr = 3; // _lastConfig = await masterConfigFile.readAsLines();
List _pubkeysTmp = await DubpRust.getBip32DewifAccountsPublicKeys( // final int _lastDerivation = int.parse(_lastConfig.last.split(':')[2]);
dewif: wallet.dewif, // final int _derivationNbr = _lastDerivation + 3;
secretCode: wallet.pin,
accountsIndex: [_derivationNbr]);
String _pubkey = _pubkeysTmp[0];
await configFile final int _derivationNbr = 3;
.writeAsString('$nbrWallet:$_name:$_derivationNbr:$_pubkey'); List _pubkeysTmp = await DubpRust.getBip32DewifAccountsPublicKeys(
// Navigator.pop(context, true); dewif: _wallet.dewif,
} else { secretCode: _wallet.pin,
final int _derivationNbr = -1; accountsIndex: [_derivationNbr]);
String _pubkey = await DubpRust.getDewifPublicKey( String _pubkey = _pubkeysTmp[0];
dewif: wallet.dewif,
pin: wallet.pin,
);
await configFile
.writeAsString('$nbrWallet:$_name:$_derivationNbr:$_pubkey');
}
// Navigator.pop(context, true); await configFile.writeAsString('0:$_name:$_derivationNbr:$_pubkey');
await dewifFile.writeAsString(_wallet.dewif);
return _name; return _name;
} }
...@@ -263,8 +243,8 @@ class GenerateWalletsProvider with ChangeNotifier { ...@@ -263,8 +243,8 @@ class GenerateWalletsProvider with ChangeNotifier {
salt: _cesiumID, password: _cesiumPWD); salt: _cesiumID, password: _cesiumPWD);
String shortPubkey = truncate(_walletPubkey, 9, String shortPubkey = truncate(_walletPubkey, 9,
omission: "...", position: TruncatePosition.end); omission: "...", position: TruncatePosition.end);
await storeWallet( // await storeWallet(
actualWallet, 'Portefeuille Cesium - $shortPubkey', context); // actualWallet, 'Portefeuille Cesium - $shortPubkey', context);
cesiumID.text = ''; cesiumID.text = '';
cesiumPWD.text = ''; cesiumPWD.text = '';
cesiumPubkey.text = ''; cesiumPubkey.text = '';
......
...@@ -13,6 +13,8 @@ class MyWalletsProvider with ChangeNotifier { ...@@ -13,6 +13,8 @@ class MyWalletsProvider with ChangeNotifier {
return false; return false;
} }
print(walletsDirectory.listSync());
List contents = walletsDirectory.listSync(); List contents = walletsDirectory.listSync();
if (contents.length == 0) { if (contents.length == 0) {
print('No wallets detected'); print('No wallets detected');
...@@ -54,6 +56,23 @@ class MyWalletsProvider with ChangeNotifier { ...@@ -54,6 +56,23 @@ class MyWalletsProvider with ChangeNotifier {
return listWallets; return listWallets;
} }
Future getDefaultWallet() async {
defaultWalletFile = File('${appPath.path}/defaultWallet');
bool isdefaultWalletFile = await defaultWalletFile.exists();
if (!isdefaultWalletFile) {
await File(defaultWalletFile.path).create();
}
try {
defaultWallet = await defaultWalletFile.readAsString();
} catch (e) {
defaultWallet = '0:3';
}
if (defaultWallet == '') defaultWallet = '0:3';
}
Future<int> deleteAllWallet(context) async { Future<int> deleteAllWallet(context) async {
try { try {
print('DELETE THAT ?: $walletsDirectory'); print('DELETE THAT ?: $walletsDirectory');
...@@ -107,11 +126,9 @@ class MyWalletsProvider with ChangeNotifier { ...@@ -107,11 +126,9 @@ class MyWalletsProvider with ChangeNotifier {
); );
} }
Future<void> generateNewDerivation( Future<void> generateNewDerivation(context, String _name) async {
context, String _name, int _walletNbr) async {
int _newDerivationNbr; int _newDerivationNbr;
final _walletConfig = final _walletConfig = File('${walletsDirectory.path}/0/config.txt');
File('${walletsDirectory.path}/$_walletNbr/config.txt');
if (await _walletConfig.readAsString() == '') { if (await _walletConfig.readAsString() == '') {
_newDerivationNbr = 3; _newDerivationNbr = 3;
...@@ -122,7 +139,7 @@ class MyWalletsProvider with ChangeNotifier { ...@@ -122,7 +139,7 @@ class MyWalletsProvider with ChangeNotifier {
_newDerivationNbr = _lastDerivation + 3; _newDerivationNbr = _lastDerivation + 3;
} }
await _walletConfig.writeAsString('\n$_walletNbr:$_name:$_newDerivationNbr', await _walletConfig.writeAsString('\n0:$_name:$_newDerivationNbr',
mode: FileMode.append); mode: FileMode.append);
print(await _walletConfig.readAsString()); print(await _walletConfig.readAsString());
......
...@@ -126,11 +126,10 @@ class ConfirmStoreWallet extends StatelessWidget with ChangeNotifier { ...@@ -126,11 +126,10 @@ class ConfirmStoreWallet extends StatelessWidget with ChangeNotifier {
.isAskedWordValid && .isAskedWordValid &&
this.walletName.text != '') this.walletName.text != '')
? () async { ? () async {
await _generateWalletProvider.storeWallet( await _generateWalletProvider.storeHDWallet(
generatedWallet, generatedWallet,
walletName.text, walletName.text,
context, context);
isHD: true);
_generateWalletProvider.isAskedWordValid = _generateWalletProvider.isAskedWordValid =
false; false;
_generateWalletProvider.askedWordColor = _generateWalletProvider.askedWordColor =
......
import 'package:flutter/services.dart'; import 'package:flutter/services.dart';
import 'package:gecko/globals.dart';
import 'package:gecko/models/myWallets.dart'; import 'package:gecko/models/myWallets.dart';
import 'package:gecko/models/walletOptions.dart'; import 'package:gecko/models/walletOptions.dart';
import 'package:flutter/material.dart'; import 'package:flutter/material.dart';
...@@ -81,7 +82,9 @@ class WalletsHome extends StatelessWidget { ...@@ -81,7 +82,9 @@ class WalletsHome extends StatelessWidget {
List _listWallets = _myWalletProvider.listWallets.split('\n'); List _listWallets = _myWalletProvider.listWallets.split('\n');
// final int nbrOfWallets = _listWallets.length; // final int nbrOfWallets = _listWallets.length;
print(_listWallets); // print(_listWallets);
// print("${_listWallets[0].split(':')[0]}:${_listWallets[0].split(':')[2]}");
// print(defaultWallet);
return GridView.count( return GridView.count(
crossAxisCount: 2, crossAxisCount: 2,
...@@ -94,27 +97,62 @@ class WalletsHome extends StatelessWidget { ...@@ -94,27 +97,62 @@ class WalletsHome extends StatelessWidget {
padding: EdgeInsets.all(16), padding: EdgeInsets.all(16),
child: ClipRRect( child: ClipRRect(
borderRadius: BorderRadius.all(Radius.circular(12)), borderRadius: BorderRadius.all(Radius.circular(12)),
child: ListTile( child: Column(children: <Widget>[
// contentPadding: const EdgeInsets.only(left: 7.0), Expanded(
tileColor: Colors.green[100], child: Container(
// leading: Text('IMAGE'), width: double.infinity,
height: double.infinity,
// subtitle: Text(_repository.split(':')[3], decoration: BoxDecoration(
// style: TextStyle(fontSize: 12.0, fontFamily: 'Monospace')), gradient: RadialGradient(
title: Center( radius: 1,
child: Text(_repository.split(':')[1], colors: [
style: TextStyle(fontSize: 16.0))), Colors.green[100],
// dense: true, Colors.green[500],
onTap: () { ],
Navigator.push(context, )),
MaterialPageRoute(builder: (context) { child:
return UnlockingWallet( // SvgPicture.asset('assets/chopp-gecko2.png',
walletNbr: int.parse(_repository.split(':')[0]), // semanticsLabel: 'Gecko', height: 48),
walletName: _repository.split(':')[1], Image.asset(
derivation: int.parse(_repository.split(':')[2])); 'assets/chopp-gecko2.png',
})); ),
}, )),
))) ListTile(
// contentPadding: const EdgeInsets.only(left: 7.0),
tileColor:
"${_repository.split(':')[0]}:${_repository.split(':')[2]}" ==
defaultWallet
? Color(0xffD28928)
: Color(0xffFFD58D),
// leading: Text('IMAGE'),
// subtitle: Text(_repository.split(':')[3],
// style: TextStyle(fontSize: 12.0, fontFamily: 'Monospace')),
title: Center(
child: Padding(
padding: EdgeInsets.symmetric(horizontal: 5),
child: Text(_repository.split(':')[1],
textAlign: TextAlign.center,
style: TextStyle(
fontSize: 16.0,
color:
"${_repository.split(':')[0]}:${_repository.split(':')[2]}" ==
defaultWallet
? Color(0xffF9F9F1)
: Colors.black)))),
// dense: true,
onTap: () {
Navigator.push(context,
MaterialPageRoute(builder: (context) {
return UnlockingWallet(
walletNbr: int.parse(_repository.split(':')[0]),
walletName: _repository.split(':')[1],
derivation:
int.parse(_repository.split(':')[2]));
}));
},
)
])))
]); ]);
} }
...@@ -200,7 +238,7 @@ class WalletsHome extends StatelessWidget { ...@@ -200,7 +238,7 @@ class WalletsHome extends StatelessWidget {
onPressed: () async { onPressed: () async {
await _myWalletProvider await _myWalletProvider
.generateNewDerivation( .generateNewDerivation(
context, _newDerivationName.text, _walletNbr) context, _newDerivationName.text)
.then((_) => _newDerivationName.text == ''); .then((_) => _newDerivationName.text == '');
}, },
child: Text("Créer")), child: Text("Créer")),
......
...@@ -142,7 +142,7 @@ class WalletsHome extends StatelessWidget { ...@@ -142,7 +142,7 @@ class WalletsHome extends StatelessWidget {
onPressed: () async { onPressed: () async {
await _myWalletProvider await _myWalletProvider
.generateNewDerivation( .generateNewDerivation(
context, _newDerivationName.text, _walletNbr) context, _newDerivationName.text)
.then((_) => _newDerivationName.text == ''); .then((_) => _newDerivationName.text == '');
}, },
child: Text("Créer")), child: Text("Créer")),
......
...@@ -116,9 +116,8 @@ class OnboardingStepFourteen extends StatelessWidget { ...@@ -116,9 +116,8 @@ class OnboardingStepFourteen extends StatelessWidget {
if (resultWallet) { if (resultWallet) {
pinColor = Colors.green[500]; pinColor = Colors.green[500];
print(generatedWallet.pin); print(generatedWallet.pin);
await _generateWalletProvider.storeWallet( await _generateWalletProvider.storeHDWallet(
generatedWallet, 'Mon portefeuille courant', context, generatedWallet, 'Mon portefeuille courant', context);
isHD: true);
_myWalletProvider.getAllWalletsNames(); _myWalletProvider.getAllWalletsNames();
_walletOptions.reloadBuild(); _walletOptions.reloadBuild();
_myWalletProvider.rebuildWidget(); _myWalletProvider.rebuildWidget();
......
...@@ -5,7 +5,7 @@ description: Pay with G1. ...@@ -5,7 +5,7 @@ description: Pay with G1.
# pub.dev using `pub publish`. This is preferred for private packages. # pub.dev using `pub publish`. This is preferred for private packages.
publish_to: 'none' # Remove this line if you wish to publish to pub.dev publish_to: 'none' # Remove this line if you wish to publish to pub.dev
version: 0.0.1+20 version: 0.0.1+21
environment: environment:
sdk: ">=2.7.0 <3.0.0" sdk: ">=2.7.0 <3.0.0"
......
0% Loading or .
You are about to add 0 people to the discussion. Proceed with caution.
Finish editing this message first!
Please register or to comment