Shopify dataLayer (Checkout Extensibility) with GTM
Updated: Saturday, February 15, 2025
Recent changes on Shopify
Checkout Extenstibility
The migration to Checkout Extensibility has brought some consequential changes to the way tracking is carried out on Shopify.
The most important change is the implementation of a sandboxed JavaScript environment for the checkout and thank you pages.
To obtain functional tracking, it is now necessary to listen to customer events to find out what’s happening on pages present in the sandboxed environment.
Migration to Checkout Extensibility also brings changes to the way pages can be customized in the sandboxed environment.
flowchart LR
subgraph abc [Customizable via <a href='https://shopify.dev/docs/api/checkout-ui-extensions' target='_blank'>Checkout UI extensions</a>]
subgraph Sandboxed JavaScript environment
D[Checkout page]
E[Thank you page]
F[Order status page]
D-->E
E-->F
end
end
subgraph Customizable via theme.liquid
subgraph Theme
A[Collection page]
B[Product page]
C[Cart page]
A-->B
B-->C
end
end
Historical customization features
Feature | Shopify classic | Shopify Plus | |
---|---|---|---|
Customize theme | ✅ via theme.liquid | ✅ via theme.liquid | |
Customize checkout page | ❌ | ✅ via checkout.liquid | |
Customize thank you page | ✅ via additional scripts. | ✅ via additional scripts. |
Current personalization features
Feature | Shopify classic | Shopify Plus | |
---|---|---|---|
Customize theme | ✅ via theme.liquid | ✅ via theme.liquid | |
Customize checkout page | ❌ | ✅ via Checkout Extensibility | |
Customize thank you page | ❌ | ✅ via Checkout Extensibility |
Application for GTM and dataLayer events
Click here to download the app to install GTM and DataLayer on your Shopify store.
Make sure you’re logged in to the right store, then click Install.
data:image/s3,"s3://crabby-images/3437a/3437a86e92c6799ca58c659b7199d8068deeee50" alt="Addingwell application - GTM & DataLayer on the Shopify app store"
Once the application is installed you’ll be taken to this page. Click Continue to start configuring the application.
data:image/s3,"s3://crabby-images/da421/da4219765d0c59aae68c1b55fbc52d2238b4ad33" alt="Addingwell app home page - GTM & DataLayer"
In the next step, check the Enable GA4 DataLayer with Standard eCommerce Events checkbox.
data:image/s3,"s3://crabby-images/9dc01/9dc0174a723931fe961c12c0c4cf117fa0e35b70" alt="Enabling dataLayer events in the Addingwell - GTM & DataLayer app"
Next, check the Include GTM.js on Site Pages checkbox, then fill in the identifier of your GTM Web container (GTM-XXXXXXX
).
data:image/s3,"s3://crabby-images/aa35c/aa35c6f3536d6f74baae4d3d4659e3a777a6ac91" alt="Adding the GTM Web ID to be injected into the Shopify store"
You now need to activate the Shopify application in your store theme. To do this, click on the Enable Addingwell Script button.
data:image/s3,"s3://crabby-images/4cf98/4cf985aa114cee70ad1572c97dbc71bb085c2dc6" alt="Button to enable the Addingwell application in your store's theme"
Then activate the Addingwell GTM application in the theme editor. Save and return to the Addingwell application configuration.
data:image/s3,"s3://crabby-images/b6674/b6674f59edc5e86de0560691320f61efbb6340a1" alt="Activating the Addingwell application in your store theme"
A message is displayed in the application to confirm its activation in the theme.
data:image/s3,"s3://crabby-images/1f81a/1f81a6acde84070458da8f7bd0516b2ba8696a31" alt="Confirmation of Addingwell app activation in theme"
We now add a custom pixel by copying the code displayed in the application.
data:image/s3,"s3://crabby-images/e3e92/e3e92c7a4ab033c67bcea0553018ffe2c1743d7c" alt="Copy custom web pixel code"
Then go to Settings > Customer events and click on Add custom pixel.
data:image/s3,"s3://crabby-images/b1404/b1404b114075bdb75310b8067c8e076fc7ce8023" alt="Copy custom web pixel code"
Name your custom pixel with the name of your choice.
data:image/s3,"s3://crabby-images/209ca/209caa7346e6ede5f24012259cf1a377b69d4ae6" alt="Naming the custom pixel"
In the Customer privacy section, check the checkboxes as in the following screenshot.
data:image/s3,"s3://crabby-images/824db/824db9e1114b59caa86e7e0799ab7103b16a2afb" alt="Customer privacy settings in custom pixel"
Then paste the code you’ve copied from the Addingwell application and click Save.
data:image/s3,"s3://crabby-images/95545/9554510c931c8f4c72065a1890415094e33e88ba" alt="Custom pixel code"
Then click Connect to connect the custom pixel to the sandbox.
data:image/s3,"s3://crabby-images/c4ef7/c4ef73c3692da0debed7a58b3ded6c3a4059b5d9" alt="Button to connect custom pixel to sandbox"
Congratulations, you’ve finished configuring the Addingwell GTM & DataLayer application. The DataLayer is now available in your theme and also in the sandbox pages (checkout + thank you page).
Debugging dataLayer events
In theme
To debug dataLayer events in the theme you can type dataLayer
in your web console or use a browser extension. You’ll find more details in this blog post.
In the sandbox
To view the dataLayer in the sandbox, you need to open the web console in the custom pixel you’ve created. To do this, click on top
in your web console.
data:image/s3,"s3://crabby-images/a24c9/a24c9abc55b92e0ea338a35bbcd7c4ad8944041c" alt="Top button in web console"
A drop-down menu appears, select the window named web-pixel-sandbox-CUSTOM-{id}-LAX
then type dataLayer
in the console.
data:image/s3,"s3://crabby-images/b31d6/b31d65a69353748c3afdc93f2fa082f4e8e9861d" alt="Viewing the dataLayer in the sandbox"