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

206 lines
8.3 KiB
Dart
Raw Normal View History

import 'package:cake_wallet/entities/item_from_theme.dart';
import 'package:cake_wallet/palette.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';
2020-07-06 20:09:03 +00:00
import 'package:esys_flutter_share/esys_flutter_share.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';
import 'package:cake_wallet/themes.dart';
2020-01-04 19:31:52 +00:00
2020-07-06 20:09:03 +00:00
class WalletSeedPage extends BasePage {
WalletSeedPage(this.walletSeedViewModel, {@required this.isNewWalletCreated});
2020-01-08 12:26:34 +00:00
static final imageLight = Image.asset('assets/images/crypto_lock_light.png');
static final imageDark = Image.asset('assets/images/crypto_lock.png');
final Map<Themes, Image> items = {
Themes.light: imageLight,
Themes.bright: imageLight,
Themes.dark: imageDark
};
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
2020-07-06 20:09:03 +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)),
color: Theme.of(context).accentTextTheme.caption.color),
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) {
2020-09-21 11:50:26 +00:00
final image =
itemFromTheme(currentTheme: currentTheme, items: items) as Image
?? 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)
2020-07-06 20:09:03 +00:00
.primaryTextTheme
.title
.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)
2020-07-06 20:09:03 +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)
.primaryTextTheme
.overline
.color),
),
)
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.text(
S.of(context).seed_share,
walletSeedViewModel.seed,
'text/plain'),
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)
.accentTextTheme
.body2
.color,
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
}
}