Skip to content

Instantly share code, notes, and snippets.

@ssajous
Last active August 29, 2015 14:01
Show Gist options
  • Select an option

  • Save ssajous/b9b2ddfd0d1f629cc53b to your computer and use it in GitHub Desktop.

Select an option

Save ssajous/b9b2ddfd0d1f629cc53b to your computer and use it in GitHub Desktop.
Setting up a google analytics service in an angularjs application
var myModule = angular.module('myModule', []);
myModule.factory('googleAnalytics', ['$window', function($window) {
// Initialize GA Tracker
(function (i, s, o, g, r, a, m) {
i['GoogleAnalyticsObject'] = r;
i[r] = i[r] || function () {
(i[r].q = i[r].q || []).push(arguments)
}, i[r].l = 1 * new Date();
a = s.createElement(o),
m = s.getElementsByTagName(o)[0];
a.async = 1;
a.src = g;
m.parentNode.insertBefore(a, m)
})($window, $window.document, 'script', '//www.google-analytics.com/analytics.js', 'ga');
$window.ga('create', 'UA-XXXXXXXX-X', 'auto');
return {
tracker: $window.ga
}
}]);
angular.run(['$rootScope', '$location', 'googleAnalytics',
function ($rootScope, $location, googleAnalytics) {
$rootScope.$on('$routeChangeSuccess',
function(event) {
googleAnalytics.tracker('send', 'pageview', { page: $location.path() });
});
});
]);
Sign up for free to join this conversation on GitHub. Already have an account? Sign in to comment