mirror of
https://github.com/cake-tech/cake_wallet.git
synced 2025-01-09 04:19:36 +00:00
Update cake phone screens with null safety
This commit is contained in:
parent
b831165aca
commit
a22234ad36
4 changed files with 213 additions and 94 deletions
|
@ -513,7 +513,7 @@ Route<dynamic> createRoute(RouteSettings settings) {
|
||||||
settings: RouteSettings(name: Routes.phoneNumberProduct),
|
settings: RouteSettings(name: Routes.phoneNumberProduct),
|
||||||
builder: (_) => PhoneNumberProductPage(
|
builder: (_) => PhoneNumberProductPage(
|
||||||
getIt.get<PhonePlanViewModel>(),
|
getIt.get<PhonePlanViewModel>(),
|
||||||
phoneNumberService: settings.arguments as PhoneNumberService,
|
phoneNumberService: settings.arguments as PhoneNumberService?,
|
||||||
),
|
),
|
||||||
);
|
);
|
||||||
|
|
||||||
|
|
|
@ -10,13 +10,15 @@ import 'package:cake_wallet/src/widgets/scollable_with_bottom_section.dart';
|
||||||
import 'package:flutter_mobx/flutter_mobx.dart';
|
import 'package:flutter_mobx/flutter_mobx.dart';
|
||||||
|
|
||||||
class AutoRenewSettingsPage extends BasePage {
|
class AutoRenewSettingsPage extends BasePage {
|
||||||
AutoRenewSettingsPage({required this.phoneNumberService, required this.phonePlanViewModel});
|
AutoRenewSettingsPage(
|
||||||
|
{required this.phoneNumberService, required this.phonePlanViewModel});
|
||||||
|
|
||||||
final PhoneNumberService phoneNumberService;
|
final PhoneNumberService phoneNumberService;
|
||||||
final PhonePlanViewModel phonePlanViewModel;
|
final PhonePlanViewModel phonePlanViewModel;
|
||||||
|
|
||||||
@override
|
@override
|
||||||
Widget body(BuildContext context) => AutoRenewSettingsBody(phoneNumberService, phonePlanViewModel);
|
Widget body(BuildContext context) =>
|
||||||
|
AutoRenewSettingsBody(phoneNumberService, phonePlanViewModel);
|
||||||
|
|
||||||
@override
|
@override
|
||||||
Widget middle(BuildContext context) {
|
Widget middle(BuildContext context) {
|
||||||
|
@ -58,7 +60,10 @@ class AutoRenewSettingsBodyState extends State<AutoRenewSettingsBody> {
|
||||||
style: TextStyle(
|
style: TextStyle(
|
||||||
fontSize: 20,
|
fontSize: 20,
|
||||||
fontWeight: FontWeight.w700,
|
fontWeight: FontWeight.w700,
|
||||||
color: Theme.of(context).primaryTextTheme.headline6?.decorationColor,
|
color: Theme.of(context)
|
||||||
|
.primaryTextTheme
|
||||||
|
.headline6
|
||||||
|
?.decorationColor,
|
||||||
fontFamily: 'Lato',
|
fontFamily: 'Lato',
|
||||||
),
|
),
|
||||||
),
|
),
|
||||||
|
@ -84,11 +89,13 @@ class AutoRenewSettingsBodyState extends State<AutoRenewSettingsBody> {
|
||||||
.map((e) => PlanCard(
|
.map((e) => PlanCard(
|
||||||
plan: e,
|
plan: e,
|
||||||
onTap: () {
|
onTap: () {
|
||||||
if (widget.phonePlanViewModel.selectedPlan != e) {
|
if (widget.phonePlanViewModel.selectedPlan !=
|
||||||
|
e) {
|
||||||
widget.phonePlanViewModel.selectedPlan = e;
|
widget.phonePlanViewModel.selectedPlan = e;
|
||||||
}
|
}
|
||||||
},
|
},
|
||||||
isSelected: widget.phonePlanViewModel.selectedPlan == e,
|
isSelected:
|
||||||
|
widget.phonePlanViewModel.selectedPlan == e,
|
||||||
))
|
))
|
||||||
.toList(),
|
.toList(),
|
||||||
),
|
),
|
||||||
|
@ -104,17 +111,23 @@ class AutoRenewSettingsBodyState extends State<AutoRenewSettingsBody> {
|
||||||
CakePhoneSettingsTile(
|
CakePhoneSettingsTile(
|
||||||
title: S.of(context).free_sms_email_forward,
|
title: S.of(context).free_sms_email_forward,
|
||||||
value: Observer(builder: (_) {
|
value: Observer(builder: (_) {
|
||||||
|
if (widget.phonePlanViewModel.selectedPlan != null) {
|
||||||
return Text(
|
return Text(
|
||||||
"${widget.phonePlanViewModel.selectedPlan.quantity}, " +
|
"${widget.phonePlanViewModel.selectedPlan?.quantity}, " +
|
||||||
"${S.of(context).then} " +
|
"${S.of(context).then} " +
|
||||||
"\$${(widget.phonePlanViewModel.rateInCents / 100).toStringAsFixed(2)} " +
|
"\$${(widget.phonePlanViewModel.rateInCents / 100).toStringAsFixed(2)} " +
|
||||||
"${S.of(context).per_message}",
|
"${S.of(context).per_message}",
|
||||||
style: TextStyle(
|
style: TextStyle(
|
||||||
fontSize: 16,
|
fontSize: 16,
|
||||||
fontWeight: FontWeight.w700,
|
fontWeight: FontWeight.w700,
|
||||||
color: Theme.of(context).primaryTextTheme.headline6?.color,
|
color: Theme.of(context)
|
||||||
|
.primaryTextTheme
|
||||||
|
.headline6
|
||||||
|
?.color,
|
||||||
),
|
),
|
||||||
);
|
);
|
||||||
|
}
|
||||||
|
return const SizedBox();
|
||||||
}),
|
}),
|
||||||
),
|
),
|
||||||
CakePhoneSettingsTile(
|
CakePhoneSettingsTile(
|
||||||
|
@ -124,7 +137,8 @@ class AutoRenewSettingsBodyState extends State<AutoRenewSettingsBody> {
|
||||||
style: TextStyle(
|
style: TextStyle(
|
||||||
fontSize: 16,
|
fontSize: 16,
|
||||||
fontWeight: FontWeight.w700,
|
fontWeight: FontWeight.w700,
|
||||||
color: Theme.of(context).primaryTextTheme.headline6?.color,
|
color:
|
||||||
|
Theme.of(context).primaryTextTheme.headline6?.color,
|
||||||
),
|
),
|
||||||
),
|
),
|
||||||
),
|
),
|
||||||
|
@ -137,16 +151,14 @@ class AutoRenewSettingsBodyState extends State<AutoRenewSettingsBody> {
|
||||||
bottomSection: Column(
|
bottomSection: Column(
|
||||||
children: <Widget>[
|
children: <Widget>[
|
||||||
PrimaryButton(
|
PrimaryButton(
|
||||||
onPressed: () {
|
onPressed: () {},
|
||||||
},
|
|
||||||
text: "${S.of(context).disable} ${S.of(context).auto_renew}",
|
text: "${S.of(context).disable} ${S.of(context).auto_renew}",
|
||||||
color: Theme.of(context).accentTextTheme.caption?.backgroundColor,
|
color: Theme.of(context).accentTextTheme.caption?.backgroundColor,
|
||||||
textColor: Theme.of(context).primaryTextTheme.headline6?.color,
|
textColor: Theme.of(context).primaryTextTheme.headline6?.color,
|
||||||
),
|
),
|
||||||
const SizedBox(height: 8),
|
const SizedBox(height: 8),
|
||||||
PrimaryButton(
|
PrimaryButton(
|
||||||
onPressed: () {
|
onPressed: () {},
|
||||||
},
|
|
||||||
text: "${S.of(context).update} ${S.of(context).auto_renew}",
|
text: "${S.of(context).update} ${S.of(context).auto_renew}",
|
||||||
color: Theme.of(context).accentTextTheme.bodyText1?.color,
|
color: Theme.of(context).accentTextTheme.bodyText1?.color,
|
||||||
textColor: Colors.white,
|
textColor: Colors.white,
|
||||||
|
|
|
@ -31,7 +31,8 @@ class PhoneNumberProductPage extends BasePage {
|
||||||
final PhoneNumberService? phoneNumberService;
|
final PhoneNumberService? phoneNumberService;
|
||||||
|
|
||||||
@override
|
@override
|
||||||
Widget body(BuildContext context) => PhoneNumberProductBody(phonePlanViewModel, phoneNumberService);
|
Widget body(BuildContext context) =>
|
||||||
|
PhoneNumberProductBody(phonePlanViewModel, phoneNumberService);
|
||||||
|
|
||||||
@override
|
@override
|
||||||
Widget middle(BuildContext context) {
|
Widget middle(BuildContext context) {
|
||||||
|
@ -74,7 +75,10 @@ class PhoneNumberProductBodyState extends State<PhoneNumberProductBody> {
|
||||||
style: TextStyle(
|
style: TextStyle(
|
||||||
fontSize: 20,
|
fontSize: 20,
|
||||||
fontWeight: FontWeight.w700,
|
fontWeight: FontWeight.w700,
|
||||||
color: Theme.of(context).primaryTextTheme.headline6?.decorationColor,
|
color: Theme.of(context)
|
||||||
|
.primaryTextTheme
|
||||||
|
.headline6
|
||||||
|
?.decorationColor,
|
||||||
fontFamily: 'Lato',
|
fontFamily: 'Lato',
|
||||||
),
|
),
|
||||||
),
|
),
|
||||||
|
@ -102,11 +106,13 @@ class PhoneNumberProductBodyState extends State<PhoneNumberProductBody> {
|
||||||
.map((e) => PlanCard(
|
.map((e) => PlanCard(
|
||||||
plan: e,
|
plan: e,
|
||||||
onTap: () {
|
onTap: () {
|
||||||
if (widget.phonePlanViewModel.selectedPlan != e) {
|
if (widget.phonePlanViewModel.selectedPlan !=
|
||||||
|
e) {
|
||||||
widget.phonePlanViewModel.selectedPlan = e;
|
widget.phonePlanViewModel.selectedPlan = e;
|
||||||
}
|
}
|
||||||
},
|
},
|
||||||
isSelected: widget.phonePlanViewModel.selectedPlan == e,
|
isSelected:
|
||||||
|
widget.phonePlanViewModel.selectedPlan == e,
|
||||||
))
|
))
|
||||||
.toList(),
|
.toList(),
|
||||||
),
|
),
|
||||||
|
@ -122,17 +128,24 @@ class PhoneNumberProductBodyState extends State<PhoneNumberProductBody> {
|
||||||
CakePhoneSettingsTile(
|
CakePhoneSettingsTile(
|
||||||
title: S.of(context).free_sms_email_forward,
|
title: S.of(context).free_sms_email_forward,
|
||||||
value: Observer(builder: (_) {
|
value: Observer(builder: (_) {
|
||||||
|
if (widget.phonePlanViewModel.selectedPlan != null) {
|
||||||
return Text(
|
return Text(
|
||||||
"${widget.phonePlanViewModel.selectedPlan.quantity}, " +
|
"${widget.phonePlanViewModel.selectedPlan!.quantity}, " +
|
||||||
"${S.of(context).then} " +
|
"${S.of(context).then} " +
|
||||||
"\$${(widget.phonePlanViewModel.rateInCents / 100).toStringAsFixed(2)} " +
|
"\$${(widget.phonePlanViewModel.rateInCents / 100).toStringAsFixed(2)} " +
|
||||||
"${S.of(context).per_message}",
|
"${S.of(context).per_message}",
|
||||||
style: TextStyle(
|
style: TextStyle(
|
||||||
fontSize: 16,
|
fontSize: 16,
|
||||||
fontWeight: FontWeight.w700,
|
fontWeight: FontWeight.w700,
|
||||||
color: Theme.of(context).primaryTextTheme.headline6?.color,
|
color: Theme.of(context)
|
||||||
|
.primaryTextTheme
|
||||||
|
.headline6
|
||||||
|
?.color,
|
||||||
),
|
),
|
||||||
);
|
);
|
||||||
|
}
|
||||||
|
|
||||||
|
return const SizedBox();
|
||||||
}),
|
}),
|
||||||
),
|
),
|
||||||
if (widget.phoneNumberService != null)
|
if (widget.phoneNumberService != null)
|
||||||
|
@ -143,7 +156,10 @@ class PhoneNumberProductBodyState extends State<PhoneNumberProductBody> {
|
||||||
style: TextStyle(
|
style: TextStyle(
|
||||||
fontSize: 16,
|
fontSize: 16,
|
||||||
fontWeight: FontWeight.w700,
|
fontWeight: FontWeight.w700,
|
||||||
color: Theme.of(context).primaryTextTheme.headline6?.color,
|
color: Theme.of(context)
|
||||||
|
.primaryTextTheme
|
||||||
|
.headline6
|
||||||
|
?.color,
|
||||||
),
|
),
|
||||||
),
|
),
|
||||||
),
|
),
|
||||||
|
@ -154,8 +170,8 @@ class PhoneNumberProductBodyState extends State<PhoneNumberProductBody> {
|
||||||
return Row(
|
return Row(
|
||||||
children: [
|
children: [
|
||||||
Image.asset(
|
Image.asset(
|
||||||
CountryPickerUtils.getFlagImageAssetPath(
|
CountryPickerUtils.getFlagImageAssetPath(widget
|
||||||
widget.phonePlanViewModel.selectedCountry.isoCode),
|
.phonePlanViewModel.selectedCountry.isoCode),
|
||||||
height: 20.0,
|
height: 20.0,
|
||||||
width: 36.0,
|
width: 36.0,
|
||||||
fit: BoxFit.fill,
|
fit: BoxFit.fill,
|
||||||
|
@ -166,13 +182,18 @@ class PhoneNumberProductBodyState extends State<PhoneNumberProductBody> {
|
||||||
children: [
|
children: [
|
||||||
Flexible(
|
Flexible(
|
||||||
child: Padding(
|
child: Padding(
|
||||||
padding: const EdgeInsets.only(left: 8, right: 6),
|
padding: const EdgeInsets.only(
|
||||||
|
left: 8, right: 6),
|
||||||
child: Text(
|
child: Text(
|
||||||
widget.phonePlanViewModel.selectedCountry.name,
|
widget.phonePlanViewModel
|
||||||
|
.selectedCountry.name,
|
||||||
style: TextStyle(
|
style: TextStyle(
|
||||||
fontSize: 16,
|
fontSize: 16,
|
||||||
fontWeight: FontWeight.w700,
|
fontWeight: FontWeight.w700,
|
||||||
color: Theme.of(context).primaryTextTheme.headline6?.color,
|
color: Theme.of(context)
|
||||||
|
.primaryTextTheme
|
||||||
|
.headline6
|
||||||
|
?.color,
|
||||||
),
|
),
|
||||||
),
|
),
|
||||||
),
|
),
|
||||||
|
@ -182,7 +203,10 @@ class PhoneNumberProductBodyState extends State<PhoneNumberProductBody> {
|
||||||
style: TextStyle(
|
style: TextStyle(
|
||||||
fontSize: 16,
|
fontSize: 16,
|
||||||
fontWeight: FontWeight.w400,
|
fontWeight: FontWeight.w400,
|
||||||
color: Theme.of(context).primaryTextTheme.headline6?.color,
|
color: Theme.of(context)
|
||||||
|
.primaryTextTheme
|
||||||
|
.headline6
|
||||||
|
?.color,
|
||||||
),
|
),
|
||||||
),
|
),
|
||||||
],
|
],
|
||||||
|
@ -190,7 +214,10 @@ class PhoneNumberProductBodyState extends State<PhoneNumberProductBody> {
|
||||||
),
|
),
|
||||||
Icon(
|
Icon(
|
||||||
Icons.arrow_forward_ios,
|
Icons.arrow_forward_ios,
|
||||||
color: Theme.of(context).primaryTextTheme.headline6?.color,
|
color: Theme.of(context)
|
||||||
|
.primaryTextTheme
|
||||||
|
.headline6
|
||||||
|
?.color,
|
||||||
size: 16,
|
size: 16,
|
||||||
),
|
),
|
||||||
],
|
],
|
||||||
|
@ -205,14 +232,17 @@ class PhoneNumberProductBodyState extends State<PhoneNumberProductBody> {
|
||||||
final Country _country = country as Country;
|
final Country _country = country as Country;
|
||||||
return "${_country.name} (+${_country.phoneCode})";
|
return "${_country.name} (+${_country.phoneCode})";
|
||||||
},
|
},
|
||||||
selectedAtIndex: countryList.indexOf(widget.phonePlanViewModel.selectedCountry),
|
selectedAtIndex: countryList.indexOf(
|
||||||
|
widget.phonePlanViewModel.selectedCountry),
|
||||||
mainAxisAlignment: MainAxisAlignment.start,
|
mainAxisAlignment: MainAxisAlignment.start,
|
||||||
onItemSelected: (Country country) {
|
onItemSelected: (Country country) {
|
||||||
widget.phonePlanViewModel.selectedCountry = country;
|
widget.phonePlanViewModel.selectedCountry =
|
||||||
|
country;
|
||||||
},
|
},
|
||||||
images: countryList
|
images: countryList
|
||||||
.map((e) => Image.asset(
|
.map((e) => Image.asset(
|
||||||
CountryPickerUtils.getFlagImageAssetPath(e.isoCode),
|
CountryPickerUtils.getFlagImageAssetPath(
|
||||||
|
e.isoCode),
|
||||||
height: 20.0,
|
height: 20.0,
|
||||||
width: 36.0,
|
width: 36.0,
|
||||||
fit: BoxFit.fill,
|
fit: BoxFit.fill,
|
||||||
|
@ -221,13 +251,20 @@ class PhoneNumberProductBodyState extends State<PhoneNumberProductBody> {
|
||||||
.toList(),
|
.toList(),
|
||||||
isSeparated: false,
|
isSeparated: false,
|
||||||
hintText: S.of(context).search_country,
|
hintText: S.of(context).search_country,
|
||||||
matchingCriteria: (dynamic country, String searchText) {
|
matchingCriteria:
|
||||||
|
(dynamic country, String searchText) {
|
||||||
final Country _country = country as Country;
|
final Country _country = country as Country;
|
||||||
searchText = searchText.toLowerCase();
|
searchText = searchText.toLowerCase();
|
||||||
return _country.name.toLowerCase().contains(searchText) ||
|
return _country.name
|
||||||
|
.toLowerCase()
|
||||||
|
.contains(searchText) ||
|
||||||
_country.phoneCode.contains(searchText) ||
|
_country.phoneCode.contains(searchText) ||
|
||||||
_country.isoCode.toLowerCase().contains(searchText) ||
|
_country.isoCode
|
||||||
_country.iso3Code.toLowerCase().contains(searchText);
|
.toLowerCase()
|
||||||
|
.contains(searchText) ||
|
||||||
|
_country.iso3Code
|
||||||
|
.toLowerCase()
|
||||||
|
.contains(searchText);
|
||||||
},
|
},
|
||||||
),
|
),
|
||||||
);
|
);
|
||||||
|
@ -240,35 +277,48 @@ class PhoneNumberProductBodyState extends State<PhoneNumberProductBody> {
|
||||||
Text(
|
Text(
|
||||||
S.of(context).additional_sms_messages,
|
S.of(context).additional_sms_messages,
|
||||||
style: TextStyle(
|
style: TextStyle(
|
||||||
color: Theme.of(context).accentTextTheme.subtitle1?.color,
|
color: Theme.of(context)
|
||||||
|
.accentTextTheme
|
||||||
|
.subtitle1
|
||||||
|
?.color,
|
||||||
),
|
),
|
||||||
),
|
),
|
||||||
Container(
|
Container(
|
||||||
decoration: BoxDecoration(
|
decoration: BoxDecoration(
|
||||||
borderRadius: BorderRadius.circular(30),
|
borderRadius: BorderRadius.circular(30),
|
||||||
color: Theme.of(context).primaryTextTheme.displayMedium?.decorationColor,
|
color: Theme.of(context)
|
||||||
|
.primaryTextTheme
|
||||||
|
.displayMedium
|
||||||
|
?.decorationColor,
|
||||||
),
|
),
|
||||||
child: Row(
|
child: Row(
|
||||||
children: [
|
children: [
|
||||||
GestureDetector(
|
GestureDetector(
|
||||||
onTap: () => widget.phonePlanViewModel.removeAdditionalSms(),
|
onTap: () => widget.phonePlanViewModel
|
||||||
|
.removeAdditionalSms(),
|
||||||
child: quantityIcon(Icons.remove),
|
child: quantityIcon(Icons.remove),
|
||||||
),
|
),
|
||||||
Padding(
|
Padding(
|
||||||
padding: const EdgeInsets.symmetric(horizontal: 16),
|
padding:
|
||||||
|
const EdgeInsets.symmetric(horizontal: 16),
|
||||||
child: Observer(builder: (_) {
|
child: Observer(builder: (_) {
|
||||||
return Text(
|
return Text(
|
||||||
widget.phonePlanViewModel.additionalSms.toString(),
|
widget.phonePlanViewModel.additionalSms
|
||||||
|
.toString(),
|
||||||
style: TextStyle(
|
style: TextStyle(
|
||||||
fontSize: 16,
|
fontSize: 16,
|
||||||
fontWeight: FontWeight.w700,
|
fontWeight: FontWeight.w700,
|
||||||
color: Theme.of(context).primaryTextTheme.headline6?.color,
|
color: Theme.of(context)
|
||||||
|
.primaryTextTheme
|
||||||
|
.headline6
|
||||||
|
?.color,
|
||||||
),
|
),
|
||||||
);
|
);
|
||||||
}),
|
}),
|
||||||
),
|
),
|
||||||
GestureDetector(
|
GestureDetector(
|
||||||
onTap: () => widget.phonePlanViewModel.addAdditionalSms(),
|
onTap: () =>
|
||||||
|
widget.phonePlanViewModel.addAdditionalSms(),
|
||||||
child: quantityIcon(Icons.add),
|
child: quantityIcon(Icons.add),
|
||||||
),
|
),
|
||||||
],
|
],
|
||||||
|
@ -293,7 +343,8 @@ class PhoneNumberProductBodyState extends State<PhoneNumberProductBody> {
|
||||||
text: "\$${widget.phonePlanViewModel.totalPrice}",
|
text: "\$${widget.phonePlanViewModel.totalPrice}",
|
||||||
style: TextStyle(
|
style: TextStyle(
|
||||||
fontWeight: FontWeight.w700,
|
fontWeight: FontWeight.w700,
|
||||||
color: Theme.of(context).primaryTextTheme.headline6?.color,
|
color:
|
||||||
|
Theme.of(context).primaryTextTheme.headline6?.color,
|
||||||
),
|
),
|
||||||
),
|
),
|
||||||
],
|
],
|
||||||
|
@ -313,21 +364,34 @@ class PhoneNumberProductBodyState extends State<PhoneNumberProductBody> {
|
||||||
builder: (dialogContext) {
|
builder: (dialogContext) {
|
||||||
return AlertWithTwoActions(
|
return AlertWithTwoActions(
|
||||||
alertTitle: S.of(context).confirm_payment,
|
alertTitle: S.of(context).confirm_payment,
|
||||||
alertTitleColor: Theme.of(context).primaryTextTheme.headline6?.decorationColor,
|
alertTitleColor: Theme.of(context)
|
||||||
|
.primaryTextTheme
|
||||||
|
.headline6
|
||||||
|
?.decorationColor,
|
||||||
alertContent: S.of(context).confirm_delete_template,
|
alertContent: S.of(context).confirm_delete_template,
|
||||||
contentWidget: Column(
|
contentWidget: Column(
|
||||||
mainAxisSize: MainAxisSize.min,
|
mainAxisSize: MainAxisSize.min,
|
||||||
children: [
|
children: [
|
||||||
ReceiptRow(
|
ReceiptRow(
|
||||||
title: S.of(context).amount, value: amountText(widget.phonePlanViewModel.totalPrice)),
|
title: S.of(context).amount,
|
||||||
ReceiptRow(title: "${S.of(context).cake_pay_balance}: ", value: amountText(100)),
|
value: amountText(
|
||||||
|
widget.phonePlanViewModel.totalPrice)),
|
||||||
|
ReceiptRow(
|
||||||
|
title: "${S.of(context).cake_pay_balance}: ",
|
||||||
|
value: amountText(100)),
|
||||||
],
|
],
|
||||||
),
|
),
|
||||||
isDividerExists: true,
|
isDividerExists: true,
|
||||||
rightButtonText: S.of(context).ok,
|
rightButtonText: S.of(context).ok,
|
||||||
leftButtonText: S.of(context).cancel,
|
leftButtonText: S.of(context).cancel,
|
||||||
rightActionButtonColor: Theme.of(context).accentTextTheme.bodyText1?.color,
|
rightActionButtonColor: Theme.of(context)
|
||||||
leftActionButtonColor: Theme.of(context).primaryTextTheme.bodyText1?.backgroundColor,
|
.accentTextTheme
|
||||||
|
.bodyText1
|
||||||
|
?.color,
|
||||||
|
leftActionButtonColor: Theme.of(context)
|
||||||
|
.primaryTextTheme
|
||||||
|
.bodyText1
|
||||||
|
?.backgroundColor,
|
||||||
actionRightButton: () {
|
actionRightButton: () {
|
||||||
Navigator.of(dialogContext).pop();
|
Navigator.of(dialogContext).pop();
|
||||||
Navigator.pushNamedAndRemoveUntil(
|
Navigator.pushNamedAndRemoveUntil(
|
||||||
|
@ -336,10 +400,12 @@ class PhoneNumberProductBodyState extends State<PhoneNumberProductBody> {
|
||||||
ModalRoute.withName(Routes.cakePhoneWelcome),
|
ModalRoute.withName(Routes.cakePhoneWelcome),
|
||||||
);
|
);
|
||||||
},
|
},
|
||||||
actionLeftButton: () => Navigator.of(dialogContext).pop());
|
actionLeftButton: () =>
|
||||||
|
Navigator.of(dialogContext).pop());
|
||||||
});
|
});
|
||||||
},
|
},
|
||||||
text: "${S.of(context).pay_with} ${S.of(context).cake_pay_balance}",
|
text:
|
||||||
|
"${S.of(context).pay_with} ${S.of(context).cake_pay_balance}",
|
||||||
color: Theme.of(context).accentTextTheme.caption?.backgroundColor,
|
color: Theme.of(context).accentTextTheme.caption?.backgroundColor,
|
||||||
textColor: Theme.of(context).primaryTextTheme.headline6?.color,
|
textColor: Theme.of(context).primaryTextTheme.headline6?.color,
|
||||||
),
|
),
|
||||||
|
@ -351,14 +417,18 @@ class PhoneNumberProductBodyState extends State<PhoneNumberProductBody> {
|
||||||
builder: (dialogContext) {
|
builder: (dialogContext) {
|
||||||
return AlertWithTwoActions(
|
return AlertWithTwoActions(
|
||||||
alertTitle: S.of(context).confirm_sending,
|
alertTitle: S.of(context).confirm_sending,
|
||||||
alertTitleColor: Theme.of(context).primaryTextTheme.headline6?.decorationColor,
|
alertTitleColor: Theme.of(context)
|
||||||
|
.primaryTextTheme
|
||||||
|
.headline6
|
||||||
|
?.decorationColor,
|
||||||
alertContent: S.of(context).confirm_delete_template,
|
alertContent: S.of(context).confirm_delete_template,
|
||||||
contentWidget: Column(
|
contentWidget: Column(
|
||||||
mainAxisSize: MainAxisSize.min,
|
mainAxisSize: MainAxisSize.min,
|
||||||
children: [
|
children: [
|
||||||
ReceiptRow(
|
ReceiptRow(
|
||||||
title: S.of(context).amount,
|
title: S.of(context).amount,
|
||||||
value: cryptoAmount(widget.phonePlanViewModel.totalPrice),
|
value: cryptoAmount(
|
||||||
|
widget.phonePlanViewModel.totalPrice),
|
||||||
),
|
),
|
||||||
ReceiptRow(
|
ReceiptRow(
|
||||||
title: S.of(context).send_fee,
|
title: S.of(context).send_fee,
|
||||||
|
@ -366,8 +436,13 @@ class PhoneNumberProductBodyState extends State<PhoneNumberProductBody> {
|
||||||
.get<AppStore>()
|
.get<AppStore>()
|
||||||
.wallet!
|
.wallet!
|
||||||
.calculateEstimatedFee(
|
.calculateEstimatedFee(
|
||||||
getIt.get<AppStore>().settingsStore.priority[getIt.get<AppStore>().wallet!.type]!,
|
getIt
|
||||||
widget.phonePlanViewModel.totalPrice.floor(),
|
.get<AppStore>()
|
||||||
|
.settingsStore
|
||||||
|
.priority[
|
||||||
|
getIt.get<AppStore>().wallet!.type]!,
|
||||||
|
widget.phonePlanViewModel.totalPrice
|
||||||
|
.floor(),
|
||||||
)
|
)
|
||||||
.toDouble()),
|
.toDouble()),
|
||||||
),
|
),
|
||||||
|
@ -377,7 +452,10 @@ class PhoneNumberProductBodyState extends State<PhoneNumberProductBody> {
|
||||||
style: TextStyle(
|
style: TextStyle(
|
||||||
fontSize: 16,
|
fontSize: 16,
|
||||||
fontWeight: FontWeight.w600,
|
fontWeight: FontWeight.w600,
|
||||||
color: Theme.of(context).primaryTextTheme.headline6?.color,
|
color: Theme.of(context)
|
||||||
|
.primaryTextTheme
|
||||||
|
.headline6
|
||||||
|
?.color,
|
||||||
),
|
),
|
||||||
),
|
),
|
||||||
const SizedBox(height: 16),
|
const SizedBox(height: 16),
|
||||||
|
@ -387,7 +465,10 @@ class PhoneNumberProductBodyState extends State<PhoneNumberProductBody> {
|
||||||
style: TextStyle(
|
style: TextStyle(
|
||||||
fontSize: 10,
|
fontSize: 10,
|
||||||
fontWeight: FontWeight.w600,
|
fontWeight: FontWeight.w600,
|
||||||
color: Theme.of(context).accentTextTheme.subtitle1?.color,
|
color: Theme.of(context)
|
||||||
|
.accentTextTheme
|
||||||
|
.subtitle1
|
||||||
|
?.color,
|
||||||
),
|
),
|
||||||
textAlign: TextAlign.center,
|
textAlign: TextAlign.center,
|
||||||
),
|
),
|
||||||
|
@ -396,16 +477,24 @@ class PhoneNumberProductBodyState extends State<PhoneNumberProductBody> {
|
||||||
isDividerExists: true,
|
isDividerExists: true,
|
||||||
rightButtonText: S.of(context).ok,
|
rightButtonText: S.of(context).ok,
|
||||||
leftButtonText: S.of(context).cancel,
|
leftButtonText: S.of(context).cancel,
|
||||||
rightActionButtonColor: Theme.of(context).accentTextTheme.bodyText1?.color,
|
rightActionButtonColor: Theme.of(context)
|
||||||
leftActionButtonColor: Theme.of(context).primaryTextTheme.bodyText1?.backgroundColor,
|
.accentTextTheme
|
||||||
|
.bodyText1
|
||||||
|
?.color,
|
||||||
|
leftActionButtonColor: Theme.of(context)
|
||||||
|
.primaryTextTheme
|
||||||
|
.bodyText1
|
||||||
|
?.backgroundColor,
|
||||||
actionRightButton: () {
|
actionRightButton: () {
|
||||||
Navigator.of(dialogContext).pop();
|
Navigator.of(dialogContext).pop();
|
||||||
showPaymentConfirmationPopup();
|
showPaymentConfirmationPopup();
|
||||||
},
|
},
|
||||||
actionLeftButton: () => Navigator.of(dialogContext).pop());
|
actionLeftButton: () =>
|
||||||
|
Navigator.of(dialogContext).pop());
|
||||||
});
|
});
|
||||||
},
|
},
|
||||||
text: "${S.of(context).pay_with} ${getIt.get<AppStore>().wallet!.currency.toString()}",
|
text:
|
||||||
|
"${S.of(context).pay_with} ${getIt.get<AppStore>().wallet!.currency.toString()}",
|
||||||
color: Theme.of(context).accentTextTheme.bodyText1?.color,
|
color: Theme.of(context).accentTextTheme.bodyText1?.color,
|
||||||
textColor: Colors.white,
|
textColor: Colors.white,
|
||||||
),
|
),
|
||||||
|
@ -504,7 +593,8 @@ class PhoneNumberProductBodyState extends State<PhoneNumberProductBody> {
|
||||||
builder: (dialogContext) {
|
builder: (dialogContext) {
|
||||||
return InfoAlertDialog(
|
return InfoAlertDialog(
|
||||||
alertTitle: S.of(context).awaiting_payment_confirmation,
|
alertTitle: S.of(context).awaiting_payment_confirmation,
|
||||||
alertTitleColor: Theme.of(context).primaryTextTheme.headline6?.decorationColor,
|
alertTitleColor:
|
||||||
|
Theme.of(context).primaryTextTheme.headline6?.decorationColor,
|
||||||
alertContentPadding: EdgeInsets.zero,
|
alertContentPadding: EdgeInsets.zero,
|
||||||
alertContent: Padding(
|
alertContent: Padding(
|
||||||
padding: const EdgeInsets.only(top: 8, bottom: 32),
|
padding: const EdgeInsets.only(top: 8, bottom: 32),
|
||||||
|
@ -517,7 +607,8 @@ class PhoneNumberProductBodyState extends State<PhoneNumberProductBody> {
|
||||||
style: TextStyle(
|
style: TextStyle(
|
||||||
fontSize: 16,
|
fontSize: 16,
|
||||||
fontWeight: FontWeight.w500,
|
fontWeight: FontWeight.w500,
|
||||||
color: Theme.of(context).primaryTextTheme.headline6?.color,
|
color:
|
||||||
|
Theme.of(context).primaryTextTheme.headline6?.color,
|
||||||
),
|
),
|
||||||
),
|
),
|
||||||
),
|
),
|
||||||
|
@ -538,7 +629,10 @@ class PhoneNumberProductBodyState extends State<PhoneNumberProductBody> {
|
||||||
style: TextStyle(
|
style: TextStyle(
|
||||||
fontSize: 12,
|
fontSize: 12,
|
||||||
fontWeight: FontWeight.w500,
|
fontWeight: FontWeight.w500,
|
||||||
color: Theme.of(context).accentTextTheme.subtitle1?.color,
|
color: Theme.of(context)
|
||||||
|
.accentTextTheme
|
||||||
|
.subtitle1
|
||||||
|
?.color,
|
||||||
),
|
),
|
||||||
),
|
),
|
||||||
Padding(
|
Padding(
|
||||||
|
@ -549,7 +643,10 @@ class PhoneNumberProductBodyState extends State<PhoneNumberProductBody> {
|
||||||
style: TextStyle(
|
style: TextStyle(
|
||||||
fontSize: 12,
|
fontSize: 12,
|
||||||
fontWeight: FontWeight.w500,
|
fontWeight: FontWeight.w500,
|
||||||
color: Theme.of(context).primaryTextTheme.headline6?.color,
|
color: Theme.of(context)
|
||||||
|
.primaryTextTheme
|
||||||
|
.headline6
|
||||||
|
?.color,
|
||||||
),
|
),
|
||||||
),
|
),
|
||||||
),
|
),
|
||||||
|
@ -558,7 +655,10 @@ class PhoneNumberProductBodyState extends State<PhoneNumberProductBody> {
|
||||||
style: TextStyle(
|
style: TextStyle(
|
||||||
fontSize: 12,
|
fontSize: 12,
|
||||||
fontWeight: FontWeight.w500,
|
fontWeight: FontWeight.w500,
|
||||||
color: Theme.of(context).accentTextTheme.subtitle1?.color,
|
color: Theme.of(context)
|
||||||
|
.accentTextTheme
|
||||||
|
.subtitle1
|
||||||
|
?.color,
|
||||||
),
|
),
|
||||||
),
|
),
|
||||||
Padding(
|
Padding(
|
||||||
|
@ -569,7 +669,10 @@ class PhoneNumberProductBodyState extends State<PhoneNumberProductBody> {
|
||||||
style: TextStyle(
|
style: TextStyle(
|
||||||
fontSize: 12,
|
fontSize: 12,
|
||||||
fontWeight: FontWeight.w500,
|
fontWeight: FontWeight.w500,
|
||||||
color: Theme.of(context).primaryTextTheme.headline6?.color,
|
color: Theme.of(context)
|
||||||
|
.primaryTextTheme
|
||||||
|
.headline6
|
||||||
|
?.color,
|
||||||
),
|
),
|
||||||
),
|
),
|
||||||
),
|
),
|
||||||
|
|
|
@ -8,41 +8,45 @@ part 'phone_plan_view_model.g.dart';
|
||||||
class PhonePlanViewModel = PhonePlanViewModelBase with _$PhonePlanViewModel;
|
class PhonePlanViewModel = PhonePlanViewModelBase with _$PhonePlanViewModel;
|
||||||
|
|
||||||
abstract class PhonePlanViewModelBase with Store {
|
abstract class PhonePlanViewModelBase with Store {
|
||||||
PhonePlanViewModelBase({this.selectedPlan}) : this.additionalSms = 0 {
|
PhonePlanViewModelBase({this.selectedPlan})
|
||||||
|
: this.additionalSms = 0,
|
||||||
|
this.rateInCents = 0,
|
||||||
|
this.selectedCountry =
|
||||||
|
countryList.firstWhere((element) => element.iso3Code == "USA"),
|
||||||
|
this.servicePlans = ObservableList<ServicePlan>.of([]) {
|
||||||
rateInCents = 20; // TODO: get from api
|
rateInCents = 20; // TODO: get from api
|
||||||
|
|
||||||
servicePlans = [
|
servicePlans = ObservableList<ServicePlan>.of([
|
||||||
ServicePlan(id: "1", duration: 1, price: 20, quantity: 30),
|
ServicePlan(id: "1", duration: 1, price: 20, quantity: 30),
|
||||||
ServicePlan(id: "2", duration: 3, price: 10, quantity: 60),
|
ServicePlan(id: "2", duration: 3, price: 10, quantity: 60),
|
||||||
ServicePlan(id: "3", duration: 6, price: 9, quantity: 120),
|
ServicePlan(id: "3", duration: 6, price: 9, quantity: 120),
|
||||||
ServicePlan(id: "4", duration: 12, price: 5, quantity: 200),
|
ServicePlan(id: "4", duration: 12, price: 5, quantity: 200),
|
||||||
ServicePlan(id: "5", duration: 24, price: 2, quantity: 400),
|
ServicePlan(id: "5", duration: 24, price: 2, quantity: 400),
|
||||||
];
|
]);
|
||||||
// TODO: servicePlans = _getServicesFromApi
|
// TODO: servicePlans = _getServicesFromApi
|
||||||
|
|
||||||
selectedPlan ??= servicePlans!.first;
|
selectedPlan ??= servicePlans.first;
|
||||||
|
|
||||||
selectedCountry = countryList.firstWhere((element) => element.iso3Code == "USA");
|
|
||||||
}
|
}
|
||||||
|
|
||||||
@observable
|
@observable
|
||||||
ServicePlan? selectedPlan;
|
ServicePlan? selectedPlan;
|
||||||
|
|
||||||
@observable
|
@observable
|
||||||
Country? selectedCountry;
|
Country selectedCountry;
|
||||||
|
|
||||||
@observable
|
@observable
|
||||||
List<ServicePlan>? servicePlans;
|
ObservableList<ServicePlan> servicePlans;
|
||||||
|
|
||||||
@observable
|
@observable
|
||||||
int additionalSms;
|
int additionalSms;
|
||||||
|
|
||||||
@observable
|
@observable
|
||||||
int? rateInCents;
|
int rateInCents;
|
||||||
|
|
||||||
@computed
|
@computed
|
||||||
double get totalPrice => (selectedPlan?.price ?? 0)
|
double get totalPrice =>
|
||||||
+ (additionalSms * ((rateInCents ?? 0) / 100)).toDouble();
|
(selectedPlan?.price ?? 0) +
|
||||||
|
(additionalSms * (rateInCents / 100)).toDouble();
|
||||||
|
|
||||||
@action
|
@action
|
||||||
void addAdditionalSms() => additionalSms++;
|
void addAdditionalSms() => additionalSms++;
|
||||||
|
|
Loading…
Reference in a new issue