Documentation
Feedback
Guides
VTEX IO Apps

VTEX IO Apps
Google Tag Manager
Official extension
Version: 3.5.3
Latest version: 3.5.3

{"base64":"","img":{"src":"https://img.shields.io/badge/all_contributors-0-orange.svg?style=flat-square","width":110,"height":20,"type":"svg"}}

The VTEX Google Tag Manager (GTM) app is a first party integration to the Google Tag Manager solution.

{"base64":"  ","img":{"width":2874,"height":1552,"type":"png","mime":"image/png","wUnits":"px","hUnits":"px","length":336025,"url":"https://user-images.githubusercontent.com/52087100/84321347-55e11c80-ab49-11ea-9445-24eec6a07785.png"}}

Installing the Google Tag Manager app

  1. Access the Apps section in your account's admin page and look for the Google Tag Manager box;
  2. Then, click on the Install button;
  3. You'll see a warning message about needing to enter the necessary configurations. Scroll down and type in your GTM ID in the Google Tag Manager field.
  4. Click on Save.

Access the Google Tag Manager page and log in to your account in order to find out what is your account GTM ID. Use the number provided by the Container ID column.

Step 2 - Creating Google Analytics variables

To set up Google Tag Manager in your store, you must create and set up all necessary variables, triggers, and tags. Follow the Setting up Google Tag Manager documentation to create them.

Step 3 - Persisting campaign data throughout a user session

To prevent GTM from creating additional session identifiers every time a user navigates the website, you must add the variables originalLocation and originalReferrer to your GTM container and configure your store’s Google Analytics tags. Notice that this is important to persist campaign data throughout a user session and avoid providing inconsistent campaign data to Google Analytics (GA).

The originalLocation and originalReferrer variables are available for VTEX IO Google Tag Manager versions 2.x and 3.x.

Creating the variables Original Location and Original Referrer

  1. Log in to your GTM account and click on the GTM container you want to work with.

    {"base64":"  ","img":{"width":1821,"height":508,"type":"png","mime":"image/png","wUnits":"px","hUnits":"px","length":69245,"url":"https://user-images.githubusercontent.com/67270558/136798596-cc0add2d-e110-4176-bc8d-665ded39da29.png"}}

  2. On the container page, click on Variables.

  3. In the Built-In Variables section, check if the Page URL and Page Path variables are enabled. Otherwise, click on Configure and select Page URL and Page Path to enable them.

  4. Go to the User-Defined Variables section and click on New. A side popup will open.

  5. Replace the Untitled Variable value with Original Location.

  6. Click on Variable Configuration.

  7. On Page Variables, click on Data Layer Variable.

  8. In the Data Layer Variable Name field, type originalLocation.

  9. Enable the Set Default Value option and fill in the Default Value field with the following value:


    _10
    {{Page URL}}

    {"base64":"  ","img":{"width":774,"height":346,"type":"gif","mime":"image/gif","wUnits":"px","hUnits":"px","length":703078,"url":"https://user-images.githubusercontent.com/67270558/139482165-21f93c6a-48e5-421a-8e06-c942bda01974.gif"}}

  10. Click Save. Once you have saved the originalLocation variable, create the originalReferrer as described in the steps below.

  11. In the User-Defined Variables section, click on New. A side popup will open.

  12. Replace the Untitled Variable value with Original Referrer.

  13. Click on Variable Configuration.

  14. On Page Variables, click on Data Layer Variable.

  15. In the Data Layer Variable Name field, type originalReferrer.

  16. Enable the Set Default Value option and fill in the Default Value field with the following value:


    _10
    {{Referrer}}

    {"base64":"  ","img":{"width":1878,"height":851,"type":"gif","mime":"image/gif","wUnits":"px","hUnits":"px","length":2028565,"url":"https://user-images.githubusercontent.com/67270558/141315033-56e6e498-8c44-490d-a6dd-51f226dd6fc9.gif"}}

  17. Click Save.

Updating Google Analytics Settings variables and tags

Now, let's configure every Google Analytics Settings variable that fires the originalLocation and originalReferrer variables.

  1. Go to the Variables section;

  2. On User-Defined Variables, click on the name of one of the Google Analytics Settings variables

    {"base64":"  ","img":{"width":1887,"height":795,"type":"png","mime":"image/png","wUnits":"px","hUnits":"px","length":66534,"url":"https://user-images.githubusercontent.com/67270558/136799579-f1bb7e68-ec4c-4deb-beb2-0dfedb88de10.png"}}

  3. Click on the Variable Configuration box;

  4. Go to More Settings > Fields to Set;

  5. Click on Add Field;

  6. Set the Field Name field as location and Value as {{Original Location}};

  7. Then, click on Add Field again;

  8. Set the Field Name field as referrer and Value as {{Original Referrer}};

  9. Click on Save.

If you have any Google Analytics tags using the Google Analytics Settings variables you have changed, apply the same changes above directly on the tags that need it.

Publishing your changes

Once you have set up the Google Analytics variables and tags, follow Google's official guide on how to submit and publish your store’s container.

Restrictions

In order to avoid performance problems and unforeseen behavior, our VTEX IO Google Tag Manager solution uses the native GTM blacklist feature. You can read more about this feature on the Google Developer Guide.

We, by default, blacklist the html ID, which automatically blocklists all the tags, variables, and triggers of the type customScripts. The main consequence of this blocklist is that Custom HTML tags will not be triggered.

The HTML blacklist is the VTEX Google Tag Manager app's default. If you want to disable this restriction, go to https://{accountName}.myvtex.com/admin/apps/vtex.google-tag-manager@2.x/setup and check the toggle below.

Most of the widely used Custom HTML tags are integrations with third-party services, like Customer Chat, Analytics, Remarketing, and Pixel tags. If your store needs a Custom HTML for one of those cases, the integration can either be done by transforming the tags into a VTEX IO Pixel App or by removing this restriction.

Check below the full list of tags and variables that are blocked, by default, in the VTEX IO Google Tag Manager solution.

Blocked tags

  • Custom HTML Tag - html
  • Eulerian Analytics Tag - ela
  • SaleCycle JavaScript Tag - scjs
  • Upsellit Global Footer Tag - uslt
  • Upsellit Confirmation Tag - uspt

Blocked variables

  • Custom JavaScript Variable - jsm

Check out a list with all the GTM available tags on the Google Developer Guide.

See also
VTEX App Store
VTEX IO Apps