Introduction to Google Tag Manager (GTM)
Google Tag Manager (GTM) is designed to help website owners organize and deploy scripts and tags on their site. When using GTM, websites are still subject to global data regulations such as the GDPR, PIPEDA, CCPA, and more.
Businesses under these regulations who use GTM to deploy third-party tracking technologies (e.g., Google Analytics, Facebook Pixel, LinkedIn, AdWords, etc.) must ensure that user consent choices are respected for people visiting their site.
Understanding Google Tag Manager and Consent Mode
GTM’s consent configuration allows users to categorize tags so that they are fired only under the right conditions when site visitors give consent.
By enabling Consent Mode in your Termly Consent Management Platform (CMP) you can use the consent given in Termly to control tag firing in GTM.
Learn more about Consent Mode and Termly.
How to Integrate Termly with Google Tag Manager
Step 1. Install Termly’s Consent Management Platform
First you will need to install your Termly Consent Management Platform (CMP) code snippet on every page of your site. You can do this in one of two ways:
Option 1: Install the Termly CMP script tag directly on your page, before the GTM snippet (recommended)
Option 2: Serve the Termly CMP script tag through Termly's GTM template (covered in step 2.3.6).
Note: We do not recommend enabling Termly’s Auto Blocker if you use GTM as it can interfere with GTM’s ability to serve scripts.
Step 2. Install the Termly Consent Management Platform Template
Termly’s native Google Tag Manager template will let your GTM container read your site visitors' consent preferences anywhere that your Termly CMP is installed.
2.1 Add the template to your workspace
Click on Templates in the left hand menu of your GTM workspace
Click Search Gallery
Search for “Termly”
Select “Termly Consent Management Platform”
Click Add to Workspace
2.2 Create a new event trigger "userPrefUpdate"
Go to your GTM workspace and create a new trigger
Click Choose a trigger type to begin setup, then click Custom Event.
Under Event name type
userPrefUpdate
Trigger should be set to fire on All Custom Events
2.3 Add the Template tag
Go to Tags
Create a new tag and select Termly Consent Mode in Tag Configuration
Click Triggering, then click New / +
Add Consent Initialization - All Pages
Add userPrefUpdate
Optional: if you want to install the Termly script tag along with the template, select 'Inject Termly consent management platform script tag' then paste in your website UUID.
Step 3. Configure tags to respond to user consent
For every tag in your GTM environment, you want to ensure that it is behaving according to the site visitor's consent preferences. In GTM you can configure this for each tag using 'Additional Consent Checks' as discussed below.
3.1 Create new event trigger "Termly.consentSaveDone"
Whenever the consent state changes on the page, your Termly CMP will fire an event Termly.consentSaveDone
.
This event can be used as a trigger for your tags that need to re-evaluate whether or not to fire each time a visitor's consent preferences change. This includes tags that:
Don't have built-in consent checks, and
Would normally fire on the 'page view' event (such as non-Google analytics or widgets)
To create a trigger that fires when the Termly.consentSaveDone
event is fired:
Go to your GTM workspace and create a new trigger
Click Choose a trigger type to begin setup, then click Custom Event.
Under Event name type
Termly.consentSaveDone
Trigger should be set to fire on All Custom Events
Note: It is normal for the "Termly.consentSaveDone" event to fire twice on page load in some cases. This behavior is designed to ensure accurate consent state updates after initial page load according to factors like the user's region and previous consent state.
3.2 Configure Consent Checks for all your tags
For each tag, you can configure Additional Consent Checks in one of three ways:
Not set: this is the default. You should aim to not have any tags with this state.
No additional consent required: this should be used for either:
Tags with built-in consent checks, such as Google's Analytics and Ads gtags
Essential tags that do not require the user to consent
Require additional consent for tag to fire: for all other non-essential tags, you should configure which consent category needs to be consented to in order for it to fire. Use the mapping table below to select the appropriate categorization.
If you do not see consent checks in your tag manager environment, you may need to enable the feature from Container Settings > Additional Settings > Enable consent overview
For tags that trigger based on page views (i.e. not based on events such as click, sign up, purchase):
Open Triggering > Firing Triggers below Tag Configuration
Select the “Termly.consentSaveDone” event you previously created
Advanced configuration and tips
Consent category mapping
See the table below for how Termly consent categories map to GTM consent types:
Termly Consent Category | GTM Consent Type |
advertising | ad_storage |
analytics | analytics_storage |
performance | functionality_storage |
performance | personalization_storage |
essential | security_storage |
social | social_storage* |
*Not a default GTM consent category
Tag firing options
The Termly.consentSaveDone event will trigger every time there is a change to the user's consent state. This can happen multiple times on the page due to the default consent configuration, and subsequent updates made (e.g. when a user interacts with the banner or due to opt-out configuration).
Therefore, it is important to set the appropriate tag firing options depending on the tag.
Once per page: For tags that require consent, if their trigger happens before consent is given, they will not fire until the next page load.
Once per event: For tags that require consent, they will fire immediately once consent is given. They will also potentially fire multiple times on the page, so be sure that that will not be a concern for the functioning of the tag.
Complex page view tags
For tags that fire on complex page view triggers (e.g. only on certain pages or when certain conditions are met), it is recommended to create a new variation of the 'Termly.consentSaveDone' trigger that meets these requirements.
For example, for a tag that only fires on a specific page:
Create a new Custom event trigger
Set the event name to 'Termly.consentSaveDone'
Change This trigger fires on to 'Some Custom Events'
Set the condition to 'Page URL contains your/page/path'\
Disclaimer
Termly's integration with Google Tag Manager relies on the default dataLayer object, where Termly's consent data is passed. Modifying the default code provided for Google Tag Manager will result in the Termly Tag not functioning correctly.
By default, Google Tag Manager provides the following code snippet:
<!-- Google Tag Manager -->
<script>
(function(w, d, s, l, i) {
w[l] = w[l] || [];
w[l].push({ 'gtm.start': new Date().getTime(), event: 'gtm.js' });
var f = d.getElementsByTagName(s)[0],
j = d.createElement(s),
dl = l != 'dataLayer' ? '&l=' + l : '';
j.async = true;
j.src = 'https://www.googletagmanager.com/gtm.js?id=' + i + dl;
f.parentNode.insertBefore(j, f);
})(window, document, 'script', 'dataLayer', 'XXX-XXXXX');
</script>
<!-- End Google Tag Manager -->
Important: Modifying the dataLayer object in this code will cause the Termly Tag to stop functioning. Ensure that the dataLayer object remains unaltered to maintain compatibility.