Flutter совет: шаблон RevenueCat
Вот несколько методов расширения, чтобы упростить работу с пакетом RevenueCat:
Получение периода подписки продукта в виде Duration
Получение количества пробных дней для продукта
Получение списка характеристик из метаданных RevenueCat в зависимости от языка пользователя
Оцените новую рубрику и напишите своё мнение! 👍💬
Все подобные новости можно найти по хэштегу #FlutterPulseTips
#flutter #dart #flutterpulse #FlutterPulseTips #RevenueCat #boilerplate #mobiledevelopment #appdevelopment #codingtips
Вот несколько методов расширения, чтобы упростить работу с пакетом RevenueCat:
Получение периода подписки продукта в виде Duration
@override
Duration get duration => switch (revenueCatPackage.storeProduct.subscriptionPeriod) {
'P1W' => const Duration(days: 7),
'P1M' => const Duration(days: 30),
'P3M' => const Duration(days: 90),
'P6M' => const Duration(days: 180),
'P1Y' => const Duration(days: 365),
_ => Duration.zero,
};
Получение количества пробных дней для продукта
@override
int? get trialDays {
final introductory = revenueCatPackage.storeProduct.introductoryPrice;
if (introductory == null) {
return null;
}
if (introductory.price == 0) {
final unit = introductory.periodUnit;
switch (unit) {
case PeriodUnit.day:
return introductory.periodNumberOfUnits;
case PeriodUnit.week:
return introductory.periodNumberOfUnits * 7;
case PeriodUnit.month:
return introductory.periodNumberOfUnits * 30;
case PeriodUnit.year:
return introductory.periodNumberOfUnits * 365;
default:
return null;
}
}
return null;
}
Получение списка характеристик из метаданных RevenueCat в зависимости от языка пользователя
@override
List<String>? get features {
final locale = LocaleSettings.currentLocale.languageCode;
if (revenueCatOffer.metadata[locale] == null) {
return null;
}
final data = revenueCatOffer.metadata[locale]! as Map<Object?, Object?>;
final featurerObj = data["features"]! as List<Object?>;
return featurerObj.map((e) => e! as String).toList();
}
Оцените новую рубрику и напишите своё мнение! 👍💬
Все подобные новости можно найти по хэштегу #FlutterPulseTips
#flutter #dart #flutterpulse #FlutterPulseTips #RevenueCat #boilerplate #mobiledevelopment #appdevelopment #codingtips
🎯 Flutter совет: Шаблон подписки с Provider
Управление подпиской через
---
🔧 Модель состояния подписки
---
🧩 Регистрация провайдера в main.dart
---
Использование подписки в UI
---
Пример обработки подписки
---
💡 Совет: Периодически проверяйте подписку при запуске приложения — особенно если используете серверную валидацию или Webhook-обновления.
💬 Поделитесь в комментариях, как вы реализуете подписки в своих приложениях!
📌 Все советы рубрики — по хэштегу #FlutterPulseTips
#flutter #dart #provider #architecture #subscriptions #revenuecat #qonversion #boilerplate #mobiledev #FlutterPulseTips #UIUX #premiumapps
Управление подпиской через
Provider
— один из самых чистых и масштабируемых способов построения архитектуры подписок в Flutter. Ниже — полный шаблон, который можно адаптировать под RevenueCat, Qonversion, Firebase и другие платформы.---
🔧 Модель состояния подписки
class SubscriptionModel extends ChangeNotifier {
bool _isSubscribed = false;
DateTime? _expiryDate;
bool get isSubscribed => _isSubscribed;
DateTime? get expiryDate => _expiryDate;
void updateStatus({required bool subscribed, DateTime? expiry}) {
_isSubscribed = subscribed;
_expiryDate = expiry;
notifyListeners();
}
void reset() {
_isSubscribed = false;
_expiryDate = null;
notifyListeners();
}
bool get isExpired {
if (_expiryDate == null) return true;
return DateTime.now().isAfter(_expiryDate!);
}
}
---
🧩 Регистрация провайдера в main.dart
void main() {
runApp(
ChangeNotifierProvider(
create: (_) => SubscriptionModel(),
child: const MyApp(),
),
);
}
---
Использование подписки в UI
Consumer<SubscriptionModel>(
builder: (context, model, _) {
if (model.isSubscribed) {
return const PremiumContent();
}
return Column(
children: [
const Text("Оформите подписку для доступа к премиум-функциям"),
ElevatedButton(
onPressed: () => handleSubscription(context),
child: const Text("Подписаться"),
),
],
);
},
)
---
Пример обработки подписки
Future<void> handleSubscription(BuildContext context) async {
final model = context.read<SubscriptionModel>();
final result = await PurchaseService.buy(); // ваша реализация
if (result.success) {
model.updateStatus(
subscribed: true,
expiry: result.expiryDate,
);
} else {
ScaffoldMessenger.of(context).showSnackBar(
const SnackBar(content: Text("Не удалось оформить подписку")),
);
}
}
---
💡 Совет: Периодически проверяйте подписку при запуске приложения — особенно если используете серверную валидацию или Webhook-обновления.
💬 Поделитесь в комментариях, как вы реализуете подписки в своих приложениях!
📌 Все советы рубрики — по хэштегу #FlutterPulseTips
#flutter #dart #provider #architecture #subscriptions #revenuecat #qonversion #boilerplate #mobiledev #FlutterPulseTips #UIUX #premiumapps