Background
Get set up with the Helium SDK for Android. Reach out over your Helium slack channel or email [email protected] for any questions.Installation
Add the Helium SDK to your project using Gradle.Requirements
- Kotlin Version: 2.0.0 or higher
- Java Version: 8 or higher
- Minimum Android SDK: 23 or higher
- Compile Android SDK: 35 or higher
1. Add repositories to your settings.gradle.kts file:
Ensure you have mavenCentral() and google() in your repositories blocks.
If you don’t have a
dependencyResolutionManagement block, ensure google() and mavenCentral() are present in your pluginManagement { repositories { ... } } block.2. Add the dependencies to your module-level build.gradle.kts file (e.g., app/build.gradle.kts):
- Core (Android View System)
- Jetpack Compose UI
- RevenueCat
Initialize Helium
You need to initialize Helium before you can present a paywall. The best place to do this is in yourMainActivity’s onCreate() method.
Checking Download Status
Checking Download Status
In most cases there is no need to check download status. Helium will display a loading indication if a paywall is presented before download has completed.
downloadStatus is a Kotlin Flow that emits HeliumConfigStatus states. The possible states are:HeliumConfigStatus.NotYetDownloaded: The initial state before the download has started.HeliumConfigStatus.Downloading: Indicates that the paywall configuration is currently being downloaded.HeliumConfigStatus.DownloadFailure: Indicates that the paywall configuration download has failed.HeliumConfigStatus.DownloadSuccess: Indicates that the paywall configuration has been successfully downloaded.
downloadStatus flow in your Activity or Fragment:HeliumPaywallDelegate
You can provide an implementation of theHeliumPaywallDelegate or use one of the default implementations that we have provided, such as PlayStorePaywallDelegate or RevenueCatPaywallDelegate.
- PlayStorePaywallDelegate
- RevenueCatPaywallDelegate
- Custom Delegate
Use the
PlayStorePaywallDelegate to handle purchases using Google Play Billing.Presenting Paywalls
You must have a trigger and workflow configured in the dashboard in order to show a paywall.
Helium.presentUpsell function. This function handles the creation and presentation of the paywall activity for you.
Looking for alternative presentation methods? Check out the guide on Ways to Show a Paywall.
PaywallEventHandlers
The Helium SDK allows you to listen for various paywall-related events. This is useful for tracking analytics, responding to user interactions, or handling the paywall lifecycle. There are two ways to listen for events: using thePaywallEventHandlers class for specific callbacks, or implementing the HeliumEventListener interface to receive all events.
Option 1: Using PaywallEventHandlers
You can create an instance ofPaywallEventHandlers and provide lambdas for the events you are interested in.
The available handlers are:
onOpen: Called when a paywall is displayed to the user.onClose: Called when a paywall is closed for any reason.onDismissed: Called when the user explicitly dismisses a paywall without purchasing.onPurchaseSucceeded: Called when a purchase completes successfully.onOpenFailed: Called when a paywall fails to open.onCustomPaywallAction: Called when a custom action is triggered from the paywall.
Helium.shared.addPaywallEventListener. You can either tie the listener to a lifecycle (recommended) or manage it manually.
Lifecycle-Aware (Recommended)
Pass a LifecycleOwner (like an Activity or Fragment) to have the listener automatically removed when the lifecycle is destroyed.
LifecycleOwner, you are responsible for removing the listener to prevent memory leaks.
Option 2: Implementing HeliumEventListener
For a more centralized approach, your class can implement theHeliumEventListener interface and handle all events in a single onHeliumEvent method.
Usage Suggestions:
- Use
onDismissfor post-paywall navigation when the paywall is dismissed but a user’s entitlement hasn’t changed - Use
onPurchaseSucceededfor your post purchase flow (e.g., a premium onboarding navigation) - Use
onCloseto handle a paywall close, regardless of reason
Fallbacks and Loading Budgets
If a paywall has not completed downloading when you attempt to present it, a loading state can be displayed. By default, Helium will show this loading state (a shimmer view) for up to 2 seconds (2000ms). You can configure this behavior, turn it off, or set trigger-specific loading budgets using the HeliumFallbackConfig object during initialization.
If the loading budget expires before the paywall is ready, a fallback paywall will be shown if one is provided. Otherwise, the loading state will hide, and a PaywallOpenFailed event will be dispatched.
There are three options for fallbacks in the Android SDK:
- Fallback bundles: A pre-packaged paywall bundle stored in your app’s
assetsdirectory. - Default fallback view: A custom Android
Viewto be used for all triggers. - Fallback view per trigger: A map of trigger names to specific Android
Views.
HeliumFallbackConfig object passed into Helium.initialize().
Here are some examples:
1. Providing a fallback bundle:
Place your fallback JSON file in the src/main/assets directory of your module. Then, initialize Helium with the fallbackBundleName.
View and fine-tune the.