The React Native SDK lets you send events to Amplitude.
The following matrix lists the support for Amplitude React Native SDK version for different versions of React Native and React Native CLI.
| @amplitude/analytics-react-native | react-native | Gradle | Android Gradle Plugin |
|---|---|---|---|
| >= 1.4.0 | >= 0.68 | 7.5.1+ | 7.2.1+ |
| >= 1.0.0, <= 1.3.6 | >= 0.61, <= 0.70 | 3.5.3+ | 3.5.3+ |
Learn more about the Android Gradle Plugin compatibility.
To get started with using Amplitude React Native SDK, install the package to your project with npm. You must also install @react-native-async-storage/async-storage for the SDK to work as expected.
npm install @amplitude/analytics-react-native
npm install @react-native-async-storage/async-storage
yarn add @amplitude/analytics-react-native
yarn add @react-native-async-storage/async-storage
expo install @amplitude/analytics-react-native
expo install @react-native-async-storage/async-storage
Install the native modules to run the SDK on iOS.
cd ios
pod install
Initialization is necessary before any instrumentation is done. The API key for your Amplitude project is required. Optionally, a user ID and config object can be passed in this call. The SDK can be used anywhere after it's initialized anywhere in an application.
import { init } from '@amplitude/analytics-react-native';
// Option 1, initialize with API_KEY only
init(API_KEY);
// Option 2, initialize including user ID if it's already known
init(API_KEY, 'user@amplitude.com');
// Option 3, initialize including configuration
init(API_KEY, 'user@amplitude.com', {
disableCookies: true, // Disables the use of browser cookies
});
Configuration options
Name
Description
Default Value
instanceNamestring. The instance name.$default_instance
flushIntervalMillisnumber. Sets the interval of uploading events to Amplitude in milliseconds.1,000 (1 second)
flushQueueSizenumber. Sets the maximum number of events that are batched in a single upload attempt.30 events
flushMaxRetriesnumber. Sets the maximum number of retries for failed upload attempts. This is only applicable to retryable errors.5 times.
logLevelLogLevel.None or LogLevel.Error or LogLevel.Warn or LogLevel.Verbose or LogLevel.Debug. Sets the log level.LogLevel.Warn
loggerProvider Logger. Sets a custom loggerProvider class from the Logger to emit log messages to desired destination.Amplitude Logger
minIdLengthnumber. Sets the minimum length for the value of userId and deviceId properties.5
optOutboolean. Sets permission to track events. Setting a value of true prevents Amplitude from tracking and uploading events.false
serverUrlstring. Sets the URL where events are upload to.https://api2.amplitude.com/2/httpapi
serverZoneEU or US. Sets the Amplitude server zone. Set this to EU for Amplitude projects created in EU data center.US
useBatchboolean. Sets whether to upload events to Batch API instead of the default HTTP V2 API or not.false
appVersionstring. Sets an app version for events tracked. This can be the version of your application. For example: "1.0.0"undefined
deviceIdstring. Sets an identifier for the device running your application.UUID()
cookieExpirationnumber. Sets expiration of cookies created in days.365 days
cookieSameSitestring. Sets SameSite property of cookies created.Lax
cookieSecureboolean. Sets Secure property of cookies created.false
cookieStorageStorage<UserSession>. Sets a custom implementation of Storage<UserSession> to persist user identity.MemoryStorage<UserSession>
cookieUpgradeboolean. Sets upgrading from cookies created by maintenance Browser SDK. If true, new Browser SDK deletes cookies created by maintenance Browser SDK. If false, Browser SDK keeps cookies created by maintenance Browser SDK.true
disableCookiesboolean. Sets permission to use cookies. If value is true, localStorage API is used to persist user identity.The cookies is enable by default.
domainstring. Sets the domain property of cookies created.undefined
partnerIdstring. Sets partner ID. Amplitude requires the customer who built an event ingestion integration to add the partner identifier to partner_id.undefined
sessionTimeoutnumber. Sets the period of inactivity from the last tracked event before a session expires in milliseconds.1,800,000 milliseconds (30 minutes)
userIdnumber. Sets an identifier for the user being tracked. Must have a minimum length of 5 characters unless overridden with the minIdLength option.undefined
trackingOptionsTrackingOptions. Configures tracking of additional properties. Please refer to Optional tracking section for more information.Enable all tracking options by default.
storageProviderStorage<Event[]>. Implements a custom storageProvider class from Storage.MemoryStorage
trackingSessionEventsboolean. Whether to automatically log start and end session events corresponding to the start and end of a user's session.false
migrateLegacyDataboolean. Available in 1.3.4+. Whether to migrate maintenance SDK data (events, user/device ID).true
To support high-performance environments, the SDK sends events in batches. Every event logged by the track method is queued in memory. Events are flushed in batches in background. You can customize batch behavior with flushQueueSize and flushIntervalMillis. By default, the serverUrl will be https://api2.amplitude.com/2/httpapi. For customers who want to send large batches of data at a time, set useBatch to true to set setServerUrl to batch event upload API https://api2.amplitude.com/batch. Both the regular mode and the batch mode use the same events upload threshold and flush time intervals.
import * as amplitude from '@amplitude/analytics-react-native';
amplitude.init(API_KEY, OPTIONAL_USER_ID, {
// Events queued in memory will flush when number of events exceed upload threshold
// Default value is 30
flushQueueSize: 50,
// Events queue will flush every certain milliseconds based on setting
// Default value is 10000 milliseconds
flushIntervalMillis: 20000,
});
You can configure the server zone when initializing the client for sending data to Amplitude's EU servers. The SDK sends data based on the server zone if it's set.
amplitude.init(API_KEY, OPTIONAL_USER_ID, {
serverZone: 'EU',
});
You can control the level of logs printed to the developer console.
logLevel isn't explicitly specified.Set the log level by configuring the logLevel with the level you want.
amplitude.init(AMPLITUDE_API_KEY, OPTIONAL_USER_ID, {
logLevel: amplitude.Types.LogLevel.Warn,
});
The default logger outputs log to the developer console. You can provide your own logger implementation based on the Logger interface for any customization purpose. For example, collecting any error messages from the SDK in a production environment.
Set the logger by configuring the loggerProvider with your own implementation.
amplitude.init(AMPLITUDE_API_KEY, OPTIONAL_USER_ID, {
loggerProvider: new MyLogger(),
});
Enable the debug mode by setting the logLevel to "Debug", for example:
amplitude.init(AMPLITUDE_API_KEY, OPTIONAL_USER_ID, {
logLevel: amplitude.Types.LogLevel.Debug,
});
The default logger outputs extra function context information to the developer console when invoking any SDK public method, including:
event_type field and at least one of deviceId (included by default) or userId, and follow the HTTP API's constraints on each of those fields.
To prevent instrumentation issues, device IDs and user IDs must be strings with a length of 5 characters or more. If an event contains a device ID or user ID that's too short, the ID value is removed from the event. If the event doesn't have a userId or deviceId value, the upload may be rejected with a 400 status. Override the default minimum length of 5 characters by setting the minIdLength config option.
Events represent how users interact with your application. For example, "Button Clicked" may be an action you want to note.
import { track } from '@amplitude/analytics-react-native';
// Track a basic event
track('Button Clicked');
// Track events with optional properties
const eventProperties = {
buttonColor: 'primary',
};
track('Button Clicked', eventProperties);
If you need to log events to multiple Amplitude projects, you'll need to create separate instances for each Amplitude project. Then, pass the instance variables to wherever you want to call Amplitude. Each instance allows for independent apiKeys, userIds, deviceIds, and settings.
import * as amplitude from '@amplitude/analytics-react-native';
const defaultInstance = amplitude.createInstance();
defaultInstance.init(API_KEY_DEFAULT);
const envInstance = amplitude.createInstance();
envInstance.init(API_KEY_ENV, {
instanceName: 'env',
});
User properties help you understand your users at the time they performed some action within your app such as their device details, their preferences, or language.
Identify is for setting the user properties of a particular user without sending any event. The SDK supports the operations set, setOnce, unset, add, append, prepend, preInsert, postInsert, and remove on individual user properties. The operations are declared via a provided Identify interface. You can chain multiple operations together in a single Identify object. The Identify object is then passed to the Amplitude client to send to the server.
The Identify object provides controls over setting user properties. An Identify object must first be instantiated, then Identify methods can be called on it, and finally the client will make a call with the Identify object.
import { identify, Identify } from '@amplitude/analytics-react-native';
const identifyObj = new Identify();
identify(identifyObj);
This method sets the value of a user property. For example, you can set a role property of a user.
import { Identify, identify } from '@amplitude/analytics-react-native';
const identifyObj = new Identify();
identifyObj.set('location', 'LAX');
identify(identifyObj);
This method sets the value of a user property only once. Subsequent calls using setOnce() will be ignored. For example, you can set an initial login method for a user and since only the initial value is tracked, setOnce() ignores subsequent calls.
import { Identify, identify } from '@amplitude/analytics-react-native';
const identifyObj = new Identify();
identifyObj.setOnce('initial-location', 'SFO');
identify(identifyObj);
This method increments a user property by some numerical value. If the user property doesn't have a value set yet, it will be initialized to 0 before being incremented. For example, you can track a user's travel count.
import { Identify, identify } from '@amplitude/analytics-react-native';
const identifyObj = new Identify();
identifyObj.add('travel-count', 1);
identify(identifyObj);
Arrays can be used as user properties. You can directly set arrays or use prepend, append, preInsert and postInsert to generate an array.
Identify.prependThis method prepends a value or values to a user property array. If the user property doesn't have a value set yet, it will be initialized to an empty list before the new values are prepended.
import { Identify, identify } from '@amplitude/analytics-react-native';
const identifyObj = new Identify();
identifyObj.prepend('visited-locations', 'LAX');
identify(identifyObj);
Identify.appendThis method appends a value or values to a user property array. If the user property doesn't have a value set yet, it will be initialized to an empty list before the new values are prepended.
import { Identify, identify } from '@amplitude/analytics-react-native';
const identifyObj = new Identify();
identifyObj.append('visited-locations', 'SFO');
identify(identifyObj);
Identify.preInsertThis method pre-inserts a value or values to a user property if it doesn't exist in the user property yet. Pre-insert means inserting the value at the beginning of a given list. If the user property doesn't have a value set yet, it will be initialized to an empty list before the new values are pre-inserted. If the user property has an existing value, it will be no operation.
import { Identify, identify } from '@amplitude/analytics-react-native';
const identifyObj = new Identify();
identifyObj.preInsert('unique-locations', 'LAX');
identify(identifyObj);
This method post-inserts a value or values to a user property if it doesn't exist in the user property yet. Post-insert means inserting the value at the end of a given list. If the user property doesn't have a value set yet, it will be initialized to an empty list before the new values are post-inserted. If the user property has an existing value, it will be no operation.
import { Identify, identify } from '@amplitude/analytics-react-native';
const identifyObj = new Identify();
identifyObj.postInsert('unique-locations', 'SFO');
identify(identifyObj);
This method removes a value or values to a user property if it exists in the user property. Remove means remove the existing values from the given list. If the item doesn't exist in the user property, it will be no operation.
import { Identify, identify } from '@amplitude/analytics-react-native';
const identifyObj = new Identify();
identifyObj.remove('unique-locations', 'JFK')
identify(identifyObj);
Amplitude supports assigning users to groups and performing queries, such as Count by Distinct, on those groups. If at least one member of the group has performed the specific event, then the count includes the group.
For example, you want to group your users based on what organization they're in by using an 'orgId'. Joe is in 'orgId' '10', and Sue is in 'orgId' '15'. Sue and Joe both perform a certain event. You can query their organizations in the Event Segmentation Chart.
When setting groups, define a groupType and groupName. In the previous example, 'orgId' is the groupType and '10' and '15' are the values for groupName. Another example of a groupType could be 'sport' with groupName values like 'tennis' and 'baseball'.
Setting a group also sets the groupType:groupName as a user property, and overwrites any existing groupName value set for that user's groupType, and the corresponding user property value. groupType is a string, and groupName can be either a string or an array of strings to indicate that a user is in multiple groups.
groupName would be '15'.
import { setGroup } from '@amplitude/analytics-react-native';
// set group with single group name
setGroup('orgId', '15');
If Joe is in 'sport' 'tennis' and 'soccer', then the groupName would be '["tennis", "soccer"]'.
import { setGroup } from '@amplitude/analytics-react-native';
// set group with multiple group names
setGroup('sport', ['soccer', 'tennis']);
You can also set event-level groups by passing an Event Object with groups to track. With event-level groups, the group designation applies only to the specific event being logged, and doesn't persist on the user unless you explicitly set it with setGroup.
import { track } from '@amplitude/analytics-react-native';
track({
event_type: 'event type',
event_properties: { eventPropertyKey: 'event property value' },
groups: { 'orgId': '15' }
});
Use the Group Identify API to set or update the properties of particular groups. These updates only affect events going forward.
The groupIdentify() method accepts a group type and group name string parameter, as well as an Identify object that will be applied to the group.
import { Identify, groupIdentify } from '@amplitude/analytics-react-native';
const groupType = 'plan';
const groupName = 'enterprise';
const event = new Identify()
event.set('key1', 'value1');
groupIdentify(groupType, groupName, identify);
The preferred method of tracking revenue for a user is to use revenue() in conjunction with the provided Revenue interface. Revenue instances will store each revenue transaction and allow you to define several special revenue properties (such as "revenueType", "productIdentifier", etc.) that are used in Amplitude's Event Segmentation and Revenue LTV charts. These Revenue instance objects are then passed into revenue() to send as revenue events to Amplitude. This lets automatically display data relevant to revenue in the platform. You can use this to track both in-app and non-in-app purchases.
To track revenue from a user, call revenue each time a user generates revenue. For example, 3 units of a product were purchased at $3.99.
import { Revenue, revenue } from '@amplitude/analytics-react-native';
const event = new Revenue()
.setProductId('com.company.productId')
.setPrice(3.99)
.setQuantity(3);
revenue(event);
| Name | Description |
|---|---|
product_id |
Optional. String. An identifier for the product. Amplitude recommends something like the Google Play Store product ID. Defaults to null. |
quantity |
Required. Int. The quantity of products purchased. revenue = quantity * price. Defaults to 1 |
price |
Required. Double. The price of the products purchased, and this can be negative. revenue = quantity * price. Defaults to null. |
revenue_type |
Optional, but required for revenue verification. String. The revenue type (for example tax, refund, income). Defaults to null. |
receipt |
Optional. String. The receipt identifier of the revenue. Defaults to null |
receipt_sig |
Optional, but required for revenue verification. String. The receipt signature of the revenue. Defaults to null. |
properties |
Optional. JSONObject. An object of event properties to include in the revenue event. Defaults to null. |
The flush method triggers the client to send buffered events.
import { flush } from '@amplitude/analytics-react-native';
flush();
By default, flush is called automatically in an interval, if you want to flush the events altogether, you can control the async flow with the optional Promise interface, for example:
await init(AMPLITUDE_API_KEY).promise;
track('Button Clicked');
await flush().promise;
If your app has its login system that you want to track users with, you can call setUserId at any time.
TypeScript
import { setUserId } from '@amplitude/analytics-react-native';
setUserId('user@amplitude.com');
You can also assign the User ID as an argument to the init call.
import { init } from '@amplitude/analytics-react-native';
init(API_KEY, 'user@amplitude.com');
You can assign a new Session ID using setSessionId. When setting a custom session ID, make sure the value is in milliseconds since epoch (Unix Timestamp).
TypeScript
import { setSessionId } from '@amplitude/analytics-react-native';
setSessionId(Date.now());
If your app has its login system that you want to track users with, you can call setUserId at any time.
You can assign a new device ID using deviceId. When setting a custom device ID, make sure the value is sufficiently unique. A UUID is recommended.
import { setDeviceId } from '@amplitude/analytics-react-native';
const { uuid } = require('uuidv4');
setDeviceId(uuid());
reset is a shortcut to anonymize users after they log out, by:
userId to undefineddeviceId to a new UUID valueWith an undefined userId and a completely new deviceId, the current user would appear as a brand new user in dashboard.
import { reset } from '@amplitude/analytics-react-native';
reset();
You can turn off logging for a given user by setting setOptOut to true.
import { setOptOut } from '@amplitude/analytics-react-native';
setOptOut(true);
No events are saved or sent to the server while setOptOut is enabled, and the setting persists across page loads.
Re-enable logging by setting setOptOut to false.
import { setOptOut } from '@amplitude/analytics-react-native';
setOptOut(false);
By default, the SDK tracks these properties automatically. You can override this behavior by passing a configuration called trackingOptions when initializing the SDK, setting the appropriate options to false.
| Tracking Options | Default |
|---|---|
adid |
true |
carrier |
true |
deviceManufacturer |
true |
deviceModel |
true |
ipAddress |
true |
language |
true |
osName |
true |
osVersion |
true |
platform |
true |
amplitude.init(API_KEY, OPTIONAL_USER_ID, {
trackingOptions: {
adid: false,
appSetId: false,
carrier: false,
deviceManufacturer: false,
deviceModel: false,
ipAddress: false,
idfv: false,
language: false,
osName: false,
osVersion: false,
platform: false,
},
});
All asynchronous APIs are optionally awaitable through a Promise interface. This also serves as a callback interface.
import { track } from '@amplitude/analytics-react-native';
// Using async/await
const results = await track('Button Clicked').promise;
result.event; // {...} (The final event object sent to Amplitude)
result.code; // 200 (The HTTP response status code of the request.
result.message; // "Event tracked successfully" (The response message)
// Using promises
track('Button Clicked').promise.then((result) => {
result.event; // {...} (The final event object sent to Amplitude)
result.code; // 200 (The HTTP response status code of the request.
result.message; // "Event tracked successfully" (The response message)
});
Plugins allow you to extend Amplitude SDK's behavior by, for example, modifying event properties (enrichment type) or sending to third-party APIs (destination type). A plugin is an object with methods setup() and execute().
For Session Replay integration with Segment, review the Session Replay React Native Segment Integration guide.
The add method adds a plugin to Amplitude. Plugins can help processing and sending events.
import { add } from '@amplitude/analytics-react-native';
add(new Plugin());
The remove method removes the given plugin name from the client instance if it exists.
import { remove } from '@amplitude/analytics-react-native';
remove(plugin.name);
This method contains logic for preparing the plugin for use and has config as a parameter. The expected return value is undefined. A typical use for this method, is to copy configuration from config or instantiate plugin dependencies. This method is called when the plugin is registered to the client via client.add().
This method contains the logic for processing events and has event as parameter. If used as enrichment type plugin, the expected return value is the modified/enriched event; while if used as a destination type plugin, the expected return value is a map with keys: event (BaseEvent), code (number), and message (string). This method is called for each event, including Identify, GroupIdentify and Revenue events, that's instrumented using the client interface.
Here's an example of a plugin that modifies each event that's instrumented by adding an increment integer to event_id property of an event starting from 100.
import { init, add } from '@amplitude/analytics-react-native';
import { ReactNativeConfig, EnrichmentPlugin, Event, PluginType } from '@amplitude/analytics-types';
export class AddEventIdPlugin implements EnrichmentPlugin {
name = 'add-event-id';
type = PluginType.ENRICHMENT as const;
currentId = 100;
config?: ReactNativeConfig;
/**
* setup() is called on plugin installation
* example: client.add(new AddEventIdPlugin());
*/
async setup(config: ReactNativeConfig): Promise<undefined> {
this.config = config;
return;
}
/**
* execute() is called on each event instrumented
* example: client.track('New Event');
*/
async execute(event: Event): Promise<Event> {
event.event_id = this.currentId++;
return event;
}
}
init('API_KEY');
add(new AddEventIdPlugin());
Here's an example of a plugin that sends each instrumented event to a target server URL using your preferred HTTP client.
import { init, add } from '@amplitude/analytics-react-native';
import { ReactNativeConfig, DestinationPlugin, Event, PluginType, Result } from '@amplitude/analytics-types';
export class MyDestinationPlugin implements DestinationPlugin {
name = 'my-destination-plugin';
type = PluginType.DESTINATION as const;
serverUrl: string;
config?: ReactNativeConfig;
constructor(serverUrl: string) {
this.serverUrl = serverUrl;
}
/**
* setup() is called on plugin installation
* example: client.add(new MyDestinationPlugin());
*/
async setup(config: ReactNativeConfig): Promise<undefined> {
this.config = config;
return;
}
/**
* execute() is called on each event instrumented
* example: client.track('New Event');
*/
async execute(event: Event): Promise<Result> {
const payload = { key: 'secret', data: event };
const response = await fetch(this.serverUrl, {
method: 'POST',
headers: {
'Content-Type': 'application/json',
Accept: '*/*',
},
body: JSON.stringify(payload),
});
return {
code: response.status,
event: event,
message: response.statusText,
};
}
}
init('API_KEY');
add(new MyDestinationPlugin('https://custom.domain.com'));
You can provide an implementation of Transport interface to the transportProvider configuration option for customization purpose, for example, sending requests to your proxy server with customized HTTP request headers.
import { Transport } from '@amplitude/analytics-types';
class MyTransport implements Transport {
async send(serverUrl: string, payload: Payload): Promise<Response | null> {
// check example: https://github.com/amplitude/Amplitude-TypeScript/blob/main/packages/analytics-client-common/src/transports/fetch.ts
}
}
amplitude.init(API_KEY, OPTIONAL_USER_ID, {
transportProvider: new MyTransport(),
});
The Amplitude ingestion servers resolve event location in the following order:
city, country, regionlocation_lat and location_lngipBy default, location will be determined by the ip on the server side. If you want more provide more granular location you can set city, country and region individually, or set location_lat and location_lng which will then be resolved to city, country and region on the server.
Amplitude doesn't set precise location in the SDK to avoid extra permissions that my not be needed by all customers.
To set fine grain location, you can use an enrichment Plugin. Here is an example of how to set location_lat and location_lng.
Disabling IP tracking with ipAddress: false in TrackingOptions prevents location from being resolved on the backend. In this case you may want to create a Plugin like above to set any relevant location information yourself.
Carrier support works on Android, but Apple stopped supporting it in iOS 16. In earlier versions of iOS, we fetch carrier info using CTCarrier and serviceSubscriberCellularProviders which are deprecated with no replacement.
Different platforms have different advertising identifiers. Due to user privacy concerns, Amplitude does not automatically collect these identifiers. However, it is easy to enable them using the instructions below. It is important to note that some identifiers are no longer recommended for use by the platform providers. Read the notes below before deciding to enable them.
| Platform | Advertising Identifier | Recommended | Notes |
|---|---|---|---|
| Android | AppSetId | Yes | AppSetId is a unique identifier for the app instance. It is reset when the app is reinstalled. |
| Android | ADID | No | ADID is a unique identifier for the device. It is reset when the user opts out of personalized ads. |
| iOS | IDFV | Yes | IDFV is a unique identifier for the app instance. It is reset when the app is reinstalled. |
| iOS | IDFA | No | IDFA is a unique identifier for the device. It is reset when the user opts out of personalized ads. |
App set ID is a unique identifier for each app install on a device. App set ID is reset by the user manually when they uninstall the app, or after 13 months of not opening the app. Google designed this as a privacy-friendly alternative to Ad ID for users who want to opt out of stronger analytics.
To use App Set ID, follow these steps.
Add play-services-appset as a dependency to the Android project of your app.
dependencies {
implementation 'com.google.android.gms:play-services-appset:16.0.2'
}
Enable trackingOptions.appSetId
amplitude.init(API_KEY, OPTIONAL_USER_ID, {
trackingOptions: {
appSetId: true,
},
});
Android Ad ID is a unique identifier for each device. Android Ad ID is reset by the user manually when they opt out of personalized ads.
To use Android Ad ID, follow these steps.
Add play-services-ads-identifier as a dependency to the Android project of your app. More detailed setup is described in our latest Android SDK docs.
dependencies {
implementation 'com.google.android.gms:play-services-ads-identifier:18.0.1'
}
Android Ad Id is enabled by default. To disable it, set trackingOptions.adId to false.
amplitude.init(API_KEY, OPTIONAL_USER_ID, {
trackingOptions: {
adId: false,
},
});
IDFV is a unique identifier for the app instance. It is reset when the app is reinstalled.
To enable IDFV on iOS devices set trackingOptions.idfv to true.
amplitude.init(API_KEY, OPTIONAL_USER_ID, {
trackingOptions: {
idfv: true,
},
});
IDFA is a unique identifier for the device. It is reset when the user opts out of personalized ads.
The React Native SDK does not directly access the IDFA as it would require adding the AdSupport.framework to your app. Instead you can use an Enrichment Plugin to set the IDFA yourself.
Here is an example Plugin that sets the IDFA using a third-party library.
If you are using platform like Expo that supports OTA updates. It is important to know our SDK has both native and JS code. If you are using OTA updates, you will need to make sure the native code is updated as well. See Expo's documentation on publishing and runtime versions for more details.
Below are versions of the SDK with the native code changes:
| @amplitude/analytics-react-native |
|---|
| 1.3.0 |
July 23rd, 2024
Need help? Contact Support
Visit Amplitude.com
Have a look at the Amplitude Blog
Learn more at Amplitude Academy
© 2025 Amplitude, Inc. All rights reserved. Amplitude is a registered trademark of Amplitude, Inc.