expo-analytics-google v1.0.4
Expo Analytics
Google Analytics integration for use with React Native apps built on Expo. This library does not require linking.
Please create issues for any bugs you find or features you would like added.
Installation
npm install expo-analytics-google --saveUsage
Your React Native app's screen resolution, app name, app ID, app version and multiple other parameters will be automatically resolved and sent with each hit or event.
import { Analytics } from 'expo-analytics-google';
await Analytics.init({ propertyId: 'UA-XXXXXX-Y' });More Options
You might want to use your own static userAgent http header instead of the default WebView header.
import { Analytics } from 'expo-analytics-google';
await Analytics.init({ propertyId: 'UA-XXXXXX-Y', config: { userAgent: 'Custom UserAgent', debug: true } });Hits
Sending page hits or screen hits is done by constructing a new PageHit or ScreenHit instance and passing it to the hit function of an Analytics instance.
import { Analytics, PageHit } from 'expo-analytics-google';
Analytics.hit(new PageHit('Home'));Events
You can also send custom events by constructing a new Event instance and passing it to the event function. Events have four parameters.
- Event Category
- Event Action
- Event Label (optional, but recommended)
- Event Value (optional, integer)
These parameters are passed to the Event constructor in that order.
import { Analytics, Event } from 'expo-analytics-google';
Analytics.event(new Event('Video', 'Play', 'The Big Lebowski', 123));Learn more about custom events.
Custom Dimensions
Custom Dimensions are also supported. Any custom dimensions set will be sent with each request.
import { Analytics, Event } from 'expo-analytics-google';
const customDimensions = [];
customDimensions[1] = 'TrialAccount';
customDimensions[2] = 'Comedy';
Analytics.event(new Event('Video', 'Play', 'The Big Lebowski', 123), { customDimensions });Custom Metrics
Custom Metrics work the same way with just a slightly different call.
import { Analytics, Event } from 'expo-analytics-google';
const customMetrics = [];
customMetrics[1] = 15;
Analytics.event(new Event('Video', 'Play', 'The Big Lebowski', 123), { customMetrics });Additional Parameters
You can also optionally include any additional supported parameters you would like.
import { Analytics } from 'expo-analytics-google';
// pass in the user ID (uid), user locale (ul), referrer (dr) and campaign name (cn)
await Analytics.init({ propertyId: 'UA-XXXXXX-Y', parameters: { uid: '999', dr: 'github.com', cn: 'get_more_views' } });Ecommerce tracking
Transaction hit type
You can also send purchase by constructing a new Transaction instance and passing it to the transaction function. Transaction have five parameters.
- id (Required, string)
- affiliation (Optional, string)
- revenue (Optional, currency, but recommended)
- shipping (Optional, currency)
- tax (Optional, currency)
These parameters are passed to the Transaction constructor in that order.
import { Analytics, Transaction } from 'expo-analytics-google';
Analytics.hit(new Transaction('1235', 'Store', 38.43, 1.29, 5));Item hit type
You can also send along the purchase the products that were purchased in the transaction, constructing a new AddItem instance and passing it to the AddItem function. 'AddItem' have six parameters.
- id (The transaction id, Required, string)
- name (Required, string)
- price (Optional, currency, but recommended)
- quantity (Optional, integer)
- sku (Optional, string, but recommended)
- category (Optional, string, but recommended)
These parameters are passed to the AddItem constructor in that order.
import { Analytics, AddItem } from 'expo-analytics-google';
Analytics.hit(new AddItem('1235', 'T-SHIRT', 11.99, 1, 'DD44', 'Clothes'));Debugging
The Google Analytics API is a bit particular. If you're not seeing Real Time hits in your Analytics console you can turn on debug mode for this package and the exact URL request being sent will be printed to the console.
import { Analytics, PageHit } from 'expo-analytics-google';
await Analytics.init({ propertyId: 'UA-XXXXXX-Y', config: { debug: true } });
...
Analytics.hit(new PageHit('IsItWorking'));Release History
- 1.0.2 Initial release