This package contains our user "telemetry" (tracking metrics such as click
and visit
) integrations that are shared across multiple web properties.
We've consolidated them here for a few reasons:
- To standardize APIs around events like tracking user clicks
- To make sure any third party integrations are CCPA & GDPR compliant
- Because this repository already has a sweet CI setup for previewing and auto-publishing new versions 😎
There are two kinds of tracking we package in this library:
-
Internal tracking (
createTracker
): sent directly to our/analytics/
endpoint -
External tracking (
useTrackingIntegrations
): scripts loaded via Google Tag Manager
Creates a "tracker" object that includes methods for user telemetry such as click
and visit
.
import { createTracker } from '@codecademy/tracking';
const tracker = createTracker('apiBaseUrl', 'authToken');
Tracks that a user has clicked an element on the page.
tracker.click({
page_name: 'my_page',
target: 'my_button',
});
Calls to event
internally.
Tracks that a user has visited a page or sub-page.
tracker.visit({
page_name: 'my_page',
});
Calls to event
internally.
Generic event for any other event.
Events that are allowed to be used here are strongly typed in the types.d.ts
file included in the package.
tracker.event('calendar', 'reminder', data);
Adds a GTM dataLayer
event to the global dataLayer
array.
If dataLayer
does not exist, it will be created.
tracker.pushDataLayerEvent('user_sign_up');
See GDPR Compliance on Notion for full docs on external tracking.
Starts the initialization process for our third-party integrations.
Integrations are loaded in an intentionally layered manner for CCPA/GDPR compliance:
- Wait 1000ms to allow any other post-hydration logic to run first
- Load in OneTrust's banner and wait for its
OptanonWrapper
callback - Load GTM
import { initializeTrackingIntegrations } from '@codecademy/tracking';
setTimeout(() => {
initializeTrackingIntegrations({
environment: process.env.NODE_ENV,
scope: window,
});
}, 1000);