Last active
July 18, 2025 12:04
-
-
Save 65/ea89c0750c728f8cf722aeb3254482fc to your computer and use it in GitHub Desktop.
JSON to import for Google Tag Manager with Consent Mode v2 configuration, Microsoft Clarity in Cookieless, and Cookie mode on acceptance, Google Analytcs v4, and User Centrics CMPv3
This file contains hidden or bidirectional Unicode text that may be interpreted or compiled differently than what appears below. To review, open the file in an editor that reveals hidden Unicode characters.
Learn more about bidirectional Unicode characters
{ | |
"exportFormatVersion": 2, | |
"exportTime": "2025-07-18 12:04:07", | |
"containerVersion": { | |
"path": "accounts/6304467255/containers/225221087/versions/0", | |
"accountId": "6304467255", | |
"containerId": "225221087", | |
"containerVersionId": "0", | |
"container": { | |
"path": "accounts/6304467255/containers/225221087", | |
"accountId": "6304467255", | |
"containerId": "225221087", | |
"name": "GTM+Clarity+GA+ConsentMode v2", | |
"publicId": "GTM-KWMHS2HR", | |
"usageContext": [ | |
"WEB" | |
], | |
"fingerprint": "1752833065407", | |
"tagManagerUrl": "https://tagmanager.google.com/#/container/accounts/6304467255/containers/225221087/workspaces?apiLink=container", | |
"features": { | |
"supportUserPermissions": true, | |
"supportEnvironments": true, | |
"supportWorkspaces": true, | |
"supportGtagConfigs": false, | |
"supportBuiltInVariables": true, | |
"supportClients": false, | |
"supportFolders": true, | |
"supportTags": true, | |
"supportTemplates": true, | |
"supportTriggers": true, | |
"supportVariables": true, | |
"supportVersions": true, | |
"supportZones": true, | |
"supportTransformations": false | |
}, | |
"tagIds": [ | |
"GTM-KWMHS2HR" | |
] | |
}, | |
"tag": [ | |
{ | |
"accountId": "6304467255", | |
"containerId": "225221087", | |
"tagId": "19", | |
"name": "GA4", | |
"type": "googtag", | |
"parameter": [ | |
{ | |
"type": "TEMPLATE", | |
"key": "tagId", | |
"value": "{{GA4 Data Stream}}" | |
} | |
], | |
"fingerprint": "1752839765502", | |
"firingTriggerId": [ | |
"18" | |
], | |
"tagFiringOption": "ONCE_PER_EVENT", | |
"monitoringMetadata": { | |
"type": "MAP" | |
}, | |
"consentSettings": { | |
"consentStatus": "NOT_SET" | |
} | |
}, | |
{ | |
"accountId": "6304467255", | |
"containerId": "225221087", | |
"tagId": "23", | |
"name": "Microsoft Clarity onConsent Activate Cookies", | |
"type": "html", | |
"parameter": [ | |
{ | |
"type": "TEMPLATE", | |
"key": "html", | |
"value": "<script>\n // https://learn.microsoft.com/en-us/clarity/setup-and-installation/cookie-consent\n (function(){\n var consent = {{dlv - Consent Status - Microsoft Clarity}}; //replace with your analytics consent variable\n if (consent) {\n window.clarity('consent');\n }\n\n })();\n</script>" | |
}, | |
{ | |
"type": "BOOLEAN", | |
"key": "supportDocumentWrite", | |
"value": "false" | |
} | |
], | |
"fingerprint": "1752839765578", | |
"firingTriggerId": [ | |
"21" | |
], | |
"tagFiringOption": "ONCE_PER_EVENT", | |
"monitoringMetadata": { | |
"type": "MAP" | |
}, | |
"consentSettings": { | |
"consentStatus": "NEEDED", | |
"consentType": { | |
"type": "LIST", | |
"list": [ | |
{ | |
"type": "TEMPLATE", | |
"value": "analytics_storage" | |
} | |
] | |
} | |
} | |
}, | |
{ | |
"accountId": "6304467255", | |
"containerId": "225221087", | |
"tagId": "25", | |
"name": "Microsoft Clarity - Official", | |
"type": "html", | |
"parameter": [ | |
{ | |
"type": "TEMPLATE", | |
"key": "html", | |
"value": "<script>(function(c,l,a,r,i,t,y){c[a]=c[a]||function(){(c[a].q=c[a].q||[]).push(arguments)};t=l.createElement(r);t.async=1;t.src=\"https://www.clarity.ms/tag/\"+i+\"?ref=gtm2\";y=l.getElementsByTagName(r)[0];y.parentNode.insertBefore(t,y);})(window,document,\"clarity\",\"script\",\"{{Microsoft Clarity ProjectID}}\");</script>\n<script>\n window.addEventListener('UC_CONSENT', function (event) {\n var clarityDpsId = 'jzMEq56vW';\n window.clarity(\n 'consent', \n event.detail.services[clarityDpsId].consent.given\n );\n });\n</script>\n" | |
}, | |
{ | |
"type": "BOOLEAN", | |
"key": "supportDocumentWrite", | |
"value": "false" | |
} | |
], | |
"fingerprint": "1752839765579", | |
"firingTriggerId": [ | |
"2147479553" | |
], | |
"tagFiringOption": "ONCE_PER_EVENT", | |
"monitoringMetadata": { | |
"type": "MAP" | |
}, | |
"consentSettings": { | |
"consentStatus": "NOT_SET" | |
} | |
}, | |
{ | |
"accountId": "6304467255", | |
"containerId": "225221087", | |
"tagId": "26", | |
"name": "Usercentrics CMP", | |
"type": "cvt_NMDHS", | |
"parameter": [ | |
{ | |
"type": "BOOLEAN", | |
"key": "advertiserConsentMode", | |
"value": "false" | |
}, | |
{ | |
"type": "TEMPLATE", | |
"key": "adsDataRedaction", | |
"value": "dynamic" | |
}, | |
{ | |
"type": "TEMPLATE", | |
"key": "data-settings-id", | |
"value": "{{UserCentrics Setting ID}}" | |
}, | |
{ | |
"type": "BOOLEAN", | |
"key": "data-tcf-enabled", | |
"value": "false" | |
}, | |
{ | |
"type": "TEMPLATE", | |
"key": "data-language", | |
"value": "auto" | |
}, | |
{ | |
"type": "TEMPLATE", | |
"key": "id-selection", | |
"value": "settingsId" | |
}, | |
{ | |
"type": "BOOLEAN", | |
"key": "data-amp-enabled", | |
"value": "false" | |
}, | |
{ | |
"type": "BOOLEAN", | |
"key": "urlPassthrough", | |
"value": "false" | |
}, | |
{ | |
"type": "BOOLEAN", | |
"key": "consentModeEnabled", | |
"value": "true" | |
}, | |
{ | |
"type": "TEMPLATE", | |
"key": "waitForUpdate", | |
"value": "500" | |
}, | |
{ | |
"type": "TEMPLATE", | |
"key": "data-banner-version", | |
"value": "V3" | |
}, | |
{ | |
"type": "LIST", | |
"key": "regionSettings", | |
"list": [ | |
{ | |
"type": "MAP", | |
"map": [ | |
{ | |
"type": "TEMPLATE", | |
"key": "region", | |
"value": "AU" | |
}, | |
{ | |
"type": "TEMPLATE", | |
"key": "defaultConsentPreferences", | |
"value": "granted" | |
}, | |
{ | |
"type": "TEMPLATE", | |
"key": "defaultConsentStatistics", | |
"value": "granted" | |
}, | |
{ | |
"type": "TEMPLATE", | |
"key": "defaultConsentMarketing", | |
"value": "granted" | |
}, | |
{ | |
"type": "TEMPLATE", | |
"key": "defaultAdPersonalization", | |
"value": "granted" | |
}, | |
{ | |
"type": "TEMPLATE", | |
"key": "defaultAdUserData", | |
"value": "granted" | |
} | |
] | |
} | |
] | |
} | |
], | |
"fingerprint": "1752839765579", | |
"firingTriggerId": [ | |
"2147479572" | |
], | |
"tagFiringOption": "ONCE_PER_EVENT", | |
"monitoringMetadata": { | |
"type": "MAP" | |
}, | |
"consentSettings": { | |
"consentStatus": "NOT_SET" | |
} | |
} | |
], | |
"trigger": [ | |
{ | |
"accountId": "6304467255", | |
"containerId": "225221087", | |
"triggerId": "18", | |
"name": "Consent - Google Analytics", | |
"type": "CUSTOM_EVENT", | |
"customEventFilter": [ | |
{ | |
"type": "EQUALS", | |
"parameter": [ | |
{ | |
"type": "TEMPLATE", | |
"key": "arg0", | |
"value": "{{_event}}" | |
}, | |
{ | |
"type": "TEMPLATE", | |
"key": "arg1", | |
"value": "consent_status" | |
} | |
] | |
} | |
], | |
"filter": [ | |
{ | |
"type": "CONTAINS", | |
"parameter": [ | |
{ | |
"type": "TEMPLATE", | |
"key": "arg0", | |
"value": "{{dlv - Consent Status - Google Analytics}}" | |
}, | |
{ | |
"type": "TEMPLATE", | |
"key": "arg1", | |
"value": "true" | |
} | |
] | |
} | |
], | |
"fingerprint": "1752839765502" | |
}, | |
{ | |
"accountId": "6304467255", | |
"containerId": "225221087", | |
"triggerId": "21", | |
"name": "Consent - Microsoft Clarity", | |
"type": "CUSTOM_EVENT", | |
"customEventFilter": [ | |
{ | |
"type": "EQUALS", | |
"parameter": [ | |
{ | |
"type": "TEMPLATE", | |
"key": "arg0", | |
"value": "{{_event}}" | |
}, | |
{ | |
"type": "TEMPLATE", | |
"key": "arg1", | |
"value": "consent_status" | |
} | |
] | |
} | |
], | |
"filter": [ | |
{ | |
"type": "EQUALS", | |
"parameter": [ | |
{ | |
"type": "TEMPLATE", | |
"key": "arg0", | |
"value": "{{dlv - Consent Status - Microsoft Clarity}}" | |
}, | |
{ | |
"type": "TEMPLATE", | |
"key": "arg1", | |
"value": "true" | |
} | |
] | |
} | |
], | |
"fingerprint": "1752839765502" | |
} | |
], | |
"variable": [ | |
{ | |
"accountId": "6304467255", | |
"containerId": "225221087", | |
"variableId": "15", | |
"name": "UserCentrics Setting ID", | |
"type": "c", | |
"notes": "UserCentrics Setting ID from the embed code in Termageddon > Embed Codes, or your UserCentrics account", | |
"parameter": [ | |
{ | |
"type": "TEMPLATE", | |
"key": "value", | |
"value": "xxxxxxxxx" | |
} | |
], | |
"fingerprint": "1752840228930", | |
"formatValue": {} | |
}, | |
{ | |
"accountId": "6304467255", | |
"containerId": "225221087", | |
"variableId": "16", | |
"name": "GA4 Data Stream", | |
"type": "c", | |
"notes": "GA4 Data Stream Measurement ID from analytics.google.com > Admin > Property > Data Streams", | |
"parameter": [ | |
{ | |
"type": "TEMPLATE", | |
"key": "value", | |
"value": "G-xxxxxxxxxx" | |
} | |
], | |
"fingerprint": "1752839765501", | |
"formatValue": {} | |
}, | |
{ | |
"accountId": "6304467255", | |
"containerId": "225221087", | |
"variableId": "17", | |
"name": "dlv - Consent Status - Google Analytics", | |
"type": "v", | |
"parameter": [ | |
{ | |
"type": "INTEGER", | |
"key": "dataLayerVersion", | |
"value": "2" | |
}, | |
{ | |
"type": "BOOLEAN", | |
"key": "setDefaultValue", | |
"value": "true" | |
}, | |
{ | |
"type": "TEMPLATE", | |
"key": "defaultValue", | |
"value": "false" | |
}, | |
{ | |
"type": "TEMPLATE", | |
"key": "name", | |
"value": "Google Analytics" | |
} | |
], | |
"fingerprint": "1752839765501", | |
"formatValue": {} | |
}, | |
{ | |
"accountId": "6304467255", | |
"containerId": "225221087", | |
"variableId": "20", | |
"name": "dlv - Consent Status - Microsoft Clarity", | |
"type": "v", | |
"parameter": [ | |
{ | |
"type": "INTEGER", | |
"key": "dataLayerVersion", | |
"value": "2" | |
}, | |
{ | |
"type": "BOOLEAN", | |
"key": "setDefaultValue", | |
"value": "true" | |
}, | |
{ | |
"type": "TEMPLATE", | |
"key": "defaultValue", | |
"value": "false" | |
}, | |
{ | |
"type": "TEMPLATE", | |
"key": "name", | |
"value": "Microsoft Clarity" | |
} | |
], | |
"fingerprint": "1752839765502", | |
"formatValue": {} | |
}, | |
{ | |
"accountId": "6304467255", | |
"containerId": "225221087", | |
"variableId": "24", | |
"name": "Microsoft Clarity ProjectID", | |
"type": "c", | |
"notes": "Microsoft Clarity Project ID from clarity.microsoft.com > Settings > Overview", | |
"parameter": [ | |
{ | |
"type": "TEMPLATE", | |
"key": "value", | |
"value": "clarity.microsoft.com>settings>overview>Project ID" | |
} | |
], | |
"fingerprint": "1752839765579", | |
"formatValue": {} | |
} | |
], | |
"fingerprint": "1752840247621", | |
"tagManagerUrl": "https://tagmanager.google.com/#/versions/accounts/6304467255/containers/225221087/versions/0?apiLink=version", | |
"customTemplate": [ | |
{ | |
"accountId": "6304467255", | |
"containerId": "225221087", | |
"templateId": "22", | |
"name": "Usercentrics CMP", | |
"fingerprint": "1752839765502", | |
"templateData": "___TERMS_OF_SERVICE___\n\nBy creating or modifying this file you agree to Google Tag Manager's Community\nTemplate Gallery Developer Terms of Service available at\nhttps://developers.google.com/tag-manager/gallery-tos (or such other URL as\nGoogle may provide), as modified from time to time.\n\n\n___INFO___\n\n{\n \"type\": \"TAG\",\n \"id\": \"cvt_NMDHS\",\n \"version\": 1,\n \"displayName\": \"Usercentrics CMP\",\n \"brand\": {\n \"id\": \"github.com_Usercentrics\",\n \"displayName\": \"Usercentrics\",\n \"thumbnail\": \"\\u003d\\u003d\"\n },\n \"description\": \"Integrate our CMP Script Tag to easily control scripts implemented on your website and manage consent settings of your users.\\n\\nMore info at www.usercentrics.com\",\n \"containerContexts\": [\n \"WEB\"\n ]\n}\n\n\n___TEMPLATE_PARAMETERS___\n\n[\n {\n \"type\": \"RADIO\",\n \"name\": \"id-selection\",\n \"displayName\": \"Add your Setting-ID or your Ruleset-ID to display the CMP configurations to users based on their location.\",\n \"radioItems\": [\n {\n \"value\": \"settingsId\",\n \"displayValue\": \"Setting-ID\"\n },\n {\n \"value\": \"rulesetId\",\n \"displayValue\": \"Ruleset-ID\"\n }\n ],\n \"simpleValueType\": true\n },\n {\n \"type\": \"TEXT\",\n \"name\": \"data-settings-id\",\n \"displayName\": \"Setting-ID\",\n \"simpleValueType\": true,\n \"valueValidators\": [\n {\n \"type\": \"NON_EMPTY\"\n }\n ],\n \"help\": \"Your settings Id\",\n \"enablingConditions\": [\n {\n \"paramName\": \"id-selection\",\n \"paramValue\": \"settingsId\",\n \"type\": \"EQUALS\"\n }\n ]\n },\n {\n \"type\": \"TEXT\",\n \"name\": \"data-ruleset-id\",\n \"displayName\": \"Ruleset-ID\",\n \"simpleValueType\": true,\n \"valueValidators\": [\n {\n \"type\": \"NON_EMPTY\"\n }\n ],\n \"help\": \"Your ruleset Id\",\n \"enablingConditions\": [\n {\n \"paramName\": \"id-selection\",\n \"paramValue\": \"rulesetId\",\n \"type\": \"EQUALS\"\n }\n ]\n },\n {\n \"type\": \"SELECT\",\n \"name\": \"data-banner-version\",\n \"displayName\": \"Banner version\",\n \"selectItems\": [\n {\n \"value\": \"V2\",\n \"displayValue\": \"V2\"\n },\n {\n \"value\": \"V3\",\n \"displayValue\": \"V3\"\n }\n ],\n \"defaultValue\": \"V3\",\n \"help\": \"Here you can choose which version of our CMP that you want to use. V3 is the newest, most performant version.\"\n },\n {\n \"type\": \"TEXT\",\n \"name\": \"data-language\",\n \"displayName\": \"Default Language\",\n \"simpleValueType\": true,\n \"help\": \"Sets the default language (if any)\",\n \"defaultValue\": \"auto\"\n },\n {\n \"type\": \"CHECKBOX\",\n \"name\": \"data-tcf-enabled\",\n \"checkboxText\": \"Enable Transparency \\u0026 Consent Framework 2.2 (TCF)\",\n \"simpleValueType\": true,\n \"help\": \"Sets whether TCF 2.2 is enabled or not\"\n },\n {\n \"type\": \"CHECKBOX\",\n \"name\": \"data-amp-enabled\",\n \"checkboxText\": \"Enable Accelerated Mobile Pages Framework (AMP)\",\n \"simpleValueType\": true,\n \"help\": \"Sets whether AMP is enabled or not\"\n },\n {\n \"type\": \"CHECKBOX\",\n \"name\": \"consentModeEnabled\",\n \"checkboxText\": \"Enable Google Consent Mode\",\n \"simpleValueType\": true,\n \"defaultValue\": true,\n \"help\": \"Enable Consent Mode if one or more of your tags rely on Google\\u0027s consent API. Usercentrics will then automatically signal the user\\u0027s consent to these tags. (If you want to disable Consent Mode make sure to turn it of in your CMP configuration as well)\",\n \"alwaysInSummary\": true\n },\n {\n \"type\": \"GROUP\",\n \"name\": \"ConsentModeSettings\",\n \"displayName\": \"Consent Mode Settings\",\n \"groupStyle\": \"NO_ZIPPY\",\n \"subParams\": [\n {\n \"type\": \"TEXT\",\n \"name\": \"waitForUpdate\",\n \"displayName\": \"Wait for update\",\n \"simpleValueType\": true,\n \"valueUnit\": \"miliseconds\",\n \"help\": \"Set how many miliseconds to wait before firing tags waiting for consent\",\n \"defaultValue\": 2000,\n \"valueValidators\": [\n {\n \"type\": \"NON_EMPTY\"\n },\n {\n \"type\": \"NON_NEGATIVE_NUMBER\"\n }\n ]\n },\n {\n \"type\": \"SELECT\",\n \"name\": \"adsDataRedaction\",\n \"displayName\": \"Redact ads data\",\n \"selectItems\": [\n {\n \"value\": true,\n \"displayValue\": \"True\"\n },\n {\n \"value\": false,\n \"displayValue\": \"False\"\n },\n {\n \"value\": \"dynamic\",\n \"displayValue\": \"Dynamic (match ad_storage)\"\n }\n ],\n \"simpleValueType\": true,\n \"defaultValue\": \"dynamic\",\n \"help\": \"When ad data redaction is true and marketing cookies are denied, ad click identifiers sent in network requests by Google Ads and Floodlight tags will be redacted. Network requests will also be sent through a cookieless domain\"\n },\n {\n \"type\": \"CHECKBOX\",\n \"name\": \"urlPassthrough\",\n \"checkboxText\": \"Enable URL passthrough\",\n \"simpleValueType\": true,\n \"help\": \"When using URL passthrough, a few query parameters may be appended to links as users navigate through pages on your website\"\n },\n {\n \"type\": \"CHECKBOX\",\n \"name\": \"advertiserConsentMode\",\n \"checkboxText\": \"Advertiser Consent Mode\",\n \"simpleValueType\": true,\n \"help\": \"If enabled, Google will deduce consents from TCF\",\n \"defaultValue\": true,\n \"enablingConditions\": [\n {\n \"paramName\": \"consentModeEnabled\",\n \"paramValue\": true,\n \"type\": \"EQUALS\"\n }\n ]\n },\n {\n \"type\": \"GROUP\",\n \"name\": \"DefaultConsent\",\n \"displayName\": \"Default Consent State\",\n \"subParams\": [\n {\n \"type\": \"PARAM_TABLE\",\n \"name\": \"regionSettings\",\n \"paramTableColumns\": [\n {\n \"param\": {\n \"type\": \"TEXT\",\n \"name\": \"region\",\n \"displayName\": \"Region (leave blank to apply globally)\",\n \"simpleValueType\": true\n },\n \"isUnique\": true\n },\n {\n \"param\": {\n \"type\": \"SELECT\",\n \"name\": \"defaultConsentPreferences\",\n \"displayName\": \"Preferences (functionality_storage and personalization_storage)\",\n \"selectItems\": [\n {\n \"value\": \"denied\",\n \"displayValue\": \"Denied\"\n },\n {\n \"value\": \"granted\",\n \"displayValue\": \"Granted\"\n }\n ],\n \"simpleValueType\": true,\n \"help\": \"Select default consent state for preference tags\",\n \"defaultValue\": \"denied\"\n },\n \"isUnique\": false\n },\n {\n \"param\": {\n \"type\": \"SELECT\",\n \"name\": \"defaultConsentStatistics\",\n \"displayName\": \"Statistics (analytics_storage)\",\n \"selectItems\": [\n {\n \"value\": \"denied\",\n \"displayValue\": \"Denied\"\n },\n {\n \"value\": \"granted\",\n \"displayValue\": \"Granted\"\n }\n ],\n \"simpleValueType\": true,\n \"defaultValue\": \"denied\",\n \"help\": \"Select default consent state for statistics tags\"\n },\n \"isUnique\": false\n },\n {\n \"param\": {\n \"type\": \"SELECT\",\n \"name\": \"defaultConsentMarketing\",\n \"displayName\": \"Marketing (ad_storage)\",\n \"selectItems\": [\n {\n \"value\": \"denied\",\n \"displayValue\": \"Denied\"\n },\n {\n \"value\": \"granted\",\n \"displayValue\": \"Granted\"\n }\n ],\n \"simpleValueType\": true,\n \"defaultValue\": \"denied\",\n \"help\": \"Select default consent state for marketing tags\"\n },\n \"isUnique\": false\n },\n {\n \"param\": {\n \"type\": \"SELECT\",\n \"name\": \"defaultAdPersonalization\",\n \"displayName\": \"Marketing (ad_personalization)\",\n \"selectItems\": [\n {\n \"value\": \"denied\",\n \"displayValue\": \"Denied\"\n },\n {\n \"value\": \"granted\",\n \"displayValue\": \"Granted\"\n }\n ],\n \"simpleValueType\": true,\n \"defaultValue\": \"denied\",\n \"help\": \"Select default consent state for marketing cookies\"\n },\n \"isUnique\": false\n },\n {\n \"param\": {\n \"type\": \"SELECT\",\n \"name\": \"defaultAdUserData\",\n \"displayName\": \"Marketing (ad_user_data)\",\n \"selectItems\": [\n {\n \"value\": \"denied\",\n \"displayValue\": \"Denied\"\n },\n {\n \"value\": \"granted\",\n \"displayValue\": \"Granted\"\n }\n ],\n \"simpleValueType\": true,\n \"defaultValue\": \"denied\",\n \"help\": \"Select default consent state for marketing cookies\"\n },\n \"isUnique\": false\n }\n ],\n \"editRowTitle\": \"Edit region\",\n \"newRowButtonText\": \"Add region\",\n \"newRowTitle\": \"Add region\"\n }\n ],\n \"help\": \"A default consent state of \\u0027denied\\u0027 will apply until the user has submitted a consent. You can add different default states for users in different geographical regions. Please use ISO-3166-1 alpha-2 country codes for region values.\"\n }\n ],\n \"enablingConditions\": [\n {\n \"paramName\": \"consentModeEnabled\",\n \"paramValue\": true,\n \"type\": \"EQUALS\"\n }\n ]\n }\n]\n\n\n___SANDBOXED_JS_FOR_WEB_TEMPLATE___\n\nconst injectScript = require('injectScript');\nconst queryPermission = require('queryPermission');\nconst setInWindow = require('setInWindow');\nconst setDefaultConsentState = require('setDefaultConsentState');\nconst updateConsentState = require('updateConsentState');\nconst makeNumber = require('makeNumber');\nconst gtagSet = require('gtagSet');\nconst localStorage = require('localStorage');\nconst JSON = require('JSON');\nconst logToConsole = require('logToConsole');\n\nconst isTcfEnabled = data['data-tcf-enabled'];\nconst defaultLanguage = data['data-language'];\nconst isRulesetEnabled = data['id-selection'] === 'rulesetId';\nconst settingsId = data['data-settings-id'];\nconst rulesetId = data['data-ruleset-id'];\nconst isAmpEnabled = data['data-amp-enabled'];\nconst consentModeEnabled = data.consentModeEnabled;\nconst regionSettings = data.regionSettings || [];\nconst urlPassthrough = data.urlPassthrough;\nconst waitForUpdate = data.waitForUpdate;\nconst adsDataRedaction = data.adsDataRedaction;\nconst bannerVersion = data['data-banner-version'];\nconst advertiserConsentMode = data.advertiserConsentMode;\nlet hasDefaultState = false;\n\n// Set developer ID\ngtagSet('developer_id.dOThhZD', true);\n\nif (consentModeEnabled !== false) {\n \n\n // Turn region string (\"DK, NL, DE\") into array ([\"DK\", \"NL\", \"DE\"])\n const getRegionArr = (regionStr) => {\n return regionStr.split(',')\n .map(region => region.trim())\n .filter(region => region.length !== 0);\n };\n\n // Get default consent state per region\n const getConsentRegionData = (regionObject) => {\n const consentRegionData = {\n ad_storage: regionObject.defaultConsentMarketing,\n ad_personalization: regionObject.defaultAdPersonalization,\n ad_user_data: regionObject.defaultAdUserData,\n analytics_storage: regionObject.defaultConsentStatistics,\n functionality_storage: regionObject.defaultConsentPreferences,\n personalization_storage: regionObject.defaultConsentPreferences,\n security_storage: 'granted'\n };\n \n const regionArr = getRegionArr(regionObject.region);\n \n if (regionArr.length) {\n consentRegionData.region = regionArr;\n }\n \n return consentRegionData;\n };\n\n // Set url_passthrough\n gtagSet({\n 'url_passthrough': urlPassthrough === true\n \n });\n \n // Set default consent for each region\n \n regionSettings.forEach(regionObj => {\n const consentRegionData = getConsentRegionData(regionObj);\n if (waitForUpdate > 0) {\n consentRegionData.wait_for_update = waitForUpdate;\n }\n\n setDefaultConsentState(consentRegionData);\n if (regionObj.region === undefined || regionObj.region.trim() === '')\n {\n hasDefaultState = true;\n }\n });\n\n // Fallback to opt-out if no global default consent state has been defined in region settings\n if(!hasDefaultState)\n {\n setDefaultConsentState({ad_storage: 'denied', ad_user_data: 'denied', ad_personalization: 'denied', analytics_storage: 'denied', functionality_storage: 'denied', personalization_storage: 'denied', security_storage: 'granted'});\n }\n \n\n // Read existing consent from if it exists\n const ucGcmString = localStorage.getItem('uc_gcm');\n let ucGcmData;\n if (ucGcmString) {\n ucGcmData = JSON.parse(ucGcmString);\n }\n if (typeof ucGcmData === 'object') {\n if (ucGcmData.adStorage && ucGcmData.analyticsStorage && ucGcmData.adPersonalization && ucGcmData.adUserData) {\n updateConsentState({\n ad_storage: ucGcmData.adStorage,\n ad_personalization: ucGcmData.adPersonalization,\n ad_user_data: ucGcmData.adUserData,\n analytics_storage: ucGcmData.analyticsStorage\n });\n \n }\n\n }\n \n // Set data redaction\n let adsDataRedactionValue = true;\n if(adsDataRedaction === 'dynamic') {\n if(ucGcmData && ucGcmData.adStorage) {\n if(ucGcmData.adStorage === 'granted') {\n adsDataRedactionValue = false;\n }\n else {\n adsDataRedactionValue = true;\n } \n }\n \n }\n else { \n adsDataRedactionValue = (adsDataRedaction === true);\n }\n gtagSet({\n 'ads_data_redaction': adsDataRedactionValue\n });\n \n}\n\n\n\nif (bannerVersion === 'V3') {\n\n const scriptUrl = 'https://web.cmp.usercentrics.eu/ui/loader.js';\n const V3TcfStubUrl = 'https://web.cmp.usercentrics.eu/tcf/stub.js';\n\n\n const ucCmpGTMConfig = {};\n\n if (settingsId) {\n ucCmpGTMConfig['settingsId'] = settingsId;\n }\n\n if (rulesetId) {\n ucCmpGTMConfig['rulesetId'] = rulesetId;\n }\n\n if (defaultLanguage !== 'auto' && queryPermission('access_globals', 'readwrite', 'language')) {\n ucCmpGTMConfig['language'] = defaultLanguage;\n }\n\n if (queryPermission('access_globals', 'readwrite', 'disableGcmDefaults')) {\n ucCmpGTMConfig['disableGcmDefaults'] = true;\n }\n\n if (isTcfEnabled && consentModeEnabled && queryPermission('access_globals', 'readwrite', 'advertiserConsentMode')) {\n ucCmpGTMConfig['advertiserConsentMode'] = advertiserConsentMode;\n }\n\n if (queryPermission('access_globals', 'readwrite', 'ucCmpGTMConfig')) {\n setInWindow('ucCmpGTMConfig', ucCmpGTMConfig);\n }\n\n if (isTcfEnabled && queryPermission('inject_script', V3TcfStubUrl)) {\n injectScript(V3TcfStubUrl, data.gtmOnSuccess, data.gtmOnFailure);\n }\n\n if (queryPermission('inject_script', scriptUrl)) {\n injectScript(scriptUrl, data.gtmOnSuccess, data.gtmOnFailure);\n } else {\n data.gtmOnFailure();\n }\n\n} else {\n\n const scriptUrl = 'https://app.usercentrics.eu/browser-ui/latest/loader.js';\n\n if (isRulesetEnabled) {\n setInWindow('rulesetId', rulesetId);\n } else {\n setInWindow('settingsId', settingsId);\n }\n\n if (defaultLanguage !== 'auto' && queryPermission('access_globals', 'readwrite', 'language'))\n {\n setInWindow('language', defaultLanguage);\n }\n\n\n if (isTcfEnabled && queryPermission('access_globals', 'readwrite', 'tcfEnabled'))\n {\n setInWindow('tcfEnabled', true);\n }\n\n if (isTcfEnabled && consentModeEnabled && queryPermission('access_globals', 'readwrite', 'advertiserConsentMode'))\n {\n setInWindow('advertiserConsentMode', advertiserConsentMode);\n } \n\n if (isAmpEnabled && queryPermission('access_globals', 'readwrite', 'ampEnabled'))\n {\n setInWindow('ampEnabled', true);\n }\n\n if (queryPermission('access_globals', 'readwrite', 'disableGcmDefaults'))\n {\n setInWindow('disableGcmDefaults', true);\n }\n\n if (queryPermission('inject_script', scriptUrl)) {\n injectScript(scriptUrl, data.gtmOnSuccess, data.gtmOnFailure);\n } else {\n data.gtmOnFailure();\n }\n\n}\n\n\n___WEB_PERMISSIONS___\n\n[\n {\n \"instance\": {\n \"key\": {\n \"publicId\": \"inject_script\",\n \"versionId\": \"1\"\n },\n \"param\": [\n {\n \"key\": \"urls\",\n \"value\": {\n \"type\": 2,\n \"listItem\": [\n {\n \"type\": 1,\n \"string\": \"https://app.usercentrics.eu/*\"\n },\n {\n \"type\": 1,\n \"string\": \"https://web.cmp.usercentrics.eu/*\"\n }\n ]\n }\n }\n ]\n },\n \"clientAnnotations\": {\n \"isEditedByUser\": true\n },\n \"isRequired\": true\n },\n {\n \"instance\": {\n \"key\": {\n \"publicId\": \"access_globals\",\n \"versionId\": \"1\"\n },\n \"param\": [\n {\n \"key\": \"keys\",\n \"value\": {\n \"type\": 2,\n \"listItem\": [\n {\n \"type\": 3,\n \"mapKey\": [\n {\n \"type\": 1,\n \"string\": \"key\"\n },\n {\n \"type\": 1,\n \"string\": \"read\"\n },\n {\n \"type\": 1,\n \"string\": \"write\"\n },\n {\n \"type\": 1,\n \"string\": \"execute\"\n }\n ],\n \"mapValue\": [\n {\n \"type\": 1,\n \"string\": \"settingsId\"\n },\n {\n \"type\": 8,\n \"boolean\": true\n },\n {\n \"type\": 8,\n \"boolean\": true\n },\n {\n \"type\": 8,\n \"boolean\": true\n }\n ]\n },\n {\n \"type\": 3,\n \"mapKey\": [\n {\n \"type\": 1,\n \"string\": \"key\"\n },\n {\n \"type\": 1,\n \"string\": \"read\"\n },\n {\n \"type\": 1,\n \"string\": \"write\"\n },\n {\n \"type\": 1,\n \"string\": \"execute\"\n }\n ],\n \"mapValue\": [\n {\n \"type\": 1,\n \"string\": \"tcfEnabled\"\n },\n {\n \"type\": 8,\n \"boolean\": true\n },\n {\n \"type\": 8,\n \"boolean\": true\n },\n {\n \"type\": 8,\n \"boolean\": true\n }\n ]\n },\n {\n \"type\": 3,\n \"mapKey\": [\n {\n \"type\": 1,\n \"string\": \"key\"\n },\n {\n \"type\": 1,\n \"string\": \"read\"\n },\n {\n \"type\": 1,\n \"string\": \"write\"\n },\n {\n \"type\": 1,\n \"string\": \"execute\"\n }\n ],\n \"mapValue\": [\n {\n \"type\": 1,\n \"string\": \"ampEnabled\"\n },\n {\n \"type\": 8,\n \"boolean\": true\n },\n {\n \"type\": 8,\n \"boolean\": true\n },\n {\n \"type\": 8,\n \"boolean\": true\n }\n ]\n },\n {\n \"type\": 3,\n \"mapKey\": [\n {\n \"type\": 1,\n \"string\": \"key\"\n },\n {\n \"type\": 1,\n \"string\": \"read\"\n },\n {\n \"type\": 1,\n \"string\": \"write\"\n },\n {\n \"type\": 1,\n \"string\": \"execute\"\n }\n ],\n \"mapValue\": [\n {\n \"type\": 1,\n \"string\": \"language\"\n },\n {\n \"type\": 8,\n \"boolean\": true\n },\n {\n \"type\": 8,\n \"boolean\": true\n },\n {\n \"type\": 8,\n \"boolean\": true\n }\n ]\n },\n {\n \"type\": 3,\n \"mapKey\": [\n {\n \"type\": 1,\n \"string\": \"key\"\n },\n {\n \"type\": 1,\n \"string\": \"read\"\n },\n {\n \"type\": 1,\n \"string\": \"write\"\n },\n {\n \"type\": 1,\n \"string\": \"execute\"\n }\n ],\n \"mapValue\": [\n {\n \"type\": 1,\n \"string\": \"gtag\"\n },\n {\n \"type\": 8,\n \"boolean\": true\n },\n {\n \"type\": 8,\n \"boolean\": true\n },\n {\n \"type\": 8,\n \"boolean\": true\n }\n ]\n },\n {\n \"type\": 3,\n \"mapKey\": [\n {\n \"type\": 1,\n \"string\": \"key\"\n },\n {\n \"type\": 1,\n \"string\": \"read\"\n },\n {\n \"type\": 1,\n \"string\": \"write\"\n },\n {\n \"type\": 1,\n \"string\": \"execute\"\n }\n ],\n \"mapValue\": [\n {\n \"type\": 1,\n \"string\": \"dataLayer\"\n },\n {\n \"type\": 8,\n \"boolean\": true\n },\n {\n \"type\": 8,\n \"boolean\": true\n },\n {\n \"type\": 8,\n \"boolean\": true\n }\n ]\n },\n {\n \"type\": 3,\n \"mapKey\": [\n {\n \"type\": 1,\n \"string\": \"key\"\n },\n {\n \"type\": 1,\n \"string\": \"read\"\n },\n {\n \"type\": 1,\n \"string\": \"write\"\n },\n {\n \"type\": 1,\n \"string\": \"execute\"\n }\n ],\n \"mapValue\": [\n {\n \"type\": 1,\n \"string\": \"rulesetId\"\n },\n {\n \"type\": 8,\n \"boolean\": true\n },\n {\n \"type\": 8,\n \"boolean\": true\n },\n {\n \"type\": 8,\n \"boolean\": true\n }\n ]\n },\n {\n \"type\": 3,\n \"mapKey\": [\n {\n \"type\": 1,\n \"string\": \"key\"\n },\n {\n \"type\": 1,\n \"string\": \"read\"\n },\n {\n \"type\": 1,\n \"string\": \"write\"\n },\n {\n \"type\": 1,\n \"string\": \"execute\"\n }\n ],\n \"mapValue\": [\n {\n \"type\": 1,\n \"string\": \"disableGcmDefaults\"\n },\n {\n \"type\": 8,\n \"boolean\": true\n },\n {\n \"type\": 8,\n \"boolean\": true\n },\n {\n \"type\": 8,\n \"boolean\": true\n }\n ]\n },\n {\n \"type\": 3,\n \"mapKey\": [\n {\n \"type\": 1,\n \"string\": \"key\"\n },\n {\n \"type\": 1,\n \"string\": \"read\"\n },\n {\n \"type\": 1,\n \"string\": \"write\"\n },\n {\n \"type\": 1,\n \"string\": \"execute\"\n }\n ],\n \"mapValue\": [\n {\n \"type\": 1,\n \"string\": \"advertiserConsentMode\"\n },\n {\n \"type\": 8,\n \"boolean\": true\n },\n {\n \"type\": 8,\n \"boolean\": true\n },\n {\n \"type\": 8,\n \"boolean\": true\n }\n ]\n },\n {\n \"type\": 3,\n \"mapKey\": [\n {\n \"type\": 1,\n \"string\": \"key\"\n },\n {\n \"type\": 1,\n \"string\": \"read\"\n },\n {\n \"type\": 1,\n \"string\": \"write\"\n },\n {\n \"type\": 1,\n \"string\": \"execute\"\n }\n ],\n \"mapValue\": [\n {\n \"type\": 1,\n \"string\": \"ucCmpGTMConfig\"\n },\n {\n \"type\": 8,\n \"boolean\": true\n },\n {\n \"type\": 8,\n \"boolean\": true\n },\n {\n \"type\": 8,\n \"boolean\": true\n }\n ]\n }\n ]\n }\n }\n ]\n },\n \"clientAnnotations\": {\n \"isEditedByUser\": true\n },\n \"isRequired\": true\n },\n {\n \"instance\": {\n \"key\": {\n \"publicId\": \"access_consent\",\n \"versionId\": \"1\"\n },\n \"param\": [\n {\n \"key\": \"consentTypes\",\n \"value\": {\n \"type\": 2,\n \"listItem\": [\n {\n \"type\": 3,\n \"mapKey\": [\n {\n \"type\": 1,\n \"string\": \"consentType\"\n },\n {\n \"type\": 1,\n \"string\": \"read\"\n },\n {\n \"type\": 1,\n \"string\": \"write\"\n }\n ],\n \"mapValue\": [\n {\n \"type\": 1,\n \"string\": \"ad_storage\"\n },\n {\n \"type\": 8,\n \"boolean\": true\n },\n {\n \"type\": 8,\n \"boolean\": true\n }\n ]\n },\n {\n \"type\": 3,\n \"mapKey\": [\n {\n \"type\": 1,\n \"string\": \"consentType\"\n },\n {\n \"type\": 1,\n \"string\": \"read\"\n },\n {\n \"type\": 1,\n \"string\": \"write\"\n }\n ],\n \"mapValue\": [\n {\n \"type\": 1,\n \"string\": \"ad_personalization\"\n },\n {\n \"type\": 8,\n \"boolean\": true\n },\n {\n \"type\": 8,\n \"boolean\": true\n }\n ]\n },\n {\n \"type\": 3,\n \"mapKey\": [\n {\n \"type\": 1,\n \"string\": \"consentType\"\n },\n {\n \"type\": 1,\n \"string\": \"read\"\n },\n {\n \"type\": 1,\n \"string\": \"write\"\n }\n ],\n \"mapValue\": [\n {\n \"type\": 1,\n \"string\": \"ad_user_data\"\n },\n {\n \"type\": 8,\n \"boolean\": true\n },\n {\n \"type\": 8,\n \"boolean\": true\n }\n ]\n },\n {\n \"type\": 3,\n \"mapKey\": [\n {\n \"type\": 1,\n \"string\": \"consentType\"\n },\n {\n \"type\": 1,\n \"string\": \"read\"\n },\n {\n \"type\": 1,\n \"string\": \"write\"\n }\n ],\n \"mapValue\": [\n {\n \"type\": 1,\n \"string\": \"analytics_storage\"\n },\n {\n \"type\": 8,\n \"boolean\": true\n },\n {\n \"type\": 8,\n \"boolean\": true\n }\n ]\n },\n {\n \"type\": 3,\n \"mapKey\": [\n {\n \"type\": 1,\n \"string\": \"consentType\"\n },\n {\n \"type\": 1,\n \"string\": \"read\"\n },\n {\n \"type\": 1,\n \"string\": \"write\"\n }\n ],\n \"mapValue\": [\n {\n \"type\": 1,\n \"string\": \"functionality_storage\"\n },\n {\n \"type\": 8,\n \"boolean\": true\n },\n {\n \"type\": 8,\n \"boolean\": true\n }\n ]\n },\n {\n \"type\": 3,\n \"mapKey\": [\n {\n \"type\": 1,\n \"string\": \"consentType\"\n },\n {\n \"type\": 1,\n \"string\": \"read\"\n },\n {\n \"type\": 1,\n \"string\": \"write\"\n }\n ],\n \"mapValue\": [\n {\n \"type\": 1,\n \"string\": \"personalization_storage\"\n },\n {\n \"type\": 8,\n \"boolean\": true\n },\n {\n \"type\": 8,\n \"boolean\": true\n }\n ]\n },\n {\n \"type\": 3,\n \"mapKey\": [\n {\n \"type\": 1,\n \"string\": \"consentType\"\n },\n {\n \"type\": 1,\n \"string\": \"read\"\n },\n {\n \"type\": 1,\n \"string\": \"write\"\n }\n ],\n \"mapValue\": [\n {\n \"type\": 1,\n \"string\": \"security_storage\"\n },\n {\n \"type\": 8,\n \"boolean\": true\n },\n {\n \"type\": 8,\n \"boolean\": true\n }\n ]\n },\n {\n \"type\": 3,\n \"mapKey\": [\n {\n \"type\": 1,\n \"string\": \"consentType\"\n },\n {\n \"type\": 1,\n \"string\": \"read\"\n },\n {\n \"type\": 1,\n \"string\": \"write\"\n }\n ],\n \"mapValue\": [\n {\n \"type\": 1,\n \"string\": \"wait_for_update\"\n },\n {\n \"type\": 8,\n \"boolean\": true\n },\n {\n \"type\": 8,\n \"boolean\": true\n }\n ]\n }\n ]\n }\n }\n ]\n },\n \"clientAnnotations\": {\n \"isEditedByUser\": true\n },\n \"isRequired\": true\n },\n {\n \"instance\": {\n \"key\": {\n \"publicId\": \"write_data_layer\",\n \"versionId\": \"1\"\n },\n \"param\": [\n {\n \"key\": \"keyPatterns\",\n \"value\": {\n \"type\": 2,\n \"listItem\": [\n {\n \"type\": 1,\n \"string\": \"ads_data_redaction\"\n },\n {\n \"type\": 1,\n \"string\": \"url_passthrough\"\n },\n {\n \"type\": 1,\n \"string\": \"developer_id.dOThhZD\"\n }\n ]\n }\n }\n ]\n },\n \"clientAnnotations\": {\n \"isEditedByUser\": true\n },\n \"isRequired\": true\n },\n {\n \"instance\": {\n \"key\": {\n \"publicId\": \"access_local_storage\",\n \"versionId\": \"1\"\n },\n \"param\": [\n {\n \"key\": \"keys\",\n \"value\": {\n \"type\": 2,\n \"listItem\": [\n {\n \"type\": 3,\n \"mapKey\": [\n {\n \"type\": 1,\n \"string\": \"key\"\n },\n {\n \"type\": 1,\n \"string\": \"read\"\n },\n {\n \"type\": 1,\n \"string\": \"write\"\n }\n ],\n \"mapValue\": [\n {\n \"type\": 1,\n \"string\": \"uc_gcm\"\n },\n {\n \"type\": 8,\n \"boolean\": true\n },\n {\n \"type\": 8,\n \"boolean\": false\n }\n ]\n }\n ]\n }\n }\n ]\n },\n \"clientAnnotations\": {\n \"isEditedByUser\": true\n },\n \"isRequired\": true\n },\n {\n \"instance\": {\n \"key\": {\n \"publicId\": \"logging\",\n \"versionId\": \"1\"\n },\n \"param\": [\n {\n \"key\": \"environments\",\n \"value\": {\n \"type\": 1,\n \"string\": \"debug\"\n }\n }\n ]\n },\n \"clientAnnotations\": {\n \"isEditedByUser\": true\n },\n \"isRequired\": true\n }\n]\n\n\n___TESTS___\n\nscenarios:\n- name: Script inject test\n code: |-\n const mockData = {\n // Mocked field values\n 'id-selection': 'settingsId',\n 'data-settings-id': 'GVl-ixMH'\n };\n\n // Call runCode to run the template's code.\n runCode(mockData);\n\n // Verify that the script was injected\n assertApi('injectScript').wasCalled();\n- name: Test settingId injection\n code: |-\n const mockData = {\n // Mocked field values\n 'id-selection': 'settingsId',\n 'data-settings-id': 'GVl-ixMH'\n };\n\n // Call runCode to run the template's code.\n runCode(mockData);\n\n // Verify that the tag finished successfully.\n assertApi('setInWindow').wasCalledWith('settingsId', mockData['data-settings-id']);\n- name: Test ruleset injection\n code: |-\n const mockData = {\n // Mocked field values\n 'id-selection': 'rulesetId',\n 'data-ruleset-id': 'Q1pG5j-W5pgWef'\n };\n\n // Call runCode to run the template's code.\n runCode(mockData);\n\n // Verify that the tag finished successfully.\n assertApi('setInWindow').wasCalledWith('rulesetId', mockData['data-ruleset-id']);\n\n\n___NOTES___\n\nCreated on 28/06/2022, 11:34:02\n\n\n", | |
"galleryReference": { | |
"host": "github.com", | |
"owner": "Usercentrics", | |
"repository": "gtm-templates-usercentrics-cmp", | |
"version": "9e0c1b617840db208b5297de1daa5cf8bfe2bd5d", | |
"signature": "c084e800d94229df9df9e2f894d9372a4ce5169e3419a1629b8c8cacf02b0ac4", | |
"galleryTemplateId": "NMDHS" | |
} | |
} | |
] | |
} | |
} |
Sign up for free
to join this conversation on GitHub.
Already have an account?
Sign in to comment