Skip to main content

Flutter

What is RevenueCat?โ€‹

RevenueCat provides a backend and a wrapper around StoreKit and Google Play Billing to make implementing in-app purchases and subscriptions easy. With our SDK, you can build and manage your app business on any platform without having to maintain IAP infrastructure. You can read more about how RevenueCat fits into your app or you can sign up free to start building.

Requirementsโ€‹

Xcode 13.3.1+ Minimum target: iOS 11.0+

Installationโ€‹

To use this plugin, add purchases_flutter as a dependency in your pubspec.yaml file (and run an implicit dart pub get):

dependencies:
purchases_flutter: ^6.0.0

Alternatively run this command:

 $ flutter pub add purchases_flutter

iOS Deployment Targetโ€‹

RevenueCat is compatible with iOS 11.0 or higher. Flutter does not automatically set the iOS deployment target for your project. You need to make sure that the deployment target is set to 11.0 or higher. To do that, simply edit ios/Podfile and add the following line if it's not already there:

platform :ios, '11.0'

Set it to 11.0 or a higher version for RevenueCat to work.

iOS Swift Versionโ€‹

RevenueCat requires Swift >= 5.0 to work. If the Podfile in your project's ios folder specifies a Swift version, make sure that it's at least 5.0, otherwise you may run into build issues.

Set the correct launchMode for Androidโ€‹

Depending on your user's payment method, they may be asked by Google Play to verify their purchase in their (banking) app. This means they will have to background your app and go to another app to verify the purchase. If your Activity's launchMode is set to anything other than standard or singleTop, backgrounding your app can cause the purchase to get cancelled. To avoid this, set the launchMode of your Activity to standard or singleTop in your Android app's android/app/src/main/AndroidManifest.xml file:

<activity 
android:name="com.your.Activity"
android:launchMode="standard" /> <!-- or singleTop -->

You can find Android's documentation on the various launchMode options here.

Import Purchasesโ€‹

You should now be able to import purchases_flutter.

import 'package:purchases_flutter/purchases_flutter.dart';
๐Ÿ“˜Enable In-App Purchase capability for iOS projects in Xcode

Don't forget to enable the In-App Purchase capability for your iOS project under Project Target -> Capabilities -> In-App Purchase

โš ๏ธ

If you're using other plugins like mobx, you may run into conflicts with types from other plugins having the same name as those defined in purchases_flutter.
If this happens, you can resolve the ambiguity in the types by adding an import alias, for example:

import 'package:purchases_flutter/purchases_flutter.dart' as purchases;

After that, you can reference the types from purchases_flutter as purchases.Foo, like purchases.PurchaserInfo.

Next Stepsโ€‹