This version of the PhoneGap/Cordova SDK wraps v3.8.2 of the Localytics Android and v3.8.0 of the Localytics iOS SDKs
The PhoneGap/Cordova SDK was tested on Cordova v6.1.1 and 6.2.0
cordova plugin add localytics-cordova
To install Localytics for Phonegap, you'll need to take three basic steps.
-
Set up your app key for each platform.
-
Integrate your app with Localytics.
-
Set up and register for Push notifications, if necessary.
App keys allow you to separate data. Create one set of app keys for each app, so you can focus on one app at a time in the Dashboard.
You’ll need an app key for each device platform, such as iOS, Android, Windows, or web. Separate test data from production data by using separate app keys.
When you release your app to the app store, make sure your production app key is in it! You can feel free to delete your test app keys and make new ones whenever you want.
In your <ApplicationName>-Info.plist, add the following under <dict> node:
<key>LocalyticsAppKey</key>
<string>YOUR_APP_KEY</string>
In AndroidManifest.xml, add the following under <application> node:
<meta-data android:name="LOCALYTICS_APP_KEY" android:value="YOUR_APP_KEY" />
Note Replace YOUR_APP_KEY with your Localytics app key.
With automatic integration, the plugin automatically opens, closes, and uploads sessions when the app goes into the background and foreground.
With manual integration, you have full control of open, close, and upload events, but you'll need to listen for pause and resume events and handle opens, closes, and uploading sessions manually.
Regardless of the integration method you choose, start by adding the following listener:
document.addEventListener('deviceready', this.onDeviceReady, false);
Add following code in MainActivity.Java
private static Intent receivedIntent;
@Override protected void onResume() { super.onResume(); receivedIntent = getIntent(); }
@Override
protected void onNewIntent(Intent intent) {
super.onNewIntent(intent);
Localytics.handlePushNotificationOpened(intent);
}
public static Intent getReceivedIntent(){
return receivedIntent;
}
Add the following for automatic integration.
onDeviceReady: function() {
Localytics.autoIntegrate();
Localytics.openSession(); // For Android, we might have missed the call to open a session by the time autoIntegrate is called. Don't worry, calling this will not open a second session.
}
Add the following for manual integration.
onDeviceReady: function() {
document.addEventListener("resume", app.onResume, false);
document.addEventListener("pause", app.onPause, false);
Localytics.integrate();
Localytics.openSession();
Localytics.upload();
}
onResume: function () {
Localytics.openSession();
Localytics.upload();
},
onPause: function () {
Localytics.closeSession();
Localytics.upload();
},
Additionally, for each platform:
Ensure the following libraries are added to your project's .xcodeproj:
AdSupport.framework
libsqlite3.tbd
libz.tbd
SystemConfiguration.framework
If compiling against iOS 9 SDK, add an App Transport Security exception to Info.plist:
<key>NSAppTransportSecurity</key>
<dict>
<key>NSExceptionDomains</key>
<dict>
<key>public.localytics.s3.amazonaws.com</key>
<dict>
<key>NSExceptionAllowsInsecureHTTPLoads</key>
<true/>
</dict>
<key>pushapi.localytics.com</key>
<dict>
<key>NSExceptionAllowsInsecureHTTPLoads</key>
<true/>
</dict>
</dict>
</dict>
Ensure the following ReferralReceiver is added to AndroidManifest.xml within the application tag:
<receiver android:name="com.localytics.android.ReferralReceiver"
android:exported="true">
<intent-filter>
<action android:name="com.android.vending.INSTALL_REFERRER" />
</intent-filter>
</receiver>
iOS uses Apple Push Notification (APN) while Android uses Google Cloud Messaging (GCM). Follow the instructions for each respective push notification service to set up the necessary configurations and upload the certificate to the Localytics Dashboard before continuing with these instructions.
Note: In-App messaging is not supported on Android at this time. The native Android implementation to handle in-app messaging makes use of the FragmentActivity class that is incompatible with the primary CordovaActivity class that holds the Webview.
Follow these instructions to set up push notifications for your app.
Afterwards, simply call the following after the integration code in the previous step.
Localytics.registerPush();
Note: registerNotification relies on "CDVRemoteNotification", "CDVRemoteNotificationError" and "CDVPluginHandleOpenURLNotification" broadcasted by cordova's AppDelegate.m class. If you change the AppDelegate, ensure to rebroadcast these events from the appropriate handlers to ensure correct behavior. Alternatively, you can also integrate manually through native code instead.
Follow these instructions to set up push notifications for your app.
Next, copy the Google Play Services library and add it as a dependency to your project:
- Copy the folder <ANDROID_SDK_DIR>/extras/google/google_play_services_lib/ to <YOUR_PROJECT>/platforms/android/
- Add an extra line to <YOUR_PROJECT>/platforms/android/project.properties: "android.library.reference.2=google-play-services_lib
In your AndroidManifest.xml, ensure the following are added before your <application> tag:
Note: replace YOUR.PACKAGE.NAME with your package name, ie, com.yourcompany.yourapp
<uses-permission android:name="android.permission.INTERNET" />
<uses-permission android:name="android.permission.WAKE_LOCK" />
<uses-permission android:name="com.google.android.c2dm.permission.RECEIVE" />
<permission android:name="YOUR.PACKAGE.NAME.permission.C2D_MESSAGE" android:protectionLevel="signature" />
<uses-permission android:name="YOUR.PACKAGE.NAME.permission.C2D_MESSAGE" />
Inside your <application> tag, add:
Note: replace YOUR.PACKAGE.NAME with your package name and <YOUR_PUSH_ID> with your GCM push id. The "\ " before the push id is intentional (ie. android:value="\ 1234567").
<activity android:name="com.localytics.android.PushTrackingActivity" />
<receiver android:name="com.localytics.android.PushReceiver" android:permission="com.google.android.c2dm.permission.SEND">
<intent-filter>
<action android:name="com.google.android.c2dm.intent.REGISTRATION" />
<action android:name="com.google.android.c2dm.intent.RECEIVE" />
<category android:name="YOUR.PACKAGE.NAME" />
</intent-filter>
</receiver>
<meta-data android:name="com.localytics.android_push_sender_id" android:value="\ <YOUR_PUSH_ID>" />
Afterwards, simply call the following function after the integration code in the previous step.
Localytics.registerPush();
After integrating, tagging events and any further instrumentation should be done inside the web app.
Anywhere in your application where an interesting event occurs, you can tag it by adding the following line of code, where “Options Saved” is a string describing the event:
Localytics.tagEvent("Options Saved", null, 0);
Sometimes you might want to collect additional data about the event, like how many lives the player has, or what the last action the user took was before clicking on an ad. Use the second parameter of tagEvent to do this. It takes a hash of attributes and values.
Localytics.tagEvent("Options Saved", { "Display Units" : "MPH", "Age Range" : "18-25" }, 0);
The third parameter of tagEvent is used to increase customer lifetime value (CLV). If the user makes a purchase, you might specify the price of the purchase in cents.
Localytics.tagEvent("Purchase Completed", { "Item Name" : "Power Up" }, 499);
The Cordova app found under SampleApp demonstrates a list of functional APIs that can be called via the JavaScript interface. Update "LocalyticsAppKey" and "LOCALYTICS_APP_KEY" for their respective platforms to easily test out the calls.