Skip to content

rajanshahsa/localytics-cordova

 
 

Folders and files

NameName
Last commit message
Last commit date

Latest commit

 

History

60 Commits
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 

Repository files navigation

Localytics for PhoneGap/Cordova

Version

This version of the PhoneGap/Cordova SDK wraps v3.8.2 of the Localytics Android and v3.8.0 of the Localytics iOS SDKs

Supported Versions

The PhoneGap/Cordova SDK was tested on Cordova v6.1.1 and 6.2.0

Installation

cordova plugin add localytics-cordova

Integration

To install Localytics for Phonegap, you'll need to take three basic steps.

  1. Set up your app key for each platform.

  2. Integrate your app with Localytics.

  3. Set up and register for Push notifications, if necessary.

1. Set up app keys

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.

iOS

In your <ApplicationName>-Info.plist, add the following under <dict> node:

<key>LocalyticsAppKey</key>
<string>YOUR_APP_KEY</string>

Android

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.

2. Automatic or manual integration?

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);        

3. For Localytics push open count:

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;
}

Automatic integration

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.
}

Manual Integration

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:

iOS

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>

Android

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>

3. Set up and register for push notifications

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.

iOS

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.

Android

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:

  1. Copy the folder <ANDROID_SDK_DIR>/extras/google/google_play_services_lib/ to <YOUR_PROJECT>/platforms/android/
  2. 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.

Event tagging

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);

SampleApp

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.

About

No description, website, or topics provided.

Resources

License

Stars

Watchers

Forks

Packages

No packages published

Languages

  • Objective-C 43.1%
  • Java 33.6%
  • JavaScript 15.9%
  • HTML 4.5%
  • Batchfile 1.7%
  • CSS 1.0%
  • Shell 0.2%