nuxt-snapchat-tracker-module v1.0.1
nuxt-snapchat-tracker-module
A nuxt module for snapchat tracker integration
Setup
- Add nuxt-snapchat-tracker-moduledependency to your project
yarn add nuxt-snapchat-tracker-module # or npm install nuxt-snapchat-tracker-module --save- Add nuxt-snapchat-tracker-moduleto themodulessection ofnuxt.config.js
{
  modules: [
    // Simple usage
    'nuxt-snapchat-tracker-module',
    // With options
    ['nuxt-snapchat-tracker-module', {
      track: 'PageView', // default
      id: '<YOUR TRACKING ID>', // mandatory
      disabled: false // default, but beware of GDPR
    }]
  ]
}You can also put your options outside modules
{
  modules: [
    'nuxt-snapchat-tracker-module',
  ],
  snaptr: {
    track: 'PAGE_VIEW', // default
    id: '<YOUR TRACKING ID>', // mandatory
    disabled: false // default, but beware of GDPR
  }
}All user informations are optionnals. Read more below
GDPR
You should collect consent before enabling the tracker to be compliant with GDPR.
First, disable snaptr in yoiur nuxt config file :
{
  modules: [
    'nuxt-snapchat-tracker-module',
  ],
  snaptr: {
    ...
    disabled: true // <-- change this
  }
}Then, collect consent on a popin or whatever then call (in any VueJS component)
this.$snaptr.enable();This will enable the tracker AND call a track event with the Event specified in options (defaut: PAGE_VIEW)
Please note that this module won't remember consent from one session to another. If you want to save the user preference, just hold the information on a local cookie and programatically call
this.$snaptr.enable()
User informations
In attempt to better match the user browser, snapchat tracker allows you to provide an email or a phone number when initialising the tracker.
To init the tracker providing user informations, simply add them as an argument when enabling the tracker. You won't be able to pass some user information if you auto start the tracker as it wouldn't make any sense.
this.$snaptr.enable({
  user_email: 'nospam@nospam.org'
})Read more about the possible user informations here : https://businesshelp.snapchat.com/en-US/a/pixel-website-install
API
Options
| Option | Default | Required | Description | 
|---|---|---|---|
| id | null | true | The unique tracker identifier provided by Snap. | 
| track | PAGE_VIEW | false | Default tracking event. | 
| disabled | false | false | Prevent the tracker to automatically initialize | 
Tracker instance
The tracker is available everywhere and allows you to call specific tracking event during navigation or on some user actions.
Access the tracker with
this.$snaptr
| Method | Purpose | Args | 
|---|---|---|
| enable(user) | Initialize the pixel and tracks the current page view | user:Object: Snapchat user information (Optionnal, see above) | 
| init(user) | Initialises the tracker but do not track the current page | user:Object: Snapchat user information (Optionnal, see above) | 
| track(event, parameters) | Sends a track event with optional parameters. | event:String: defaults totrackoption if not specified.parameters:Object: Some object containing additional info such as purchase price. defaults to null. | 
| query(cmd, name, parameters) | Call the snaptr tracker directly. Only use case would be to call future commands yet not implemented in this module. | cmd:String: the snaptr command (ex: "track").value:String: The snaptr event name (ex: "PAGE_VIEW").parameters:Object: Optionnal snaptr parameters | 
License
Copyright (c) Nicolas Chesné
5 years ago