Automatically trigger on events and mutations for sending analytics
Install with npm:
npm i automatic-analytics-trigger -save
Or with yarn:
yarn add automatic-analytics-trigger
Or you can use the UMD build version in dist/automatic-analytics-trigger.min.js
if you don't use a module bundler
https://unpkg.com/browse/automatic-analytics-trigger/dist/
and then add it to your html:
<script src="https://unpkg.com/automatic-analytics-trigger/dist/automatic-analytics-trigger.min.js"></script>
To use a fixed version, see https://unpkg.com/
Instantiate a new AutomaticAnalyticsTrigger
passing a callback function that will be called each time a data event is dispatched. I suggest to use the callback to increment your dataLayer
:)
import AutomaticAnalyticsTrigger from 'automatic-analytics-trigger';
dataLayer = [];
const automaticAnalyticsTrigger = new AutomaticAnalyticsTrigger((dataEvent) => dataLayer.push(dataEvent));
automaticAnalyticsTrigger.init();
And add the analytics data attributes to the elements you want to watch:
<button
data-analytics-click
data-analytics-event="my-page-click"
data-analytics-event-category="my-application:my-page"
data-analytics-event-action="click:my-button"
data-analytics-event-label="my-label-button"
data-analytics-screen-name="my-page"
data-analytics-dimension-22="my-dimension-value"
>
Click to trigger
</button>
See the demo
If you will use Google Analytics and you don't know how to configure it, see https://developers.google.com/tag-manager/quickstart.
You can use a custom configuration to change the target
, events
and mutations
that will trigger your callback:
- events: any javascript event and custom event.
Default value:['click']
- mutations: a DOM mutation type, at this moment,
show
is the only mutation implemented and it occurs when the element is displayed.
Default value:['show']
- target: the element you want to listen
events
andmutations
.
Default value:documentElement
- maxAncestorsChecks: maximum elements depth that events will be captured (e.g, if section has
data-analytics-click
attribute in element tree:section > div > button
when button is clicked even it haven't analytics attribute the event will be dispatched, because the button is in the 2 depth). Default value:5
const callback = (dataEvent) => dataLayer.push(dataEvent);
const config = { events: ['click', 'focus'], target: document.getElementById('my-form')}
const myFormAnalyticsTrigger = new AutomaticAnalyticsTrigger(callback, config);
myFormAnalyticsTrigger.init();