React Native bridge to the AppMetrica on both iOS and Android.
- Only for iOS: setup AppMetrica.
YandexMobileMetrica.framework
should be placed at<project_dir>/ios/
or<project_dir>/ios/Frameworks/
. Otherwise you'll get build error. npm install --save react-native-appmetrica
react-native link react-native-appmetrica
iOS notice: If you build failed after installing SDK and react-native-appmetrica
make sure YandexMobileMetrica.framework
and libRCTAppMetrica.a
are included at Build Phase -> Link Binary With Libraries
import AppMetrica from 'react-native-appmetrica';
AppMetrica.activateWithApiKey('2dee16d2-1143-4cd3-a904-39ce10ac2755');
AppMetrica.reportEvent('Hello world');
import AppMetrica from 'react-native-appmetrica';
// Start the statistics collection process.
AppMetrica.activateWithApiKey('...KEY...');
// OR
AppMetrica.activateWithConfig({
apiKey: '...KEY...',
sessionTimeout: 120,
firstActivationAsUpdate: true,
});
// Send a custom event message and additional parameters (optional).
AppMetrica.reportEvent('My event');
AppMetrica.reportEvent('My event', { foo: 'bar' });
// Send a custom error event.
AppMetrica.reportError('My error');
// Send user profile with predefined attributes.
AppMetrica.reportUserProfile({ name: 'User 1', age: 87 });
// Send user profile with custom attributes.
AppMetrica.reportUserProfile({
likesMusic: true,
addedToFavorites: '+1',
score: 150,
});
All predefined attributes are supported. Use null
to reset them.
type UserProfileAttributes = {
name?: ?string,
gender?: 'female' | 'male' | string | void,
age?: ?number,
birthDate?: Date | [number] | [number, number] | [number, number, number] | void,
notificationsEnabled?: boolean,
/** custom attributes */
[string]: string | number | boolean,
};
Custom attributes are supported. They can't be reset for now.
Use values like '+1'
, '-10'
for counters. Current limitation is any custom attribute which value started with '+'
or '-'
will be considered as a counter.