cake_wallet/lib/src/screens/seed/wallet_seed_page.dart

196 lines
8 KiB
Dart
Raw Normal View History

import 'package:cake_wallet/palette.dart';
import 'package:cake_wallet/themes/theme_base.dart';
import 'package:cake_wallet/src/widgets/alert_with_two_actions.dart';
2020-09-30 18:23:15 +00:00
import 'package:cake_wallet/utils/show_bar.dart';
2020-09-25 15:32:44 +00:00
import 'package:cake_wallet/utils/show_pop_up.dart';
import 'package:flutter/cupertino.dart';
2020-01-04 19:31:52 +00:00
import 'package:flutter/material.dart';
import 'package:flutter/services.dart';
import 'package:share_plus/share_plus.dart';
2020-01-04 19:31:52 +00:00
import 'package:flutter_mobx/flutter_mobx.dart';
import 'package:cake_wallet/generated/i18n.dart';
import 'package:cake_wallet/src/widgets/primary_button.dart';
import 'package:cake_wallet/src/screens/base_page.dart';
2020-07-06 20:09:03 +00:00
import 'package:cake_wallet/view_model/wallet_seed_view_model.dart';
2020-01-04 19:31:52 +00:00
2020-07-06 20:09:03 +00:00
class WalletSeedPage extends BasePage {
2022-10-12 17:09:57 +00:00
WalletSeedPage(this.walletSeedViewModel, {required this.isNewWalletCreated});
2020-01-08 12:26:34 +00:00
final imageLight = Image.asset('assets/images/crypto_lock_light.png');
final imageDark = Image.asset('assets/images/crypto_lock.png');
2020-01-08 12:26:34 +00:00
@override
2020-01-04 19:31:52 +00:00
String get title => S.current.seed_title;
final bool isNewWalletCreated;
2020-07-06 20:09:03 +00:00
final WalletSeedViewModel walletSeedViewModel;
2020-01-04 19:31:52 +00:00
2020-01-08 12:26:34 +00:00
@override
void onClose(BuildContext context) async {
if (isNewWalletCreated) {
2020-09-30 18:23:15 +00:00
final confirmed = await showPopUp<bool>(
context: context,
builder: (BuildContext context) {
return AlertWithTwoActions(
alertTitle: S.of(context).seed_alert_title,
alertContent: S.of(context).seed_alert_content,
leftButtonText: S.of(context).seed_alert_back,
rightButtonText: S.of(context).seed_alert_yes,
2020-09-30 18:23:15 +00:00
actionLeftButton: () => Navigator.of(context).pop(false),
actionRightButton: () => Navigator.of(context).pop(true));
}) ??
false;
if (confirmed) {
Navigator.of(context).popUntil((route) => route.isFirst);
}
return;
}
Navigator.of(context).pop();
}
2020-01-04 19:31:52 +00:00
@override
2022-10-12 17:09:57 +00:00
Widget? leading(BuildContext context) =>
isNewWalletCreated ? Offstage() : super.leading(context);
2020-01-04 19:31:52 +00:00
@override
Widget trailing(BuildContext context) {
return isNewWalletCreated
? GestureDetector(
2020-09-30 18:23:15 +00:00
onTap: () => onClose(context),
child: Container(
width: 100,
height: 32,
alignment: Alignment.center,
margin: EdgeInsets.only(left: 10),
decoration: BoxDecoration(
borderRadius: BorderRadius.all(Radius.circular(16)),
2022-10-12 17:09:57 +00:00
color: Theme.of(context).accentTextTheme!.caption!.color!),
2020-09-30 18:23:15 +00:00
child: Text(
S.of(context).seed_language_next,
style: TextStyle(
fontSize: 14,
fontWeight: FontWeight.w600,
color: Palette.blueCraiola),
),
),
)
: Offstage();
}
2020-01-04 19:31:52 +00:00
@override
Widget body(BuildContext context) {
final image = currentTheme.type == ThemeType.dark ? imageDark : imageLight;
2020-01-04 19:31:52 +00:00
return WillPopScope(onWillPop: () async => false, child: Container(
2020-07-06 20:09:03 +00:00
padding: EdgeInsets.all(24),
child: Column(
children: <Widget>[
Flexible(
flex: 2,
child: AspectRatio(
aspectRatio: 1,
child: FittedBox(child: image, fit: BoxFit.fill))),
Flexible(
flex: 3,
child: Column(
mainAxisAlignment: MainAxisAlignment.spaceBetween,
children: <Widget>[
Padding(
padding: EdgeInsets.only(top: 33),
child: Observer(builder: (_) {
return Column(
crossAxisAlignment: CrossAxisAlignment.center,
children: <Widget>[
Text(
2020-07-06 20:09:03 +00:00
walletSeedViewModel.name,
style: TextStyle(
fontSize: 20,
fontWeight: FontWeight.w600,
2020-09-30 18:23:15 +00:00
color: Theme.of(context)
2022-10-12 17:09:57 +00:00
.primaryTextTheme!
.headline6!
.color!),
),
Padding(
2020-09-21 11:50:26 +00:00
padding:
2020-09-30 18:23:15 +00:00
EdgeInsets.only(top: 20, left: 16, right: 16),
child: Text(
2020-07-06 20:09:03 +00:00
walletSeedViewModel.seed,
textAlign: TextAlign.center,
style: TextStyle(
fontSize: 14,
fontWeight: FontWeight.normal,
2020-09-30 18:23:15 +00:00
color: Theme.of(context)
2022-10-12 17:09:57 +00:00
.primaryTextTheme!
.caption!
.color!),
),
)
],
);
2020-07-06 20:09:03 +00:00
}),
),
Column(
2020-07-06 20:09:03 +00:00
children: <Widget>[
isNewWalletCreated
2020-09-21 11:50:26 +00:00
? Padding(
2020-09-30 18:23:15 +00:00
padding: EdgeInsets.only(
bottom: 52, left: 43, right: 43),
child: Text(
S.of(context).seed_reminder,
textAlign: TextAlign.center,
style: TextStyle(
fontSize: 12,
fontWeight: FontWeight.normal,
color: Theme.of(context)
2022-10-12 17:09:57 +00:00
.primaryTextTheme!
.overline!
.color!),
2020-09-30 18:23:15 +00:00
),
)
2020-09-21 11:50:26 +00:00
: Offstage(),
Row(
mainAxisSize: MainAxisSize.max,
children: <Widget>[
Flexible(
child: Container(
2020-09-30 18:23:15 +00:00
padding: EdgeInsets.only(right: 8.0),
child: PrimaryButton(
onPressed: () =>
Share.share(walletSeedViewModel.seed),
2020-09-30 18:23:15 +00:00
text: S.of(context).save,
color: Colors.green,
textColor: Colors.white),
)),
Flexible(
child: Container(
2020-09-30 18:23:15 +00:00
padding: EdgeInsets.only(left: 8.0),
child: Builder(
builder: (context) => PrimaryButton(
onPressed: () {
Clipboard.setData(ClipboardData(
text: walletSeedViewModel.seed));
showBar<void>(context,
S.of(context).copied_to_clipboard);
},
text: S.of(context).copy,
color: Theme.of(context)
2022-10-12 17:09:57 +00:00
.accentTextTheme!
.bodyText2!
.color!,
2020-09-30 18:23:15 +00:00
textColor: Colors.white)),
))
],
)
2020-07-06 20:09:03 +00:00
],
)
],
2020-07-06 20:09:03 +00:00
))
],
)));
2020-01-04 19:31:52 +00:00
}
}