clarity-gtm-template/template.tpl

232 строки
5.9 KiB
Smarty
Исходник Обычный вид История

2021-02-02 13:53:56 +03:00
___TERMS_OF_SERVICE___
By creating or modifying this file you agree to Google Tag Manager's Community
Template Gallery Developer Terms of Service available at
https://developers.google.com/tag-manager/gallery-tos (or such other URL as
Google may provide), as modified from time to time.
___INFO___
{
"type": "TAG",
"id": "cvt_temp_public_id",
"version": 1,
"securityGroups": [],
"displayName": "Microsof Clarity",
2021-02-05 12:13:21 +03:00
"categories": ["ANALYTICS", "HEAT_MAP", "SESSION_RECORDING"],
2021-02-02 13:53:56 +03:00
"brand": {
"id": "Microsoft",
"displayName": "Microsoft",
"thumbnail": "\u003d"
},
"description": "Clarity is a user behavior analytics tool, which helps you understand how users are interacting with your website. Supported features include:\nSession Recordings\nHeatmaps\nML Insights",
"containerContexts": [
"WEB"
]
}
___TEMPLATE_PARAMETERS___
[
{
"type": "TEXT",
"name": "projectId",
"displayName": "Clarity Project Id",
"simpleValueType": true,
"help": "Copy your clarity project Id here. You can find it in the project Url from the browser. Example: https://clarity.microsoft.com/projects/view/\"projectId\"/",
"valueValidators": [
{
"type": "NON_EMPTY",
"errorMessage": "You must provide a clarity project Id"
},
{
"type": "REGEX",
"args": [
"[0-9a-z]+"
],
"errorMessage": "Incorrect project Id. You can find it in the project Url from the browser. Example: https://clarity.microsoft.com/projects/view/\"projectId\"/"
}
]
}
]
___SANDBOXED_JS_FOR_WEB_TEMPLATE___
// Require the necessary APIs
const injectScript = require('injectScript');
const queryPermission = require('queryPermission');
const createArgumentsQueue = require('createArgumentsQueue');
2021-02-05 13:10:11 +03:00
const encodeUri = require('encodeUri');
2021-02-02 13:53:56 +03:00
//Create clarity const
const clarity = createArgumentsQueue('clarity', 'clarity.q');
// Reconstruct customer clarity script URL
2021-02-05 13:10:11 +03:00
const url = "https://www.clarity.ms/tag/"+encodeUri(data.projectId);
2021-02-02 13:53:56 +03:00
// Handle Success
const onCustomerSuccess = () => {
data.gtmOnSuccess();
};
// Handle Failure
const onCustomerFailure = () => {
data.gtmOnFailure();
};
// If the URL input by the user matches the permissions set for the template,
// inject the script with the onSuccess and onFailure methods as callbacks.
if (queryPermission('inject_script', "https://www.clarity.ms")) {
injectScript(url, onCustomerSuccess, onCustomerFailure);
} else {
data.gtmOnFailure();
}
___WEB_PERMISSIONS___
[
{
"instance": {
"key": {
"publicId": "inject_script",
"versionId": "1"
},
"param": [
{
"key": "urls",
"value": {
"type": 2,
"listItem": [
{
"type": 1,
"string": "https://www.clarity.ms/*"
}
]
}
}
]
},
"clientAnnotations": {
"isEditedByUser": true
},
"isRequired": true
},
{
"instance": {
"key": {
"publicId": "access_globals",
"versionId": "1"
},
"param": [
{
"key": "keys",
"value": {
"type": 2,
"listItem": [
{
"type": 3,
"mapKey": [
{
"type": 1,
"string": "key"
},
{
"type": 1,
"string": "read"
},
{
"type": 1,
"string": "write"
},
{
"type": 1,
"string": "execute"
}
],
"mapValue": [
{
"type": 1,
"string": "clarity"
},
{
"type": 8,
"boolean": true
},
{
"type": 8,
"boolean": true
},
{
"type": 8,
"boolean": true
}
]
},
{
"type": 3,
"mapKey": [
{
"type": 1,
"string": "key"
},
{
"type": 1,
"string": "read"
},
{
"type": 1,
"string": "write"
},
{
"type": 1,
"string": "execute"
}
],
"mapValue": [
{
"type": 1,
"string": "clarity.q"
},
{
"type": 8,
"boolean": true
},
{
"type": 8,
"boolean": true
},
{
"type": 8,
"boolean": true
}
]
}
]
}
}
]
},
"clientAnnotations": {
"isEditedByUser": true
},
"isRequired": true
}
]
___TESTS___
scenarios: []
___NOTES___
Created on 2/2/2021, 12:41:15 PM