Kollegorna Tracking Utility
GDPR compliant tracking.
Supported services
- Google Tag Manager (GTM)
- Google Analytics (GA)
Example codes
Usual workflow
<div class="consent-dialog" hidden>
<p>Do you wanna get tracked?</p>
<p>
<button type="button" data-type="accept">Accept</button>
<button type="button" data-type="deny">Deny</button>
</p>
</div>
import TrackingUtil from "@kollegorna/tracking-util"
const tu = new TrackingUtil({
services: {
gtm: {
id: `GTM-XXXX`,
},
ga: {
id: `UA-XXXXX-Y`,
}
},
})
const dialogEl = document.querySelector(`.consent-dialog`)
if (tu.userReacted()) {
dialogEl.removeAttribute(`hidden`)
}
dialogEl
.querySelector(`button[data-type="accept"]`)
.addEventListener(`click`, () => {
tu.setTrackingAccepted(true, {
defaultGTMdataLayer: [
{ pageTitle: `Home` },
{ event: `pageview` },
],
defaultGAcommands: [
[`set`, `anonymizeIp`, true],
[`send`, `pageview`],
],
})
dialogEl.setAttribute(`hidden`, ``)
})
dialogEl
.querySelector(`button[data-type="deny"]`)
.addEventListener(`click`, () => {
tu.setTrackingAccepted(false)
dialogEl.setAttribute(`hidden`, ``)
})
Tracking clicks
Once TrackingUtil
instance is created it also becomes accessible via
window.trackingUtil
, e.g.:
document.querySelector(`a.logo`).addEventListener(`click`, () => {
if (window.trackingUtil) {
window.trackingUtil.registerGTMdata({
event: `Click`,
eventCategory: `Links`,
eventLabel: `Logo`,
})
window.trackingUtil.runGAcommand([
`send`,
`event`,
{
eventCategory: `Links`,
eventAction: `Click`,
eventValue: `Logo`,
},
])
}
})
Tracking categories with Google Tag Manager
You may want to allow the user to choose how advanced tracking they are fine
with:
<div class="consent-dialog" hidden>
<label><input type="checkbox" name="performance" /> Performance</label>
<label><input type="checkbox" name="marketing" /> Marketing</label>
<label><input type="checkbox" name="analytics" /> Analytics</label>
</div>
dialogEl
.querySelector(`button[data-type="accept"]`)
.addEventListener(`click`, () => {
const defaultGTMdataLayer = [{ event: `pageview` }]
if (dialogEl.querySelector(`input[name="performance"]`).checked)
defaultGTMdataLayer.push({ event: `trackingCategory:performance` })
if (dialogEl.querySelector(`input[name="marketing"]`).checked)
defaultGTMdataLayer.push({ event: `trackingCategory:marketing` })
if (dialogEl.querySelector(`input[name="analytics"]`).checked)
defaultGTMdataLayer.push({ event: `trackingCategory:analytics` })
tu.setTrackingAccepted(true, { defaultGTMdataLayer })
dialogEl.setAttribute(`hidden`, ``)
})
Default options
{
enabled: true,
cookie: {
name: `tracking-util-reacted`,
options: {
path: `/`,
maxAge: 3600 * 24 * 30 * 12,
secure: false,
},
},
services: {
gtm: {
id: ``,
dataLayerName: `dataLayer`,
},
gtm: {
id: ``,
commandQueue: `ga`,
createFields: {},
},
},
}
Methods
userReacted()
trackingAccepted()
setTrackingAccepted(value, options = {})
If tracking was accepted by user the defaultGTMdataLayer/defaultGAcommands
are
saved in a cookie (Options → cookie.name
) and the data is automatically
injected in GTM's data layer every time TrackingUtil
instance is created.
Therefore it's useful for tracking page views and storing other default
information. Check out /example
for demo.
registerGTMdata(data)
Doesn't do anything if tracking hasn't been accepted by user.
registeredGTMdata()
runGAcommand(data)
Doesn't do anything if tracking hasn't been accepted by user.
Local development and testing
$ yarn dev
or $ yarn build
TODO