trala-angulartics2
Version:
Vendor-agnostic web analytics for Angular2 applications
114 lines • 14.4 kB
JavaScript
import { Injectable } from '@angular/core';
import * as i0 from "@angular/core";
import * as i1 from "../../angulartics2-core";
export class GoogleTagManagerDefaults {
constructor() {
this.userId = null;
}
}
export class Angulartics2GoogleTagManager {
constructor(angulartics2) {
this.angulartics2 = angulartics2;
// The dataLayer needs to be initialized
if (typeof dataLayer !== 'undefined' && dataLayer) {
dataLayer = window.dataLayer = window.dataLayer || [];
}
const defaults = new GoogleTagManagerDefaults();
// Set the default settings for this module
this.angulartics2.settings.gtm = { ...defaults, ...this.angulartics2.settings.gtm };
this.angulartics2.setUsername.subscribe((x) => this.setUsername(x));
}
startTracking() {
this.angulartics2.pageTrack
.pipe(this.angulartics2.filterDeveloperMode())
.subscribe(x => this.pageTrack(x.path));
this.angulartics2.eventTrack
.pipe(this.angulartics2.filterDeveloperMode())
.subscribe(x => this.eventTrack(x.action, x.properties));
this.angulartics2.exceptionTrack
.pipe(this.angulartics2.filterDeveloperMode())
.subscribe((x) => this.exceptionTrack(x));
}
pageTrack(path) {
this.pushLayer({
event: 'Page View',
'content-name': path,
userId: this.angulartics2.settings.gtm.userId,
});
}
/**
* Send Data Layer
*
* @layer data layer object
*/
pushLayer(layer) {
if (typeof dataLayer !== 'undefined' && dataLayer) {
dataLayer.push(layer);
}
}
/**
* Send interactions to the dataLayer, i.e. for event tracking in Google Analytics
*
* @param action associated with the event
*/
eventTrack(action, properties) {
// TODO: make interface
// @param {string} properties.category
// @param {string} [properties.label]
// @param {number} [properties.value]
// @param {boolean} [properties.noninteraction]
// Set a default GTM category
properties = properties || {};
this.pushLayer({
event: properties.event || 'interaction',
target: properties.category || 'Event',
action,
label: properties.label,
value: properties.value,
interactionType: properties.noninteraction,
userId: this.angulartics2.settings.gtm.userId,
...properties.gtmCustom,
});
}
/**
* Exception Track Event in GTM
*
*/
exceptionTrack(properties) {
// TODO: make interface
// @param {Object} properties
// @param {string} properties.appId
// @param {string} properties.appName
// @param {string} properties.appVersion
// @param {string} [properties.description]
// @param {boolean} [properties.fatal]
if (!properties || !properties.appId || !properties.appName || !properties.appVersion) {
console.error('Must be setted appId, appName and appVersion.');
return;
}
if (properties.fatal === undefined) {
console.log('No "fatal" provided, sending with fatal=true');
properties.exFatal = true;
}
properties.exDescription = properties.event ? properties.event.stack : properties.description;
this.eventTrack(`Exception thrown for ${properties.appName} <${properties.appId}@${properties.appVersion}>`, {
category: 'Exception',
label: properties.exDescription,
});
}
/**
* Set userId for use with Universal Analytics User ID feature
*
* @param userId used to identify user cross-device in Google Analytics
*/
setUsername(userId) {
this.angulartics2.settings.gtm.userId = userId;
}
}
Angulartics2GoogleTagManager.ɵfac = i0.ɵɵngDeclareFactory({ minVersion: "12.0.0", version: "13.0.3", ngImport: i0, type: Angulartics2GoogleTagManager, deps: [{ token: i1.Angulartics2 }], target: i0.ɵɵFactoryTarget.Injectable });
Angulartics2GoogleTagManager.ɵprov = i0.ɵɵngDeclareInjectable({ minVersion: "12.0.0", version: "13.0.3", ngImport: i0, type: Angulartics2GoogleTagManager, providedIn: 'root' });
i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "13.0.3", ngImport: i0, type: Angulartics2GoogleTagManager, decorators: [{
type: Injectable,
args: [{ providedIn: 'root' }]
}], ctorParameters: function () { return [{ type: i1.Angulartics2 }]; } });
//# sourceMappingURL=data:application/json;base64,{"version":3,"file":"gtm.js","sourceRoot":"","sources":["../../../../src/lib/providers/gtm/gtm.ts"],"names":[],"mappings":"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","sourcesContent":["import { Injectable } from '@angular/core';\r\n\r\nimport { Angulartics2 } from '../../angulartics2-core';\r\nimport { GoogleTagManagerSettings } from '../../angulartics2-config';\r\n\r\ndeclare var dataLayer: any;\r\n\r\nexport class GoogleTagManagerDefaults implements GoogleTagManagerSettings {\r\n  userId = null;\r\n}\r\n\r\n@Injectable({ providedIn: 'root' })\r\nexport class Angulartics2GoogleTagManager {\r\n  constructor(protected angulartics2: Angulartics2) {\r\n    // The dataLayer needs to be initialized\r\n    if (typeof dataLayer !== 'undefined' && dataLayer) {\r\n      dataLayer = (window as any).dataLayer = (window as any).dataLayer || [];\r\n    }\r\n    const defaults = new GoogleTagManagerDefaults();\r\n    // Set the default settings for this module\r\n    this.angulartics2.settings.gtm = { ...defaults, ...this.angulartics2.settings.gtm };\r\n    this.angulartics2.setUsername.subscribe((x: string) => this.setUsername(x));\r\n  }\r\n\r\n  startTracking() {\r\n    this.angulartics2.pageTrack\r\n      .pipe(this.angulartics2.filterDeveloperMode())\r\n      .subscribe(x => this.pageTrack(x.path));\r\n    this.angulartics2.eventTrack\r\n      .pipe(this.angulartics2.filterDeveloperMode())\r\n      .subscribe(x => this.eventTrack(x.action, x.properties));\r\n    this.angulartics2.exceptionTrack\r\n      .pipe(this.angulartics2.filterDeveloperMode())\r\n      .subscribe((x: any) => this.exceptionTrack(x));\r\n  }\r\n\r\n  pageTrack(path: string) {\r\n    this.pushLayer({\r\n      event: 'Page View',\r\n      'content-name': path,\r\n      userId: this.angulartics2.settings.gtm.userId,\r\n    });\r\n  }\r\n\r\n  /**\r\n   * Send Data Layer\r\n   *\r\n   * @layer data layer object\r\n   */\r\n  pushLayer(layer: any) {\r\n    if (typeof dataLayer !== 'undefined' && dataLayer) {\r\n      dataLayer.push(layer);\r\n    }\r\n  }\r\n\r\n  /**\r\n   * Send interactions to the dataLayer, i.e. for event tracking in Google Analytics\r\n   *\r\n   * @param action associated with the event\r\n   */\r\n  eventTrack(action: string, properties: any) {\r\n    // TODO: make interface\r\n    //  @param {string} properties.category\r\n    //  @param {string} [properties.label]\r\n    //  @param {number} [properties.value]\r\n    //  @param {boolean} [properties.noninteraction]\r\n    // Set a default GTM category\r\n    properties = properties || {};\r\n\r\n    this.pushLayer({\r\n      event: properties.event || 'interaction',\r\n      target: properties.category || 'Event',\r\n      action,\r\n      label: properties.label,\r\n      value: properties.value,\r\n      interactionType: properties.noninteraction,\r\n      userId: this.angulartics2.settings.gtm.userId,\r\n      ...properties.gtmCustom,\r\n    });\r\n  }\r\n\r\n  /**\r\n   * Exception Track Event in GTM\r\n   *\r\n   */\r\n  exceptionTrack(properties: any) {\r\n    // TODO: make interface\r\n    //  @param {Object} properties\r\n    //  @param {string} properties.appId\r\n    //  @param {string} properties.appName\r\n    //  @param {string} properties.appVersion\r\n    //  @param {string} [properties.description]\r\n    //  @param {boolean} [properties.fatal]\r\n    if (!properties || !properties.appId || !properties.appName || !properties.appVersion) {\r\n      console.error('Must be setted appId, appName and appVersion.');\r\n      return;\r\n    }\r\n\r\n    if (properties.fatal === undefined) {\r\n      console.log('No \"fatal\" provided, sending with fatal=true');\r\n      properties.exFatal = true;\r\n    }\r\n\r\n    properties.exDescription = properties.event ? properties.event.stack : properties.description;\r\n\r\n    this.eventTrack(\r\n      `Exception thrown for ${properties.appName} <${properties.appId}@${properties.appVersion}>`,\r\n      {\r\n        category: 'Exception',\r\n        label: properties.exDescription,\r\n      },\r\n    );\r\n  }\r\n\r\n  /**\r\n   * Set userId for use with Universal Analytics User ID feature\r\n   *\r\n   * @param userId used to identify user cross-device in Google Analytics\r\n   */\r\n  setUsername(userId: string) {\r\n    this.angulartics2.settings.gtm.userId = userId;\r\n  }\r\n}\r\n"]}