Files
phonegap-plugins/Android/Analytics/1.6/www/analytics.js

95 lines
2.9 KiB
JavaScript

/*
* PhoneGap is available under *either* the terms of the modified BSD license *or* the
* MIT License (2008). See http://opensource.org/licenses/alphabetical for full text.
*
* Copyright (c) 2006-2011 Worklight, Ltd.
*/
/**
* Constructor
*/
function Analytics() {
}
/**
* Initialize Google Analytics configuration
*
* @param accountId The Google Analytics account id
* @param successCallback The success callback
* @param failureCallback The error callback
*/
Analytics.prototype.start = function(accountId, successCallback, failureCallback) {
return PhoneGap.exec(
successCallback,
failureCallback,
'GoogleAnalyticsTracker',
'start',
[accountId]);
};
/**
* Track a page view on Google Analytics
* @param key The name of the tracked item (can be a url or some logical name).
* The key name will be presented in Google Analytics report.
* @param successCallback The success callback
* @param failureCallback The error callback
*/
Analytics.prototype.trackPageView = function(key, successCallback, failureCallback) {
return PhoneGap.exec(
successCallback,
failureCallback,
'GoogleAnalyticsTracker',
'trackPageView',
[key]);
};
/**
* Track an event on Google Analytics
* @param category The name that you supply as a way to group objects that you want to track
* @param action The name the type of event or interaction you want to track for a particular web object
* @param label Provides additional information for events that you want to track (optional)
* @param value Assign a numerical value to a tracked page object (optional)
* @param successCallback The success callback
* @param failureCallback The error callback
*/
Analytics.prototype.trackEvent = function(category, action, label, value, successCallback, failureCallback){
return PhoneGap.exec(
successCallback,
failureCallback,
'GoogleAnalyticsTracker',
'trackEvent',
[
category,
action,
typeof label === "undefined" ? "" : label,
(isNaN(parseInt(value,10))) ? 0 : parseInt(value, 10)
]);
};
Analytics.prototype.setCustomVar = function(index, label, value, scope, successCallback, failureCallback){
return PhoneGap.exec(
successCallback,
failureCallback,
'GoogleAnalyticsTracker',
'setCustomVariable',
[
(isNaN(parseInt(index,10))) ? 0 : parseInt(index, 10),
label,
value,
(isNaN(parseInt(scope,10))) ? 0 : parseInt(scope, 10)
]);
};
/**
* Load Analytics
*/
PhoneGap.addConstructor(function() {
PhoneGap.addPlugin('analytics', new Analytics());
// @deprecated: No longer needed in PhoneGap 1.0. Uncomment the addService code for earlier
// PhoneGap releases.
// PluginManager.addService("GoogleAnalyticsTracker", "com.phonegap.plugins.analytics.GoogleAnalyticsTracker");
});