Google Analytics is implemented on the website with the primary goal of analyzing flows, and identifying areas of improvement for the user.
Every event and pageview must include an invocation of sendToGA()
.
Events are used to track interactions with the user. Mostly button or link clicks.
The structure for the events include 3 parts
eventCategory
: The name you supply for the group of objects you want to track.eventAction
: A string that is uniquely paired with each category, and commonly used to define the type of user interaction for the web object.eventLabel
: An optional string to provide additional dimensions to the event data.
This example shows the use of outboundURL
. Anytime we are redirecting to another page we have to include this property.
app.sendToGA('event', {
eventCategory: 'HomePage Interactions',
eventAction: 'button click',
eventLabel: 'Install the Add-on',
outboundURL: downloadUrl
});
app.sendToGA('event', {
eventCategory: 'Menu Interactions',
eventAction: 'drop-down menu',
eventLabel: 'Toggle Menu'
});
Here are the current events on the website as of this writing
Description | eventCategory | eventAction | eventLabel |
---|---|---|---|
Toggle settings menu | Menu Interactions | drop-down menu | Toggle Menu |
Click Leave from settings | Menu Interactions | drop-down menu | Retire |
Click Discuss from settings | Menu Interactions | drop-down menu | Discuss |
Click Wiki from settings | Menu Interactions | drop-down menu | wiki |
Click File Issue from settings | Menu Interactions | drop-down menu | File Issue |
Click on experiment from landing page | ExperimentsPage Interactions | Open details page | {experiment title} |
Click on Install from experiment details page | ExperimentDetailsPage Interactions | install button click | Install the Add-on from ${experiment title} |
Click on the "Try out these experiments as well" section | ExperimentsDetailPage Interactions | Open details page | try out {experiment title} |
Click Enable Experiment | ExperimentDetailsPage Interactions | Enable Experiment | {experiment title} |
Click Disable Experiment | ExperimentDetailsPage Interactions | Disable Experiment | {experiment title} |
Click Give Feedback for experiment | ExperimentDetailsPage Interactions | Give Feedback | {experiment title} |
Click Give Feedback for experiment from PreFeedback | ExperimentDetailsPage Interactions | PreFeedback Confirm | {experiment title} |
Click upgrade notice | ExperimentDetailsPage Interactions | Upgrade Notice | {experiment title} |
Click Take Survey after disable | ExperimentDetailsPage Interactions | button click | exit survey disabled |
Click Cancel on tour dialogue | ExperimentDetailsPage Interactions | button click | cancel tour |
Complete the tour | ExperimentDetailsPage Interactions | button click | complete tour |
Click Take Tour on tour dialogue | ExperimentDetailsPage Interactions | button click | take tour |
Click next during Tour | ExperimentDetailsPage Interactions | button click | forward to step n |
Click back during Tour | ExperimentDetailsPage Interactions | button click | back to step n |
Click on Install from landing page | HomePage Interactions | install button click | Install the Add-on |
Click on the no thank you survey after coming from no experiments notification | HomePage Interactions | button click | no experiments no thank you |
Click on experiment from landing page | HomePage Interactions | Open details page | {experiment title} |
Click take survey after Leave | RetirePage Interactions | button click | take survey |
Click on Twitter link in footer | FooterView Interactions | social link clicked | |
Click on GitHub link in footer | FooterView Interactions | social link clicked | GitHub |
Click on a button in the Share section | ShareView Interactions | button click | {facebook,twitter,email,copy} |
Prompted to restart the browser | PostInstall Interactions | view modal | restart required |
- Indicates whether or not a restart is required.
testpilot.firefox.com is a single page application. This means that instead of just placing our JS snippet at the top of the page and registering every pageview on load, we have to manually trigger a pageview on every view.
TODO: issue #839 - this manually sets the page URL as well which makes pageview tracking for SPA more reliable.
The pageview
send also uses sendToGA
, but with slightly different parameters.
Here is an example - viewing the home page.
app.sendToGA('pageview', {
'dimension1': this.hasAddon,
'dimension2': anyInstalled,
'dimension3': installedCount
});
The URL does not need to be sent here. As seen in the above example, you can also include Custom Dimensions
with the pageview calls.
We use custom dimensions to refine our pageviews on Test Pilot (docs from Google). Dimensions are unique to an application.
Here is a list of dimensions we are currently using
Page | Description | dimension | values |
---|---|---|---|
Home Page, Experiment Detail Page, Share Page | Does the user have the add-on installed | 1 | {0,1} |
Home Page, Share Page | Does the user have any experiments installed | 2 | {0,1} |
Home Page, Share Page | How many experiments does the user have installed | 3 | {n} |
Experiment Detail Page | Is the experiment enabled | 4 | {0,1} |
Experiment Detail Page | Experiment title | 5 | "xyz" |
Experiment Detail Page | Installation count | 6 | {n} |
Home Page, Experiment Detail Page | Determine if installation will require a restart | 7 | {'no restart','restart required'} |
Home Page, Experiment Detail Page, Share Page | Which test has this user been selected for? | 8 | {'installButtonBorder', ''} |
Home Page, Experiment Detail Page, Share Page | Which cohort has this user been selected for? | 9 | {'bigButton', ''} |
Whenever we are referring users to the Test Pilot website (either from an external website, or the add-on itself via a doorhanger/notification), we should include utm_*
paramaters to allow us to properly measure conversion rates of the channel.
Here is a description of the different utm tags (URL builder tool from Google)
utm_source
: Identify the advertiser, site, publication, etc. that is sending traffic to your property, for example: google, newsletter4, billboard.utm_medium
: The advertising or marketing medium, for example: cpc, banner, email newsletter.utm_campaign
: The individual campaign name, slogan, promo code, etc. for a product.utm_content
: Used to differentiate similar content, or links within the same ad. For example, if you have two call-to-action links within the same email message, you can use utm_content and set different values for each so you can tell which version is more effective.
We should maintain a consistent convention when using campaign parameters.
Description | utm_source | utm_medium | utm_campaign | utm_content |
---|---|---|---|---|
Clicking on an experiment (or "view all") from the doorhanger | testpilot-addon | firefox-browser | testpilot-doorhanger | {'badged','not badged'} |
Clicking on an experiment from the in-product messaging | testpilot-addon | firefox-browser | push notification | {messageID} |
Tab opens after user has tried an experiment for n days (#1292) | testpilot-addon | firefox-browser | share-page | |
Links that get shared from /share | {facebook,twitter,email,copy} | social | share-page | |
User hits home page after being sent by the add-on after installation. | testpilot-addon | firefox-browser | restart-required | |
Clicks on the no experiments installed notification | testpilot-addon | firefox-browser | testpilot-notification | no-experiments-installed |
- Indicates whether the toolbar button had the 'New' badge on it.