Skip to main content

Snowplow Template

This template implements the Snowplow JavaScript tracker for Google Tag Manager. It allows for the sending of Snowplow events from your website to your Snowplow collector.

Tag Types are the kinds of events that can be tracked with the Snowplow v4 Tag Template. Each tag type has its own set of options and parameters that can be configured.

You can also configure plugins to use with this template.

Ad Tracking

The Ad Tracking tag is used to track impressions and ad clicks. This can used by, for example, ad networks to identify which sites and web pages users visit across a network, so that they can be segmented.

Ad Tracking Parameters

All ad tracking events take the following common parameters:

NameRequired?DescriptionExample
advertiserIdNoThe advertiser ID201
campaignIdNoThe campaign ID12
costNoThe cost of the ad5.5
costModelNoThe cost model for the campaign. Must be one of cpc, cpm, or cpacpc

The ad tracking tag includes three event types, each with its own set of additional parameters:

Impression Event

NameRequired?DescriptionExample
impressionIdNoIdentifier for the particular impression instance67965967893
targetUrlNoThe destination URLhttps://www.example.com
bannerIdNoAdserver identifier for the ad banner (creative) being displayed23
zoneIdNoAdserver identifier for the zone where the ad banner is located7

Click Event

NameRequired?DescriptionExample
targetUrlYesThe destination URLhttps://www.example.com
clickIdNoIdentifier for the particular click instance12243253
bannerIdNoAdserver identifier for the ad banner (creative) being displayed23
zoneIdNoAdserver identifier for the zone where the ad banner is located7

Conversion Event

NameRequired?DescriptionExample
conversionIdNoIdentifier for the particular conversion instance743560297
categoryNoConversion categoryecommerce
actionNoThe type of user interactionpurchase
propertyNoDescribes the object of the conversionshoes
initialValueNoHow much the conversion is initially worth99

Button Click Tracking

This tag will enable the tracking of clicks on buttons, covering both <button> and <input type="button"> elements.

info

This does not track track a button click event directly, but rather will enable listen for button clicks.

Filter

The Filter option allows you to specify a list of CSS classes that will be used to filter out elements that should not be tracked. This can be useful if you have a large number of buttons on your site, but only want to track clicks on a subset of them.

There are two types of filters you can use:

  • Allow: Only elements that match the specified CSS classes will be tracked.
  • Block: Elements that match the specified CSS classes will not be tracked.

Each filter takes a comma-separated list of CSS classes. For example, to only track clicks on buttons with the classes "track-me" and "click-me" you would add enter track-me, click-me into Classes when the Allow filter type is selected.

Cart Tracking

The Cart Tracking tag is used to track interactions with a shopping cart. This can be used to track the addition and removal of items to a cart.

Cart Tracking Parameters

Add To Cart and Remove From Cart events take the following parameters:

NameRequired?DescriptionExample
skuYesThe stock keeping unit (SKU) of the product being added/removed000345
unitPriceYesThe price of the product being added/removed12.99
quantityYesThe quantity of the product being added/removed2
nameNoThe name of the product being added/removed'blue tie'
categoryNoThe category of the product being added/removed'clothing'
currencyNoThe currency of the product being added/removed'USD'

info

We recommend migrating to the Snowplow Ecommerce Tag template to take advantage of the latest ecommerce tracking features.

The Site Search tag can be used to track searches on your website, using the Site Search Schema

Site Search Parameters
NameRequired?DescriptionExample
termsYesSearch terms['unified, log']
filtersNoSearch filters{'category': 'clothing'}
totalResultsNoResults found10
pageResultsNoResults displayed on first page5

Timing

This is used to track user timing events, such as how long resources take to load.

Timing Parameters
NameRequired?DescriptionExample
categoryYesTiming category'load'
variableYesTimed variable'map_loaded'
timingYesNumber of milliseconds elapsed50
labelNoLabel for the event'Map loading time'

The Enhanced Consent tag is used to track user consent preferences. This can be used to track whether a user has given consent to certain tracking activities, such as tracking cookies or personalized ads.

Enhanced Consent Events
NameDescription
Allow AllTrack an acceptance of user consent.
Allow SelectedTrack a specific selection of consented scopes.
PendingTrack the unconfirmed selection about user consent.
ImplicitTrack the implicit consent on user consent preferences.
DenyTrack a denial of user consent.
ExpiredTrack the expiration of a consent selection.
WithdrawnTrack the withdrawal of user consent.
Enhanced Consent Parameters
AttributeDescriptionExample
basisForProcessingGDPR lawful basis for data collection & processing.Consent
consentUrlURI of the privacy policy related document.https://example.com
consentVersionVersion of the privacy policy related document.1.0
consentScopesThe scopes allowed after the user finalized their selection of consent preferences.'analytics, functional'
domainsAppliedThe domains for which this consent allows these preferences to persist to.https://example.com
gdprAppliesDetermine if GDPR applies based on the user's geo-location.-

Enhanced Ecommerce

For Google Analytics 4 compatible ecommerce tracking, see the dedicated Snowplow v3 Ecommerce Tag template instead.

info

The following Enhanced Ecommerce plugin has been deprecated in favor of the Snowplow Ecommerce Tag template, it is recommended to use the new template for the latest ecommerce tracking features. This tag remains for compatibility with existing setups.

The Enhanced Ecommerce tag is used to track ecommerce events, such as product views, add to cart, and purchases.

When you select Enhanced Ecommerce, you are left with two options: Use Data Layer or Choose Variable. The way it works is very similar to Enhanced Ecommerce in Google Analytics.

If you choose the first, the template will look into the dataLayer structure for the most recently pushed Enhanced Ecommerce object, and map this object to the request to Snowplow Analytics.

If you selected Choose Variable, you need to provide a GTM variable that returns an object in the correct, expected format.

Error Tracking

The Errors tracker tag provides a way to manually track any errors that occur on your website.

Error Tracking Parameters
NameRequired?DescriptionExample
messageYesError message'Cannot get user object'
filenameNoFilename or URL'shop.js'
linenoNoLine number of problem code chunk23
colnoNoColumn number of problem code chunk45
errorNoJS ErrorEvent{Stack trace string}

Page View

You can provide a Custom Page Title if you wish, and you can add a custom context to the request, as also described here.

If you enable Page Activity Tracking, page pings will be sent at intervals that you can specify.

The Callback Function is something you can set to a JavaScript function. If you set the callback, then instead of sending the page ping to Snowplow, the function gets invoked instead. See the JavaScript tracker documentation for more information.

The Track Link Click event is similar to regular parameter-based events, as it lets you add parameters and track a link click as a manually encoded hit.

The Enable Automatic Link Click Tracking adds listeners to the page, which will track clicks on links permitting they adhere to the allow/denylisted class names you can optionally provide. It is intended to trigger early on a page to begin listening for click events, not to trigger on click events like Click Triggers.

The Fix Middle-click Tracking adds a fix for some browsers where middle-clicks were not tracked properly.

If you check Track HTML Content Of Clicked Link, then the full text content of the link element will be sent to Snowplow as well.

note

This setting enables the tracker's native Link Click Tracking plugin, it does not directly fire an event.

Form Tracking

Form tracking has just two options, because filters and transformations won’t work with the custom template (due to lack of support for processing HTML elements). The options are to set form and/or field denylists and allowlists.

Denylists and allowlists for forms are a list of comma-separated HTML class names. If denylisted, then any form element with a listed class will not trigger the form event. If allowlisted, then only form elements with a listed classname will be tracked.

For fields, denylists and allowlists work similarly, except they use the name attribute rather than the class.

Note that this tag enables the tracker's native Form Tracking plugin, it does not directly fire an event. It is intended to trigger early on a page to begin listening for form events, not to trigger on form events like Form Submit Triggers.

Custom commands

For any other commands which are supported by the Snowplow JavaScript Tracker v4, you can select the [Custom Command] option. Once selected, you can enter any function name and the associated parameter for that function. The parameter can either be a simple string, in examples such as setUserId:

setUserId

Or it can be set to a Custom JavaScript Variable in the instances where an Object should be passed to the function, such as with enableAnonymousTracking:

enableAnonymousTracking Custom JavaScript variable

And then use this variable as your Command Argument:

enableAnonymousTracking Custom Command argument

For a list of available commands, consult the API documentation for the Browser Tracker

Additional Tracking Parameters

Add custom context entities

Using the Context Entities table allows you to attach custom context entities to the Snowplow event. Each row should be set to a variable value that must be an array of custom context objects that will all be concatenated to add to the Event.

For example to manually attach the web page context, create a custom JavaScript variable that returns an array with the custom context object:

function() {
return [{
schema: 'iglu:com.example/web_page/jsonschema/1-0-0',
data: {
id: '12345',
title: 'Example Page',
url: 'https://example.com'
}
}];
}

Then set this variable as the value in the Context Entities table.

Set Custom Timestamp

You can also choose to set the True Timestamp with this field. The format must be UNIX time in milliseconds.

Parameter Object

Tags that can derive their parameters from a Google Tag Manager variable are:

You can set the Retrieve Parameters From Variable setting to a Google Tag Manager variable. This parameter must return an object. In the object, the key-value pairs should reflect the named parameters in the event documentation. For example, to have the variable populate an Error event, you could use a Custom JavaScript variable like this:

function() {
return {
message: 'Some Error Happened',
filename: 'somefile.js',
lineno: 5,
colno: 236,
error: null
}
}

Alternatively, you can set the drop-down to the value No, and add the parameters manually instead:

adding parameters manually

Some tag types will add additional selections to this section. Follow the official tracker documentation for more information about what each option does.