gecko/lib/screens/onBoarding/12.dart

156 lines
6.0 KiB
Dart
Raw Normal View History

2021-11-14 19:21:20 +01:00
// ignore_for_file: file_names
2021-03-02 08:19:20 +01:00
import 'dart:async';
import 'package:flutter/services.dart';
import 'package:flutter/material.dart';
import 'package:gecko/globals.dart';
import 'package:gecko/providers/generate_wallets.dart';
import 'package:gecko/providers/my_wallets.dart';
2022-05-04 19:00:09 +02:00
import 'package:gecko/providers/substrate_sdk.dart';
import 'package:gecko/providers/wallet_options.dart';
2021-11-14 19:21:20 +01:00
import 'package:gecko/screens/common_elements.dart';
2021-03-08 06:21:04 +01:00
import 'package:gecko/screens/onBoarding/13_congratulations.dart';
2021-03-02 08:19:20 +01:00
import 'package:pin_code_fields/pin_code_fields.dart';
import 'package:provider/provider.dart';
// ignore: must_be_immutable
class OnboardingStepFourteen extends StatelessWidget {
OnboardingStepFourteen({
2021-12-23 12:36:09 +01:00
Key? validationKey,
}) : super(key: validationKey);
2021-03-08 01:08:26 +01:00
final int progress = 11;
2021-03-02 08:19:20 +01:00
final formKey = GlobalKey<FormState>();
2021-12-23 12:36:09 +01:00
Color? pinColor = const Color(0xFFA4B600);
2021-03-02 08:19:20 +01:00
bool hasError = false;
@override
Widget build(BuildContext context) {
SystemChrome.setPreferredOrientations([DeviceOrientation.portraitUp]);
GenerateWalletsProvider _generateWalletProvider =
Provider.of<GenerateWalletsProvider>(context);
2021-03-02 08:19:20 +01:00
WalletOptionsProvider _walletOptions =
Provider.of<WalletOptionsProvider>(context);
CommonElements common = CommonElements();
final int _pinLenght = _generateWalletProvider.pin.text.length;
return Scaffold(
extendBodyBehindAppBar: true,
body: SafeArea(
child: Column(children: <Widget>[
2021-03-08 17:23:56 +01:00
common.onboardingProgressBar(
context, 'Ma phrase de restauration', progress),
common.bubbleSpeak(
2021-04-24 20:27:18 +02:00
"Avez-vous bien mémorisé votre code secret ?\n\nVérifions ça ensemble !\n\nTapez votre code secret dans le champ ci-dessous (après cest fini, promis-juré-gecko).",
2021-11-14 19:21:20 +01:00
textKey: const Key('step12'),
2021-04-24 20:27:18 +02:00
),
SizedBox(height: isTall ? 80 : 10),
pinForm(context, _walletOptions, _pinLenght, 1, 2)
]),
));
}
2021-03-02 08:19:20 +01:00
Widget pinForm(context, WalletOptionsProvider _walletOptions, _pinLenght,
int _walletNbr, int _derivation) {
// var _walletPin = '';
// ignore: close_sinks
StreamController<ErrorAnimationType> errorController =
StreamController<ErrorAnimationType>();
TextEditingController _enterPin = TextEditingController();
MyWalletsProvider _myWalletProvider =
Provider.of<MyWalletsProvider>(context);
GenerateWalletsProvider _generateWalletProvider =
Provider.of<GenerateWalletsProvider>(context);
SubstrateSdk _sub = Provider.of<SubstrateSdk>(context, listen: false);
2021-03-02 08:19:20 +01:00
2021-12-23 12:36:09 +01:00
final int? _currentChest = _myWalletProvider.getCurrentChest();
2021-03-23 16:01:07 +01:00
2021-03-02 08:19:20 +01:00
return Form(
key: formKey,
child: Padding(
padding: const EdgeInsets.symmetric(vertical: 8.0, horizontal: 30),
child: PinCodeTextField(
2021-11-14 19:21:20 +01:00
key: const Key('formKey2'),
2021-03-02 08:19:20 +01:00
autoFocus: true,
appContext: context,
pastedTextStyle: TextStyle(
color: Colors.green.shade600,
fontWeight: FontWeight.bold,
),
length: _pinLenght,
obscureText: true,
2021-03-02 08:19:20 +01:00
obscuringCharacter: '*',
animationType: AnimationType.fade,
validator: (v) {
2021-12-23 12:36:09 +01:00
if (v!.length < _pinLenght) {
2021-03-02 08:19:20 +01:00
return "Votre code PIN fait $_pinLenght caractères";
} else {
return null;
}
},
pinTheme: PinTheme(
activeColor: pinColor,
borderWidth: 4,
shape: PinCodeFieldShape.box,
borderRadius: BorderRadius.circular(5),
fieldHeight: 60,
fieldWidth: 50,
activeFillColor: hasError ? Colors.blueAccent : Colors.black,
),
cursorColor: Colors.black,
2021-11-14 19:21:20 +01:00
animationDuration: const Duration(milliseconds: 300),
textStyle: const TextStyle(fontSize: 20, height: 1.6),
backgroundColor: const Color(0xffF9F9F1),
2021-03-02 08:19:20 +01:00
enableActiveFill: false,
errorAnimationController: errorController,
controller: _enterPin,
keyboardType: TextInputType.text,
2021-11-14 19:21:20 +01:00
boxShadows: const [
2021-03-02 08:19:20 +01:00
BoxShadow(
offset: Offset(0, 1),
color: Colors.black12,
blurRadius: 10,
)
],
onCompleted: (_pin) async {
2021-12-23 21:44:24 +01:00
_myWalletProvider.pinCode = _pin.toUpperCase();
2021-04-05 20:48:28 +02:00
_myWalletProvider.pinLenght = _pinLenght;
log.d(_pin + ' || ' + _generateWalletProvider.pin.text);
if (_pin.toUpperCase() == _generateWalletProvider.pin.text) {
2021-03-02 08:19:20 +01:00
pinColor = Colors.green[500];
final address = await _sub.importAccount(
2022-05-04 19:00:09 +02:00
fromMnemonic: true,
2022-05-19 09:07:26 +02:00
mnemonic: _generateWalletProvider.generatedMnemonic!,
derivePath: '//2',
2022-05-19 09:07:26 +02:00
password: _generateWalletProvider.pin.text);
await _generateWalletProvider.storeHDWChest(
2022-05-04 19:00:09 +02:00
address, 'Mon portefeuille courant', context);
2021-03-31 02:38:44 +02:00
_myWalletProvider.readAllWallets(_currentChest);
2021-12-23 21:44:24 +01:00
// scheduleMicrotask(() {
2021-12-24 15:27:38 +01:00
// _walletOptions.reloadBuild();
_myWalletProvider.rebuildWidget();
2021-12-23 21:44:24 +01:00
// });
2021-12-24 15:27:38 +01:00
_generateWalletProvider.generatedMnemonic = '';
Navigator.push(
2021-03-02 08:19:20 +01:00
context,
2021-03-08 06:21:04 +01:00
FaderTransition(
page: OnboardingStepFiveteen(), isFast: false),
2021-03-02 08:19:20 +01:00
);
} else {
errorController.add(ErrorAnimationType
.shake); // Triggering error shake animation
hasError = true;
pinColor = Colors.red[600];
_walletOptions.reloadBuild();
2021-03-02 08:19:20 +01:00
}
},
onChanged: (value) {
2021-11-14 19:21:20 +01:00
if (pinColor != const Color(0xFFA4B600)) {
pinColor = const Color(0xFFA4B600);
2021-03-02 08:19:20 +01:00
}
},
)),
);
}
}