Skip to content
30 changes: 26 additions & 4 deletions website/src/plugins/docusaurus-plugin-segment/index.js
Original file line number Diff line number Diff line change
Expand Up @@ -22,13 +22,35 @@ module.exports = function (context, options) {

return {
headTags: [
{
tagName: 'script',
attributes: {
src: "https://cdn.cookielaw.org/scripttemplates/otSDKStub.js",
type: "text/javascript",
charset: "UTF-8",
"data-domain-script": "01973a98-9773-77d8-b45b-95386ff12b5e",
},
},
{
tagName: 'script',
attributes: {
type: "text/javascript",
},
innerHTML: 'function OptanonWrapper() {}',
},
{
tagName: 'script',
attributes: {
src: "https://cdn.jsdelivr.net/npm/@segment/analytics-consent-wrapper-onetrust@latest/dist/umd/analytics-onetrust.umd.js",
},
},
{
tagName: 'script',
innerHTML: `
!function(){var i="analytics",analytics=window[i]=window[i]||[];if(!analytics.initialize)if(analytics.invoked)window.console&&console.error&&console.error("Segment snippet included twice.");else{analytics.invoked=!0;analytics.methods=["trackSubmit","trackClick","trackLink","trackForm","pageview","identify","reset","group","track","ready","alias","debug","page","screen","once","off","on","addSourceMiddleware","addIntegrationMiddleware","setAnonymousId","addDestinationMiddleware","register"];analytics.factory=function(e){return function(){if(window[i].initialized)return window[i][e].apply(window[i],arguments);var n=Array.prototype.slice.call(arguments);if(["track","screen","alias","group","page","identify"].indexOf(e)>-1){var c=document.querySelector("link[rel='canonical']");n.push({__t:"bpc",c:c&&c.getAttribute("href")||void 0,p:location.pathname,u:location.href,s:location.search,t:document.title,r:document.referrer})}n.unshift(e);analytics.push(n);return analytics}};for(var n=0;n<analytics.methods.length;n++){var key=analytics.methods[n];analytics[key]=analytics.factory(key)}analytics.load=function(key,n){var t=document.createElement("script");t.type="text/javascript";t.async=!0;t.setAttribute("data-global-segment-analytics-key",i);t.src="https://cdn.segment.com/analytics.js/v1/" + key + "/analytics.min.js";var r=document.getElementsByTagName("script")[0];r.parentNode.insertBefore(t,r);analytics._loadOptions=n};analytics._writeKey="${writeKey}";;analytics.SNIPPET_VERSION="5.2.0";
analytics.load("${writeKey}", { integrations: { "Segment.io": { apiHost: "analytics.apify.com/v1" } } });
}}();
`,
!function(){var i="analytics",analytics=window[i]=window[i]||[];if(!analytics.initialize)if(analytics.invoked)window.console&&console.error&&console.error("Segment snippet included twice.");else{analytics.invoked=!0;analytics.methods=["trackSubmit","trackClick","trackLink","trackForm","pageview","identify","reset","group","track","ready","alias","debug","page","screen","once","off","on","addSourceMiddleware","addIntegrationMiddleware","setAnonymousId","addDestinationMiddleware","register"];analytics.factory=function(e){return function(){if(window[i].initialized)return window[i][e].apply(window[i],arguments);var n=Array.prototype.slice.call(arguments);if(["track","screen","alias","group","page","identify"].indexOf(e)>-1){var c=document.querySelector("link[rel='canonical']");n.push({__t:"bpc",c:c&&c.getAttribute("href")||void 0,p:location.pathname,u:location.href,s:location.search,t:document.title,r:document.referrer})}n.unshift(e);analytics.push(n);return analytics}};for(var n=0;n<analytics.methods.length;n++){var key=analytics.methods[n];analytics[key]=analytics.factory(key)}analytics.load=function(key,n){var t=document.createElement("script");t.type="text/javascript";t.async=!0;t.setAttribute("data-global-segment-analytics-key",i);t.src="https://cdn.segment.com/analytics.js/v1/" + key + "/analytics.min.js";var r=document.getElementsByTagName("script")[0];r.parentNode.insertBefore(t,r);analytics._loadOptions=n};analytics._writeKey="${writeKey}";;analytics.SNIPPET_VERSION="5.2.0";
withOneTrust(analytics.load("${writeKey}", { integrations: { "Segment.io": { apiHost: "analytics.apify.com/v1" } } }));
}}();
`,
},
],
};
Expand Down
30 changes: 30 additions & 0 deletions website/src/plugins/docusaurus-plugin-segment/segment.js
Original file line number Diff line number Diff line change
@@ -1,5 +1,34 @@
import ExecutionEnvironment from '@docusaurus/ExecutionEnvironment';

const DEFAULT_CONSENT = {
C0001: false,
C0002: false,
C0003: false,
C0004: false,
C0005: false,
};

function getOneTrustConsentContext() {
const consent = { ...DEFAULT_CONSENT };
// obtain `OptanonConsent` cookie and extract `groups` substring
const match = document.cookie.match(/(^|;\s*)OptanonConsent=[^;]*&groups=([^;&]*)/);
// decode the value and parse it - expected format: [C0001:1, COOO2:0,...]
const input = decodeURIComponent(match?.[2] ?? '').split(',');

for (const chunk of input) {
const [name, value] = chunk.split(':');

// we only want to update specific groups
if (name in consent) {
// just to be extra sure, only "1" is considered to pass
consent[name] = value === '1';
}
}

return consent;
}


export default ExecutionEnvironment.canUseDOM ? {
onRouteUpdate({ location }) {
// Don't track page views on development
Expand All @@ -9,6 +38,7 @@ export default ExecutionEnvironment.canUseDOM ? {
path: location.pathname,
url: location.href,
search: location.search,
...getOneTrustConsentContext(),
});
}
},
Expand Down