Help!

Or search support forum

What's Global Moxie?

Global Moxie specializes in mobile design strategy and user experience for a multiscreen world. We offer consulting services, training, and product-invention workshops to help creative organizations build tapworthy mobile apps and effective websites. We're based in Brooklyn, NY. Learn more.

On Shelves

Books by Josh Clark

Tapworthy: Designing Great iPhone Apps

Best iPhone Apps: The Guide for Discriminating Downloaders

iWork ’09: The Mising Manual

Moxiemail

Enter your e-mail to receive occasional updates:

Can Google Analytics track Big Medium file downloads?

Question

I use Google Analytics to track visitor activity on my Big Medium-powered site. How can I configure it to track file downloads in addition to regular HTML pages?

Answer

The default HTML that Google tells you to insert into your pages will track only those pages that include that code. This means that it can’t track file downloads (because they are not HTML pages, downloads cannot include JavaScript code).

Google offers a workaround for this. The solution involves adding an onclick attribute to every link to files you would like to track. However, there’s another way to attach an onclick event to all Big Medium download files, which does not require this kind of intervention in the code. Here’s how.

Google’s recommended script looks like this (where UA-xxxxxx-x is replaced by your Google Analytics account number):

<script type="text/javascript">
var gaJsHost = (("https:" == document.location.protocol) ? "https://ssl." : "http://www.");
document.write(unescape("%3Cscript src='" + gaJsHost + "google-analytics.com/ga.js' type='text/javascript'%3E%3C/script%3E"));
</script>
<script type="text/javascript">
var pageTracker = _gat._getTracker("UA-xxxxxx-x");
pageTracker._initData();
pageTracker._trackPageview();
</script>

To track Big Medium document files, update the code like so (be sure to change UA-xxxxxx-x to your actual Google Analytics account number):

<script type="text/javascript">
var gaJsHost = (("https:" == document.location.protocol) ? "https://ssl." : "http://www.");
document.write(unescape("%3Cscript src='" + gaJsHost + "google-analytics.com/ga.js' type='text/javascript'%3E%3C/script%3E"));
</script>
<script type="text/javascript">
  var pageTracker = _gat._getTracker("UA-xxxxxx-x");
  pageTracker._initData();
  pageTracker._trackPageview();
  (function(){ //track BM document files
    var logDoc = function(evt) {
      var e = Event.element(evt);
      if(e.nodeType == 3) { e = e.parentNode; } //Safari bug
      if (e.tagName=='A') {
          var match = e.href.match(/(\/bm~doc\/.*)/);
          if (match) { pageTracker._trackPageview(match[1]); }
      }
    };
    BM.onDOM.addEvent(function(){
      Event.observe(document.body,'click',logDoc);
    });
  })();
</script>

Limitations

This code change makes Google Analytics track links only to files loaded via Big Medium's control panel. It will not track downloads of files that are linked directly from other sites, and it will not track downloads to files that were not loaded via Big Medium's control panel.

Download Big Medium
Try it free for 30 days, or buy to unlock.

Blown Away

“I’m blown away by Josh Clark’s deep understanding of the iPhone user experience.”
—Jürgen Schweizer, founder of Cultured Code, maker of Things iPhone app

“It’s rare to find a person like Josh Clark who speaks so intently to the topic of interface design and mobile devices.”
—John Maeda, president of Rhode Island School of Design

“If you have time to read only one book on what makes apps successful, it is Tapworthy by Josh Clark.”
—Andreas Sjostrom, manager of mobile solutions, Sogeti

More praise for Tapworthy