@firestitch/analytics
Advanced tools
Comparing version 12.3.9 to 12.3.10
import { Provider } from "./provider"; | ||
export declare class GoogleTagManagerProvider extends Provider { | ||
private _initData; | ||
private _init$; | ||
init(): void; | ||
@@ -16,4 +18,3 @@ pushData(...data: any): void; | ||
private _mapItems; | ||
private _mapTypeEvent; | ||
private _mapEventData; | ||
private _getMapping; | ||
} |
@@ -547,8 +547,22 @@ (function (global, factory) { | ||
function GoogleTagManagerProvider() { | ||
return _super !== null && _super.apply(this, arguments) || this; | ||
var _this = _super.apply(this, __spreadArray([], __read(arguments))) || this; | ||
_this._initData = []; | ||
_this._init$ = new rxjs.BehaviorSubject(false); | ||
return _this; | ||
} | ||
GoogleTagManagerProvider.prototype.init = function () { | ||
var _this = this; | ||
if (this.containerId) { | ||
var scriptDomain = this.scriptDomain || 'www.googletagmanager.com'; | ||
this.addScript("https://" + scriptDomain + "/gtm.js?id=" + this.containerId); | ||
rxjs.from(this.addScript("https://" + scriptDomain + "/gtm.js?id=" + this.containerId)) | ||
.pipe(operators.switchMap(function () { return rxjs.interval(10); }), operators.take(50), operators.takeWhile(function () { return !_this._init$.getValue(); }), operators.filter(function () { | ||
return _this.window.dataLayer.some(function (item) { return item.event === 'gtm.load'; }); | ||
})) | ||
.subscribe(function () { | ||
_this._init$.next(true); | ||
_this._init$.complete(); | ||
_this._initData.forEach(function (data) { | ||
_this.window.dataLayer.push(data); | ||
}); | ||
}); | ||
this.window.dataLayer = this.window.dataLayer || []; | ||
@@ -574,6 +588,17 @@ this.pushData('js', new Date()); | ||
GoogleTagManagerProvider.prototype.trackEvent = function (type, value, options) { | ||
var data = this._mapEventData(type, value, options); | ||
var event = this._mapTypeEvent(type); | ||
this.window.dataLayer.push({ ecommerce: null }); | ||
this.window.dataLayer.push(Object.assign({ event: event }, data)); | ||
var mapping = this._getMapping(type); | ||
var data = mapping.transform ? | ||
mapping.transform(mapping.type, value) : { | ||
event: type, | ||
value: value, | ||
category: options === null || options === void 0 ? void 0 : options.category, | ||
label: options === null || options === void 0 ? void 0 : options.label, | ||
}; | ||
var dataLayer = this._init$.getValue() ? | ||
this.window.dataLayer : | ||
this._initData; | ||
if (mapping.ecommerce) { | ||
dataLayer.push({ ecommerce: null }); | ||
} | ||
dataLayer.push(data); | ||
}; | ||
@@ -597,4 +622,5 @@ GoogleTagManagerProvider.prototype.setUser = function (data) { }; | ||
}); | ||
GoogleTagManagerProvider.prototype._mapPurchaseEventData = function (value) { | ||
GoogleTagManagerProvider.prototype._mapPurchaseEventData = function (event, value) { | ||
return { | ||
event: event, | ||
ecommerce: { | ||
@@ -610,4 +636,5 @@ transaction_id: value.transactionId, | ||
}; | ||
GoogleTagManagerProvider.prototype._mapBeginCheckoutEventData = function (value) { | ||
GoogleTagManagerProvider.prototype._mapBeginCheckoutEventData = function (event, value) { | ||
return { | ||
event: event, | ||
ecommerce: { | ||
@@ -620,4 +647,5 @@ value: value.total, | ||
}; | ||
GoogleTagManagerProvider.prototype._mapAddToCartEventData = function (value) { | ||
GoogleTagManagerProvider.prototype._mapAddToCartEventData = function (event, value) { | ||
return { | ||
event: event, | ||
ecommerce: { | ||
@@ -630,4 +658,5 @@ value: value.total, | ||
}; | ||
GoogleTagManagerProvider.prototype._mapRemoveFromCartEventData = function (value) { | ||
GoogleTagManagerProvider.prototype._mapRemoveFromCartEventData = function (event, value) { | ||
return { | ||
event: event, | ||
ecommerce: { | ||
@@ -640,4 +669,5 @@ value: value.total, | ||
}; | ||
GoogleTagManagerProvider.prototype._mapAddPaymentEventData = function (value) { | ||
GoogleTagManagerProvider.prototype._mapAddPaymentEventData = function (event, value) { | ||
return { | ||
event: event, | ||
ecommerce: { | ||
@@ -662,42 +692,27 @@ value: value.total, | ||
}; | ||
GoogleTagManagerProvider.prototype._mapTypeEvent = function (type) { | ||
GoogleTagManagerProvider.prototype._getMapping = function (type) { | ||
var _this = this; | ||
var transform; | ||
if (type === exports.EventType.Purcahse) { | ||
return 'purchase'; | ||
type = 'purchase'; | ||
transform = function (event, value) { return _this._mapPurchaseEventData(event, value); }; | ||
} | ||
else if (type === exports.EventType.BeginCheckout) { | ||
return 'begin_checkout'; | ||
type = 'begin_checkout'; | ||
transform = function (event, value) { return _this._mapBeginCheckoutEventData(event, value); }; | ||
} | ||
else if (type === exports.EventType.AddPayment) { | ||
return 'add_payment_info'; | ||
type = 'add_payment_info'; | ||
transform = function (event, value) { return _this._mapAddPaymentEventData(event, value); }; | ||
} | ||
else if (type === exports.EventType.AddToCart) { | ||
return 'add_to_cart'; | ||
type = 'add_to_cart'; | ||
transform = function (event, value) { return _this._mapAddToCartEventData(event, value); }; | ||
} | ||
else if (type === exports.EventType.RemoveFromCart) { | ||
return 'remove_from_cart'; | ||
type = 'remove_from_cart'; | ||
transform = function (event, value) { return _this._mapRemoveFromCartEventData(event, value); }; | ||
} | ||
return type; | ||
return { type: type, transform: transform, ecommerce: !!transform }; | ||
}; | ||
GoogleTagManagerProvider.prototype._mapEventData = function (type, value, options) { | ||
if (type === exports.EventType.Purcahse) { | ||
return this._mapPurchaseEventData(value); | ||
} | ||
else if (type === exports.EventType.BeginCheckout) { | ||
return this._mapBeginCheckoutEventData(value); | ||
} | ||
else if (type === exports.EventType.AddPayment) { | ||
return this._mapAddPaymentEventData(value); | ||
} | ||
else if (type === exports.EventType.AddToCart) { | ||
return this._mapAddToCartEventData(value); | ||
} | ||
else if (type === exports.EventType.RemoveFromCart) { | ||
return this._mapRemoveFromCartEventData(value); | ||
} | ||
return { | ||
value: value, | ||
category: options === null || options === void 0 ? void 0 : options.category, | ||
label: options === null || options === void 0 ? void 0 : options.label, | ||
}; | ||
}; | ||
return GoogleTagManagerProvider; | ||
@@ -704,0 +719,0 @@ }(Provider)); |
import { Provider } from "./provider"; | ||
import { BehaviorSubject, from, interval } from "rxjs"; | ||
import { filter, switchMap, take, takeWhile } from "rxjs/operators"; | ||
import { EventType } from "../enums"; | ||
export class GoogleTagManagerProvider extends Provider { | ||
constructor() { | ||
super(...arguments); | ||
this._initData = []; | ||
this._init$ = new BehaviorSubject(false); | ||
} | ||
init() { | ||
if (this.containerId) { | ||
const scriptDomain = this.scriptDomain || 'www.googletagmanager.com'; | ||
this.addScript(`https://${scriptDomain}/gtm.js?id=${this.containerId}`); | ||
from(this.addScript(`https://${scriptDomain}/gtm.js?id=${this.containerId}`)) | ||
.pipe(switchMap(() => interval(10)), take(50), takeWhile(() => !this._init$.getValue()), filter(() => { | ||
return this.window.dataLayer.some((item) => item.event === 'gtm.load'); | ||
})) | ||
.subscribe(() => { | ||
this._init$.next(true); | ||
this._init$.complete(); | ||
this._initData.forEach((data) => { | ||
this.window.dataLayer.push(data); | ||
}); | ||
}); | ||
this.window.dataLayer = this.window.dataLayer || []; | ||
@@ -24,6 +41,17 @@ this.pushData('js', new Date()); | ||
trackEvent(type, value, options) { | ||
const data = this._mapEventData(type, value, options); | ||
const event = this._mapTypeEvent(type); | ||
this.window.dataLayer.push({ ecommerce: null }); | ||
this.window.dataLayer.push(Object.assign({ event }, data)); | ||
const mapping = this._getMapping(type); | ||
const data = mapping.transform ? | ||
mapping.transform(mapping.type, value) : { | ||
event: type, | ||
value, | ||
category: options === null || options === void 0 ? void 0 : options.category, | ||
label: options === null || options === void 0 ? void 0 : options.label, | ||
}; | ||
const dataLayer = this._init$.getValue() ? | ||
this.window.dataLayer : | ||
this._initData; | ||
if (mapping.ecommerce) { | ||
dataLayer.push({ ecommerce: null }); | ||
} | ||
dataLayer.push(data); | ||
} | ||
@@ -39,4 +67,5 @@ setUser(data) { } | ||
} | ||
_mapPurchaseEventData(value) { | ||
_mapPurchaseEventData(event, value) { | ||
return { | ||
event, | ||
ecommerce: { | ||
@@ -52,4 +81,5 @@ transaction_id: value.transactionId, | ||
} | ||
_mapBeginCheckoutEventData(value) { | ||
_mapBeginCheckoutEventData(event, value) { | ||
return { | ||
event, | ||
ecommerce: { | ||
@@ -62,4 +92,5 @@ value: value.total, | ||
} | ||
_mapAddToCartEventData(value) { | ||
_mapAddToCartEventData(event, value) { | ||
return { | ||
event, | ||
ecommerce: { | ||
@@ -72,4 +103,5 @@ value: value.total, | ||
} | ||
_mapRemoveFromCartEventData(value) { | ||
_mapRemoveFromCartEventData(event, value) { | ||
return { | ||
event, | ||
ecommerce: { | ||
@@ -82,4 +114,5 @@ value: value.total, | ||
} | ||
_mapAddPaymentEventData(value) { | ||
_mapAddPaymentEventData(event, value) { | ||
return { | ||
event, | ||
ecommerce: { | ||
@@ -104,43 +137,27 @@ value: value.total, | ||
} | ||
_mapTypeEvent(type) { | ||
_getMapping(type) { | ||
let transform; | ||
if (type === EventType.Purcahse) { | ||
return 'purchase'; | ||
type = 'purchase'; | ||
transform = (event, value) => this._mapPurchaseEventData(event, value); | ||
} | ||
else if (type === EventType.BeginCheckout) { | ||
return 'begin_checkout'; | ||
type = 'begin_checkout'; | ||
transform = (event, value) => this._mapBeginCheckoutEventData(event, value); | ||
} | ||
else if (type === EventType.AddPayment) { | ||
return 'add_payment_info'; | ||
type = 'add_payment_info'; | ||
transform = (event, value) => this._mapAddPaymentEventData(event, value); | ||
} | ||
else if (type === EventType.AddToCart) { | ||
return 'add_to_cart'; | ||
type = 'add_to_cart'; | ||
transform = (event, value) => this._mapAddToCartEventData(event, value); | ||
} | ||
else if (type === EventType.RemoveFromCart) { | ||
return 'remove_from_cart'; | ||
type = 'remove_from_cart'; | ||
transform = (event, value) => this._mapRemoveFromCartEventData(event, value); | ||
} | ||
return type; | ||
return { type, transform, ecommerce: !!transform }; | ||
} | ||
_mapEventData(type, value, options) { | ||
if (type === EventType.Purcahse) { | ||
return this._mapPurchaseEventData(value); | ||
} | ||
else if (type === EventType.BeginCheckout) { | ||
return this._mapBeginCheckoutEventData(value); | ||
} | ||
else if (type === EventType.AddPayment) { | ||
return this._mapAddPaymentEventData(value); | ||
} | ||
else if (type === EventType.AddToCart) { | ||
return this._mapAddToCartEventData(value); | ||
} | ||
else if (type === EventType.RemoveFromCart) { | ||
return this._mapRemoveFromCartEventData(value); | ||
} | ||
return { | ||
value, | ||
category: options === null || options === void 0 ? void 0 : options.category, | ||
label: options === null || options === void 0 ? void 0 : options.label, | ||
}; | ||
} | ||
} | ||
//# sourceMappingURL=data:application/json;base64,{"version":3,"file":"google-tag-manager.js","sourceRoot":"","sources":["../../../../src/app/providers/google-tag-manager.ts"],"names":[],"mappings":"AAAA,OAAO,EAAE,QAAQ,EAAE,MAAM,YAAY,CAAC;AAEtC,OAAO,EAAE,SAAS,EAAE,MAAM,UAAU,CAAC;AAIrC,MAAM,OAAO,wBAAyB,SAAQ,QAAQ;IAE7C,IAAI;QACT,IAAI,IAAI,CAAC,WAAW,EAAE;YACpB,MAAM,YAAY,GAAG,IAAI,CAAC,YAAY,IAAI,0BAA0B,CAAC;YACrE,IAAI,CAAC,SAAS,CAAC,WAAW,YAAY,cAAc,IAAI,CAAC,WAAW,EAAE,CAAC,CAAC;YACxE,IAAI,CAAC,MAAM,CAAC,SAAS,GAAG,IAAI,CAAC,MAAM,CAAC,SAAS,IAAI,EAAE,CAAC;YAEpD,IAAI,CAAC,QAAQ,CAAC,IAAI,EAAE,IAAI,IAAI,EAAE,CAAC,CAAC;YAChC,IAAI,CAAC,QAAQ,CAAC,QAAQ,EAAE,IAAI,CAAC,WAAW,EAAE,EAAE,SAAS,EAAE,IAAI,CAAC,OAAO,CAAC,GAAG,EAAE,CAAC,CAAC;SAC5E;IACH,CAAC;IAEM,QAAQ,CAAC,GAAG,IAAS;QAC1B,IAAI,CAAC,MAAM,CAAC,SAAS,CAAC,IAAI,CAAC,IAAI,CAAC,CAAC;IACnC,CAAC;IAEM,SAAS,CAAC,IAAY;QAC3B,IAAI,CAAC,UAAU,CAAC,UAAU,EAAE;YAC1B,IAAI,EAAE;gBACJ,IAAI;aACL;SACF,CAAC,CAAC;IACL,CAAC;IAEM,UAAU,CAAC,IAAS,EAAE,KAAM,EAAE,OAAQ;QAC3C,MAAM,IAAI,GAAG,IAAI,CAAC,aAAa,CAAC,IAAI,EAAE,KAAK,EAAE,OAAO,CAAC,CAAC;QACtD,MAAM,KAAK,GAAG,IAAI,CAAC,aAAa,CAAC,IAAI,CAAC,CAAC;QAEvC,IAAI,CAAC,MAAM,CAAC,SAAS,CAAC,IAAI,CAAC,EAAE,SAAS,EAAE,IAAI,EAAE,CAAC,CAAC;QAChD,IAAI,CAAC,MAAM,CAAC,SAAS,CAAC,IAAI,iBACxB,KAAK,IACF,IAAI,EACP,CAAC;IACL,CAAC;IAEM,OAAO,CAAC,IAAI,IAAI,CAAC;IAExB,IAAW,WAAW;;QACpB,OAAO,MAAA,IAAI,CAAC,OAAO,CAAC,SAAS,CAAC,gBAAgB,0CAAE,WAAW,CAAC;IAC9D,CAAC;IAED,IAAW,YAAY;;QACrB,OAAO,MAAA,IAAI,CAAC,OAAO,CAAC,SAAS,CAAC,gBAAgB,0CAAE,YAAY,CAAC;IAC/D,CAAC;IAEO,qBAAqB,CAAC,KAAoB;QAChD,OAAO;YACL,SAAS,EAAE;gBACT,cAAc,EAAE,KAAK,CAAC,aAAa;gBACnC,KAAK,EAAE,KAAK,CAAC,KAAK;gBAClB,GAAG,EAAE,KAAK,CAAC,GAAG;gBACd,QAAQ,EAAE,KAAK,CAAC,QAAQ;gBACxB,QAAQ,EAAE,KAAK,CAAC,QAAQ;gBACxB,KAAK,EAAE,IAAI,CAAC,SAAS,CAAC,KAAK,CAAC,KAAK,CAAC;aACnC;SACF,CAAA;IACH,CAAC;IAEO,0BAA0B,CAAC,KAAyB;QAC1D,OAAO;YACL,SAAS,EAAE;gBACT,KAAK,EAAE,KAAK,CAAC,KAAK;gBAClB,QAAQ,EAAE,KAAK,CAAC,QAAQ;gBACxB,KAAK,EAAE,IAAI,CAAC,SAAS,CAAC,KAAK,CAAC,KAAK,CAAC;aACnC;SACF,CAAA;IACH,CAAC;IAEO,sBAAsB,CAAC,KAAqB;QAClD,OAAO;YACL,SAAS,EAAE;gBACT,KAAK,EAAE,KAAK,CAAC,KAAK;gBAClB,QAAQ,EAAE,KAAK,CAAC,QAAQ;gBACxB,KAAK,EAAE,IAAI,CAAC,SAAS,CAAC,KAAK,CAAC,KAAK,CAAC;aACnC;SACF,CAAA;IACH,CAAC;IAEO,2BAA2B,CAAC,KAA0B;QAC5D,OAAO;YACL,SAAS,EAAE;gBACT,KAAK,EAAE,KAAK,CAAC,KAAK;gBAClB,QAAQ,EAAE,KAAK,CAAC,QAAQ;gBACxB,KAAK,EAAE,IAAI,CAAC,SAAS,CAAC,KAAK,CAAC,KAAK,CAAC;aACnC;SACF,CAAA;IACH,CAAC;IAEO,uBAAuB,CAAC,KAAsB;QACpD,OAAO;YACL,SAAS,EAAE;gBACT,KAAK,EAAE,KAAK,CAAC,KAAK;gBAClB,QAAQ,EAAE,KAAK,CAAC,QAAQ;gBACxB,YAAY,EAAE,KAAK,CAAC,WAAW;gBAC/B,KAAK,EAAE,IAAI,CAAC,SAAS,CAAC,KAAK,CAAC,KAAK,CAAC;aACnC;SACF,CAAA;IACH,CAAC;IAEO,SAAS,CAAC,KAAa;QAC7B,OAAO,KAAK;aACT,GAAG,CAAC,CAAC,IAAI,EAAE,EAAE,CAAC,CAAC;YACd,OAAO,EAAE,IAAI,CAAC,EAAE;YAChB,SAAS,EAAE,IAAI,CAAC,IAAI;YACpB,KAAK,EAAE,IAAI,CAAC,KAAK,IAAI,CAAC;YACtB,QAAQ,EAAE,IAAI,CAAC,QAAQ,IAAI,CAAC;YAC5B,aAAa,EAAE,IAAI,CAAC,QAAQ;YAC5B,cAAc,EAAE,IAAI,CAAC,SAAS;SAC/B,CAAC,CAAC,CAAC;IACR,CAAC;IAEO,aAAa,CAAC,IAAe;QACnC,IAAI,IAAI,KAAK,SAAS,CAAC,QAAQ,EAAE;YAC/B,OAAO,UAAU,CAAC;SACnB;aAAM,IAAI,IAAI,KAAK,SAAS,CAAC,aAAa,EAAE;YAC3C,OAAO,gBAAgB,CAAC;SACzB;aAAM,IAAI,IAAI,KAAK,SAAS,CAAC,UAAU,EAAE;YACxC,OAAO,kBAAkB,CAAC;SAC3B;aAAM,IAAI,IAAI,KAAK,SAAS,CAAC,SAAS,EAAE;YACvC,OAAO,aAAa,CAAC;SACtB;aAAM,IAAI,IAAI,KAAK,SAAS,CAAC,cAAc,EAAE;YAC5C,OAAO,kBAAkB,CAAC;SAC3B;QAED,OAAO,IAAI,CAAC;IACd,CAAC;IAEO,aAAa,CAAC,IAAe,EAAE,KAAK,EAAE,OAAO;QACnD,IAAI,IAAI,KAAK,SAAS,CAAC,QAAQ,EAAE;YAC/B,OAAO,IAAI,CAAC,qBAAqB,CAAC,KAAK,CAAC,CAAC;SAC1C;aAAM,IAAI,IAAI,KAAK,SAAS,CAAC,aAAa,EAAE;YAC3C,OAAO,IAAI,CAAC,0BAA0B,CAAC,KAAK,CAAC,CAAC;SAC/C;aAAM,IAAI,IAAI,KAAK,SAAS,CAAC,UAAU,EAAE;YACxC,OAAO,IAAI,CAAC,uBAAuB,CAAC,KAAK,CAAC,CAAC;SAC5C;aAAM,IAAI,IAAI,KAAK,SAAS,CAAC,SAAS,EAAE;YACvC,OAAO,IAAI,CAAC,sBAAsB,CAAC,KAAK,CAAC,CAAC;SAC3C;aAAM,IAAI,IAAI,KAAK,SAAS,CAAC,cAAc,EAAE;YAC5C,OAAO,IAAI,CAAC,2BAA2B,CAAC,KAAK,CAAC,CAAC;SAChD;QAED,OAAO;YACL,KAAK;YACL,QAAQ,EAAE,OAAO,aAAP,OAAO,uBAAP,OAAO,CAAE,QAAQ;YAC3B,KAAK,EAAE,OAAO,aAAP,OAAO,uBAAP,OAAO,CAAE,KAAK;SACf,CAAC;IACX,CAAC;CACF","sourcesContent":["import { Provider } from \"./provider\";\n\nimport { EventType } from \"../enums\";\nimport { AddToCartEvent, AppPaymentEvent, BeginCheckoutEvent, Item, PurchaseEvent, RemoveFromCartEvent } from \"../interfaces\";\n\n\nexport class GoogleTagManagerProvider extends Provider {\n\n  public init() {\n    if (this.containerId) {\n      const scriptDomain = this.scriptDomain || 'www.googletagmanager.com';\n      this.addScript(`https://${scriptDomain}/gtm.js?id=${this.containerId}`);\n      this.window.dataLayer = this.window.dataLayer || [];\n\n      this.pushData('js', new Date());\n      this.pushData('config', this.containerId, { path_path: this._router.url });\n    }\n  }\n\n  public pushData(...data: any): void {\n    this.window.dataLayer.push(data);\n  }\n\n  public trackPage(path: string): void {\n    this.trackEvent('pageview', {\n      page: {\n        path,\n      }\n    });\n  }\n\n  public trackEvent(type: any, value?, options?): void {\n    const data = this._mapEventData(type, value, options);\n    const event = this._mapTypeEvent(type);\n\n    this.window.dataLayer.push({ ecommerce: null });\n    this.window.dataLayer.push({\n      event,\n      ...data\n    });\n  }\n\n  public setUser(data) { }\n\n  public get containerId() {\n    return this._config.providers.googleTagManager?.containerId;\n  }\n\n  public get scriptDomain() {\n    return this._config.providers.googleTagManager?.scriptDomain;\n  }\n\n  private _mapPurchaseEventData(value: PurchaseEvent) {\n    return {\n      ecommerce: {\n        transaction_id: value.transactionId,\n        value: value.total,\n        tax: value.tax,\n        shipping: value.shipping,\n        currency: value.currency,\n        items: this._mapItems(value.items),\n      }\n    }\n  }\n\n  private _mapBeginCheckoutEventData(value: BeginCheckoutEvent) {\n    return {\n      ecommerce: {\n        value: value.total,\n        currency: value.currency,\n        items: this._mapItems(value.items),\n      }\n    }\n  }\n\n  private _mapAddToCartEventData(value: AddToCartEvent) {\n    return {\n      ecommerce: {\n        value: value.total,\n        currency: value.currency,\n        items: this._mapItems(value.items),\n      }\n    }\n  }\n\n  private _mapRemoveFromCartEventData(value: RemoveFromCartEvent) {\n    return {\n      ecommerce: {\n        value: value.total,\n        currency: value.currency,\n        items: this._mapItems(value.items),\n      }\n    }\n  }\n\n  private _mapAddPaymentEventData(value: AppPaymentEvent) {\n    return {\n      ecommerce: {\n        value: value.total,\n        currency: value.currency,\n        payment_type: value.paymentType,\n        items: this._mapItems(value.items),\n      }\n    }\n  }\n\n  private _mapItems(items: Item[]) {\n    return items\n      .map((item) => ({\n        item_id: item.id,\n        item_name: item.name,\n        price: item.price || 0,\n        quantity: item.quantity || 1,\n        item_category: item.category,\n        item_category2: item.category2,\n      }));\n  }\n\n  private _mapTypeEvent(type: EventType) {\n    if (type === EventType.Purcahse) {\n      return 'purchase';\n    } else if (type === EventType.BeginCheckout) {\n      return 'begin_checkout';\n    } else if (type === EventType.AddPayment) {\n      return 'add_payment_info';\n    } else if (type === EventType.AddToCart) {\n      return 'add_to_cart';\n    } else if (type === EventType.RemoveFromCart) {\n      return 'remove_from_cart';\n    }\n\n    return type;\n  }\n\n  private _mapEventData(type: EventType, value, options) {\n    if (type === EventType.Purcahse) {\n      return this._mapPurchaseEventData(value);\n    } else if (type === EventType.BeginCheckout) {\n      return this._mapBeginCheckoutEventData(value);\n    } else if (type === EventType.AddPayment) {\n      return this._mapAddPaymentEventData(value);\n    } else if (type === EventType.AddToCart) {\n      return this._mapAddToCartEventData(value);\n    } else if (type === EventType.RemoveFromCart) {\n      return this._mapRemoveFromCartEventData(value);\n    }\n\n    return {\n      value,\n      category: options?.category,\n      label: options?.label,\n    } as any;\n  }\n}"]} | ||
//# sourceMappingURL=data:application/json;base64,{"version":3,"file":"google-tag-manager.js","sourceRoot":"","sources":["../../../../src/app/providers/google-tag-manager.ts"],"names":[],"mappings":"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","sourcesContent":["import { Provider } from \"./provider\";\n\nimport { BehaviorSubject, from, interval } from \"rxjs\";\nimport { filter, switchMap, take, takeWhile } from \"rxjs/operators\";\nimport { EventType } from \"../enums\";\nimport { AddToCartEvent, AppPaymentEvent, BeginCheckoutEvent, Item, PurchaseEvent, RemoveFromCartEvent } from \"../interfaces\";\n\n\nexport class GoogleTagManagerProvider extends Provider {\n\n  private _initData = [];\n  private _init$ = new BehaviorSubject<boolean>(false);\n\n  public init() {\n    if (this.containerId) {\n      const scriptDomain = this.scriptDomain || 'www.googletagmanager.com';\n      from(this.addScript(`https://${scriptDomain}/gtm.js?id=${this.containerId}`))\n        .pipe(\n          switchMap(() => interval(10)),\n          take(50),\n          takeWhile(() => !this._init$.getValue()),\n          filter(() => {\n            return this.window.dataLayer.some((item) => item.event === 'gtm.load');\n          })\n        )\n        .subscribe(() => {\n          this._init$.next(true);\n          this._init$.complete();\n          this._initData.forEach((data) => {\n            this.window.dataLayer.push(data);\n          });\n        });\n\n      this.window.dataLayer = this.window.dataLayer || [];\n\n      this.pushData('js', new Date());\n      this.pushData('config', this.containerId, { path_path: this._router.url });\n    }\n  }\n\n\n  public pushData(...data: any): void {\n    this.window.dataLayer.push(data);\n  }\n\n  public trackPage(path: string): void {\n    this.trackEvent('pageview', {\n      page: {\n        path,\n      }\n    });\n  }\n\n  public trackEvent(type: any, value?, options?): void {\n    const mapping = this._getMapping(type);\n    const data = mapping.transform ?\n      mapping.transform(mapping.type, value) : {\n        event: type,\n        value,\n        category: options?.category,\n        label: options?.label,\n      } as any;\n\n    const dataLayer = this._init$.getValue() ?\n      this.window.dataLayer :\n      this._initData;\n\n    if (mapping.ecommerce) {\n      dataLayer.push({ ecommerce: null });\n    }\n\n    dataLayer.push(data);\n  }\n\n  public setUser(data) { }\n\n  public get containerId() {\n    return this._config.providers.googleTagManager?.containerId;\n  }\n\n  public get scriptDomain() {\n    return this._config.providers.googleTagManager?.scriptDomain;\n  }\n\n  private _mapPurchaseEventData(event: string, value: PurchaseEvent) {\n    return {\n      event,\n      ecommerce: {\n        transaction_id: value.transactionId,\n        value: value.total,\n        tax: value.tax,\n        shipping: value.shipping,\n        currency: value.currency,\n        items: this._mapItems(value.items),\n      }\n    }\n  }\n\n  private _mapBeginCheckoutEventData(event: string, value: BeginCheckoutEvent) {\n    return {\n      event,\n      ecommerce: {\n        value: value.total,\n        currency: value.currency,\n        items: this._mapItems(value.items),\n      }\n    }\n  }\n\n  private _mapAddToCartEventData(event: string, value: AddToCartEvent) {\n    return {\n      event,\n      ecommerce: {\n        value: value.total,\n        currency: value.currency,\n        items: this._mapItems(value.items),\n      }\n    }\n  }\n\n  private _mapRemoveFromCartEventData(event: string, value: RemoveFromCartEvent) {\n    return {\n      event,\n      ecommerce: {\n        value: value.total,\n        currency: value.currency,\n        items: this._mapItems(value.items),\n      }\n    }\n  }\n\n  private _mapAddPaymentEventData(event: string, value: AppPaymentEvent) {\n    return {\n      event,\n      ecommerce: {\n        value: value.total,\n        currency: value.currency,\n        payment_type: value.paymentType,\n        items: this._mapItems(value.items),\n      }\n    }\n  }\n\n  private _mapItems(items: Item[]) {\n    return items\n      .map((item) => ({\n        item_id: item.id,\n        item_name: item.name,\n        price: item.price || 0,\n        quantity: item.quantity || 1,\n        item_category: item.category,\n        item_category2: item.category2,\n      }));\n  }\n\n  private _getMapping(type: EventType | string): { type: string, transform: (event: string, value: any) => any, ecommerce: boolean } {\n    let transform: (event: string, value: any) => any;\n    if (type === EventType.Purcahse) {\n      type = 'purchase';\n      transform = (event: string, value: any) => this._mapPurchaseEventData(event, value);\n    } else if (type === EventType.BeginCheckout) {\n      type = 'begin_checkout';\n      transform = (event: string, value: any) => this._mapBeginCheckoutEventData(event, value);\n    } else if (type === EventType.AddPayment) {\n      type = 'add_payment_info';\n      transform = (event: string, value: any) => this._mapAddPaymentEventData(event, value);\n    } else if (type === EventType.AddToCart) {\n      type = 'add_to_cart';\n      transform = (event: string, value: any) => this._mapAddToCartEventData(event, value);\n    } else if (type === EventType.RemoveFromCart) {\n      type = 'remove_from_cart';\n      transform = (event: string, value: any) => this._mapRemoveFromCartEventData(event, value);\n    }\n\n    return { type, transform, ecommerce: !!transform };\n  }\n}"]} |
@@ -34,2 +34,2 @@ import { NavigationEnd } from "@angular/router"; | ||
} | ||
//# sourceMappingURL=data:application/json;base64,eyJ2ZXJzaW9uIjozLCJmaWxlIjoicHJvdmlkZXIuanMiLCJzb3VyY2VSb290IjoiIiwic291cmNlcyI6WyIuLi8uLi8uLi8uLi9zcmMvYXBwL3Byb3ZpZGVycy9wcm92aWRlci50cyJdLCJuYW1lcyI6W10sIm1hcHBpbmdzIjoiQUFDQSxPQUFPLEVBQUUsYUFBYSxFQUFVLE1BQU0saUJBQWlCLENBQUM7QUFFeEQsT0FBTyxFQUFFLE1BQU0sRUFBRSxJQUFJLEVBQUUsTUFBTSxnQkFBZ0IsQ0FBQztBQUk5QyxNQUFNLE9BQWdCLFFBQVE7SUFhNUIsWUFDWSxTQUFtQixFQUNuQixPQUEwQixFQUMxQixPQUFlO1FBRmYsY0FBUyxHQUFULFNBQVMsQ0FBVTtRQUNuQixZQUFPLEdBQVAsT0FBTyxDQUFtQjtRQUMxQixZQUFPLEdBQVAsT0FBTyxDQUFRO1FBRXpCLElBQUksQ0FBQyxPQUFPLENBQUMsTUFBTSxDQUFDLElBQUksQ0FDdEIsSUFBSSxDQUFDLENBQUMsQ0FBQyxFQUNQLE1BQU0sQ0FBQyxLQUFLLENBQUMsRUFBRSxDQUFDLEtBQUssWUFBWSxhQUFhLENBQUMsQ0FDaEQ7YUFDRSxTQUFTLENBQUMsQ0FBQyxLQUFvQixFQUFFLEVBQUU7WUFDbEMsSUFBSSxDQUFDLFNBQVMsQ0FBQyxLQUFLLENBQUMsaUJBQWlCLENBQUMsQ0FBQztRQUMxQyxDQUFDLENBQUMsQ0FBQztJQUNQLENBQUM7SUFFRCxJQUFXLE1BQU07UUFDZixPQUFRLE1BQWMsQ0FBQztJQUN6QixDQUFDO0lBRU0sU0FBUyxDQUFDLEdBQUc7UUFDbEIsT0FBTyxJQUFJLE9BQU8sQ0FBQyxDQUFDLE9BQU8sRUFBRSxLQUFLLEVBQUUsRUFBRTtZQUNwQyxJQUFJLE1BQU0sR0FBRyxRQUFRLENBQUMsYUFBYSxDQUFDLFFBQVEsQ0FBQyxDQUFDO1lBQzlDLE1BQU0sQ0FBQyxHQUFHLEdBQUcsR0FBRyxDQUFDO1lBQ2pCLE1BQU0sQ0FBQyxZQUFZLENBQUMsT0FBTyxFQUFFLEVBQUUsQ0FBQyxDQUFDO1lBRWpDLE1BQU0sQ0FBQyxNQUFNLEdBQUcsR0FBRyxFQUFFO2dCQUNuQixPQUFPLEVBQUUsQ0FBQztZQUNaLENBQUMsQ0FBQztZQUVGLE1BQU0sQ0FBQyxPQUFPLEdBQUcsR0FBRyxFQUFFO2dCQUNwQixLQUFLLEVBQUUsQ0FBQztZQUNWLENBQUMsQ0FBQztZQUVGLElBQUksQ0FBQyxVQUFVLENBQUMsTUFBTSxDQUFDLENBQUM7UUFDMUIsQ0FBQyxDQUFDLENBQUM7SUFDTCxDQUFDO0lBRU0sVUFBVSxDQUFDLEVBQUU7UUFDbEIsUUFBUSxDQUFDLG9CQUFvQixDQUFDLE1BQU0sQ0FBQyxDQUFDLENBQUMsQ0FBQyxDQUFDLFdBQVcsQ0FBQyxFQUFFLENBQUMsQ0FBQztJQUMzRCxDQUFDO0NBQ0YiLCJzb3VyY2VzQ29udGVudCI6WyJpbXBvcnQgeyBJbmplY3RvciB9IGZyb20gXCJAYW5ndWxhci9jb3JlXCI7XG5pbXBvcnQgeyBOYXZpZ2F0aW9uRW5kLCBSb3V0ZXIgfSBmcm9tIFwiQGFuZ3VsYXIvcm91dGVyXCI7XG5cbmltcG9ydCB7IGZpbHRlciwgc2tpcCB9IGZyb20gXCJyeGpzL29wZXJhdG9yc1wiO1xuaW1wb3J0IHsgRnNBbmFseXRpY3NDb25maWcgfSBmcm9tIFwiLi4vaW50ZXJmYWNlcy9hbmFseXRpY3MtY29uZmlnXCI7XG5cblxuZXhwb3J0IGFic3RyYWN0IGNsYXNzIFByb3ZpZGVyIHtcblxuICBwdWJsaWMgYWJzdHJhY3QgaW5pdCgpOiB2b2lkO1xuICBwdWJsaWMgYWJzdHJhY3QgdHJhY2tFdmVudCh0eXBlOiBzdHJpbmcsIHZhbHVlPywgY2F0Z2Vnb3J5PywgbGFiZWw/KTogdm9pZDtcbiAgcHVibGljIGFic3RyYWN0IHRyYWNrUGFnZShwYXRoKTogdm9pZDtcbiAgcHVibGljIGFic3RyYWN0IHNldFVzZXIoZGF0YToge1xuICAgIG5hbWU/OiBzdHJpbmcsXG4gICAgZmlyc3ROYW1lPzogc3RyaW5nLFxuICAgIGxhc3ROYW1lPzogc3RyaW5nLFxuICAgIGVtYWlsPzogc3RyaW5nLFxuICAgIGlkPzogc3RyaW5nLFxuICB9KTogdm9pZDtcblxuICBwdWJsaWMgY29uc3RydWN0b3IoXG4gICAgcHJvdGVjdGVkIF9pbmplY3RvcjogSW5qZWN0b3IsXG4gICAgcHJvdGVjdGVkIF9jb25maWc6IEZzQW5hbHl0aWNzQ29uZmlnLFxuICAgIHByb3RlY3RlZCBfcm91dGVyOiBSb3V0ZXIsXG4gICkge1xuICAgIHRoaXMuX3JvdXRlci5ldmVudHMucGlwZShcbiAgICAgIHNraXAoMSksXG4gICAgICBmaWx0ZXIoZXZlbnQgPT4gZXZlbnQgaW5zdGFuY2VvZiBOYXZpZ2F0aW9uRW5kKVxuICAgIClcbiAgICAgIC5zdWJzY3JpYmUoKGV2ZW50OiBOYXZpZ2F0aW9uRW5kKSA9PiB7XG4gICAgICAgIHRoaXMudHJhY2tQYWdlKGV2ZW50LnVybEFmdGVyUmVkaXJlY3RzKTtcbiAgICAgIH0pO1xuICB9XG5cbiAgcHVibGljIGdldCB3aW5kb3coKSB7XG4gICAgcmV0dXJuICh3aW5kb3cgYXMgYW55KTtcbiAgfVxuXG4gIHB1YmxpYyBhZGRTY3JpcHQoc3JjKTogUHJvbWlzZTx2b2lkPiB7XG4gICAgcmV0dXJuIG5ldyBQcm9taXNlKChyZXNvbHZlLCBlcnJvcikgPT4ge1xuICAgICAgdmFyIHNjcmlwdCA9IGRvY3VtZW50LmNyZWF0ZUVsZW1lbnQoJ3NjcmlwdCcpO1xuICAgICAgc2NyaXB0LnNyYyA9IHNyYztcbiAgICAgIHNjcmlwdC5zZXRBdHRyaWJ1dGUoJ2FzeW5jJywgJycpO1xuXG4gICAgICBzY3JpcHQub25sb2FkID0gKCkgPT4ge1xuICAgICAgICByZXNvbHZlKCk7XG4gICAgICB9O1xuXG4gICAgICBzY3JpcHQub25lcnJvciA9ICgpID0+IHtcbiAgICAgICAgZXJyb3IoKTtcbiAgICAgIH07XG5cbiAgICAgIHRoaXMuYXBwZW5kSGVhZChzY3JpcHQpO1xuICAgIH0pO1xuICB9XG5cbiAgcHVibGljIGFwcGVuZEhlYWQoZWwpIHtcbiAgICBkb2N1bWVudC5nZXRFbGVtZW50c0J5VGFnTmFtZSgnaGVhZCcpWzBdLmFwcGVuZENoaWxkKGVsKTtcbiAgfVxufSJdfQ== | ||
//# sourceMappingURL=data:application/json;base64,eyJ2ZXJzaW9uIjozLCJmaWxlIjoicHJvdmlkZXIuanMiLCJzb3VyY2VSb290IjoiIiwic291cmNlcyI6WyIuLi8uLi8uLi8uLi9zcmMvYXBwL3Byb3ZpZGVycy9wcm92aWRlci50cyJdLCJuYW1lcyI6W10sIm1hcHBpbmdzIjoiQUFDQSxPQUFPLEVBQUUsYUFBYSxFQUFVLE1BQU0saUJBQWlCLENBQUM7QUFFeEQsT0FBTyxFQUFFLE1BQU0sRUFBRSxJQUFJLEVBQUUsTUFBTSxnQkFBZ0IsQ0FBQztBQUk5QyxNQUFNLE9BQWdCLFFBQVE7SUFhNUIsWUFDWSxTQUFtQixFQUNuQixPQUEwQixFQUMxQixPQUFlO1FBRmYsY0FBUyxHQUFULFNBQVMsQ0FBVTtRQUNuQixZQUFPLEdBQVAsT0FBTyxDQUFtQjtRQUMxQixZQUFPLEdBQVAsT0FBTyxDQUFRO1FBRXpCLElBQUksQ0FBQyxPQUFPLENBQUMsTUFBTSxDQUFDLElBQUksQ0FDdEIsSUFBSSxDQUFDLENBQUMsQ0FBQyxFQUNQLE1BQU0sQ0FBQyxLQUFLLENBQUMsRUFBRSxDQUFDLEtBQUssWUFBWSxhQUFhLENBQUMsQ0FDaEQ7YUFDRSxTQUFTLENBQUMsQ0FBQyxLQUFvQixFQUFFLEVBQUU7WUFDbEMsSUFBSSxDQUFDLFNBQVMsQ0FBQyxLQUFLLENBQUMsaUJBQWlCLENBQUMsQ0FBQztRQUMxQyxDQUFDLENBQUMsQ0FBQztJQUNQLENBQUM7SUFFRCxJQUFXLE1BQU07UUFDZixPQUFRLE1BQWMsQ0FBQztJQUN6QixDQUFDO0lBRU0sU0FBUyxDQUFDLEdBQUc7UUFDbEIsT0FBTyxJQUFJLE9BQU8sQ0FBQyxDQUFDLE9BQU8sRUFBRSxLQUFLLEVBQUUsRUFBRTtZQUNwQyxJQUFJLE1BQU0sR0FBRyxRQUFRLENBQUMsYUFBYSxDQUFDLFFBQVEsQ0FBQyxDQUFDO1lBQzlDLE1BQU0sQ0FBQyxHQUFHLEdBQUcsR0FBRyxDQUFDO1lBQ2pCLE1BQU0sQ0FBQyxZQUFZLENBQUMsT0FBTyxFQUFFLEVBQUUsQ0FBQyxDQUFDO1lBQ2pDLE1BQU0sQ0FBQyxNQUFNLEdBQUcsR0FBRyxFQUFFO2dCQUNuQixPQUFPLEVBQUUsQ0FBQztZQUNaLENBQUMsQ0FBQztZQUVGLE1BQU0sQ0FBQyxPQUFPLEdBQUcsR0FBRyxFQUFFO2dCQUNwQixLQUFLLEVBQUUsQ0FBQztZQUNWLENBQUMsQ0FBQztZQUVGLElBQUksQ0FBQyxVQUFVLENBQUMsTUFBTSxDQUFDLENBQUM7UUFDMUIsQ0FBQyxDQUFDLENBQUM7SUFDTCxDQUFDO0lBRU0sVUFBVSxDQUFDLEVBQUU7UUFDbEIsUUFBUSxDQUFDLG9CQUFvQixDQUFDLE1BQU0sQ0FBQyxDQUFDLENBQUMsQ0FBQyxDQUFDLFdBQVcsQ0FBQyxFQUFFLENBQUMsQ0FBQztJQUMzRCxDQUFDO0NBQ0YiLCJzb3VyY2VzQ29udGVudCI6WyJpbXBvcnQgeyBJbmplY3RvciB9IGZyb20gXCJAYW5ndWxhci9jb3JlXCI7XG5pbXBvcnQgeyBOYXZpZ2F0aW9uRW5kLCBSb3V0ZXIgfSBmcm9tIFwiQGFuZ3VsYXIvcm91dGVyXCI7XG5cbmltcG9ydCB7IGZpbHRlciwgc2tpcCB9IGZyb20gXCJyeGpzL29wZXJhdG9yc1wiO1xuaW1wb3J0IHsgRnNBbmFseXRpY3NDb25maWcgfSBmcm9tIFwiLi4vaW50ZXJmYWNlcy9hbmFseXRpY3MtY29uZmlnXCI7XG5cblxuZXhwb3J0IGFic3RyYWN0IGNsYXNzIFByb3ZpZGVyIHtcblxuICBwdWJsaWMgYWJzdHJhY3QgaW5pdCgpOiB2b2lkO1xuICBwdWJsaWMgYWJzdHJhY3QgdHJhY2tFdmVudCh0eXBlOiBzdHJpbmcsIHZhbHVlPywgY2F0Z2Vnb3J5PywgbGFiZWw/KTogdm9pZDtcbiAgcHVibGljIGFic3RyYWN0IHRyYWNrUGFnZShwYXRoKTogdm9pZDtcbiAgcHVibGljIGFic3RyYWN0IHNldFVzZXIoZGF0YToge1xuICAgIG5hbWU/OiBzdHJpbmcsXG4gICAgZmlyc3ROYW1lPzogc3RyaW5nLFxuICAgIGxhc3ROYW1lPzogc3RyaW5nLFxuICAgIGVtYWlsPzogc3RyaW5nLFxuICAgIGlkPzogc3RyaW5nLFxuICB9KTogdm9pZDtcblxuICBwdWJsaWMgY29uc3RydWN0b3IoXG4gICAgcHJvdGVjdGVkIF9pbmplY3RvcjogSW5qZWN0b3IsXG4gICAgcHJvdGVjdGVkIF9jb25maWc6IEZzQW5hbHl0aWNzQ29uZmlnLFxuICAgIHByb3RlY3RlZCBfcm91dGVyOiBSb3V0ZXIsXG4gICkge1xuICAgIHRoaXMuX3JvdXRlci5ldmVudHMucGlwZShcbiAgICAgIHNraXAoMSksXG4gICAgICBmaWx0ZXIoZXZlbnQgPT4gZXZlbnQgaW5zdGFuY2VvZiBOYXZpZ2F0aW9uRW5kKVxuICAgIClcbiAgICAgIC5zdWJzY3JpYmUoKGV2ZW50OiBOYXZpZ2F0aW9uRW5kKSA9PiB7XG4gICAgICAgIHRoaXMudHJhY2tQYWdlKGV2ZW50LnVybEFmdGVyUmVkaXJlY3RzKTtcbiAgICAgIH0pO1xuICB9XG5cbiAgcHVibGljIGdldCB3aW5kb3coKSB7XG4gICAgcmV0dXJuICh3aW5kb3cgYXMgYW55KTtcbiAgfVxuXG4gIHB1YmxpYyBhZGRTY3JpcHQoc3JjKTogUHJvbWlzZTx2b2lkPiB7XG4gICAgcmV0dXJuIG5ldyBQcm9taXNlKChyZXNvbHZlLCBlcnJvcikgPT4ge1xuICAgICAgdmFyIHNjcmlwdCA9IGRvY3VtZW50LmNyZWF0ZUVsZW1lbnQoJ3NjcmlwdCcpO1xuICAgICAgc2NyaXB0LnNyYyA9IHNyYztcbiAgICAgIHNjcmlwdC5zZXRBdHRyaWJ1dGUoJ2FzeW5jJywgJycpO1xuICAgICAgc2NyaXB0Lm9ubG9hZCA9ICgpID0+IHtcbiAgICAgICAgcmVzb2x2ZSgpO1xuICAgICAgfTtcblxuICAgICAgc2NyaXB0Lm9uZXJyb3IgPSAoKSA9PiB7XG4gICAgICAgIGVycm9yKCk7XG4gICAgICB9O1xuXG4gICAgICB0aGlzLmFwcGVuZEhlYWQoc2NyaXB0KTtcbiAgICB9KTtcbiAgfVxuXG4gIHB1YmxpYyBhcHBlbmRIZWFkKGVsKSB7XG4gICAgZG9jdW1lbnQuZ2V0RWxlbWVudHNCeVRhZ05hbWUoJ2hlYWQnKVswXS5hcHBlbmRDaGlsZChlbCk7XG4gIH1cbn0iXX0= |
import * as i0 from '@angular/core'; | ||
import { InjectionToken, Injectable, Inject, Directive, Input, NgModule } from '@angular/core'; | ||
import { of, Subject, fromEvent } from 'rxjs'; | ||
import { skip, filter, take, takeUntil } from 'rxjs/operators'; | ||
import { BehaviorSubject, from, interval, of, Subject, fromEvent } from 'rxjs'; | ||
import { skip, filter, switchMap, take, takeWhile, takeUntil } from 'rxjs/operators'; | ||
import * as i1 from '@angular/router'; | ||
@@ -171,6 +171,21 @@ import { NavigationEnd } from '@angular/router'; | ||
class GoogleTagManagerProvider extends Provider { | ||
constructor() { | ||
super(...arguments); | ||
this._initData = []; | ||
this._init$ = new BehaviorSubject(false); | ||
} | ||
init() { | ||
if (this.containerId) { | ||
const scriptDomain = this.scriptDomain || 'www.googletagmanager.com'; | ||
this.addScript(`https://${scriptDomain}/gtm.js?id=${this.containerId}`); | ||
from(this.addScript(`https://${scriptDomain}/gtm.js?id=${this.containerId}`)) | ||
.pipe(switchMap(() => interval(10)), take(50), takeWhile(() => !this._init$.getValue()), filter(() => { | ||
return this.window.dataLayer.some((item) => item.event === 'gtm.load'); | ||
})) | ||
.subscribe(() => { | ||
this._init$.next(true); | ||
this._init$.complete(); | ||
this._initData.forEach((data) => { | ||
this.window.dataLayer.push(data); | ||
}); | ||
}); | ||
this.window.dataLayer = this.window.dataLayer || []; | ||
@@ -192,6 +207,17 @@ this.pushData('js', new Date()); | ||
trackEvent(type, value, options) { | ||
const data = this._mapEventData(type, value, options); | ||
const event = this._mapTypeEvent(type); | ||
this.window.dataLayer.push({ ecommerce: null }); | ||
this.window.dataLayer.push(Object.assign({ event }, data)); | ||
const mapping = this._getMapping(type); | ||
const data = mapping.transform ? | ||
mapping.transform(mapping.type, value) : { | ||
event: type, | ||
value, | ||
category: options === null || options === void 0 ? void 0 : options.category, | ||
label: options === null || options === void 0 ? void 0 : options.label, | ||
}; | ||
const dataLayer = this._init$.getValue() ? | ||
this.window.dataLayer : | ||
this._initData; | ||
if (mapping.ecommerce) { | ||
dataLayer.push({ ecommerce: null }); | ||
} | ||
dataLayer.push(data); | ||
} | ||
@@ -207,4 +233,5 @@ setUser(data) { } | ||
} | ||
_mapPurchaseEventData(value) { | ||
_mapPurchaseEventData(event, value) { | ||
return { | ||
event, | ||
ecommerce: { | ||
@@ -220,4 +247,5 @@ transaction_id: value.transactionId, | ||
} | ||
_mapBeginCheckoutEventData(value) { | ||
_mapBeginCheckoutEventData(event, value) { | ||
return { | ||
event, | ||
ecommerce: { | ||
@@ -230,4 +258,5 @@ value: value.total, | ||
} | ||
_mapAddToCartEventData(value) { | ||
_mapAddToCartEventData(event, value) { | ||
return { | ||
event, | ||
ecommerce: { | ||
@@ -240,4 +269,5 @@ value: value.total, | ||
} | ||
_mapRemoveFromCartEventData(value) { | ||
_mapRemoveFromCartEventData(event, value) { | ||
return { | ||
event, | ||
ecommerce: { | ||
@@ -250,4 +280,5 @@ value: value.total, | ||
} | ||
_mapAddPaymentEventData(value) { | ||
_mapAddPaymentEventData(event, value) { | ||
return { | ||
event, | ||
ecommerce: { | ||
@@ -272,42 +303,26 @@ value: value.total, | ||
} | ||
_mapTypeEvent(type) { | ||
_getMapping(type) { | ||
let transform; | ||
if (type === EventType.Purcahse) { | ||
return 'purchase'; | ||
type = 'purchase'; | ||
transform = (event, value) => this._mapPurchaseEventData(event, value); | ||
} | ||
else if (type === EventType.BeginCheckout) { | ||
return 'begin_checkout'; | ||
type = 'begin_checkout'; | ||
transform = (event, value) => this._mapBeginCheckoutEventData(event, value); | ||
} | ||
else if (type === EventType.AddPayment) { | ||
return 'add_payment_info'; | ||
type = 'add_payment_info'; | ||
transform = (event, value) => this._mapAddPaymentEventData(event, value); | ||
} | ||
else if (type === EventType.AddToCart) { | ||
return 'add_to_cart'; | ||
type = 'add_to_cart'; | ||
transform = (event, value) => this._mapAddToCartEventData(event, value); | ||
} | ||
else if (type === EventType.RemoveFromCart) { | ||
return 'remove_from_cart'; | ||
type = 'remove_from_cart'; | ||
transform = (event, value) => this._mapRemoveFromCartEventData(event, value); | ||
} | ||
return type; | ||
return { type, transform, ecommerce: !!transform }; | ||
} | ||
_mapEventData(type, value, options) { | ||
if (type === EventType.Purcahse) { | ||
return this._mapPurchaseEventData(value); | ||
} | ||
else if (type === EventType.BeginCheckout) { | ||
return this._mapBeginCheckoutEventData(value); | ||
} | ||
else if (type === EventType.AddPayment) { | ||
return this._mapAddPaymentEventData(value); | ||
} | ||
else if (type === EventType.AddToCart) { | ||
return this._mapAddToCartEventData(value); | ||
} | ||
else if (type === EventType.RemoveFromCart) { | ||
return this._mapRemoveFromCartEventData(value); | ||
} | ||
return { | ||
value, | ||
category: options === null || options === void 0 ? void 0 : options.category, | ||
label: options === null || options === void 0 ? void 0 : options.label, | ||
}; | ||
} | ||
} | ||
@@ -314,0 +329,0 @@ |
{ | ||
"name": "@firestitch/analytics", | ||
"version": "12.3.9", | ||
"version": "12.3.10", | ||
"repository": { | ||
@@ -5,0 +5,0 @@ "type": "git", |
Sorry, the diff of this file is not supported yet
Sorry, the diff of this file is not supported yet
License Policy Violation
LicenseThis package is not allowed per your license policy. Review the package's license to ensure compliance.
Found 1 instance in 1 package
License Policy Violation
LicenseThis package is not allowed per your license policy. Review the package's license to ensure compliance.
Found 1 instance in 1 package
256673
2211