@codecademy/tracking
v1.0.43
Published
Tracking library for Codecademy
Downloads
3,487
Readme
@codecademy/tracking
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
createTracker
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');
Event Usage
click
Tracks that a user has clicked an element on the page.
tracker.click({
page_name: 'my_page',
target: 'my_button',
});
Calls to event
internally.
visit
Tracks that a user has visited a page or sub-page.
tracker.visit({
page_name: 'my_page',
});
Calls to event
internally.
event
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);
Miscellaneous Usage
pushDataLayerEvent
Adds a GTM dataLayer
event to the global dataLayer
array.
If dataLayer
does not exist, it will be created.
tracker.pushDataLayerEvent('user_sign_up');
initializeTrackingIntegrations
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);