React Native Demo Project
See how easy it is to integrate high-performance ads into your React Native app using our lightweight SDK.
Requirements
- React Native: 0.73.2 or later
Getting started
1. Installation
To get started, you will need to set up a publisher account to get a
publisherToken and code.2. Initialize AdsProvider
TheAdsProvider handles all data-fetching logic and must have access to the chat messages. Place it high enough in your component tree so it can contain all ad placements.
3. Set up IFA (Identifier for Advertisers)
The SDK automatically reads and forwards the IFA with each ad request once the user has granted permission. To enable this, you need to complete a one-time setup on each platform.iOS
Apple requires a usage description before the ATT (App Tracking Transparency) prompt can be shown. Add the following to yourios/<YourApp>/Info.plist:
The SDK calls
ATTrackingManager.requestTrackingAuthorization automatically. To avoid App Store rejection, ensure the prompt is triggered at a natural point in your app flow (e.g. after onboarding) rather than immediately on launch.Android
TheAD_ID permission is automatically included via manifest merger from the SDK — no changes to your AndroidManifest.xml are required. No runtime prompt is required — this is an install-time permission.
If your app targets Android 13+ (API level 33+) and you have set
tools:node="remove" on the AD_ID permission anywhere in your manifest configuration, remove that override or the advertising identifier will not be accessible.4. Set up SKAdNetwork (iOS only)
SKAdNetwork (SKAN) is Apple’s privacy-preserving install attribution framework. To allow DSPs to measure ad conversions on iOS, you need to add their SKAdNetwork identifiers to yourios/<YourApp>/Info.plist.
The full list of required SKAdNetwork identifiers will be provided during onboarding. Make sure to add all of them, as missing an identifier means conversions from that DSP will not be attributed.
5. Show your first ad
An ad slot is a designated area in your UI where an ad can be rendered. In most cases, it appears below a chat message. During onboarding, you’ll receive a uniquecode for each ad slot you plan to use.
Copy the markup <InlineAd /> and place it in your application where it should be rendered. Don’t forget to assign messageId as a unique identifier. For example, if you have a MessageList component, you can show an ad after each message like this (every message will have a unique ad displayed because of messageId).
API documentation
AdsProvider properties
Your unique publisher token.
List of messages between the assistant and the user.
Unique identifier that remains the same for the user’s lifetime (used for retargeting and rewarded ads).
Email of the user.
Unique ID of the conversation.
Placement codes enabled for the conversation. Example:
['inlineAd'].Character object used in this conversation.
Regulatory compliance information.TCF (Transparency and Consent Framework) signals —
gdpr and gdprConsent — are handled automatically by the SDK if you have a TCF-compliant CMP (Consent Management Platform) integrated in your app. You do not need to set these manually.Publisher-provided identifier for the user cohort (for A/B testing).
Callback triggered when an event occurs. See Supported events for more details.
Flag indicating if the ads are disabled.Note: This does not disable the display of old ads; that behavior is controlled by
staleAdsHandling.Determines how stale ads (ads not linked to the latest message) are handled.
preserve- keep displaying the last anchored ad until it’s replaced by a new adhide(default) - hide the ad when it becomes stale
InlineAd properties
Placement code provided during onboarding.
Unique ID of the message.
Theme of the ad, e.g.
light or dark.Wrapper function to wrap the ad content.
Supported Events
ad.clicked
The user has clicked the ad.
ad.viewed
The user has viewed the ad.
ad.filled
Ad is available.
ad.no-fill
Ad is not available.
ad.render-started
Triggered before the first token is received.
ad.render-completed
Triggered after the last token is received.
ad.error
Triggered when an error occurs.
reward.granted
Triggered when the user receives a reward.
video.started
Triggered when the video playback starts.
video.completed
Triggered when the video playback finishes.
Guides
Handling no-fill events
You can notify when the ad is not available by using theonEvent callback.