ente/lib/ui/payment/subscription_common_widgets.dart

203 lines
6.1 KiB
Dart
Raw Normal View History

import 'package:flutter/material.dart';
2023-05-04 10:35:47 +00:00
import "package:intl/intl.dart";
import 'package:photos/ente_theme_data.dart';
import "package:photos/generated/l10n.dart";
import "package:photos/models/api/storage_bonus/bonus.dart";
import 'package:photos/models/subscription.dart';
2023-06-29 11:30:06 +00:00
import "package:photos/services/update_service.dart";
import "package:photos/theme/ente_theme.dart";
import "package:photos/ui/components/captioned_text_widget.dart";
import "package:photos/ui/components/menu_item_widget/menu_item_widget.dart";
import 'package:photos/ui/payment/billing_questions_widget.dart';
import 'package:photos/utils/data_util.dart';
class SubscriptionHeaderWidget extends StatefulWidget {
final bool? isOnboarding;
final int? currentUsage;
2022-06-11 08:23:52 +00:00
const SubscriptionHeaderWidget({
Key? key,
2022-06-11 08:23:52 +00:00
this.isOnboarding,
this.currentUsage,
}) : super(key: key);
@override
State<StatefulWidget> createState() {
return _SubscriptionHeaderWidgetState();
}
}
class _SubscriptionHeaderWidgetState extends State<SubscriptionHeaderWidget> {
@override
Widget build(BuildContext context) {
if (widget.isOnboarding!) {
return Padding(
padding: const EdgeInsets.fromLTRB(20, 20, 20, 24),
child: Column(
crossAxisAlignment: CrossAxisAlignment.start,
children: [
Row(
children: [
Text(
S.of(context).selectYourPlan,
2023-06-13 06:41:31 +00:00
style: Theme.of(context).textTheme.headlineMedium,
),
],
),
2023-02-18 06:31:43 +00:00
const SizedBox(height: 10),
Text(
S.of(context).enteSubscriptionPitch,
2023-06-13 06:41:31 +00:00
style: Theme.of(context).textTheme.bodySmall,
),
2023-02-18 06:31:43 +00:00
const SizedBox(height: 4),
Text(
S.of(context).enteSubscriptionShareWithFamily,
2023-06-13 06:41:31 +00:00
style: Theme.of(context).textTheme.bodySmall,
),
],
),
);
} else {
return SizedBox(
2022-05-03 11:53:40 +00:00
height: 72,
2022-04-28 05:24:26 +00:00
width: double.infinity,
child: Padding(
2022-05-03 11:53:40 +00:00
padding: const EdgeInsets.all(24.0),
child: RichText(
text: TextSpan(
children: [
TextSpan(
text: S.of(context).currentUsageIs,
2023-06-13 06:41:31 +00:00
style: Theme.of(context).textTheme.titleMedium,
2022-06-11 08:23:52 +00:00
),
2022-05-03 11:53:40 +00:00
TextSpan(
text: formatBytes(widget.currentUsage!),
2022-07-03 09:49:33 +00:00
style: Theme.of(context)
.textTheme
2023-06-13 06:41:31 +00:00
.titleMedium!
2022-07-03 09:49:33 +00:00
.copyWith(fontWeight: FontWeight.bold),
2023-08-19 11:39:56 +00:00
),
2022-05-03 11:53:40 +00:00
],
),
),
),
);
}
}
}
class ValidityWidget extends StatelessWidget {
final Subscription? currentSubscription;
final BonusData? bonusData;
const ValidityWidget({Key? key, this.currentSubscription, this.bonusData})
: super(key: key);
@override
Widget build(BuildContext context) {
if (currentSubscription == null) {
2022-09-20 13:03:00 +00:00
return const SizedBox.shrink();
}
2023-11-20 13:10:57 +00:00
final List<Bonus> addOnBonus = bonusData?.getAddOnBonuses() ?? <Bonus>[];
final bool isFreeTrialSub = currentSubscription!.productID == freeProductID;
2023-11-20 13:10:57 +00:00
bool hideSubValidityView = false;
if (isFreeTrialSub && addOnBonus.isNotEmpty) {
hideSubValidityView = true;
}
if (!currentSubscription!.isValid()) {
hideSubValidityView = true;
}
2023-05-04 10:35:47 +00:00
final endDate =
DateFormat.yMMMd(Localizations.localeOf(context).languageCode).format(
DateTime.fromMicrosecondsSinceEpoch(currentSubscription!.expiryTime),
2022-06-11 08:23:52 +00:00
);
2023-05-04 10:35:47 +00:00
var message = S.of(context).renewsOn(endDate);
if (isFreeTrialSub) {
2023-06-29 11:30:06 +00:00
message = UpdateService.instance.isPlayStoreFlavor()
? S.of(context).playStoreFreeTrialValidTill(endDate)
: S.of(context).freeTrialValidTill(endDate);
} else if (currentSubscription!.attributes?.isCancelled ?? false) {
message = S.of(context).subWillBeCancelledOn(endDate);
2023-11-20 13:10:57 +00:00
if (addOnBonus.isNotEmpty) {
hideSubValidityView = true;
}
}
2023-11-20 13:10:57 +00:00
return Padding(
padding: const EdgeInsets.only(top: 0),
child: Column(
children: [
if (!hideSubValidityView)
Text(
message,
style: Theme.of(context).textTheme.bodySmall,
textAlign: TextAlign.center,
),
if (addOnBonus.isNotEmpty)
...addOnBonus.map((bonus) => AddOnBonusValidity(bonus)).toList(),
],
),
);
}
}
class AddOnBonusValidity extends StatelessWidget {
final Bonus bonus;
const AddOnBonusValidity(this.bonus, {super.key});
@override
Widget build(BuildContext context) {
final endDate =
DateFormat.yMMMd(Localizations.localeOf(context).languageCode).format(
DateTime.fromMicrosecondsSinceEpoch(bonus.validTill),
);
final String storage = formatBytes(bonus.storage);
2021-08-23 10:22:07 +00:00
return Padding(
2023-11-20 13:10:57 +00:00
padding: const EdgeInsets.only(top: 8, bottom: 8),
2021-08-23 10:22:07 +00:00
child: Text(
2023-11-20 13:10:57 +00:00
S.of(context).addOnValidTill(storage, endDate),
2023-06-13 06:41:31 +00:00
style: Theme.of(context).textTheme.bodySmall,
2023-06-29 11:40:58 +00:00
textAlign: TextAlign.center,
),
);
}
}
class SubFaqWidget extends StatelessWidget {
final bool isOnboarding;
const SubFaqWidget({Key? key, this.isOnboarding = false}) : super(key: key);
2022-07-03 06:49:00 +00:00
@override
Widget build(BuildContext context) {
final colorScheme = getEnteColorScheme(context);
return Padding(
padding: EdgeInsets.fromLTRB(16, 40, 16, isOnboarding ? 40 : 4),
child: MenuItemWidget(
captionedTextWidget: CaptionedTextWidget(
title: S.of(context).faqs,
),
menuItemColor: colorScheme.fillFaint,
trailingWidget: Icon(
Icons.chevron_right_outlined,
color: colorScheme.strokeBase,
),
singleBorderRadius: 4,
alignCaptionedTextToLeft: true,
onTap: () async {
showModalBottomSheet<void>(
backgroundColor: Theme.of(context).colorScheme.bgColorForQuestions,
barrierColor: Colors.black87,
context: context,
builder: (context) {
2022-07-04 06:02:17 +00:00
return const BillingQuestionsWidget();
},
);
},
),
);
}
}