@surfside/browser-sdk
TypeScript icon, indicating that this package has built-in type declarations

2.0.0 • Public • Published

Surfside Browser Tracker

Setup repository

npm install -g @microsoft/rush 
git clone repo
rush update

Package Installation

With npm:

npm install @surfside/browser-sdk

Usage

Initialize your tracker with your desired configuration and optional plugins:

import { newTracker } from '@surfside/browser-sdk';
import { SiteTrackingPlugin } from '@snowplow/browser-plugin-site-tracking';
import { PerformanceTimingPlugin } from '@snowplow/browser-plugin-performance-timing';
import { ClientHintsPlugin } from '@snowplow/browser-plugin-client-hints';
import { FormTrackingPlugin, enableFormTracking } from '@snowplow/browser-plugin-form-tracking';

newTracker('sp1', '{{collector}}', { plugins: [ PerformanceTimingPlugin(), SiteTrackingPlugin(), ClientHintsPlugin(), FormTrackingPlugin() ] }); // Also stores reference at module level
newTracker('sp2', '{{collector}}', { plugins: [ PerformanceTimingPlugin(), SiteTrackingPlugin() ] }); // You can have multiple trackers with different configs!

enableFormTracking() // Switch on form tracking

Then use the trackX functions from this package and your plugins to track to all trackers which have been initialized, or select just some trackers:

import { trackPageView } from '@surfside/browser-sdk';
import { trackSocialInteraction } from '@snowplow/browser-plugin-site-tracking';

trackPageView({}, ['sp1']); // Just to `sp1`

// OR to all trackers with some extra context!
trackPageView({
  title: 'My Title',
  context: [
    {
      schema: 'iglu:org.schema/WebPage/jsonschema/1-0-0',
      data: {
        keywords: ['tester'],
      },
    },
  ],
});

// Use your plugin track methods too
trackSocialInteraction({
  action: 'retweet',
  network: 'twitter',
  target: '1234',
});

Copyright and license

Licensed and distributed under the BSD 3-Clause License (An OSI Approved License).

Copyright (c) 2022 Surfside Solutions Inc, Snowplow Analytics Ltd, 2010 Anthon Pang.

All rights reserved.

Package Sidebar

Install

npm i @surfside/browser-sdk

Weekly Downloads

3

Version

2.0.0

License

BSD-3-Clause

Unpacked Size

1.73 MB

Total Files

12

Last publish

Collaborators

  • michael.blanche