import 'package:flutter/services.dart'; import 'package:gecko/globals.dart'; import 'package:gecko/models/chest_data.dart'; import 'package:gecko/models/my_wallets.dart'; import 'package:gecko/models/queries.dart'; import 'package:gecko/models/wallet_data.dart'; import 'package:gecko/models/wallet_options.dart'; import 'package:flutter/material.dart'; import 'package:gecko/screens/common_elements.dart'; import 'package:gecko/screens/myWallets/choose_chest.dart'; import 'package:gecko/screens/myWallets/wallet_options.dart'; import 'package:gecko/screens/onBoarding/0_no_keychain_found.dart'; import 'package:graphql_flutter/graphql_flutter.dart'; import 'package:provider/provider.dart'; class WalletsHome extends StatelessWidget { final _derivationKey = GlobalKey(); WalletsHome({Key key}) : super(key: key); @override Widget build(BuildContext context) { SystemChrome.setPreferredOrientations([DeviceOrientation.portraitUp]); MyWalletsProvider myWalletProvider = Provider.of(context); final int _currentChestNumber = myWalletProvider.getCurrentChest(); final ChestData _currentChest = chestBox.get(_currentChestNumber); bool isWalletsExists; if (!_currentChest.isCesium) { myWalletProvider.listWallets = myWalletProvider.readAllWallets(_currentChestNumber); } isWalletsExists = myWalletProvider.checkIfWalletExist(); return WillPopScope( onWillPop: () { Navigator.popUntil( context, ModalRoute.withName('/'), ); return Future.value(true); }, child: Scaffold( appBar: AppBar( toolbarHeight: 60 * ratio, leading: IconButton( icon: const Icon(Icons.arrow_back, color: Colors.black), onPressed: () { Navigator.popUntil( context, ModalRoute.withName('/'), ); }), title: Text(_currentChest.name, key: const Key('myWallets'), style: TextStyle(color: Colors.grey[850])), backgroundColor: const Color(0xffFFD58D), ), body: SafeArea( child: !isWalletsExists ? const NoKeyChainScreen() : _currentChest.isCesium ? cesiumWalletOptions(context) : myWalletsTiles(context), ), ), ); } Widget cesiumWalletOptions(BuildContext context) { return Column(children: const [ Center(child: Text('This is a Cesium wallet')), ]); } Widget chestOptions(BuildContext context) { return Column(children: [ const SizedBox(height: 50), SizedBox( height: 120, width: 445, child: ElevatedButton.icon( icon: Image.asset( 'assets/chests/config.png', ), style: ElevatedButton.styleFrom( elevation: 2, primary: floattingYellow, // background onPrimary: Colors.black, // foreground ), onPressed: () => null, label: const Text( " Paramétrer ce coffre", style: TextStyle( fontSize: 25, fontWeight: FontWeight.w700, color: Color(0xff8a3c0f), ), ), )), const SizedBox(height: 30), SizedBox( height: 120, width: 445, child: ElevatedButton.icon( icon: Image.asset('assets/chests/miniChests.png'), style: ElevatedButton.styleFrom( elevation: 2, primary: floattingYellow, // background onPrimary: Colors.black, // foreground ), onPressed: () => Navigator.push( context, MaterialPageRoute(builder: (context) { return const ChooseChest(); }), ), label: const Text( " Changer de coffre", style: TextStyle( fontSize: 25, fontWeight: FontWeight.w700, color: Color(0xff8a3c0f), ), ), )), const SizedBox(height: 30) ]); } Widget myWalletsTiles(BuildContext context) { MyWalletsProvider _myWalletProvider = Provider.of(context); WalletOptionsProvider _walletOptions = Provider.of(context); final bool isWalletsExists = _myWalletProvider.checkIfWalletExist(); if (!isWalletsExists) { return const Text(''); } if (_myWalletProvider.listWallets.isEmpty) { return Expanded( child: Column(children: const [ Center( child: Text( 'Veuillez générer votre premier portefeuille', style: TextStyle(fontSize: 17, fontWeight: FontWeight.w500), )), ])); } List _listWallets = _myWalletProvider.listWallets; WalletData defaultWallet = _myWalletProvider.getDefaultWallet(configBox.get('currentChest')); return CustomScrollView(slivers: [ const SliverToBoxAdapter(child: SizedBox(height: 20)), SliverGrid.count( key: const Key('listWallets'), crossAxisCount: 2, childAspectRatio: 1, crossAxisSpacing: 0, mainAxisSpacing: 0, children: [ for (WalletData _repository in _listWallets) Padding( padding: const EdgeInsets.all(16), child: GestureDetector( onTap: () async { await _walletOptions.readLocalWallet( context, _repository, _myWalletProvider.pinCode, _myWalletProvider.pinLenght); Navigator.push( context, SmoothTransition( page: WalletOptions( wallet: _repository, ))); // Navigator.push(context, // MaterialPageRoute(builder: (context) { // return UnlockingWallet(wallet: _repository); // })); }, child: ClipOvalShadow( shadow: const Shadow( color: Colors.transparent, offset: Offset(0, 0), blurRadius: 5, ), clipper: CustomClipperOval(), child: ClipRRect( borderRadius: const BorderRadius.all(Radius.circular(12)), child: Column(children: [ Expanded( child: Container( width: double.infinity, height: double.infinity, decoration: BoxDecoration( gradient: RadialGradient( radius: 0.6, colors: [ Colors.green[400], const Color(0xFFE7E7A6), ], )), child: // SvgPicture.asset('assets/chopp-gecko2.png', // semanticsLabel: 'Gecko', height: 48), Image.asset( 'assets/avatars/${_repository.imageName}', alignment: Alignment.bottomCenter, scale: 0.5, ), )), // balanceBuilder(context, _walletOptions.pubkey.text), ListTile( shape: const RoundedRectangleBorder( borderRadius: BorderRadius.vertical( bottom: Radius.circular(12))), // contentPadding: const EdgeInsets.only(left: 7.0), tileColor: _repository.id()[1] == defaultWallet.id()[1] ? orangeC : const Color(0xffFFD58D), // leading: Text('IMAGE'), // subtitle: Text(_repository.split(':')[3], // style: TextStyle(fontSize: 12.0, fontFamily: 'Monospace')), title: Center( child: Padding( padding: const EdgeInsets.symmetric(horizontal: 5), child: Text( _repository.name, textAlign: TextAlign.center, style: TextStyle( fontSize: 17.0, color: _repository.id()[1] == defaultWallet.id()[1] ? const Color(0xffF9F9F1) : Colors.black, fontStyle: FontStyle.italic), ), ), ), // dense: true, onTap: () { Navigator.push( context, SmoothTransition( page: WalletOptions( wallet: _repository, ), ), ); }, ) ]), ), ), )), addNewDerivation(context), // SizedBox(height: 1), // Padding( // padding: EdgeInsets.symmetric(horizontal: 35), // child: Text( // 'Ajouter un portefeuille', // textAlign: TextAlign.center, // style: TextStyle(fontSize: 18), // )) ]), // SliverToBoxAdapter(child: Spacer()), SliverToBoxAdapter(child: chestOptions(context)), ]); } Widget balanceBuilder(context, String _pubkey) { return Query( options: QueryOptions( document: gql(getBalance), variables: { 'pubkey': _pubkey, }, // pollInterval: Duration(seconds: 1), ), builder: (QueryResult result, {VoidCallback refetch, FetchMore fetchMore}) { if (result.hasException) { return Text(result.exception.toString()); } if (result.isLoading) { return const Text('Loading'); } String wBalanceUD; if (result.data['balance'] == null) { wBalanceUD = '0.0'; } else { int wBalanceG1 = result.data['balance']['amount']; int currentUD = result.data['currentUd']['amount']; double wBalanceUDBrut = wBalanceG1 / currentUD; // .toString(); wBalanceUD = double.parse((wBalanceUDBrut).toStringAsFixed(2)).toString(); } return Text(wBalanceUD); }); } Widget addNewDerivation(context) { MyWalletsProvider _myWalletProvider = Provider.of(context); String _newDerivationName = 'Portefeuille ${_myWalletProvider.listWallets.last.number + 2}'; return Padding( padding: const EdgeInsets.all(16), child: ClipRRect( borderRadius: const BorderRadius.all(Radius.circular(12)), child: Column(children: [ Expanded( child: InkWell( key: const Key('addDerivation'), onTap: () async { await _myWalletProvider.generateNewDerivation( context, _newDerivationName); }, child: Container( width: double.infinity, height: double.infinity, decoration: BoxDecoration(color: floattingYellow), child: const Center( child: Text( '+', style: TextStyle( fontSize: 150, fontWeight: FontWeight.w700, color: Color(0xFFFCB437)), )), )), ), ]))); } Widget addNewDerivationPopup(context) { final TextEditingController _newDerivationName = TextEditingController(); MyWalletsProvider _myWalletProvider = Provider.of(context); return AlertDialog( content: Stack( clipBehavior: Clip.hardEdge, children: [ Form( key: _derivationKey, child: Column( mainAxisSize: MainAxisSize.min, children: [ const Text('Nom du portefeuille:'), Padding( padding: const EdgeInsets.all(8.0), child: TextFormField( key: const Key('DerivationNameKey'), controller: _newDerivationName, textAlign: TextAlign.center, autofocus: true, ), ), const SizedBox(height: 20), Padding( padding: const EdgeInsets.all(8.0), child: ElevatedButton( key: const Key('validDerivation'), style: ElevatedButton.styleFrom( elevation: 1, primary: yellowC, // background onPrimary: Colors.black, // foreground ), onPressed: () async { await _myWalletProvider .generateNewDerivation( context, _newDerivationName.text) .then((_) => _newDerivationName.text == ''); }, child: const Text("Créer")), ) ], ), ), ], ), ); } } // extension Range on num { // bool isBetween(num from, num to) { // return from < this && this < to; // } // } class CustomClipperOval extends CustomClipper { @override Rect getClip(Size size) { return Rect.fromCircle( center: Offset(size.width / 2, size.width / 2), radius: size.width / 2 + 3); } @override bool shouldReclip(CustomClipper oldClipper) { return false; } } class ClipOvalShadow extends StatelessWidget { final Shadow shadow; final CustomClipper clipper; final Widget child; const ClipOvalShadow({ Key key, @required this.shadow, @required this.clipper, @required this.child, }) : super(key: key); @override Widget build(BuildContext context) { return CustomPaint( painter: _ClipOvalShadowPainter( clipper: clipper, shadow: shadow, ), child: ClipRect(child: child, clipper: clipper), ); } } class _ClipOvalShadowPainter extends CustomPainter { final Shadow shadow; final CustomClipper clipper; _ClipOvalShadowPainter({@required this.shadow, @required this.clipper}); @override void paint(Canvas canvas, Size size) { var paint = shadow.toPaint(); var clipRect = clipper.getClip(size).shift(const Offset(0, 0)); canvas.drawOval(clipRect, paint); } @override bool shouldRepaint(CustomPainter oldDelegate) { return true; } }