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

Merge branch 'figmaWalletsViewsUX' into 'master'

Add figma UX for wallet option screen - rework wallet list storage

See merge request !9
parents 459a7990 de478e93
No related branches found
No related tags found
1 merge request!9Add figma UX for wallet option screen - rework wallet list storage
Pipeline #11410 passed
Showing
with 160 additions and 90 deletions
<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

assets/walletOptions/QR_icon.png

1.58 KiB

assets/walletOptions/android-checkmark.png

264 B

assets/walletOptions/camera.png

585 B

assets/walletOptions/clock.png

1.02 KiB

assets/walletOptions/copy-white.png

482 B

assets/walletOptions/edit.png

284 B

assets/walletOptions/ellipse1.png

1.72 KiB

assets/walletOptions/icon_oeuil.png

719 B

assets/walletOptions/icon_oeuil_close.png

3.93 KiB

assets/walletOptions/key.png

492 B

assets/walletOptions/trash.png

2.22 KiB

import 'dart:io'; import 'dart:io';
import 'package:shared_preferences/shared_preferences.dart'; import 'package:shared_preferences/shared_preferences.dart';
// Files paths
Directory appPath; Directory appPath;
Directory walletsDirectory; Directory walletsDirectory;
File defaultWalletFile;
File currentChestFile;
String defaultWallet;
String appVersion; String appVersion;
SharedPreferences prefs; SharedPreferences prefs;
String endPointGVA; String endPointGVA;
......
...@@ -25,12 +25,14 @@ Future<void> main() async { ...@@ -25,12 +25,14 @@ 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.initWalletFolder();
appVersion = await _homeProvider.getAppVersion(); appVersion = await _homeProvider.getAppVersion();
prefs = await SharedPreferences.getInstance(); prefs = await SharedPreferences.getInstance();
final HiveStore _store = // final HiveStore _store =
await HiveStore.open(path: '${appPath.path}/gqlCache'); // await HiveStore.open(path: '${appPath.path}/gqlCache');
// Get a valid GVA endpoint // Get a valid GVA endpoint
endPointGVA = await _homeProvider.getValidEndpoint(); endPointGVA = await _homeProvider.getValidEndpoint();
...@@ -49,7 +51,7 @@ Future<void> main() async { ...@@ -49,7 +51,7 @@ Future<void> main() async {
await SentryFlutter.init((options) { await SentryFlutter.init((options) {
options.dsn = options.dsn =
'https://c09587b46eaa42e8b9fda28d838ed180@o496840.ingest.sentry.io/5572110'; 'https://c09587b46eaa42e8b9fda28d838ed180@o496840.ingest.sentry.io/5572110';
}, appRunner: () => runApp(Gecko(endPointGVA, _store))); }, appRunner: () => runApp(Gecko(endPointGVA)));
// runZoned<Future<void>>( // runZoned<Future<void>>(
// () async { // () async {
...@@ -66,14 +68,13 @@ Future<void> main() async { ...@@ -66,14 +68,13 @@ Future<void> main() async {
} else { } else {
print('Debug mode enabled: No sentry alerte'); print('Debug mode enabled: No sentry alerte');
runApp(Gecko(endPointGVA, _store)); runApp(Gecko(endPointGVA));
} }
} }
class Gecko extends StatelessWidget { class Gecko extends StatelessWidget {
Gecko(this.randomEndpoint, this._store); Gecko(this.randomEndpoint);
final String randomEndpoint; final String randomEndpoint;
final HiveStore _store;
@override @override
Widget build(BuildContext context) { Widget build(BuildContext context) {
...@@ -84,7 +85,7 @@ class Gecko extends StatelessWidget { ...@@ -84,7 +85,7 @@ class Gecko extends StatelessWidget {
final _client = ValueNotifier( final _client = ValueNotifier(
GraphQLClient( GraphQLClient(
cache: GraphQLCache(store: _store), cache: GraphQLCache(),
link: _httpLink, link: _httpLink,
), ),
); );
......
...@@ -67,7 +67,7 @@ class CesiumPlusProvider with ChangeNotifier { ...@@ -67,7 +67,7 @@ class CesiumPlusProvider with ChangeNotifier {
String _name; String _name;
List queryOptions = await _buildQuery(_pubkey); List queryOptions = await _buildQuery(_pubkey);
final response = await http.post(queryOptions[0], final response = await http.post((Uri.parse(queryOptions[0])),
body: queryOptions[1], headers: queryOptions[2]); body: queryOptions[1], headers: queryOptions[2]);
// print('RESULT CESIUM QUERY: ${response.body}'); //For debug // print('RESULT CESIUM QUERY: ${response.body}'); //For debug
final responseJson = json.decode(response.body); final responseJson = json.decode(response.body);
...@@ -87,7 +87,7 @@ class CesiumPlusProvider with ChangeNotifier { ...@@ -87,7 +87,7 @@ class CesiumPlusProvider with ChangeNotifier {
Future<List> getAvatar(String _pubkey) async { Future<List> getAvatar(String _pubkey) async {
List queryOptions = await _buildQuery(_pubkey); List queryOptions = await _buildQuery(_pubkey);
final response = await http.post(queryOptions[0], final response = await http.post((Uri.parse(queryOptions[0])),
body: queryOptions[1], headers: queryOptions[2]); body: queryOptions[1], headers: queryOptions[2]);
// print('RESULT CESIUM QUERY: ${response.body}'); //For debug // print('RESULT CESIUM QUERY: ${response.body}'); //For debug
final responseJson = json.decode(response.body); final responseJson = json.decode(response.body);
......
...@@ -10,7 +10,6 @@ import 'package:gecko/globals.dart'; ...@@ -10,7 +10,6 @@ import 'package:gecko/globals.dart';
import 'package:pdf/pdf.dart'; import 'package:pdf/pdf.dart';
import 'package:pdf/widgets.dart' as pw; import 'package:pdf/widgets.dart' as pw;
import 'package:printing/printing.dart'; import 'package:printing/printing.dart';
import 'package:truncate/truncate.dart';
class GenerateWalletsProvider with ChangeNotifier { class GenerateWalletsProvider with ChangeNotifier {
GenerateWalletsProvider(); GenerateWalletsProvider();
...@@ -39,50 +38,38 @@ class GenerateWalletsProvider with ChangeNotifier { ...@@ -39,50 +38,38 @@ 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 storeHDWChest(
{bool isHD = false}) async { NewWallet _wallet, String _name, BuildContext context) async {
int nbrWallet; // Directory walletDirectory;
if (isHD) {
nbrWallet = 0;
} else {
nbrWallet = 1;
}
Directory walletNbrDirectory; final Directory hdDirectory = Directory('${walletsDirectory.path}/0');
do { await hdDirectory.create();
nbrWallet++;
walletNbrDirectory = Directory('${walletsDirectory.path}/$nbrWallet');
} while (await walletNbrDirectory.exists());
final walletFile = File('${walletNbrDirectory.path}/wallet.dewif'); final configFile = File('${hdDirectory.path}/list.conf');
File _currentChestFile = File('${walletsDirectory.path}/currentChest.conf');
await walletNbrDirectory.create(); final dewifFile = File('${hdDirectory.path}/wallet.dewif');
await walletFile.writeAsString(wallet.dewif);
final configFile = File('${walletNbrDirectory.path}/config.txt'); // List<String> _lastConfig = [];
// _lastConfig = await masterConfigFile.readAsLines();
// final int _lastDerivation = int.parse(_lastConfig.last.split(':')[2]);
// final int _derivationNbr = _lastDerivation + 3;
if (isHD) { final int _derivationNbr = 3;
final int _derivationNbr = 3; List _pubkeysTmp = await DubpRust.getBip32DewifAccountsPublicKeys(
List _pubkeysTmp = await DubpRust.getBip32DewifAccountsPublicKeys( dewif: _wallet.dewif,
dewif: wallet.dewif, secretCode: _wallet.pin,
secretCode: wallet.pin, accountsIndex: [_derivationNbr]);
accountsIndex: [_derivationNbr]); String _pubkey = _pubkeysTmp[0];
String _pubkey = _pubkeysTmp[0];
await configFile await configFile.writeAsString('0:0:$_name:$_derivationNbr:$_pubkey');
.writeAsString('$nbrWallet:$_name:$_derivationNbr:$_pubkey'); await dewifFile.writeAsString(_wallet.dewif);
// Navigator.pop(context, true); bool isCurrentChestExist = _currentChestFile.existsSync();
} else { if (isCurrentChestExist) {
final int _derivationNbr = -1; await _currentChestFile.delete();
String _pubkey = await DubpRust.getDewifPublicKey(
dewif: wallet.dewif,
pin: wallet.pin,
);
await configFile
.writeAsString('$nbrWallet:$_name:$_derivationNbr:$_pubkey');
} }
await _currentChestFile.create();
// Navigator.pop(context, true); await _currentChestFile.writeAsString('0');
return _name; return _name;
} }
...@@ -167,11 +154,9 @@ class GenerateWalletsProvider with ChangeNotifier { ...@@ -167,11 +154,9 @@ class GenerateWalletsProvider with ChangeNotifier {
generatedMnemonic = await DubpRust.genMnemonic(language: Language.french); generatedMnemonic = await DubpRust.genMnemonic(language: Language.french);
this.actualWallet = await generateWallet(this.generatedMnemonic); this.actualWallet = await generateWallet(this.generatedMnemonic);
walletIsGenerated = true; walletIsGenerated = true;
// notifyListeners();
} catch (e) { } catch (e) {
print(e); print(e);
} }
// await checkIfWalletExist();
return generatedMnemonic; return generatedMnemonic;
} }
...@@ -259,12 +244,12 @@ class GenerateWalletsProvider with ChangeNotifier { ...@@ -259,12 +244,12 @@ class GenerateWalletsProvider with ChangeNotifier {
} }
Future importWallet(context, _cesiumID, _cesiumPWD) async { Future importWallet(context, _cesiumID, _cesiumPWD) async {
String _walletPubkey = await DubpRust.getLegacyPublicKey( // String _walletPubkey = await DubpRust.getLegacyPublicKey(
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 = '';
......
...@@ -4,6 +4,7 @@ import 'package:gecko/globals.dart'; ...@@ -4,6 +4,7 @@ import 'package:gecko/globals.dart';
import 'package:gecko/models/home.dart'; import 'package:gecko/models/home.dart';
import 'package:gecko/screens/history.dart'; import 'package:gecko/screens/history.dart';
import 'package:graphql_flutter/graphql_flutter.dart'; import 'package:graphql_flutter/graphql_flutter.dart';
import 'package:jdenticon_dart/jdenticon_dart.dart';
import 'package:permission_handler/permission_handler.dart'; import 'package:permission_handler/permission_handler.dart';
import 'package:provider/provider.dart'; import 'package:provider/provider.dart';
import 'package:qrscan/qrscan.dart' as scanner; import 'package:qrscan/qrscan.dart' as scanner;
...@@ -24,6 +25,7 @@ class HistoryProvider with ChangeNotifier { ...@@ -24,6 +25,7 @@ class HistoryProvider with ChangeNotifier {
Map pageInfo; Map pageInfo;
bool isHistoryScreen = false; bool isHistoryScreen = false;
String historySwitchButtun = "Voir l'historique"; String historySwitchButtun = "Voir l'historique";
String rawSvg;
Future scan(context) async { Future scan(context) async {
await Permission.camera.request(); await Permission.camera.request();
...@@ -43,7 +45,7 @@ class HistoryProvider with ChangeNotifier { ...@@ -43,7 +45,7 @@ class HistoryProvider with ChangeNotifier {
return barcode; return barcode;
} }
String isPubkey(context, pubkey) { String isPubkey(context, pubkey, {bool goHistory}) {
HomeProvider _homeProvider = HomeProvider _homeProvider =
Provider.of<HomeProvider>(context, listen: false); Provider.of<HomeProvider>(context, listen: false);
final RegExp regExp = new RegExp( final RegExp regExp = new RegExp(
...@@ -62,8 +64,16 @@ class HistoryProvider with ChangeNotifier { ...@@ -62,8 +64,16 @@ class HistoryProvider with ChangeNotifier {
this.outputPubkey.text = pubkey; this.outputPubkey.text = pubkey;
isHistoryScreen = false; if (goHistory == null) goHistory = false;
historySwitchButtun = "Voir l'historique";
if (goHistory) {
isHistoryScreen = true;
historySwitchButtun = "Payer";
} else {
isHistoryScreen = false;
historySwitchButtun = "Voir l'historique";
}
_homeProvider.handleSearchEnd(); _homeProvider.handleSearchEnd();
Navigator.push( Navigator.push(
context, context,
...@@ -101,7 +111,6 @@ class HistoryProvider with ChangeNotifier { ...@@ -101,7 +111,6 @@ class HistoryProvider with ChangeNotifier {
// Lion simone: 78jhpprYkMNF6i5kQPXfkAVBpd2aqcpieNsXTSW4c21f // Lion simone: 78jhpprYkMNF6i5kQPXfkAVBpd2aqcpieNsXTSW4c21f
List parseHistory(txs, _pubkey) { List parseHistory(txs, _pubkey) {
// print(txs);
var transBC = []; var transBC = [];
int i = 0; int i = 0;
...@@ -135,7 +144,7 @@ class HistoryProvider with ChangeNotifier { ...@@ -135,7 +144,7 @@ class HistoryProvider with ChangeNotifier {
transBC[i].add(date); transBC[i].add(date);
// print( // print(
// "DEBUG date et comment: ${date.toString()} -- ${transaction['comment'].toString()}"); // "DEBUG date et comment: ${date.toString()} -- ${transaction['comment'].toString()}");
int amountBrut = int.parse(output.split(':')[0]); final int amountBrut = int.parse(output.split(':')[0]);
final base = int.parse(output.split(':')[1]); final base = int.parse(output.split(':')[1]);
final int applyBase = base - currentBase; final int applyBase = base - currentBase;
final num amount = final num amount =
...@@ -242,6 +251,10 @@ class HistoryProvider with ChangeNotifier { ...@@ -242,6 +251,10 @@ class HistoryProvider with ChangeNotifier {
notifyListeners(); notifyListeners();
} }
String generateIdenticon(String _pubkey) {
return Jdenticon.toSvg(_pubkey);
}
// num getBalance(_pubkey) { // num getBalance(_pubkey) {
// getBalance(_pubkey); // getBalance(_pubkey);
// } // }
......
...@@ -8,13 +8,50 @@ import 'package:provider/provider.dart'; ...@@ -8,13 +8,50 @@ import 'package:provider/provider.dart';
class MyWalletsProvider with ChangeNotifier { class MyWalletsProvider with ChangeNotifier {
String listWallets; String listWallets;
Future initWalletFolder() async {
await getDefaultWallet();
final bool isWalletFolderExist = await walletsDirectory.exists();
if (!isWalletFolderExist) {
await Directory(walletsDirectory.path).create();
}
File _currentChestFile = File('${walletsDirectory.path}/currentChest.conf');
await _currentChestFile.create();
await _currentChestFile.writeAsString('0');
final bool isChestsExist =
await Directory('${walletsDirectory.path}/0').exists();
if (!isChestsExist) {
await Directory('${walletsDirectory.path}/0').create();
await Directory('${walletsDirectory.path}/1').create();
await File('${walletsDirectory.path}/0/list.conf').create();
await File('${walletsDirectory.path}/0/order.conf').create();
await File('${walletsDirectory.path}/1/list.conf').create();
await File('${walletsDirectory.path}/1/order.conf').create();
}
}
int getCurrentChest() {
File _currentChestFile = File('${walletsDirectory.path}/currentChest.conf');
bool isCurrentChestExist = _currentChestFile.existsSync();
if (!isCurrentChestExist) {
_currentChestFile.createSync();
_currentChestFile.writeAsString('0');
}
return int.parse(_currentChestFile.readAsStringSync());
}
bool checkIfWalletExist() { bool checkIfWalletExist() {
if (appPath == null) { if (appPath == null) {
return false; return false;
} }
List contents = walletsDirectory.listSync(); final String _walletList = getAllWalletsNames(0);
if (contents.length == 0) {
if (_walletList == '') {
print('No wallets detected'); print('No wallets detected');
return false; return false;
} else { } else {
...@@ -23,12 +60,7 @@ class MyWalletsProvider with ChangeNotifier { ...@@ -23,12 +60,7 @@ class MyWalletsProvider with ChangeNotifier {
} }
} }
String getAllWalletsNames() { String getAllWalletsNames(int _chest) {
final bool _isWalletsExists = checkIfWalletExist();
if (!_isWalletsExists) {
return '';
}
if (listWallets != null && listWallets.isNotEmpty) { if (listWallets != null && listWallets.isNotEmpty) {
listWallets = ''; listWallets = '';
} }
...@@ -36,24 +68,39 @@ class MyWalletsProvider with ChangeNotifier { ...@@ -36,24 +68,39 @@ class MyWalletsProvider with ChangeNotifier {
listWallets = ''; listWallets = '';
} }
print(walletsDirectory.path);
// int i = 0; // int i = 0;
walletsDirectory File _walletConfig = File('${walletsDirectory.path}/$_chest/list.conf');
.listSync(recursive: false, followLinks: false) _walletConfig.readAsLinesSync().forEach((element) {
.forEach((_wallet) { if (listWallets != '') {
File _walletConfig = File('${_wallet.path}/config.txt'); listWallets += '\n';
_walletConfig.readAsLinesSync().forEach((element) { }
if (listWallets != '') { listWallets += element;
listWallets += '\n'; // listWallets += "${element.split(':')[0]}:${element.split(':')[1]}:${element.split(':')[2]}"
}
listWallets += element;
// listWallets += "${element.split(':')[0]}:${element.split(':')[1]}:${element.split(':')[2]}"
});
}); });
print(listWallets); print(listWallets);
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:0';
}
if (defaultWallet == '') defaultWallet = '0:0';
}
Future<int> deleteAllWallet(context) async { Future<int> deleteAllWallet(context) async {
try { try {
print('DELETE THAT ?: $walletsDirectory'); print('DELETE THAT ?: $walletsDirectory');
...@@ -63,6 +110,7 @@ class MyWalletsProvider with ChangeNotifier { ...@@ -63,6 +110,7 @@ class MyWalletsProvider with ChangeNotifier {
if (_answer) { if (_answer) {
await walletsDirectory.delete(recursive: true); await walletsDirectory.delete(recursive: true);
await walletsDirectory.create(); await walletsDirectory.create();
await initWalletFolder();
notifyListeners(); notifyListeners();
Navigator.pop(context); Navigator.pop(context);
} }
...@@ -95,7 +143,7 @@ class MyWalletsProvider with ChangeNotifier { ...@@ -95,7 +143,7 @@ class MyWalletsProvider with ChangeNotifier {
onPressed: () { onPressed: () {
WidgetsBinding.instance.addPostFrameCallback((_) { WidgetsBinding.instance.addPostFrameCallback((_) {
_myWalletProvider.listWallets = _myWalletProvider.listWallets =
_myWalletProvider.getAllWalletsNames(); _myWalletProvider.getAllWalletsNames(getCurrentChest());
_myWalletProvider.rebuildWidget(); _myWalletProvider.rebuildWidget();
}); });
Navigator.pop(context, true); Navigator.pop(context, true);
...@@ -107,22 +155,26 @@ class MyWalletsProvider with ChangeNotifier { ...@@ -107,22 +155,26 @@ 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 = int _newWalletNbr;
File('${walletsDirectory.path}/$_walletNbr/config.txt'); final _walletConfig = File('${walletsDirectory.path}/0/list.conf');
if (await _walletConfig.readAsString() == '') { if (await _walletConfig.readAsString() == '') {
_newDerivationNbr = 3; _newDerivationNbr = 3;
_newWalletNbr = 0;
} else { } else {
String _lastWallet = String _lastWallet =
await _walletConfig.readAsLines().then((value) => value.last); await _walletConfig.readAsLines().then((value) => value.last);
int _lastDerivation = int.parse(_lastWallet.split(':')[2]); int _lastDerivation = int.parse(_lastWallet.split(':')[3]);
_newDerivationNbr = _lastDerivation + 3; _newDerivationNbr = _lastDerivation + 3;
int _lastWalletNbr = int.parse(_lastWallet.split(':')[1]);
_newWalletNbr = _lastWalletNbr + 1;
} }
await _walletConfig.writeAsString('\n$_walletNbr:$_name:$_newDerivationNbr', await _walletConfig.writeAsString(
'\n0:$_newWalletNbr:$_name:$_newDerivationNbr',
mode: FileMode.append); mode: FileMode.append);
print(await _walletConfig.readAsString()); print(await _walletConfig.readAsString());
......
const String getHistory = r''' const String getHistory = r'''
query ($pubkey: String!, $number: Int!, $cursor: String) { query ($pubkey: String!, $number: Int!, $cursor: String) {
txsHistoryBc( txsHistoryBc(
pubkeyOrScript: $pubkey script: $pubkey
pagination: { pageSize: $number, ord: DESC, cursor: $cursor } pagination: { pageSize: $number, ord: DESC, cursor: $cursor }
) { ) {
both { both {
...@@ -52,8 +52,13 @@ const String getHistory = r''' ...@@ -52,8 +52,13 @@ const String getHistory = r'''
const String getBalance = r''' const String getBalance = r'''
query ($pubkey: String!) { query ($pubkey: String!) {
balance(script: $pubkey) { balance(script: $pubkey) {
amount amount
base base
}
currentUd {
amount
base
}
} }
'''; ''';
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