I've implemented Google analytics Opt out
feature, but what I actually need is an option for a user to undo
his action.
Lats say a user clicks the button to opt out, but then changes his mind. In any case we all want to have that tracking, so would be a good thing for a user to have an option to enable tracking again.
The problem I'm having is not being sure how to handle this. At the end of this post is the jsFiddle example.
What I'm doing is initially including the tracking code, and then optionally creating the tracker
.
if (document.cookie.indexOf(disableGa + '=true') > -1) {
window[disableGa] = true;
// Remove the tracker
ga(function () {
ga('remove', gaProperty);
});
} else {
// Create the tracker
ga('create', gaProperty, 'auto', {
anonymizeIp: true
});
ga('send', 'pageview');
}
So, when the user reaches the page I either instantiate the create tracker, or not.
What I'm not clear on is the remove
property.
After this, on the page there is the button which allows the user to toggle GA state.
The functionality is pretty much the same as the above described one. But I also want to allow an option for the Google analytics to be dynamically enabled.
I'm handling the cookie as per the example:
// Set to the same value as the web property used on the site
var gaProperty = 'UA-XXXX-Y';
// Disable tracking if the opt-out cookie exists.
var disableStr = 'ga-disable-' + gaProperty;
if (document.cookie.indexOf(disableStr + '=true') > -1) {
window[disableStr] = true;
}
// Opt-out function
function gaOptout() {
document.cookie = disableStr + '=true; expires=Thu, 31 Dec 2099 23:59:59 UTC; path=/';
window[disableStr] = true;
}
And then my idea was to register/unregister the tracker per user request, but I'm not sure if I'm doing it correctly.
// Remove the tracker
ga(function () {
ga('remove', gaProperty);
});
Not sure if it's worth mentioning, but I'm implementing this in an Angular app.
Also, the reason why I'm doing the create and remove conditionally is because I remember reading that the global property window.ga-disable-UA-XXXX-Y = true
has to be set before issuing the ga('create')
.
For debugging I'm using Google's Tag Assistant, and it is reporting duplicate use of the tracking ID when toggling the GA. https://jsfiddle.net/vLyeszfg/18/
As you might be able to see, I'm successfully programmatically enabling google analytics, but the removal is the problem.