Background
Thanks for getting started with Helium 🎈 Helium is an upsell experimentation and optimization platform for mobile apps of all sizes. We take your app’s existing paywalls and turn them into remotely editable templates that you can experiment with and optimize without waiting for new app releases. Email founders@tryhelium.com for help/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
settings.gradle.kts
file:
Ensure you have mavenCentral()
and google()
in your repositories blocks.
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.
Observing Paywall Configuration Download Status
The Helium SDK provides adownloadStatus
flow that you can observe to get updates on the status of the paywall configuration download. This is useful for showing loading indicators or handling download failures.
The 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
To present a Paywall, ensure you have initialized the library. The SDK provides UI components that handle the underlyingPaywallWebViewManager
.
We provide two different ways of presenting the Paywall:
- Jetpack Compose
- Android View System
The recommended way to present a paywall in Jetpack Compose is by launching the Alternatively, if you are using To present a paywall, you can then navigate to the Helium route with a specific trigger:
HeliumPaywallActivity
using rememberLauncherForActivityResult
. This approach allows you to receive a result back from the paywall, such as whether a purchase was successful.Here is an example of how to set it up in your Composable function:NavController
, you can add the paywall to your navigation graph using buildHelium()
: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
assets
directory. - Default fallback view: A custom Android
View
to be used for all triggers. - Fallback view per trigger: A map of trigger names to specific Android
View
s.
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.