Comparing version 1.0.0 to 1.0.1
@@ -135,3 +135,3 @@ (function (global, factory) { | ||
.pipe(operators.filter(function (event) { return event instanceof i1.NavigationEnd; }), operators.map(function () { return _this.route; }), operators.map(function (route) { return route.firstChild; }), operators.switchMap(function (route) { return route.data; }), operators.map(function (data) { return lodash.get(data, 'title', _this.options.appName); }), operators.tap(function (title) { | ||
_this.trackPageView({ title: title }); | ||
_this.trackPageView({ page_title: title }); | ||
})) | ||
@@ -229,2 +229,2 @@ .subscribe(); | ||
//# sourceMappingURL=data:application/json;charset=utf-8;base64,{"version":3,"file":"nwx-gtag.umd.js.map","sources":["ng://@nwx/gtag/src/gtag.types.ts","ng://@nwx/gtag/src/gtag.defaults.ts","ng://@nwx/gtag/src/gtag.module.ts","ng://@nwx/gtag/src/gtag.service.ts"],"sourcesContent":["/**\n * @license\n * Copyright Neekware Inc. All Rights Reserved.\n *\n * Use of this source code is governed by an MIT-style license that can be\n * found in the LICENSE file at http://neekware.com/license/MIT.html\n */\n\nexport class GtagCfg {\n  // google tracking id (UA-XXXXX-Y)\n  trackingId: string;\n  // track page view on start\n  autoPageTrack?: boolean;\n  // tracking gtag.js URL\n  gtagUrl?: string;\n  // more optional parameters\n  [key: string]: any;\n}\n\n// https://developers.google.com/analytics/devguides/collection/gtagjs/pages\nexport class GtagPageViewParams {\n  // title of the page\n  page_title?: string;\n  // uri portion of the page location starting with /\n  page_path?: string;\n  // page_location\tstring\tNo\tThe page's URL.\n  page_location?: string;\n  // more optional future parameters\n  [key: string]: any;\n}\n\n// https://developers.google.com/analytics/devguides/collection/gtagjs/events\nexport interface GtagEventParams {\n  event_category?: string;\n  event_label?: string;\n  value?: any;\n  [key: string]: any;\n}\n","/**\n * @license\n * Copyright Neekware Inc. All Rights Reserved.\n *\n * Use of this source code is governed by an MIT-style license that can be\n * found in the LICENSE file at http://neekware.com/license/MIT.html\n */\n\nimport { GtagCfg } from './gtag.types';\n\nexport const DefaultGtagCfg: GtagCfg = {\n  // google tracking id (UA-XXXXX-Y)\n  trackingId: null,\n  // track page view on start\n  autoPageTrack: false,\n  // gtag.js url\n  gtagUrl: 'https://www.googletagmanager.com/gtag/js'\n};\n","/**\n * @license\n * Copyright Neekware Inc. All Rights Reserved.\n *\n * Use of this source code is governed by an MIT-style license that can be\n * found in the LICENSE file at http://neekware.com/license/MIT.html\n */\n\nimport { NgModule, Optional, SkipSelf } from '@angular/core';\nimport { CommonModule } from '@angular/common';\n\nimport { GtagService } from './gtag.service';\n\n@NgModule({\n  imports: [CommonModule]\n})\nexport class GtagModule {\n  /**\n   * Constructor - Ensures a singleton copy\n   * @param parentModule parent module that imports the module\n   */\n  constructor(\n    @Optional()\n    @SkipSelf()\n    parentModule: GtagModule\n  ) {\n    if (parentModule) {\n      throw new Error('GtagModule is already loaded. Import it in the AppModule only');\n    }\n  }\n}\n","/**\n * @license\n * Copyright Neekware Inc. All Rights Reserved.\n *\n * Use of this source code is governed by an MIT-style license that can be\n * found in the LICENSE file at http://neekware.com/license/MIT.html\n */\n\nimport { Injectable } from '@angular/core';\nimport { Router, NavigationEnd, ActivatedRoute } from '@angular/router';\n\nimport { get, merge } from 'lodash';\nimport { tap, filter, map, switchMap } from 'rxjs/operators';\nimport { CfgService, AppCfg } from '@nwx/cfg';\nimport { LogService } from '@nwx/logger';\n\nimport { DefaultGtagCfg } from './gtag.defaults';\nimport { GtagModule } from './gtag.module';\nimport { GtagPageViewParams, GtagEventParams } from './gtag.types';\n\ndeclare var gtag: Function;\n\n@Injectable({\n  providedIn: 'root'\n})\nexport class GtagService {\n  options: AppCfg = null;\n\n  constructor(\n    private router: Router,\n    private route: ActivatedRoute,\n    private cfg: CfgService,\n    private log: LogService\n  ) {\n    this.options = merge({ gtag: DefaultGtagCfg }, this.cfg.options);\n    if (this.options.gtag.trackingId) {\n      this.loadScript();\n      this.initScript();\n      this.log.debug(`GtagService ready ... (${this.options.gtag.trackingId})`);\n      if (this.options.gtag.autoPageTrack) {\n        this.enablePageView();\n      }\n    }\n  }\n\n  private initScript() {\n    const id = this.options.gtag.trackingId;\n    const enabled = this.options.gtag.autoPageTrack;\n    const tag = `\n      window.dataLayer = window.dataLayer || [];\n      function gtag(){dataLayer.push(arguments);}\n      gtag('js', new Date());\n      gtag('config', '${id}', { 'send_page_view': ${enabled} });\n    `;\n    const elNode = Object.assign(document.createElement('script'), {\n      text: tag\n    });\n    document.body.appendChild(elNode);\n  }\n\n  private loadScript() {\n    const url = `${this.options.gtag.gtagUrl}?id=${this.options.gtag.trackingId}`;\n    if (!document.querySelectorAll(`[src=\"${url}\"]`).length) {\n      const elNode = Object.assign(document.createElement('script'), {\n        type: 'text/javascript',\n        src: url,\n        async: true\n      });\n      document.body.appendChild(elNode);\n    }\n  }\n\n  private enablePageView() {\n    this.router.events\n      .pipe(\n        filter(event => event instanceof NavigationEnd),\n        map(() => this.route),\n        map(route => route.firstChild),\n        switchMap(route => route.data),\n        map(data => get(data, 'title', this.options.appName)),\n        tap(title => {\n          this.trackPageView({ title });\n        })\n      )\n      .subscribe();\n  }\n\n  trackPageView(params?: GtagPageViewParams) {\n    params = {\n      ...{\n        page_path: this.router.url,\n        page_location: window.location.href,\n        page_title: this.options.appName\n      },\n      ...params\n    };\n    if (typeof gtag === 'function') {\n      try {\n        gtag('config', this.options.gtag.trackingId, params);\n      } catch (err) {\n        this.log.error('Failed to track page view', err);\n      }\n    } else {\n      this.log.debug('skip page track. gtag not ready yet ...');\n    }\n  }\n\n  trackEvent(name: string, params: GtagEventParams = {}) {\n    if (typeof gtag === 'function') {\n      try {\n        gtag('event', name, params);\n      } catch (err) {\n        console.error('Failed to track event', err);\n      }\n    } else {\n      this.log.debug('skip event track. gtag not ready yet ...');\n    }\n  }\n}\n"],"names":["NgModule","CommonModule","Optional","SkipSelf","merge","filter","NavigationEnd","map","switchMap","get","tap","Injectable","Router","ActivatedRoute","CfgService","LogService"],"mappings":"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"} | ||
//# sourceMappingURL=data:application/json;charset=utf-8;base64,{"version":3,"file":"nwx-gtag.umd.js.map","sources":["ng://@nwx/gtag/src/gtag.types.ts","ng://@nwx/gtag/src/gtag.defaults.ts","ng://@nwx/gtag/src/gtag.module.ts","ng://@nwx/gtag/src/gtag.service.ts"],"sourcesContent":["/**\n * @license\n * Copyright Neekware Inc. All Rights Reserved.\n *\n * Use of this source code is governed by an MIT-style license that can be\n * found in the LICENSE file at http://neekware.com/license/MIT.html\n */\n\nexport class GtagCfg {\n  // google tracking id (UA-XXXXX-Y)\n  trackingId: string;\n  // track page view on start\n  autoPageTrack?: boolean;\n  // tracking gtag.js URL\n  gtagUrl?: string;\n  // more optional parameters\n  [key: string]: any;\n}\n\n// https://developers.google.com/analytics/devguides/collection/gtagjs/pages\nexport class GtagPageViewParams {\n  // title of the page\n  page_title?: string;\n  // uri portion of the page location starting with /\n  page_path?: string;\n  // page_location\tstring\tNo\tThe page's URL.\n  page_location?: string;\n  // more optional future parameters\n  [key: string]: any;\n}\n\n// https://developers.google.com/analytics/devguides/collection/gtagjs/events\nexport interface GtagEventParams {\n  event_category?: string;\n  event_label?: string;\n  value?: any;\n  [key: string]: any;\n}\n","/**\n * @license\n * Copyright Neekware Inc. All Rights Reserved.\n *\n * Use of this source code is governed by an MIT-style license that can be\n * found in the LICENSE file at http://neekware.com/license/MIT.html\n */\n\nimport { GtagCfg } from './gtag.types';\n\nexport const DefaultGtagCfg: GtagCfg = {\n  // google tracking id (UA-XXXXX-Y)\n  trackingId: null,\n  // track page view on start\n  autoPageTrack: false,\n  // gtag.js url\n  gtagUrl: 'https://www.googletagmanager.com/gtag/js'\n};\n","/**\n * @license\n * Copyright Neekware Inc. All Rights Reserved.\n *\n * Use of this source code is governed by an MIT-style license that can be\n * found in the LICENSE file at http://neekware.com/license/MIT.html\n */\n\nimport { NgModule, Optional, SkipSelf } from '@angular/core';\nimport { CommonModule } from '@angular/common';\n\nimport { GtagService } from './gtag.service';\n\n@NgModule({\n  imports: [CommonModule]\n})\nexport class GtagModule {\n  /**\n   * Constructor - Ensures a singleton copy\n   * @param parentModule parent module that imports the module\n   */\n  constructor(\n    @Optional()\n    @SkipSelf()\n    parentModule: GtagModule\n  ) {\n    if (parentModule) {\n      throw new Error('GtagModule is already loaded. Import it in the AppModule only');\n    }\n  }\n}\n","/**\n * @license\n * Copyright Neekware Inc. All Rights Reserved.\n *\n * Use of this source code is governed by an MIT-style license that can be\n * found in the LICENSE file at http://neekware.com/license/MIT.html\n */\n\nimport { Injectable } from '@angular/core';\nimport { Router, NavigationEnd, ActivatedRoute } from '@angular/router';\n\nimport { get, merge } from 'lodash';\nimport { tap, filter, map, switchMap } from 'rxjs/operators';\nimport { CfgService, AppCfg } from '@nwx/cfg';\nimport { LogService } from '@nwx/logger';\n\nimport { DefaultGtagCfg } from './gtag.defaults';\nimport { GtagModule } from './gtag.module';\nimport { GtagPageViewParams, GtagEventParams } from './gtag.types';\n\ndeclare var gtag: Function;\n\n@Injectable({\n  providedIn: 'root'\n})\nexport class GtagService {\n  options: AppCfg = null;\n\n  constructor(\n    private router: Router,\n    private route: ActivatedRoute,\n    private cfg: CfgService,\n    private log: LogService\n  ) {\n    this.options = merge({ gtag: DefaultGtagCfg }, this.cfg.options);\n    if (this.options.gtag.trackingId) {\n      this.loadScript();\n      this.initScript();\n      this.log.debug(`GtagService ready ... (${this.options.gtag.trackingId})`);\n      if (this.options.gtag.autoPageTrack) {\n        this.enablePageView();\n      }\n    }\n  }\n\n  private initScript() {\n    const id = this.options.gtag.trackingId;\n    const enabled = this.options.gtag.autoPageTrack;\n    const tag = `\n      window.dataLayer = window.dataLayer || [];\n      function gtag(){dataLayer.push(arguments);}\n      gtag('js', new Date());\n      gtag('config', '${id}', { 'send_page_view': ${enabled} });\n    `;\n    const elNode = Object.assign(document.createElement('script'), {\n      text: tag\n    });\n    document.body.appendChild(elNode);\n  }\n\n  private loadScript() {\n    const url = `${this.options.gtag.gtagUrl}?id=${this.options.gtag.trackingId}`;\n    if (!document.querySelectorAll(`[src=\"${url}\"]`).length) {\n      const elNode = Object.assign(document.createElement('script'), {\n        type: 'text/javascript',\n        src: url,\n        async: true\n      });\n      document.body.appendChild(elNode);\n    }\n  }\n\n  private enablePageView() {\n    this.router.events\n      .pipe(\n        filter(event => event instanceof NavigationEnd),\n        map(() => this.route),\n        map(route => route.firstChild),\n        switchMap(route => route.data),\n        map(data => get(data, 'title', this.options.appName)),\n        tap(title => {\n          this.trackPageView({ page_title: title });\n        })\n      )\n      .subscribe();\n  }\n\n  trackPageView(params?: GtagPageViewParams) {\n    params = {\n      ...{\n        page_path: this.router.url,\n        page_location: window.location.href,\n        page_title: this.options.appName\n      },\n      ...params\n    };\n    if (typeof gtag === 'function') {\n      try {\n        gtag('config', this.options.gtag.trackingId, params);\n      } catch (err) {\n        this.log.error('Failed to track page view', err);\n      }\n    } else {\n      this.log.debug('skip page track. gtag not ready yet ...');\n    }\n  }\n\n  trackEvent(name: string, params: GtagEventParams = {}) {\n    if (typeof gtag === 'function') {\n      try {\n        gtag('event', name, params);\n      } catch (err) {\n        console.error('Failed to track event', err);\n      }\n    } else {\n      this.log.debug('skip event track. gtag not ready yet ...');\n    }\n  }\n}\n"],"names":["NgModule","CommonModule","Optional","SkipSelf","merge","filter","NavigationEnd","map","switchMap","get","tap","Injectable","Router","ActivatedRoute","CfgService","LogService"],"mappings":"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"} |
@@ -8,3 +8,3 @@ !function(t,e){"object"==typeof exports&&"undefined"!=typeof module?e(exports,require("@angular/core"),require("@angular/common"),require("tslib"),require("@angular/router"),require("lodash"),require("rxjs/operators"),require("@nwx/cfg"),require("@nwx/logger")):"function"==typeof define&&define.amd?define("@nwx/gtag",["exports","@angular/core","@angular/common","tslib","@angular/router","lodash","rxjs/operators","@nwx/cfg","@nwx/logger"],e):e((t.nwx=t.nwx||{},t.nwx.gtag={}),t.ng.core,t.ng.common,t.tslib,t.ng.router,null,t.Rx.Observable.prototype,null,null)}(this,function(t,e,o,n,r,i,a,g,c){"use strict"; | ||
* found in the LICENSE file at http://neekware.com/license/MIT.html | ||
*/var s=function(){},u={trackingId:null,autoPageTrack:!1,gtagUrl:"https://www.googletagmanager.com/gtag/js"},p=function(){function t(t){if(t)throw new Error("GtagModule is already loaded. Import it in the AppModule only")}return t.decorators=[{type:e.NgModule,args:[{imports:[o.CommonModule]}]}],t.ctorParameters=function(){return[{type:t,decorators:[{type:e.Optional},{type:e.SkipSelf}]}]},t}(),l=function(){function t(t,e,o,n){this.router=t,this.route=e,this.cfg=o,this.log=n,this.options=null,this.options=i.merge({gtag:u},this.cfg.options),this.options.gtag.trackingId&&(this.loadScript(),this.initScript(),this.log.debug("GtagService ready ... ("+this.options.gtag.trackingId+")"),this.options.gtag.autoPageTrack&&this.enablePageView())}return t.prototype.initScript=function(){var t="\n window.dataLayer = window.dataLayer || [];\n function gtag(){dataLayer.push(arguments);}\n gtag('js', new Date());\n gtag('config', '"+this.options.gtag.trackingId+"', { 'send_page_view': "+this.options.gtag.autoPageTrack+" });\n ",e=Object.assign(document.createElement("script"),{text:t});document.body.appendChild(e)},t.prototype.loadScript=function(){var t=this.options.gtag.gtagUrl+"?id="+this.options.gtag.trackingId;if(!document.querySelectorAll('[src="'+t+'"]').length){var e=Object.assign(document.createElement("script"),{type:"text/javascript",src:t,async:!0});document.body.appendChild(e)}},t.prototype.enablePageView=function(){var e=this;this.router.events.pipe(a.filter(function(t){return t instanceof r.NavigationEnd}),a.map(function(){return e.route}),a.map(function(t){return t.firstChild}),a.switchMap(function(t){return t.data}),a.map(function(t){return i.get(t,"title",e.options.appName)}),a.tap(function(t){e.trackPageView({title:t})})).subscribe()},t.prototype.trackPageView=function(t){if(t=n.__assign({page_path:this.router.url,page_location:window.location.href,page_title:this.options.appName},t),"function"==typeof gtag)try{gtag("config",this.options.gtag.trackingId,t)}catch(e){this.log.error("Failed to track page view",e)}else this.log.debug("skip page track. gtag not ready yet ...")},t.prototype.trackEvent=function(t,e){if(void 0===e&&(e={}),"function"==typeof gtag)try{gtag("event",t,e)}catch(o){console.error("Failed to track event",o)}else this.log.debug("skip event track. gtag not ready yet ...")},t.decorators=[{type:e.Injectable,args:[{providedIn:"root"}]}],t.ctorParameters=function(){return[{type:r.Router},{type:r.ActivatedRoute},{type:g.CfgService},{type:c.LogService}]},t.ngInjectableDef=e.defineInjectable({factory:function(){return new t(e.inject(r.Router),e.inject(r.ActivatedRoute),e.inject(g.CfgService),e.inject(c.LogService))},token:t,providedIn:"root"}),t}(); | ||
*/var s=function(){},u={trackingId:null,autoPageTrack:!1,gtagUrl:"https://www.googletagmanager.com/gtag/js"},p=function(){function t(t){if(t)throw new Error("GtagModule is already loaded. Import it in the AppModule only")}return t.decorators=[{type:e.NgModule,args:[{imports:[o.CommonModule]}]}],t.ctorParameters=function(){return[{type:t,decorators:[{type:e.Optional},{type:e.SkipSelf}]}]},t}(),l=function(){function t(t,e,o,n){this.router=t,this.route=e,this.cfg=o,this.log=n,this.options=null,this.options=i.merge({gtag:u},this.cfg.options),this.options.gtag.trackingId&&(this.loadScript(),this.initScript(),this.log.debug("GtagService ready ... ("+this.options.gtag.trackingId+")"),this.options.gtag.autoPageTrack&&this.enablePageView())}return t.prototype.initScript=function(){var t="\n window.dataLayer = window.dataLayer || [];\n function gtag(){dataLayer.push(arguments);}\n gtag('js', new Date());\n gtag('config', '"+this.options.gtag.trackingId+"', { 'send_page_view': "+this.options.gtag.autoPageTrack+" });\n ",e=Object.assign(document.createElement("script"),{text:t});document.body.appendChild(e)},t.prototype.loadScript=function(){var t=this.options.gtag.gtagUrl+"?id="+this.options.gtag.trackingId;if(!document.querySelectorAll('[src="'+t+'"]').length){var e=Object.assign(document.createElement("script"),{type:"text/javascript",src:t,async:!0});document.body.appendChild(e)}},t.prototype.enablePageView=function(){var e=this;this.router.events.pipe(a.filter(function(t){return t instanceof r.NavigationEnd}),a.map(function(){return e.route}),a.map(function(t){return t.firstChild}),a.switchMap(function(t){return t.data}),a.map(function(t){return i.get(t,"title",e.options.appName)}),a.tap(function(t){e.trackPageView({page_title:t})})).subscribe()},t.prototype.trackPageView=function(t){if(t=n.__assign({page_path:this.router.url,page_location:window.location.href,page_title:this.options.appName},t),"function"==typeof gtag)try{gtag("config",this.options.gtag.trackingId,t)}catch(e){this.log.error("Failed to track page view",e)}else this.log.debug("skip page track. gtag not ready yet ...")},t.prototype.trackEvent=function(t,e){if(void 0===e&&(e={}),"function"==typeof gtag)try{gtag("event",t,e)}catch(o){console.error("Failed to track event",o)}else this.log.debug("skip event track. gtag not ready yet ...")},t.decorators=[{type:e.Injectable,args:[{providedIn:"root"}]}],t.ctorParameters=function(){return[{type:r.Router},{type:r.ActivatedRoute},{type:g.CfgService},{type:c.LogService}]},t.ngInjectableDef=e.defineInjectable({factory:function(){return new t(e.inject(r.Router),e.inject(r.ActivatedRoute),e.inject(g.CfgService),e.inject(c.LogService))},token:t,providedIn:"root"}),t}(); | ||
/** | ||
@@ -11,0 +11,0 @@ * @license |
@@ -83,3 +83,3 @@ /** | ||
.pipe(filter(event => event instanceof NavigationEnd), map(() => this.route), map(route => route.firstChild), switchMap(route => route.data), map(data => get(data, 'title', this.options.appName)), tap(title => { | ||
this.trackPageView({ title }); | ||
this.trackPageView({ page_title: title }); | ||
})) | ||
@@ -162,2 +162,2 @@ .subscribe(); | ||
//# sourceMappingURL=data:application/json;base64,{"version":3,"file":"gtag.service.js","sourceRoot":"ng://@nwx/gtag/","sources":["src/gtag.service.ts"],"names":[],"mappings":"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","sourcesContent":["/**\n * @license\n * Copyright Neekware Inc. All Rights Reserved.\n *\n * Use of this source code is governed by an MIT-style license that can be\n * found in the LICENSE file at http://neekware.com/license/MIT.html\n */\n\nimport { Injectable } from '@angular/core';\nimport { Router, NavigationEnd, ActivatedRoute } from '@angular/router';\n\nimport { get, merge } from 'lodash';\nimport { tap, filter, map, switchMap } from 'rxjs/operators';\nimport { CfgService, AppCfg } from '@nwx/cfg';\nimport { LogService } from '@nwx/logger';\n\nimport { DefaultGtagCfg } from './gtag.defaults';\nimport { GtagModule } from './gtag.module';\nimport { GtagPageViewParams, GtagEventParams } from './gtag.types';\n\ndeclare var gtag: Function;\n\n@Injectable({\n  providedIn: 'root'\n})\nexport class GtagService {\n  options: AppCfg = null;\n\n  constructor(\n    private router: Router,\n    private route: ActivatedRoute,\n    private cfg: CfgService,\n    private log: LogService\n  ) {\n    this.options = merge({ gtag: DefaultGtagCfg }, this.cfg.options);\n    if (this.options.gtag.trackingId) {\n      this.loadScript();\n      this.initScript();\n      this.log.debug(`GtagService ready ... (${this.options.gtag.trackingId})`);\n      if (this.options.gtag.autoPageTrack) {\n        this.enablePageView();\n      }\n    }\n  }\n\n  private initScript() {\n    const id = this.options.gtag.trackingId;\n    const enabled = this.options.gtag.autoPageTrack;\n    const tag = `\n      window.dataLayer = window.dataLayer || [];\n      function gtag(){dataLayer.push(arguments);}\n      gtag('js', new Date());\n      gtag('config', '${id}', { 'send_page_view': ${enabled} });\n    `;\n    const elNode = Object.assign(document.createElement('script'), {\n      text: tag\n    });\n    document.body.appendChild(elNode);\n  }\n\n  private loadScript() {\n    const url = `${this.options.gtag.gtagUrl}?id=${this.options.gtag.trackingId}`;\n    if (!document.querySelectorAll(`[src=\"${url}\"]`).length) {\n      const elNode = Object.assign(document.createElement('script'), {\n        type: 'text/javascript',\n        src: url,\n        async: true\n      });\n      document.body.appendChild(elNode);\n    }\n  }\n\n  private enablePageView() {\n    this.router.events\n      .pipe(\n        filter(event => event instanceof NavigationEnd),\n        map(() => this.route),\n        map(route => route.firstChild),\n        switchMap(route => route.data),\n        map(data => get(data, 'title', this.options.appName)),\n        tap(title => {\n          this.trackPageView({ title });\n        })\n      )\n      .subscribe();\n  }\n\n  trackPageView(params?: GtagPageViewParams) {\n    params = {\n      ...{\n        page_path: this.router.url,\n        page_location: window.location.href,\n        page_title: this.options.appName\n      },\n      ...params\n    };\n    if (typeof gtag === 'function') {\n      try {\n        gtag('config', this.options.gtag.trackingId, params);\n      } catch (err) {\n        this.log.error('Failed to track page view', err);\n      }\n    } else {\n      this.log.debug('skip page track. gtag not ready yet ...');\n    }\n  }\n\n  trackEvent(name: string, params: GtagEventParams = {}) {\n    if (typeof gtag === 'function') {\n      try {\n        gtag('event', name, params);\n      } catch (err) {\n        console.error('Failed to track event', err);\n      }\n    } else {\n      this.log.debug('skip event track. gtag not ready yet ...');\n    }\n  }\n}\n"]} | ||
//# sourceMappingURL=data:application/json;base64,{"version":3,"file":"gtag.service.js","sourceRoot":"ng://@nwx/gtag/","sources":["src/gtag.service.ts"],"names":[],"mappings":"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","sourcesContent":["/**\n * @license\n * Copyright Neekware Inc. All Rights Reserved.\n *\n * Use of this source code is governed by an MIT-style license that can be\n * found in the LICENSE file at http://neekware.com/license/MIT.html\n */\n\nimport { Injectable } from '@angular/core';\nimport { Router, NavigationEnd, ActivatedRoute } from '@angular/router';\n\nimport { get, merge } from 'lodash';\nimport { tap, filter, map, switchMap } from 'rxjs/operators';\nimport { CfgService, AppCfg } from '@nwx/cfg';\nimport { LogService } from '@nwx/logger';\n\nimport { DefaultGtagCfg } from './gtag.defaults';\nimport { GtagModule } from './gtag.module';\nimport { GtagPageViewParams, GtagEventParams } from './gtag.types';\n\ndeclare var gtag: Function;\n\n@Injectable({\n  providedIn: 'root'\n})\nexport class GtagService {\n  options: AppCfg = null;\n\n  constructor(\n    private router: Router,\n    private route: ActivatedRoute,\n    private cfg: CfgService,\n    private log: LogService\n  ) {\n    this.options = merge({ gtag: DefaultGtagCfg }, this.cfg.options);\n    if (this.options.gtag.trackingId) {\n      this.loadScript();\n      this.initScript();\n      this.log.debug(`GtagService ready ... (${this.options.gtag.trackingId})`);\n      if (this.options.gtag.autoPageTrack) {\n        this.enablePageView();\n      }\n    }\n  }\n\n  private initScript() {\n    const id = this.options.gtag.trackingId;\n    const enabled = this.options.gtag.autoPageTrack;\n    const tag = `\n      window.dataLayer = window.dataLayer || [];\n      function gtag(){dataLayer.push(arguments);}\n      gtag('js', new Date());\n      gtag('config', '${id}', { 'send_page_view': ${enabled} });\n    `;\n    const elNode = Object.assign(document.createElement('script'), {\n      text: tag\n    });\n    document.body.appendChild(elNode);\n  }\n\n  private loadScript() {\n    const url = `${this.options.gtag.gtagUrl}?id=${this.options.gtag.trackingId}`;\n    if (!document.querySelectorAll(`[src=\"${url}\"]`).length) {\n      const elNode = Object.assign(document.createElement('script'), {\n        type: 'text/javascript',\n        src: url,\n        async: true\n      });\n      document.body.appendChild(elNode);\n    }\n  }\n\n  private enablePageView() {\n    this.router.events\n      .pipe(\n        filter(event => event instanceof NavigationEnd),\n        map(() => this.route),\n        map(route => route.firstChild),\n        switchMap(route => route.data),\n        map(data => get(data, 'title', this.options.appName)),\n        tap(title => {\n          this.trackPageView({ page_title: title });\n        })\n      )\n      .subscribe();\n  }\n\n  trackPageView(params?: GtagPageViewParams) {\n    params = {\n      ...{\n        page_path: this.router.url,\n        page_location: window.location.href,\n        page_title: this.options.appName\n      },\n      ...params\n    };\n    if (typeof gtag === 'function') {\n      try {\n        gtag('config', this.options.gtag.trackingId, params);\n      } catch (err) {\n        this.log.error('Failed to track page view', err);\n      }\n    } else {\n      this.log.debug('skip page track. gtag not ready yet ...');\n    }\n  }\n\n  trackEvent(name: string, params: GtagEventParams = {}) {\n    if (typeof gtag === 'function') {\n      try {\n        gtag('event', name, params);\n      } catch (err) {\n        console.error('Failed to track event', err);\n      }\n    } else {\n      this.log.debug('skip event track. gtag not ready yet ...');\n    }\n  }\n}\n"]} |
@@ -83,3 +83,3 @@ /** | ||
.pipe(filter(function (event) { return event instanceof NavigationEnd; }), map(function () { return _this.route; }), map(function (route) { return route.firstChild; }), switchMap(function (route) { return route.data; }), map(function (data) { return get(data, 'title', _this.options.appName); }), tap(function (title) { | ||
_this.trackPageView({ title: title }); | ||
_this.trackPageView({ page_title: title }); | ||
})) | ||
@@ -174,2 +174,2 @@ .subscribe(); | ||
//# sourceMappingURL=data:application/json;base64,{"version":3,"file":"gtag.service.js","sourceRoot":"ng://@nwx/gtag/","sources":["src/gtag.service.ts"],"names":[],"mappings":"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","sourcesContent":["/**\n * @license\n * Copyright Neekware Inc. All Rights Reserved.\n *\n * Use of this source code is governed by an MIT-style license that can be\n * found in the LICENSE file at http://neekware.com/license/MIT.html\n */\n\nimport { Injectable } from '@angular/core';\nimport { Router, NavigationEnd, ActivatedRoute } from '@angular/router';\n\nimport { get, merge } from 'lodash';\nimport { tap, filter, map, switchMap } from 'rxjs/operators';\nimport { CfgService, AppCfg } from '@nwx/cfg';\nimport { LogService } from '@nwx/logger';\n\nimport { DefaultGtagCfg } from './gtag.defaults';\nimport { GtagModule } from './gtag.module';\nimport { GtagPageViewParams, GtagEventParams } from './gtag.types';\n\ndeclare var gtag: Function;\n\n@Injectable({\n  providedIn: 'root'\n})\nexport class GtagService {\n  options: AppCfg = null;\n\n  constructor(\n    private router: Router,\n    private route: ActivatedRoute,\n    private cfg: CfgService,\n    private log: LogService\n  ) {\n    this.options = merge({ gtag: DefaultGtagCfg }, this.cfg.options);\n    if (this.options.gtag.trackingId) {\n      this.loadScript();\n      this.initScript();\n      this.log.debug(`GtagService ready ... (${this.options.gtag.trackingId})`);\n      if (this.options.gtag.autoPageTrack) {\n        this.enablePageView();\n      }\n    }\n  }\n\n  private initScript() {\n    const id = this.options.gtag.trackingId;\n    const enabled = this.options.gtag.autoPageTrack;\n    const tag = `\n      window.dataLayer = window.dataLayer || [];\n      function gtag(){dataLayer.push(arguments);}\n      gtag('js', new Date());\n      gtag('config', '${id}', { 'send_page_view': ${enabled} });\n    `;\n    const elNode = Object.assign(document.createElement('script'), {\n      text: tag\n    });\n    document.body.appendChild(elNode);\n  }\n\n  private loadScript() {\n    const url = `${this.options.gtag.gtagUrl}?id=${this.options.gtag.trackingId}`;\n    if (!document.querySelectorAll(`[src=\"${url}\"]`).length) {\n      const elNode = Object.assign(document.createElement('script'), {\n        type: 'text/javascript',\n        src: url,\n        async: true\n      });\n      document.body.appendChild(elNode);\n    }\n  }\n\n  private enablePageView() {\n    this.router.events\n      .pipe(\n        filter(event => event instanceof NavigationEnd),\n        map(() => this.route),\n        map(route => route.firstChild),\n        switchMap(route => route.data),\n        map(data => get(data, 'title', this.options.appName)),\n        tap(title => {\n          this.trackPageView({ title });\n        })\n      )\n      .subscribe();\n  }\n\n  trackPageView(params?: GtagPageViewParams) {\n    params = {\n      ...{\n        page_path: this.router.url,\n        page_location: window.location.href,\n        page_title: this.options.appName\n      },\n      ...params\n    };\n    if (typeof gtag === 'function') {\n      try {\n        gtag('config', this.options.gtag.trackingId, params);\n      } catch (err) {\n        this.log.error('Failed to track page view', err);\n      }\n    } else {\n      this.log.debug('skip page track. gtag not ready yet ...');\n    }\n  }\n\n  trackEvent(name: string, params: GtagEventParams = {}) {\n    if (typeof gtag === 'function') {\n      try {\n        gtag('event', name, params);\n      } catch (err) {\n        console.error('Failed to track event', err);\n      }\n    } else {\n      this.log.debug('skip event track. gtag not ready yet ...');\n    }\n  }\n}\n"]} | ||
//# sourceMappingURL=data:application/json;base64,{"version":3,"file":"gtag.service.js","sourceRoot":"ng://@nwx/gtag/","sources":["src/gtag.service.ts"],"names":[],"mappings":"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","sourcesContent":["/**\n * @license\n * Copyright Neekware Inc. All Rights Reserved.\n *\n * Use of this source code is governed by an MIT-style license that can be\n * found in the LICENSE file at http://neekware.com/license/MIT.html\n */\n\nimport { Injectable } from '@angular/core';\nimport { Router, NavigationEnd, ActivatedRoute } from '@angular/router';\n\nimport { get, merge } from 'lodash';\nimport { tap, filter, map, switchMap } from 'rxjs/operators';\nimport { CfgService, AppCfg } from '@nwx/cfg';\nimport { LogService } from '@nwx/logger';\n\nimport { DefaultGtagCfg } from './gtag.defaults';\nimport { GtagModule } from './gtag.module';\nimport { GtagPageViewParams, GtagEventParams } from './gtag.types';\n\ndeclare var gtag: Function;\n\n@Injectable({\n  providedIn: 'root'\n})\nexport class GtagService {\n  options: AppCfg = null;\n\n  constructor(\n    private router: Router,\n    private route: ActivatedRoute,\n    private cfg: CfgService,\n    private log: LogService\n  ) {\n    this.options = merge({ gtag: DefaultGtagCfg }, this.cfg.options);\n    if (this.options.gtag.trackingId) {\n      this.loadScript();\n      this.initScript();\n      this.log.debug(`GtagService ready ... (${this.options.gtag.trackingId})`);\n      if (this.options.gtag.autoPageTrack) {\n        this.enablePageView();\n      }\n    }\n  }\n\n  private initScript() {\n    const id = this.options.gtag.trackingId;\n    const enabled = this.options.gtag.autoPageTrack;\n    const tag = `\n      window.dataLayer = window.dataLayer || [];\n      function gtag(){dataLayer.push(arguments);}\n      gtag('js', new Date());\n      gtag('config', '${id}', { 'send_page_view': ${enabled} });\n    `;\n    const elNode = Object.assign(document.createElement('script'), {\n      text: tag\n    });\n    document.body.appendChild(elNode);\n  }\n\n  private loadScript() {\n    const url = `${this.options.gtag.gtagUrl}?id=${this.options.gtag.trackingId}`;\n    if (!document.querySelectorAll(`[src=\"${url}\"]`).length) {\n      const elNode = Object.assign(document.createElement('script'), {\n        type: 'text/javascript',\n        src: url,\n        async: true\n      });\n      document.body.appendChild(elNode);\n    }\n  }\n\n  private enablePageView() {\n    this.router.events\n      .pipe(\n        filter(event => event instanceof NavigationEnd),\n        map(() => this.route),\n        map(route => route.firstChild),\n        switchMap(route => route.data),\n        map(data => get(data, 'title', this.options.appName)),\n        tap(title => {\n          this.trackPageView({ page_title: title });\n        })\n      )\n      .subscribe();\n  }\n\n  trackPageView(params?: GtagPageViewParams) {\n    params = {\n      ...{\n        page_path: this.router.url,\n        page_location: window.location.href,\n        page_title: this.options.appName\n      },\n      ...params\n    };\n    if (typeof gtag === 'function') {\n      try {\n        gtag('config', this.options.gtag.trackingId, params);\n      } catch (err) {\n        this.log.error('Failed to track page view', err);\n      }\n    } else {\n      this.log.debug('skip page track. gtag not ready yet ...');\n    }\n  }\n\n  trackEvent(name: string, params: GtagEventParams = {}) {\n    if (typeof gtag === 'function') {\n      try {\n        gtag('event', name, params);\n      } catch (err) {\n        console.error('Failed to track event', err);\n      }\n    } else {\n      this.log.debug('skip event track. gtag not ready yet ...');\n    }\n  }\n}\n"]} |
@@ -132,3 +132,3 @@ import { NgModule, Optional, SkipSelf, Injectable, defineInjectable, inject } from '@angular/core'; | ||
.pipe(filter(event => event instanceof NavigationEnd), map(() => this.route), map(route => route.firstChild), switchMap(route => route.data), map(data => get(data, 'title', this.options.appName)), tap(title => { | ||
this.trackPageView({ title }); | ||
this.trackPageView({ page_title: title }); | ||
})) | ||
@@ -204,2 +204,2 @@ .subscribe(); | ||
//# sourceMappingURL=data:application/json;charset=utf-8;base64,{"version":3,"file":"nwx-gtag.js.map","sources":["ng://@nwx/gtag/src/gtag.types.ts","ng://@nwx/gtag/src/gtag.defaults.ts","ng://@nwx/gtag/src/gtag.module.ts","ng://@nwx/gtag/src/gtag.service.ts"],"sourcesContent":["/**\n * @license\n * Copyright Neekware Inc. All Rights Reserved.\n *\n * Use of this source code is governed by an MIT-style license that can be\n * found in the LICENSE file at http://neekware.com/license/MIT.html\n */\n\nexport class GtagCfg {\n  // google tracking id (UA-XXXXX-Y)\n  trackingId: string;\n  // track page view on start\n  autoPageTrack?: boolean;\n  // tracking gtag.js URL\n  gtagUrl?: string;\n  // more optional parameters\n  [key: string]: any;\n}\n\n// https://developers.google.com/analytics/devguides/collection/gtagjs/pages\nexport class GtagPageViewParams {\n  // title of the page\n  page_title?: string;\n  // uri portion of the page location starting with /\n  page_path?: string;\n  // page_location\tstring\tNo\tThe page's URL.\n  page_location?: string;\n  // more optional future parameters\n  [key: string]: any;\n}\n\n// https://developers.google.com/analytics/devguides/collection/gtagjs/events\nexport interface GtagEventParams {\n  event_category?: string;\n  event_label?: string;\n  value?: any;\n  [key: string]: any;\n}\n","/**\n * @license\n * Copyright Neekware Inc. All Rights Reserved.\n *\n * Use of this source code is governed by an MIT-style license that can be\n * found in the LICENSE file at http://neekware.com/license/MIT.html\n */\n\nimport { GtagCfg } from './gtag.types';\n\nexport const DefaultGtagCfg: GtagCfg = {\n  // google tracking id (UA-XXXXX-Y)\n  trackingId: null,\n  // track page view on start\n  autoPageTrack: false,\n  // gtag.js url\n  gtagUrl: 'https://www.googletagmanager.com/gtag/js'\n};\n","/**\n * @license\n * Copyright Neekware Inc. All Rights Reserved.\n *\n * Use of this source code is governed by an MIT-style license that can be\n * found in the LICENSE file at http://neekware.com/license/MIT.html\n */\n\nimport { NgModule, Optional, SkipSelf } from '@angular/core';\nimport { CommonModule } from '@angular/common';\n\nimport { GtagService } from './gtag.service';\n\n@NgModule({\n  imports: [CommonModule]\n})\nexport class GtagModule {\n  /**\n   * Constructor - Ensures a singleton copy\n   * @param parentModule parent module that imports the module\n   */\n  constructor(\n    @Optional()\n    @SkipSelf()\n    parentModule: GtagModule\n  ) {\n    if (parentModule) {\n      throw new Error('GtagModule is already loaded. Import it in the AppModule only');\n    }\n  }\n}\n","/**\n * @license\n * Copyright Neekware Inc. All Rights Reserved.\n *\n * Use of this source code is governed by an MIT-style license that can be\n * found in the LICENSE file at http://neekware.com/license/MIT.html\n */\n\nimport { Injectable } from '@angular/core';\nimport { Router, NavigationEnd, ActivatedRoute } from '@angular/router';\n\nimport { get, merge } from 'lodash';\nimport { tap, filter, map, switchMap } from 'rxjs/operators';\nimport { CfgService, AppCfg } from '@nwx/cfg';\nimport { LogService } from '@nwx/logger';\n\nimport { DefaultGtagCfg } from './gtag.defaults';\nimport { GtagModule } from './gtag.module';\nimport { GtagPageViewParams, GtagEventParams } from './gtag.types';\n\ndeclare var gtag: Function;\n\n@Injectable({\n  providedIn: 'root'\n})\nexport class GtagService {\n  options: AppCfg = null;\n\n  constructor(\n    private router: Router,\n    private route: ActivatedRoute,\n    private cfg: CfgService,\n    private log: LogService\n  ) {\n    this.options = merge({ gtag: DefaultGtagCfg }, this.cfg.options);\n    if (this.options.gtag.trackingId) {\n      this.loadScript();\n      this.initScript();\n      this.log.debug(`GtagService ready ... (${this.options.gtag.trackingId})`);\n      if (this.options.gtag.autoPageTrack) {\n        this.enablePageView();\n      }\n    }\n  }\n\n  private initScript() {\n    const id = this.options.gtag.trackingId;\n    const enabled = this.options.gtag.autoPageTrack;\n    const tag = `\n      window.dataLayer = window.dataLayer || [];\n      function gtag(){dataLayer.push(arguments);}\n      gtag('js', new Date());\n      gtag('config', '${id}', { 'send_page_view': ${enabled} });\n    `;\n    const elNode = Object.assign(document.createElement('script'), {\n      text: tag\n    });\n    document.body.appendChild(elNode);\n  }\n\n  private loadScript() {\n    const url = `${this.options.gtag.gtagUrl}?id=${this.options.gtag.trackingId}`;\n    if (!document.querySelectorAll(`[src=\"${url}\"]`).length) {\n      const elNode = Object.assign(document.createElement('script'), {\n        type: 'text/javascript',\n        src: url,\n        async: true\n      });\n      document.body.appendChild(elNode);\n    }\n  }\n\n  private enablePageView() {\n    this.router.events\n      .pipe(\n        filter(event => event instanceof NavigationEnd),\n        map(() => this.route),\n        map(route => route.firstChild),\n        switchMap(route => route.data),\n        map(data => get(data, 'title', this.options.appName)),\n        tap(title => {\n          this.trackPageView({ title });\n        })\n      )\n      .subscribe();\n  }\n\n  trackPageView(params?: GtagPageViewParams) {\n    params = {\n      ...{\n        page_path: this.router.url,\n        page_location: window.location.href,\n        page_title: this.options.appName\n      },\n      ...params\n    };\n    if (typeof gtag === 'function') {\n      try {\n        gtag('config', this.options.gtag.trackingId, params);\n      } catch (err) {\n        this.log.error('Failed to track page view', err);\n      }\n    } else {\n      this.log.debug('skip page track. gtag not ready yet ...');\n    }\n  }\n\n  trackEvent(name: string, params: GtagEventParams = {}) {\n    if (typeof gtag === 'function') {\n      try {\n        gtag('event', name, params);\n      } catch (err) {\n        console.error('Failed to track event', err);\n      }\n    } else {\n      this.log.debug('skip event track. gtag not ready yet ...');\n    }\n  }\n}\n"],"names":[],"mappings":"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"} | ||
//# sourceMappingURL=data:application/json;charset=utf-8;base64,{"version":3,"file":"nwx-gtag.js.map","sources":["ng://@nwx/gtag/src/gtag.types.ts","ng://@nwx/gtag/src/gtag.defaults.ts","ng://@nwx/gtag/src/gtag.module.ts","ng://@nwx/gtag/src/gtag.service.ts"],"sourcesContent":["/**\n * @license\n * Copyright Neekware Inc. All Rights Reserved.\n *\n * Use of this source code is governed by an MIT-style license that can be\n * found in the LICENSE file at http://neekware.com/license/MIT.html\n */\n\nexport class GtagCfg {\n  // google tracking id (UA-XXXXX-Y)\n  trackingId: string;\n  // track page view on start\n  autoPageTrack?: boolean;\n  // tracking gtag.js URL\n  gtagUrl?: string;\n  // more optional parameters\n  [key: string]: any;\n}\n\n// https://developers.google.com/analytics/devguides/collection/gtagjs/pages\nexport class GtagPageViewParams {\n  // title of the page\n  page_title?: string;\n  // uri portion of the page location starting with /\n  page_path?: string;\n  // page_location\tstring\tNo\tThe page's URL.\n  page_location?: string;\n  // more optional future parameters\n  [key: string]: any;\n}\n\n// https://developers.google.com/analytics/devguides/collection/gtagjs/events\nexport interface GtagEventParams {\n  event_category?: string;\n  event_label?: string;\n  value?: any;\n  [key: string]: any;\n}\n","/**\n * @license\n * Copyright Neekware Inc. All Rights Reserved.\n *\n * Use of this source code is governed by an MIT-style license that can be\n * found in the LICENSE file at http://neekware.com/license/MIT.html\n */\n\nimport { GtagCfg } from './gtag.types';\n\nexport const DefaultGtagCfg: GtagCfg = {\n  // google tracking id (UA-XXXXX-Y)\n  trackingId: null,\n  // track page view on start\n  autoPageTrack: false,\n  // gtag.js url\n  gtagUrl: 'https://www.googletagmanager.com/gtag/js'\n};\n","/**\n * @license\n * Copyright Neekware Inc. All Rights Reserved.\n *\n * Use of this source code is governed by an MIT-style license that can be\n * found in the LICENSE file at http://neekware.com/license/MIT.html\n */\n\nimport { NgModule, Optional, SkipSelf } from '@angular/core';\nimport { CommonModule } from '@angular/common';\n\nimport { GtagService } from './gtag.service';\n\n@NgModule({\n  imports: [CommonModule]\n})\nexport class GtagModule {\n  /**\n   * Constructor - Ensures a singleton copy\n   * @param parentModule parent module that imports the module\n   */\n  constructor(\n    @Optional()\n    @SkipSelf()\n    parentModule: GtagModule\n  ) {\n    if (parentModule) {\n      throw new Error('GtagModule is already loaded. Import it in the AppModule only');\n    }\n  }\n}\n","/**\n * @license\n * Copyright Neekware Inc. All Rights Reserved.\n *\n * Use of this source code is governed by an MIT-style license that can be\n * found in the LICENSE file at http://neekware.com/license/MIT.html\n */\n\nimport { Injectable } from '@angular/core';\nimport { Router, NavigationEnd, ActivatedRoute } from '@angular/router';\n\nimport { get, merge } from 'lodash';\nimport { tap, filter, map, switchMap } from 'rxjs/operators';\nimport { CfgService, AppCfg } from '@nwx/cfg';\nimport { LogService } from '@nwx/logger';\n\nimport { DefaultGtagCfg } from './gtag.defaults';\nimport { GtagModule } from './gtag.module';\nimport { GtagPageViewParams, GtagEventParams } from './gtag.types';\n\ndeclare var gtag: Function;\n\n@Injectable({\n  providedIn: 'root'\n})\nexport class GtagService {\n  options: AppCfg = null;\n\n  constructor(\n    private router: Router,\n    private route: ActivatedRoute,\n    private cfg: CfgService,\n    private log: LogService\n  ) {\n    this.options = merge({ gtag: DefaultGtagCfg }, this.cfg.options);\n    if (this.options.gtag.trackingId) {\n      this.loadScript();\n      this.initScript();\n      this.log.debug(`GtagService ready ... (${this.options.gtag.trackingId})`);\n      if (this.options.gtag.autoPageTrack) {\n        this.enablePageView();\n      }\n    }\n  }\n\n  private initScript() {\n    const id = this.options.gtag.trackingId;\n    const enabled = this.options.gtag.autoPageTrack;\n    const tag = `\n      window.dataLayer = window.dataLayer || [];\n      function gtag(){dataLayer.push(arguments);}\n      gtag('js', new Date());\n      gtag('config', '${id}', { 'send_page_view': ${enabled} });\n    `;\n    const elNode = Object.assign(document.createElement('script'), {\n      text: tag\n    });\n    document.body.appendChild(elNode);\n  }\n\n  private loadScript() {\n    const url = `${this.options.gtag.gtagUrl}?id=${this.options.gtag.trackingId}`;\n    if (!document.querySelectorAll(`[src=\"${url}\"]`).length) {\n      const elNode = Object.assign(document.createElement('script'), {\n        type: 'text/javascript',\n        src: url,\n        async: true\n      });\n      document.body.appendChild(elNode);\n    }\n  }\n\n  private enablePageView() {\n    this.router.events\n      .pipe(\n        filter(event => event instanceof NavigationEnd),\n        map(() => this.route),\n        map(route => route.firstChild),\n        switchMap(route => route.data),\n        map(data => get(data, 'title', this.options.appName)),\n        tap(title => {\n          this.trackPageView({ page_title: title });\n        })\n      )\n      .subscribe();\n  }\n\n  trackPageView(params?: GtagPageViewParams) {\n    params = {\n      ...{\n        page_path: this.router.url,\n        page_location: window.location.href,\n        page_title: this.options.appName\n      },\n      ...params\n    };\n    if (typeof gtag === 'function') {\n      try {\n        gtag('config', this.options.gtag.trackingId, params);\n      } catch (err) {\n        this.log.error('Failed to track page view', err);\n      }\n    } else {\n      this.log.debug('skip page track. gtag not ready yet ...');\n    }\n  }\n\n  trackEvent(name: string, params: GtagEventParams = {}) {\n    if (typeof gtag === 'function') {\n      try {\n        gtag('event', name, params);\n      } catch (err) {\n        console.error('Failed to track event', err);\n      }\n    } else {\n      this.log.debug('skip event track. gtag not ready yet ...');\n    }\n  }\n}\n"],"names":[],"mappings":"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"} |
@@ -136,3 +136,3 @@ import { NgModule, Optional, SkipSelf, Injectable, defineInjectable, inject } from '@angular/core'; | ||
.pipe(filter(function (event) { return event instanceof NavigationEnd; }), map(function () { return _this.route; }), map(function (route) { return route.firstChild; }), switchMap(function (route) { return route.data; }), map(function (data) { return get(data, 'title', _this.options.appName); }), tap(function (title) { | ||
_this.trackPageView({ title: title }); | ||
_this.trackPageView({ page_title: title }); | ||
})) | ||
@@ -219,2 +219,2 @@ .subscribe(); | ||
//# sourceMappingURL=data:application/json;charset=utf-8;base64,{"version":3,"file":"nwx-gtag.js.map","sources":["ng://@nwx/gtag/src/gtag.types.ts","ng://@nwx/gtag/src/gtag.defaults.ts","ng://@nwx/gtag/src/gtag.module.ts","ng://@nwx/gtag/src/gtag.service.ts"],"sourcesContent":["/**\n * @license\n * Copyright Neekware Inc. All Rights Reserved.\n *\n * Use of this source code is governed by an MIT-style license that can be\n * found in the LICENSE file at http://neekware.com/license/MIT.html\n */\n\nexport class GtagCfg {\n  // google tracking id (UA-XXXXX-Y)\n  trackingId: string;\n  // track page view on start\n  autoPageTrack?: boolean;\n  // tracking gtag.js URL\n  gtagUrl?: string;\n  // more optional parameters\n  [key: string]: any;\n}\n\n// https://developers.google.com/analytics/devguides/collection/gtagjs/pages\nexport class GtagPageViewParams {\n  // title of the page\n  page_title?: string;\n  // uri portion of the page location starting with /\n  page_path?: string;\n  // page_location\tstring\tNo\tThe page's URL.\n  page_location?: string;\n  // more optional future parameters\n  [key: string]: any;\n}\n\n// https://developers.google.com/analytics/devguides/collection/gtagjs/events\nexport interface GtagEventParams {\n  event_category?: string;\n  event_label?: string;\n  value?: any;\n  [key: string]: any;\n}\n","/**\n * @license\n * Copyright Neekware Inc. All Rights Reserved.\n *\n * Use of this source code is governed by an MIT-style license that can be\n * found in the LICENSE file at http://neekware.com/license/MIT.html\n */\n\nimport { GtagCfg } from './gtag.types';\n\nexport const DefaultGtagCfg: GtagCfg = {\n  // google tracking id (UA-XXXXX-Y)\n  trackingId: null,\n  // track page view on start\n  autoPageTrack: false,\n  // gtag.js url\n  gtagUrl: 'https://www.googletagmanager.com/gtag/js'\n};\n","/**\n * @license\n * Copyright Neekware Inc. All Rights Reserved.\n *\n * Use of this source code is governed by an MIT-style license that can be\n * found in the LICENSE file at http://neekware.com/license/MIT.html\n */\n\nimport { NgModule, Optional, SkipSelf } from '@angular/core';\nimport { CommonModule } from '@angular/common';\n\nimport { GtagService } from './gtag.service';\n\n@NgModule({\n  imports: [CommonModule]\n})\nexport class GtagModule {\n  /**\n   * Constructor - Ensures a singleton copy\n   * @param parentModule parent module that imports the module\n   */\n  constructor(\n    @Optional()\n    @SkipSelf()\n    parentModule: GtagModule\n  ) {\n    if (parentModule) {\n      throw new Error('GtagModule is already loaded. Import it in the AppModule only');\n    }\n  }\n}\n","/**\n * @license\n * Copyright Neekware Inc. All Rights Reserved.\n *\n * Use of this source code is governed by an MIT-style license that can be\n * found in the LICENSE file at http://neekware.com/license/MIT.html\n */\n\nimport { Injectable } from '@angular/core';\nimport { Router, NavigationEnd, ActivatedRoute } from '@angular/router';\n\nimport { get, merge } from 'lodash';\nimport { tap, filter, map, switchMap } from 'rxjs/operators';\nimport { CfgService, AppCfg } from '@nwx/cfg';\nimport { LogService } from '@nwx/logger';\n\nimport { DefaultGtagCfg } from './gtag.defaults';\nimport { GtagModule } from './gtag.module';\nimport { GtagPageViewParams, GtagEventParams } from './gtag.types';\n\ndeclare var gtag: Function;\n\n@Injectable({\n  providedIn: 'root'\n})\nexport class GtagService {\n  options: AppCfg = null;\n\n  constructor(\n    private router: Router,\n    private route: ActivatedRoute,\n    private cfg: CfgService,\n    private log: LogService\n  ) {\n    this.options = merge({ gtag: DefaultGtagCfg }, this.cfg.options);\n    if (this.options.gtag.trackingId) {\n      this.loadScript();\n      this.initScript();\n      this.log.debug(`GtagService ready ... (${this.options.gtag.trackingId})`);\n      if (this.options.gtag.autoPageTrack) {\n        this.enablePageView();\n      }\n    }\n  }\n\n  private initScript() {\n    const id = this.options.gtag.trackingId;\n    const enabled = this.options.gtag.autoPageTrack;\n    const tag = `\n      window.dataLayer = window.dataLayer || [];\n      function gtag(){dataLayer.push(arguments);}\n      gtag('js', new Date());\n      gtag('config', '${id}', { 'send_page_view': ${enabled} });\n    `;\n    const elNode = Object.assign(document.createElement('script'), {\n      text: tag\n    });\n    document.body.appendChild(elNode);\n  }\n\n  private loadScript() {\n    const url = `${this.options.gtag.gtagUrl}?id=${this.options.gtag.trackingId}`;\n    if (!document.querySelectorAll(`[src=\"${url}\"]`).length) {\n      const elNode = Object.assign(document.createElement('script'), {\n        type: 'text/javascript',\n        src: url,\n        async: true\n      });\n      document.body.appendChild(elNode);\n    }\n  }\n\n  private enablePageView() {\n    this.router.events\n      .pipe(\n        filter(event => event instanceof NavigationEnd),\n        map(() => this.route),\n        map(route => route.firstChild),\n        switchMap(route => route.data),\n        map(data => get(data, 'title', this.options.appName)),\n        tap(title => {\n          this.trackPageView({ title });\n        })\n      )\n      .subscribe();\n  }\n\n  trackPageView(params?: GtagPageViewParams) {\n    params = {\n      ...{\n        page_path: this.router.url,\n        page_location: window.location.href,\n        page_title: this.options.appName\n      },\n      ...params\n    };\n    if (typeof gtag === 'function') {\n      try {\n        gtag('config', this.options.gtag.trackingId, params);\n      } catch (err) {\n        this.log.error('Failed to track page view', err);\n      }\n    } else {\n      this.log.debug('skip page track. gtag not ready yet ...');\n    }\n  }\n\n  trackEvent(name: string, params: GtagEventParams = {}) {\n    if (typeof gtag === 'function') {\n      try {\n        gtag('event', name, params);\n      } catch (err) {\n        console.error('Failed to track event', err);\n      }\n    } else {\n      this.log.debug('skip event track. gtag not ready yet ...');\n    }\n  }\n}\n"],"names":[],"mappings":"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"} | ||
//# sourceMappingURL=data:application/json;charset=utf-8;base64,{"version":3,"file":"nwx-gtag.js.map","sources":["ng://@nwx/gtag/src/gtag.types.ts","ng://@nwx/gtag/src/gtag.defaults.ts","ng://@nwx/gtag/src/gtag.module.ts","ng://@nwx/gtag/src/gtag.service.ts"],"sourcesContent":["/**\n * @license\n * Copyright Neekware Inc. All Rights Reserved.\n *\n * Use of this source code is governed by an MIT-style license that can be\n * found in the LICENSE file at http://neekware.com/license/MIT.html\n */\n\nexport class GtagCfg {\n  // google tracking id (UA-XXXXX-Y)\n  trackingId: string;\n  // track page view on start\n  autoPageTrack?: boolean;\n  // tracking gtag.js URL\n  gtagUrl?: string;\n  // more optional parameters\n  [key: string]: any;\n}\n\n// https://developers.google.com/analytics/devguides/collection/gtagjs/pages\nexport class GtagPageViewParams {\n  // title of the page\n  page_title?: string;\n  // uri portion of the page location starting with /\n  page_path?: string;\n  // page_location\tstring\tNo\tThe page's URL.\n  page_location?: string;\n  // more optional future parameters\n  [key: string]: any;\n}\n\n// https://developers.google.com/analytics/devguides/collection/gtagjs/events\nexport interface GtagEventParams {\n  event_category?: string;\n  event_label?: string;\n  value?: any;\n  [key: string]: any;\n}\n","/**\n * @license\n * Copyright Neekware Inc. All Rights Reserved.\n *\n * Use of this source code is governed by an MIT-style license that can be\n * found in the LICENSE file at http://neekware.com/license/MIT.html\n */\n\nimport { GtagCfg } from './gtag.types';\n\nexport const DefaultGtagCfg: GtagCfg = {\n  // google tracking id (UA-XXXXX-Y)\n  trackingId: null,\n  // track page view on start\n  autoPageTrack: false,\n  // gtag.js url\n  gtagUrl: 'https://www.googletagmanager.com/gtag/js'\n};\n","/**\n * @license\n * Copyright Neekware Inc. All Rights Reserved.\n *\n * Use of this source code is governed by an MIT-style license that can be\n * found in the LICENSE file at http://neekware.com/license/MIT.html\n */\n\nimport { NgModule, Optional, SkipSelf } from '@angular/core';\nimport { CommonModule } from '@angular/common';\n\nimport { GtagService } from './gtag.service';\n\n@NgModule({\n  imports: [CommonModule]\n})\nexport class GtagModule {\n  /**\n   * Constructor - Ensures a singleton copy\n   * @param parentModule parent module that imports the module\n   */\n  constructor(\n    @Optional()\n    @SkipSelf()\n    parentModule: GtagModule\n  ) {\n    if (parentModule) {\n      throw new Error('GtagModule is already loaded. Import it in the AppModule only');\n    }\n  }\n}\n","/**\n * @license\n * Copyright Neekware Inc. All Rights Reserved.\n *\n * Use of this source code is governed by an MIT-style license that can be\n * found in the LICENSE file at http://neekware.com/license/MIT.html\n */\n\nimport { Injectable } from '@angular/core';\nimport { Router, NavigationEnd, ActivatedRoute } from '@angular/router';\n\nimport { get, merge } from 'lodash';\nimport { tap, filter, map, switchMap } from 'rxjs/operators';\nimport { CfgService, AppCfg } from '@nwx/cfg';\nimport { LogService } from '@nwx/logger';\n\nimport { DefaultGtagCfg } from './gtag.defaults';\nimport { GtagModule } from './gtag.module';\nimport { GtagPageViewParams, GtagEventParams } from './gtag.types';\n\ndeclare var gtag: Function;\n\n@Injectable({\n  providedIn: 'root'\n})\nexport class GtagService {\n  options: AppCfg = null;\n\n  constructor(\n    private router: Router,\n    private route: ActivatedRoute,\n    private cfg: CfgService,\n    private log: LogService\n  ) {\n    this.options = merge({ gtag: DefaultGtagCfg }, this.cfg.options);\n    if (this.options.gtag.trackingId) {\n      this.loadScript();\n      this.initScript();\n      this.log.debug(`GtagService ready ... (${this.options.gtag.trackingId})`);\n      if (this.options.gtag.autoPageTrack) {\n        this.enablePageView();\n      }\n    }\n  }\n\n  private initScript() {\n    const id = this.options.gtag.trackingId;\n    const enabled = this.options.gtag.autoPageTrack;\n    const tag = `\n      window.dataLayer = window.dataLayer || [];\n      function gtag(){dataLayer.push(arguments);}\n      gtag('js', new Date());\n      gtag('config', '${id}', { 'send_page_view': ${enabled} });\n    `;\n    const elNode = Object.assign(document.createElement('script'), {\n      text: tag\n    });\n    document.body.appendChild(elNode);\n  }\n\n  private loadScript() {\n    const url = `${this.options.gtag.gtagUrl}?id=${this.options.gtag.trackingId}`;\n    if (!document.querySelectorAll(`[src=\"${url}\"]`).length) {\n      const elNode = Object.assign(document.createElement('script'), {\n        type: 'text/javascript',\n        src: url,\n        async: true\n      });\n      document.body.appendChild(elNode);\n    }\n  }\n\n  private enablePageView() {\n    this.router.events\n      .pipe(\n        filter(event => event instanceof NavigationEnd),\n        map(() => this.route),\n        map(route => route.firstChild),\n        switchMap(route => route.data),\n        map(data => get(data, 'title', this.options.appName)),\n        tap(title => {\n          this.trackPageView({ page_title: title });\n        })\n      )\n      .subscribe();\n  }\n\n  trackPageView(params?: GtagPageViewParams) {\n    params = {\n      ...{\n        page_path: this.router.url,\n        page_location: window.location.href,\n        page_title: this.options.appName\n      },\n      ...params\n    };\n    if (typeof gtag === 'function') {\n      try {\n        gtag('config', this.options.gtag.trackingId, params);\n      } catch (err) {\n        this.log.error('Failed to track page view', err);\n      }\n    } else {\n      this.log.debug('skip page track. gtag not ready yet ...');\n    }\n  }\n\n  trackEvent(name: string, params: GtagEventParams = {}) {\n    if (typeof gtag === 'function') {\n      try {\n        gtag('event', name, params);\n      } catch (err) {\n        console.error('Failed to track event', err);\n      }\n    } else {\n      this.log.debug('skip event track. gtag not ready yet ...');\n    }\n  }\n}\n"],"names":[],"mappings":"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"} |
@@ -24,3 +24,3 @@ { | ||
"author": "Val Neekman", | ||
"version": "1.0.0", | ||
"version": "1.0.1", | ||
"license": "MIT", | ||
@@ -27,0 +27,0 @@ "homepage": "https://github.com/neekware/nwx-gtag", |
Sorry, the diff of this file is not supported yet
Sorry, the diff of this file is not supported yet
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
158477