Skip to content

Instantly share code, notes, and snippets.

Embed
What would you like to do?
Google Tag Manager JSON Import for Intercom Chat Widget (see comments below for instructions)
{
"exportFormatVersion": 2,
"exportTime": "2017-12-23 01:07:53",
"containerVersion": {
"path": "accounts/1234567890/containers/8139018/versions/0",
"accountId": "1234567890",
"containerId": "12345678",
"containerVersionId": "0",
"container": {
"path": "accounts/1234567890/containers/8139018",
"accountId": "1234567890",
"containerId": "12345678",
"name": "example.com",
"publicId": "GTM-W245W9T",
"usageContext": [
"WEB"
],
"fingerprint": "1513990671635",
"tagManagerUrl": "https://tagmanager.google.com/#/container/accounts/1234567890/containers/8139018/workspaces?apiLink=container"
},
"tag": [
{
"accountId": "1234567890",
"containerId": "12345678",
"tagId": "8",
"name": "intercom_0_snippet",
"type": "html",
"parameter": [
{
"type": "TEMPLATE",
"key": "html",
"value": "<script>\n window.intercomSettings = { app_id: {{intercom_chat_widget_id}} };\n</script>\n\n<script>\n (function () { var w = window; var ic = w.Intercom; if (typeof ic === \"function\") { ic('reattach_activator'); ic('update', intercomSettings); } else { var d = document; var i = function () { i.c(arguments) }; i.q = []; i.c = function (args) { i.q.push(args) }; w.Intercom = i; function l() { var s = d.createElement('script'); s.type = 'text/javascript'; s.async = true; s.src = 'https://widget.intercom.io/widget/{{intercom_chat_widget_id}}'; var x = d.getElementsByTagName('script')[0]; x.parentNode.insertBefore(s, x); } if (w.attachEvent) { w.attachEvent('onload', l); } else { w.addEventListener('load', l, false); } } })()\n</script>"
},
{
"type": "BOOLEAN",
"key": "supportDocumentWrite",
"value": "false"
}
],
"fingerprint": "1513990671635",
"firingTriggerId": [
"11"
],
"teardownTag": [
{
"tagName": "intercom_1_widget_styles_logic",
"stopTeardownOnFailure": true
}
],
"tagFiringOption": "ONCE_PER_EVENT"
},
{
"accountId": "1234567890",
"containerId": "12345678",
"tagId": "7",
"name": "intercom_1_widget_styles_logic",
"type": "html",
"parameter": [
{
"type": "TEMPLATE",
"key": "html",
"value": "<a class=\"intercom-launcher\" href=\"{{intercom_chat_widget_id}}@incoming.intercom.io\">\n <div class=\"intercom-icon-close\"></div>\n <div class=\"intercom-icon-open\"></div>\n <span class=\"intercom-unread-count\"></span>\n</a>\n\n<style>\n .intercom-launcher {\n backface-visibility: hidden;\n background: {{color_black}};\n border-radius: 50%;\n bottom: 20px;\n box-shadow: 0 1px 6px rgba(0, 0, 0, 0.06), 0 2px 32px rgba(0, 0, 0, 0.16);\n cursor: pointer;\n font-family: Helvetica, Arial, sans-serif;\n height: 0;\n opacity: 0;\n outline: 0;\n position: fixed;\n right: 20px;\n transform: scale(0.5);\n transform-origin: center;\n transition: opacity 0.25s ease, transform 0.25s ease;\n width: 0;\n z-index: 2147483000;\n }\n\n .intercom-launcher:focus {\n outline: 0;\n }\n\n .intercom-launcher.intercom-booted {\n height: 50px;\n opacity: 1;\n transform: scale(1);\n width: 50px;\n }\n\n .intercom-launcher * {\n cursor: pointer;\n }\n\n .intercom-unread-count {\n backface-visibility: hidden;\n background: {{color_black}};\n border-radius: 10px;\n box-shadow: 0 1px 0 rgba(0, 0, 0, 0.15);\n box-sizing: border-box;\n color: #fff;\n font-size: 12px;\n height: 20px;\n line-height: 20px;\n min-width: 20px;\n opacity: 0;\n padding: 0 4px;\n position: absolute;\n right: -2px;\n text-align: center;\n top: -2px;\n transform: scale(0.5);\n transform-origin: center;\n transition: opacity 0.15s ease, transform 0.15s ease;\n }\n\n .intercom-unread-count.active {\n opacity: 1;\n transform: scale(1);\n }\n\n .intercom-icon-open,\n .intercom-icon-close {\n background-position: 50%;\n background-repeat: no-repeat;\n border-radius: 50%;\n bottom: 0;\n position: absolute;\n top: 0;\n transition: transform 0.16s linear, opacity 0.08s linear;\n width: 100%;\n }\n\n .intercom-icon-open {\n /* below is a data uri of the open icon */\n /* change it if you'd like a different icon */\n background-image: url('');\n background-position: 50% 70%;\n background-size: 67% 64%;\n opacity: 1;\n transform: rotate(0deg) scale(1);\n }\n\n .intercom-open .intercom-icon-open {\n opacity: 0;\n transform: rotate(30deg) scale(0);\n }\n\n .intercom-icon-close {\n /* below is a data uri of the close icon */\n /* change it if you'd like a different icon */\n background-image: url('');\n background-size: 25%;\n opacity: 0;\n transform: rotate(-30deg);\n }\n\n .intercom-open .intercom-icon-close {\n opacity: 1;\n transform: rotate(0deg);\n }\n</style>\n\n<script>\n var launcher = document.querySelector('.intercom-launcher');\n var unreadCount = launcher.querySelector('.intercom-unread-count');\n\n // Initialize Intercom\n window.Intercom('boot', {\n app_id: {{intercom_chat_widget_id}},\n custom_launcher_selector: '.intercom-launcher'\n });\n\n // Register callbacks\n window.Intercom('onShow', function () { launcher.classList.add('intercom-open') });\n\n window.Intercom('onHide', function () { launcher.classList.remove('intercom-open') });\n\n window.Intercom('onUnreadCountChange', function (count) {\n unreadCount.textContent = count;\n if (count) {\n unreadCount.classList.add('active');\n } else {\n unreadCount.classList.remove('active');\n }\n });\n\n // Wait for Intercom to boot (max 30 seconds)\n var timeout = setTimeout(function () { clearInterval(interval) }, 30000);\n var interval = setInterval(function () {\n if (window.Intercom.booted) {\n // Add class to show the launcher\n launcher.classList.add('intercom-booted');\n clearInterval(interval);\n clearTimeout(timeout);\n }\n }, 100);\n</style>"
},
{
"type": "BOOLEAN",
"key": "supportDocumentWrite",
"value": "false"
}
],
"fingerprint": "1513991259707",
"tagFiringOption": "ONCE_PER_EVENT"
}
],
"trigger": [
{
"accountId": "1234567890",
"containerId": "12345678",
"triggerId": "11",
"name": "example.com",
"type": "PAGEVIEW",
"fingerprint": "1513990779440"
}
],
"variable": [
{
"accountId": "1234567890",
"containerId": "12345678",
"variableId": "1",
"name": "color_black",
"type": "c",
"parameter": [
{
"type": "TEMPLATE",
"key": "value",
"value": "#000"
}
],
"fingerprint": "1513990847622"
},
{
"accountId": "1234567890",
"containerId": "12345678",
"variableId": "6",
"name": "intercom_chat_widget_id",
"type": "c",
"parameter": [
{
"type": "TEMPLATE",
"key": "value",
"value": "abc1234"
}
],
"fingerprint": "1513990858130"
}
],
"fingerprint": "0",
"tagManagerUrl": "https://tagmanager.google.com/#/versions/accounts/1234567890/containers/8139018/versions/0?apiLink=version"
}
}
@benjaminhoffman

This comment has been minimized.

Copy link
Owner Author

@benjaminhoffman benjaminhoffman commented Dec 23, 2017

read full blog post with step-by-step instructions here: https://grandcrucapital.com/how-to-install-intercom-chat-widget-via-google-tag-manager-gtm

how to use this file:

  1. download this file
  2. upload this file to your GTM account (Admin > Import Container)
  3. use these settings:
    • choose workspace: choose whatever workspace you want to import this too
    • import option: choose Merge
    • overwrite or rename: choose "Rename conflicting tags, triggers, and variables"
    • confirm you are importing 2 new tags, 1 new trigger, 2 new variables
  4. update variables
    • color_black: rename this variable to whatever your brand color is and update the hex color constant
    • intercom_chat_widget_id: update this constant variable value to whatever your Intercom chat widget ID is
  5. optionally, you can edit the CSS (specifically the default Intercom "open" logo icon)
  6. click Save, ensure it's working via debugger, then publish!

In sum, your setup should look like this:

google_tag_manager_intercom_chat_widget

@patricklindsay

This comment has been minimized.

Copy link

@patricklindsay patricklindsay commented Mar 28, 2018

The provided initialise script has an incorrect closing </style> instead of </script>.

I was also getting some lint issues so this is what I ended up using;

<script>
    window.intercomSettings = { app_id: {{your_intercom__chat_id_var}} };
</script>

<script>
    (function () { var w = window; var ic = w.Intercom; if (typeof ic === "function") { ic('reattach_activator'); ic('update', intercomSettings); } else { var d = document; var i = function () { i.c(arguments) }; i.q = []; i.c = function (args) { i.q.push(args) }; w.Intercom = i; var l = function () { var s = d.createElement('script'); s.type = 'text/javascript'; s.async = true; s.src = 'https://widget.intercom.io/widget/{{your_intercom__chat_id_var}}'; var x = d.getElementsByTagName('script')[0]; x.parentNode.insertBefore(s, x); }; if (w.attachEvent) { w.attachEvent('onload', l); } else { w.addEventListener('load', l, false); } } })()
</script>
@marchowardbegins

This comment has been minimized.

Copy link

@marchowardbegins marchowardbegins commented Feb 6, 2019

I tried Patrick's snippet (great btw!) I seem to get a double image of the Intercom icon as if one is overlaid on the other. The second one comes up a second later and slightly on the edge of the original. Does anyone else get this?

Sign up for free to join this conversation on GitHub. Already have an account? Sign in to comment