Use one API, thanks to Segment.io's analytics.js, to easily and automatically record and send data from your JavaScript application to your analytics platforms.
NOTE: The @okgrow/auto-analytics
package replaces the now deprecated okgrow-auto-analytics
package.
> npm install @okgrow/auto-analytics --save
- Amplitude
- Chartbeat
- comScore
- Google Analytics
- HubSpot
- Intercom
- Keen IO
- KISSmetrics
- Mixpanel
- Quantcast
- Segment.io
If you, or your users, are running an ad blocker in their browser and the analytics package is not bundled into a single JavaScript file to the browser (i.e., is downloads as analytics.js or something similar) the browser's ad blocker may prevent analytics tracking. This can happen during development mode when all JavaScript files are typically not bundled together.
To solve this problem with a Meteor application, for example, you can run the application in production mode like this:
meteor run --production --settings settings.json
NOTE: If an Adblocker is enabled the expected behavior is that your analytic events will not be received. You will see an error message in your console reporting the events being blocked.
Add various platforms by adding each tool's configuration to the settings object passed to OKGAnalytics:
import OKGAnalytics, { analytics } from '@okgrow/auto-analytics';
const settings = {
// Add your analytics tracking ids here (remove this line before running)
"Google Analytics" : {"trackingId": "Your tracking ID"},
"Amplitude" : {"apiKey": "..."},
"Chartbeat" : {"uid": "..."},
"comScore" : {"c2": "..."},
"HubSpot" : {"portalId": "..."},
"Intercom" : {"appId": "..."},
"Keen IO" : {"projectId": "...", "writeKey": "..."},
"KISSmetrics" : {"apiKey": "..."},
"Mixpanel" : {"token": "...", "people": true},
"Quantcast" : {"pCode": "..."},
"Segment.io" : {"apiKey": "..."}
};
OKGAnalytics(settings);
The service names and API key-names provided above are specific to each platform. Make sure to use the correct service name and key shown for the platform you're adding.
There are other options which not documented here. To find them search for your specific integration in this file and look at the options and their defaults that are set with .option(...)
.
If you use a different service for tracking events or page views and you think it's popular enough that we should add it then please open an issue on the repo and we'll see how many supporters we get. Each additional integration adds a small amount to the file size so we want to support only the most common ones to economize the download size of this package.
Compatible with any router, this package will log page views automatically. Each page is logged with the follow parameters:
path
: path part of the URLtitle
: the page's titleurl
: hostname + pathsearch
: the URL's query string, if provided. blank otherwisereferrer
: hostname + old path, if coming from a previous route
To disable automatic page view tracking add autorun: false
to your settings object when configuring then manually log a page view by calling analytics.page('page name')
:
Track any event by simply calling the analytics.track()
function:
analytics.track("Bought Ticket", {
eventName: "Wine Tasting",
couponValue: 50,
});
Check Segment.io's analytics.js track documentation for a full description of track()
and all the other functions available in this package.
When adding your platforms and setting events to track you may want to keep debug on locally. This will log all the analytics package's activity to the console.
To turn on debugging, in the console:
> analytics.debug()
Turn debugging off, in the console:
> analytics.debug(false)
This package includes an examples
directory containing a simple (Meteor) application using react-router. This is just an example with a common router and doesn't imply this plugin only works with this router or only with Meteor. This application can be run from its directory with:
meteor --settings settings.json --production
.
Released under the MIT license.
Issues and Pull Requests are always welcome. Please read our contribution guidelines.