Huge News!Announcing our $40M Series B led by Abstract Ventures.Learn More
Socket
Sign inDemoInstall
Socket

ng-intercom

Package Overview
Dependencies
Maintainers
2
Versions
44
Alerts
File Explorer

Advanced tools

Socket logo

Install Socket

Detect and block malicious and high-risk dependencies

Install

ng-intercom - npm Package Compare versions

Comparing version 8.0.0-beta.1 to 8.0.0

103

bundles/ng-intercom.umd.js

@@ -148,3 +148,3 @@ (function (global, factory) {

var data = __assign({}, intercomData, { app_id: app_id });
return _this.callIntercom('boot', data);
return _this._callIntercom('boot', data);
}));

@@ -176,6 +176,3 @@ };

function () {
if (!common.isPlatformBrowser(this.platformId)) {
return;
}
return this.callIntercom('shutdown');
return this._callIntercom('shutdown');
};

@@ -211,6 +208,3 @@ /**

function (data) {
if (!common.isPlatformBrowser(this.platformId)) {
return;
}
return this.callIntercom('update', data);
return this._callIntercom('update', data);
};

@@ -229,6 +223,3 @@ /**

function () {
if (!common.isPlatformBrowser(this.platformId)) {
return;
}
return this.callIntercom('hide');
return this._callIntercom('hide');
};

@@ -261,9 +252,6 @@ /**

function (message) {
if (!common.isPlatformBrowser(this.platformId)) {
return;
}
if (message) {
return this.showNewMessage(message);
}
return this.callIntercom('show');
return this._callIntercom('show');
};

@@ -282,6 +270,3 @@ /**

function () {
if (!common.isPlatformBrowser(this.platformId)) {
return;
}
return this.callIntercom('showMessages');
return this._callIntercom('showMessages');
};

@@ -308,6 +293,3 @@ /**

function (message) {
if (!common.isPlatformBrowser(this.platformId)) {
return;
}
return this.callIntercom('showNewMessage', message);
return this._callIntercom('showNewMessage', message);
};

@@ -342,6 +324,3 @@ /**

function (eventName, metadata) {
if (!common.isPlatformBrowser(this.platformId)) {
return;
}
return this.callIntercom('trackEvent', eventName, metadata);
return this._callIntercom('trackEvent', eventName, metadata);
};

@@ -366,6 +345,3 @@ /**

function () {
if (!common.isPlatformBrowser(this.platformId)) {
return;
}
return this.callIntercom('getVisitorId');
return this._callIntercom('getVisitorId');
};

@@ -384,6 +360,3 @@ Object.defineProperty(Intercom.prototype, "visitorId", {

*/ function () {
if (!common.isPlatformBrowser(this.platformId)) {
return;
}
return this.callIntercom('getVisitorId');
return this._callIntercom('getVisitorId');
},

@@ -407,6 +380,3 @@ enumerable: true,

function (handler) {
if (!common.isPlatformBrowser(this.platformId)) {
return;
}
return this.callIntercom('onShow', handler);
return this._callIntercom('onShow', handler);
};

@@ -427,6 +397,3 @@ /**

function (handler) {
if (!common.isPlatformBrowser(this.platformId)) {
return;
}
return this.callIntercom('onHide', handler);
return this._callIntercom('onHide', handler);
};

@@ -447,8 +414,40 @@ /**

function (handler) {
if (!common.isPlatformBrowser(this.platformId)) {
return;
}
return this.callIntercom('onUnreadCountChange', handler);
return this._callIntercom('onUnreadCountChange', handler);
};
/**
* If you would like to trigger a tour based on an action a user or visitor takes in your site or application,
* ou can use this API method. You need to call this method with the id of the tour you wish to show. The id of
* the tour can be found in the “Use tour everywhere” section of the tour editor.
*
* Please note that tours shown via this API must be published and the “Use tour everywhere” section must be
* turned on. If you're calling this API using an invalid tour id, nothing will happen.
*/
/**
* If you would like to trigger a tour based on an action a user or visitor takes in your site or application,
* ou can use this API method. You need to call this method with the id of the tour you wish to show. The id of
* the tour can be found in the “Use tour everywhere” section of the tour editor.
*
* Please note that tours shown via this API must be published and the “Use tour everywhere” section must be
* turned on. If you're calling this API using an invalid tour id, nothing will happen.
* @param {?} tourId
* @return {?}
*/
Intercom.prototype.startTour = /**
* If you would like to trigger a tour based on an action a user or visitor takes in your site or application,
* ou can use this API method. You need to call this method with the id of the tour you wish to show. The id of
* the tour can be found in the “Use tour everywhere” section of the tour editor.
*
* Please note that tours shown via this API must be published and the “Use tour everywhere” section must be
* turned on. If you're calling this API using an invalid tour id, nothing will happen.
* @param {?} tourId
* @return {?}
*/
function (tourId) {
return this._callIntercom('startTour', tourId);
};
/**
* Private handler to run Intercom methods safely
*/
/**
* Private handler to run Intercom methods safely
* @private

@@ -459,3 +458,4 @@ * @param {?} fn

*/
Intercom.prototype.callIntercom = /**
Intercom.prototype._callIntercom = /**
* Private handler to run Intercom methods safely
* @private

@@ -471,2 +471,5 @@ * @param {?} fn

}
if (!common.isPlatformBrowser(this.platformId)) {
return;
}
if ((( /** @type {?} */(window))).Intercom) {

@@ -473,0 +476,0 @@ return (( /** @type {?} */(window))).Intercom.apply((( /** @type {?} */(window))), __spread([fn], args));

@@ -1,2 +0,2 @@

!function(t,e){"object"==typeof exports&&"undefined"!=typeof module?e(exports,require("@angular/common"),require("@angular/router"),require("@angular/core")):"function"==typeof define&&define.amd?define("ng-intercom",["exports","@angular/common","@angular/router","@angular/core"],e):e(t["ng-intercom"]={},t.ng.common,t.ng.router,t.ng.core)}(this,function(t,s,r,c){"use strict";var i=function(){return(i=Object.assign||function(t){for(var e,r=1,o=arguments.length;r<o;r++)for(var n in e=arguments[r])Object.prototype.hasOwnProperty.call(e,n)&&(t[n]=e[n]);return t}).apply(this,arguments)};function n(t,e){var r="function"==typeof Symbol&&t[Symbol.iterator];if(!r)return t;var o,n,i=r.call(t),s=[];try{for(;(void 0===e||0<e--)&&!(o=i.next()).done;)s.push(o.value)}catch(c){n={error:c}}finally{try{o&&!o.done&&(r=i["return"])&&r.call(i)}finally{if(n)throw n.error}}return s}var o=function(){function t(){}return t.decorators=[{type:c.Injectable}],t}(),a=function(){function t(t,e,r,o,n){var i=this;this.config=t,this.platformId=e,this.router=r,this.rendererFactory=o,this.document=n,s.isPlatformBrowser(this.platformId)&&(this.renderer2=this.rendererFactory.createRenderer(this.document,{id:"-1",encapsulation:c.ViewEncapsulation.None,styles:[],data:{}}),t&&t.updateOnRouterChange?this.router.events.subscribe(function(t){i.update()}):c.isDevMode()&&console.warn("\n Common practice in single page applications is to update whenever the route changes.\n ng-intercom supports this functionality out of the box just set 'updateOnRouterChange' to true in your Intercom Module config.\n This warning will not appear in production, if you choose not to use router updating.\n "))}return t.prototype.boot=function(r){var o=this;if(s.isPlatformBrowser(this.platformId)){var n=r.app_id?r.app_id:this.config.appId;this.loadIntercom(this.config,function(t){var e=i({},r,{app_id:n});return o.callIntercom("boot",e)})}},t.prototype.shutdown=function(){if(s.isPlatformBrowser(this.platformId))return this.callIntercom("shutdown")},t.prototype.update=function(t){if(s.isPlatformBrowser(this.platformId))return this.callIntercom("update",t)},t.prototype.hide=function(){if(s.isPlatformBrowser(this.platformId))return this.callIntercom("hide")},t.prototype.show=function(t){if(s.isPlatformBrowser(this.platformId))return t?this.showNewMessage(t):this.callIntercom("show")},t.prototype.showMessages=function(){if(s.isPlatformBrowser(this.platformId))return this.callIntercom("showMessages")},t.prototype.showNewMessage=function(t){if(s.isPlatformBrowser(this.platformId))return this.callIntercom("showNewMessage",t)},t.prototype.trackEvent=function(t,e){if(s.isPlatformBrowser(this.platformId))return this.callIntercom("trackEvent",t,e)},t.prototype.getVisitorId=function(){if(s.isPlatformBrowser(this.platformId))return this.callIntercom("getVisitorId")},Object.defineProperty(t.prototype,"visitorId",{get:function(){if(s.isPlatformBrowser(this.platformId))return this.callIntercom("getVisitorId")},enumerable:!0,configurable:!0}),t.prototype.onShow=function(t){if(s.isPlatformBrowser(this.platformId))return this.callIntercom("onShow",t)},t.prototype.onHide=function(t){if(s.isPlatformBrowser(this.platformId))return this.callIntercom("onHide",t)},t.prototype.onUnreadCountChange=function(t){if(s.isPlatformBrowser(this.platformId))return this.callIntercom("onUnreadCountChange",t)},t.prototype.callIntercom=function(t){for(var e=[],r=1;r<arguments.length;r++)e[r-1]=arguments[r];if(window.Intercom)return window.Intercom.apply(window,function o(){for(var t=[],e=0;e<arguments.length;e++)t=t.concat(n(arguments[e]));return t}([t],e))},t.prototype.injectIntercomScript=function(t,e){if(s.isPlatformBrowser(this.platformId)){window.intercomSettings=t;var r=this.document.createElement("script");r.type="text/javascript",r.async=!0,r.src="https://widget.intercom.io/widget/"+this.id,r.attachEvent?r.attachEvent("onload",e):r.addEventListener("load",e,!1),this.renderer2&&this.renderer2.appendChild&&this.renderer2.appendChild(this.document.head,r),window.Intercom("update",t)}},t.prototype.loadIntercom=function(t,e){if(s.isPlatformBrowser(this.platformId)){this.id=t.appId;var r=window,o=r.Intercom;if(r.intercomSettings=t,"function"==typeof o)o("reattach_activator"),o("update",t),e();else{var n=function(){n.c(arguments)};n.q=[],n.c=function(t){n.q.push(t)},r.Intercom=n,this.injectIntercomScript(t,e)}}},t.decorators=[{type:c.Injectable}],t.ctorParameters=function(){return[{type:o,decorators:[{type:c.Inject,args:[o]}]},{type:Object,decorators:[{type:c.Inject,args:[c.PLATFORM_ID]}]},{type:r.Router,decorators:[{type:c.Optional},{type:c.Inject,args:[r.Router]}]},{type:c.RendererFactory2},{type:undefined,decorators:[{type:c.Optional},{type:c.Inject,args:[s.DOCUMENT]}]}]},t}(),p=function(){function t(t){this.intercom=t}return t.prototype.onClick=function(){!1!==this.intercomHide&&this.intercom.hide()},t.decorators=[{type:c.Directive,args:[{selector:"[intercomHide]"}]}],t.ctorParameters=function(){return[{type:a}]},t.propDecorators={intercomHide:[{type:c.Input}],onClick:[{type:c.HostListener,args:["click"]}]},t}(),u=function(){function t(t){this.intercom=t}return t.prototype.onClick=function(){!1!==this.intercomShowMessages&&this.intercom.showMessages()},t.decorators=[{type:c.Directive,args:[{selector:"[intercomShowMessages]"}]}],t.ctorParameters=function(){return[{type:a}]},t.propDecorators={intercomShowMessages:[{type:c.Input}],onClick:[{type:c.HostListener,args:["click"]}]},t}(),h=function(){function t(t){this.intercom=t}return t.prototype.onClick=function(){(this.message?this.message:this.intercomShowNewMessage)?this.intercom.showNewMessage(this.message):this.intercom.showNewMessage()},t.decorators=[{type:c.Directive,args:[{selector:"[intercomShowNewMessage]"}]}],t.ctorParameters=function(){return[{type:a}]},t.propDecorators={message:[{type:c.Input}],intercomShowNewMessage:[{type:c.Input}],onClick:[{type:c.HostListener,args:["click"]}]},t}(),f=function(){function t(t){this.intercom=t}return t.prototype.onClick=function(){(this.message?this.message:this.intercomShow)?this.intercom.showNewMessage(this.message):this.intercom.show()},t.decorators=[{type:c.Directive,args:[{selector:"[intercomShow]"}]}],t.ctorParameters=function(){return[{type:a}]},t.propDecorators={message:[{type:c.Input}],intercomShow:[{type:c.Input}],onClick:[{type:c.HostListener,args:["click"]}]},t}(),m=function(){function t(t){this.intercom=t}return t.prototype.onClick=function(){!1!==this.intercomShutdown&&this.intercom.shutdown()},t.decorators=[{type:c.Directive,args:[{selector:"[intercomShutdown]"}]}],t.ctorParameters=function(){return[{type:a}]},t.propDecorators={intercomShutdown:[{type:c.Input}],onClick:[{type:c.HostListener,args:["click"]}]},t}(),l=function(){function t(t){this.intercom=t}return t.prototype.onClick=function(){var t=this.event?this.event:this.intercomTrackEvent;if(t&&this.metadata)this.intercom.trackEvent(t,this.metadata);else{if(!t||this.metadata)throw new Error("Error in intercomTrackEvent directive: You must specify an event to track.");this.intercom.trackEvent(t)}},t.decorators=[{type:c.Directive,args:[{selector:"[intercomTrackEvent]"}]}],t.ctorParameters=function(){return[{type:a}]},t.propDecorators={event:[{type:c.Input}],intercomTrackEvent:[{type:c.Input}],metadata:[{type:c.Input}],onClick:[{type:c.HostListener,args:["click"]}]},t}(),e=function(){function e(){}return e.forRoot=function(t){return{ngModule:e,providers:[a,{provide:o,useValue:t}]}},e.decorators=[{type:c.NgModule,args:[{imports:[r.RouterModule],declarations:[p,u,h,f,m,l],exports:[p,u,h,f,m,l],providers:[a,o]}]}],e}();t.Intercom=a,t.IntercomConfig=o,t.IntercomHideDirective=p,t.IntercomModule=e,t.IntercomShowDirective=f,t.IntercomShowMessagesDirective=u,t.IntercomShowNewMessageDirective=h,t.IntercomShutdownDirective=m,t.IntercomTrackEventDirective=l,Object.defineProperty(t,"__esModule",{value:!0})});
!function(t,e){"object"==typeof exports&&"undefined"!=typeof module?e(exports,require("@angular/common"),require("@angular/router"),require("@angular/core")):"function"==typeof define&&define.amd?define("ng-intercom",["exports","@angular/common","@angular/router","@angular/core"],e):e(t["ng-intercom"]={},t.ng.common,t.ng.router,t.ng.core)}(this,function(t,c,r,s){"use strict";var i=function(){return(i=Object.assign||function(t){for(var e,r=1,o=arguments.length;r<o;r++)for(var n in e=arguments[r])Object.prototype.hasOwnProperty.call(e,n)&&(t[n]=e[n]);return t}).apply(this,arguments)};function n(t,e){var r="function"==typeof Symbol&&t[Symbol.iterator];if(!r)return t;var o,n,i=r.call(t),c=[];try{for(;(void 0===e||0<e--)&&!(o=i.next()).done;)c.push(o.value)}catch(s){n={error:s}}finally{try{o&&!o.done&&(r=i["return"])&&r.call(i)}finally{if(n)throw n.error}}return c}var o=function(){function t(){}return t.decorators=[{type:s.Injectable}],t}(),a=function(){function t(t,e,r,o,n){var i=this;this.config=t,this.platformId=e,this.router=r,this.rendererFactory=o,this.document=n,c.isPlatformBrowser(this.platformId)&&(this.renderer2=this.rendererFactory.createRenderer(this.document,{id:"-1",encapsulation:s.ViewEncapsulation.None,styles:[],data:{}}),t&&t.updateOnRouterChange?this.router.events.subscribe(function(t){i.update()}):s.isDevMode()&&console.warn("\n Common practice in single page applications is to update whenever the route changes.\n ng-intercom supports this functionality out of the box just set 'updateOnRouterChange' to true in your Intercom Module config.\n This warning will not appear in production, if you choose not to use router updating.\n "))}return t.prototype.boot=function(r){var o=this;if(c.isPlatformBrowser(this.platformId)){var n=r.app_id?r.app_id:this.config.appId;this.loadIntercom(this.config,function(t){var e=i({},r,{app_id:n});return o._callIntercom("boot",e)})}},t.prototype.shutdown=function(){return this._callIntercom("shutdown")},t.prototype.update=function(t){return this._callIntercom("update",t)},t.prototype.hide=function(){return this._callIntercom("hide")},t.prototype.show=function(t){return t?this.showNewMessage(t):this._callIntercom("show")},t.prototype.showMessages=function(){return this._callIntercom("showMessages")},t.prototype.showNewMessage=function(t){return this._callIntercom("showNewMessage",t)},t.prototype.trackEvent=function(t,e){return this._callIntercom("trackEvent",t,e)},t.prototype.getVisitorId=function(){return this._callIntercom("getVisitorId")},Object.defineProperty(t.prototype,"visitorId",{get:function(){return this._callIntercom("getVisitorId")},enumerable:!0,configurable:!0}),t.prototype.onShow=function(t){return this._callIntercom("onShow",t)},t.prototype.onHide=function(t){return this._callIntercom("onHide",t)},t.prototype.onUnreadCountChange=function(t){return this._callIntercom("onUnreadCountChange",t)},t.prototype.startTour=function(t){return this._callIntercom("startTour",t)},t.prototype._callIntercom=function(t){for(var e=[],r=1;r<arguments.length;r++)e[r-1]=arguments[r];if(c.isPlatformBrowser(this.platformId))return window.Intercom?window.Intercom.apply(window,function o(){for(var t=[],e=0;e<arguments.length;e++)t=t.concat(n(arguments[e]));return t}([t],e)):void 0},t.prototype.injectIntercomScript=function(t,e){if(c.isPlatformBrowser(this.platformId)){window.intercomSettings=t;var r=this.document.createElement("script");r.type="text/javascript",r.async=!0,r.src="https://widget.intercom.io/widget/"+this.id,r.attachEvent?r.attachEvent("onload",e):r.addEventListener("load",e,!1),this.renderer2&&this.renderer2.appendChild&&this.renderer2.appendChild(this.document.head,r),window.Intercom("update",t)}},t.prototype.loadIntercom=function(t,e){if(c.isPlatformBrowser(this.platformId)){this.id=t.appId;var r=window,o=r.Intercom;if(r.intercomSettings=t,"function"==typeof o)o("reattach_activator"),o("update",t),e();else{var n=function(){n.c(arguments)};n.q=[],n.c=function(t){n.q.push(t)},r.Intercom=n,this.injectIntercomScript(t,e)}}},t.decorators=[{type:s.Injectable}],t.ctorParameters=function(){return[{type:o,decorators:[{type:s.Inject,args:[o]}]},{type:Object,decorators:[{type:s.Inject,args:[s.PLATFORM_ID]}]},{type:r.Router,decorators:[{type:s.Optional},{type:s.Inject,args:[r.Router]}]},{type:s.RendererFactory2},{type:undefined,decorators:[{type:s.Optional},{type:s.Inject,args:[c.DOCUMENT]}]}]},t}(),u=function(){function t(t){this.intercom=t}return t.prototype.onClick=function(){!1!==this.intercomHide&&this.intercom.hide()},t.decorators=[{type:s.Directive,args:[{selector:"[intercomHide]"}]}],t.ctorParameters=function(){return[{type:a}]},t.propDecorators={intercomHide:[{type:s.Input}],onClick:[{type:s.HostListener,args:["click"]}]},t}(),p=function(){function t(t){this.intercom=t}return t.prototype.onClick=function(){!1!==this.intercomShowMessages&&this.intercom.showMessages()},t.decorators=[{type:s.Directive,args:[{selector:"[intercomShowMessages]"}]}],t.ctorParameters=function(){return[{type:a}]},t.propDecorators={intercomShowMessages:[{type:s.Input}],onClick:[{type:s.HostListener,args:["click"]}]},t}(),h=function(){function t(t){this.intercom=t}return t.prototype.onClick=function(){(this.message?this.message:this.intercomShowNewMessage)?this.intercom.showNewMessage(this.message):this.intercom.showNewMessage()},t.decorators=[{type:s.Directive,args:[{selector:"[intercomShowNewMessage]"}]}],t.ctorParameters=function(){return[{type:a}]},t.propDecorators={message:[{type:s.Input}],intercomShowNewMessage:[{type:s.Input}],onClick:[{type:s.HostListener,args:["click"]}]},t}(),m=function(){function t(t){this.intercom=t}return t.prototype.onClick=function(){(this.message?this.message:this.intercomShow)?this.intercom.showNewMessage(this.message):this.intercom.show()},t.decorators=[{type:s.Directive,args:[{selector:"[intercomShow]"}]}],t.ctorParameters=function(){return[{type:a}]},t.propDecorators={message:[{type:s.Input}],intercomShow:[{type:s.Input}],onClick:[{type:s.HostListener,args:["click"]}]},t}(),l=function(){function t(t){this.intercom=t}return t.prototype.onClick=function(){!1!==this.intercomShutdown&&this.intercom.shutdown()},t.decorators=[{type:s.Directive,args:[{selector:"[intercomShutdown]"}]}],t.ctorParameters=function(){return[{type:a}]},t.propDecorators={intercomShutdown:[{type:s.Input}],onClick:[{type:s.HostListener,args:["click"]}]},t}(),d=function(){function t(t){this.intercom=t}return t.prototype.onClick=function(){var t=this.event?this.event:this.intercomTrackEvent;if(t&&this.metadata)this.intercom.trackEvent(t,this.metadata);else{if(!t||this.metadata)throw new Error("Error in intercomTrackEvent directive: You must specify an event to track.");this.intercom.trackEvent(t)}},t.decorators=[{type:s.Directive,args:[{selector:"[intercomTrackEvent]"}]}],t.ctorParameters=function(){return[{type:a}]},t.propDecorators={event:[{type:s.Input}],intercomTrackEvent:[{type:s.Input}],metadata:[{type:s.Input}],onClick:[{type:s.HostListener,args:["click"]}]},t}(),e=function(){function e(){}return e.forRoot=function(t){return{ngModule:e,providers:[a,{provide:o,useValue:t}]}},e.decorators=[{type:s.NgModule,args:[{imports:[r.RouterModule],declarations:[u,p,h,m,l,d],exports:[u,p,h,m,l,d],providers:[a,o]}]}],e}();t.Intercom=a,t.IntercomConfig=o,t.IntercomHideDirective=u,t.IntercomModule=e,t.IntercomShowDirective=m,t.IntercomShowMessagesDirective=p,t.IntercomShowNewMessageDirective=h,t.IntercomShutdownDirective=l,t.IntercomTrackEventDirective=d,Object.defineProperty(t,"__esModule",{value:!0})});
//# sourceMappingURL=ng-intercom.umd.min.js.map

@@ -78,3 +78,3 @@ /**

const data = Object.assign({}, intercomData, { app_id });
return this.callIntercom('boot', data);
return this._callIntercom('boot', data);
}));

@@ -91,6 +91,3 @@ }

shutdown() {
if (!isPlatformBrowser(this.platformId)) {
return;
}
return this.callIntercom('shutdown');
return this._callIntercom('shutdown');
}

@@ -108,6 +105,3 @@ /**

update(data) {
if (!isPlatformBrowser(this.platformId)) {
return;
}
return this.callIntercom('update', data);
return this._callIntercom('update', data);
}

@@ -119,6 +113,3 @@ /**

hide() {
if (!isPlatformBrowser(this.platformId)) {
return;
}
return this.callIntercom('hide');
return this._callIntercom('hide');
}

@@ -135,9 +126,6 @@ /**

show(message) {
if (!isPlatformBrowser(this.platformId)) {
return;
}
if (message) {
return this.showNewMessage(message);
}
return this.callIntercom('show');
return this._callIntercom('show');
}

@@ -149,6 +137,3 @@ /**

showMessages() {
if (!isPlatformBrowser(this.platformId)) {
return;
}
return this.callIntercom('showMessages');
return this._callIntercom('showMessages');
}

@@ -163,6 +148,3 @@ /**

showNewMessage(message) {
if (!isPlatformBrowser(this.platformId)) {
return;
}
return this.callIntercom('showNewMessage', message);
return this._callIntercom('showNewMessage', message);
}

@@ -180,6 +162,3 @@ /**

trackEvent(eventName, metadata) {
if (!isPlatformBrowser(this.platformId)) {
return;
}
return this.callIntercom('trackEvent', eventName, metadata);
return this._callIntercom('trackEvent', eventName, metadata);
}

@@ -193,6 +172,3 @@ /**

getVisitorId() {
if (!isPlatformBrowser(this.platformId)) {
return;
}
return this.callIntercom('getVisitorId');
return this._callIntercom('getVisitorId');
}

@@ -206,6 +182,3 @@ /**

get visitorId() {
if (!isPlatformBrowser(this.platformId)) {
return;
}
return this.callIntercom('getVisitorId');
return this._callIntercom('getVisitorId');
}

@@ -218,6 +191,3 @@ /**

onShow(handler) {
if (!isPlatformBrowser(this.platformId)) {
return;
}
return this.callIntercom('onShow', handler);
return this._callIntercom('onShow', handler);
}

@@ -230,6 +200,3 @@ /**

onHide(handler) {
if (!isPlatformBrowser(this.platformId)) {
return;
}
return this.callIntercom('onHide', handler);
return this._callIntercom('onHide', handler);
}

@@ -242,8 +209,19 @@ /**

onUnreadCountChange(handler) {
if (!isPlatformBrowser(this.platformId)) {
return;
}
return this.callIntercom('onUnreadCountChange', handler);
return this._callIntercom('onUnreadCountChange', handler);
}
/**
* If you would like to trigger a tour based on an action a user or visitor takes in your site or application,
* ou can use this API method. You need to call this method with the id of the tour you wish to show. The id of
* the tour can be found in the “Use tour everywhere” section of the tour editor.
*
* Please note that tours shown via this API must be published and the “Use tour everywhere” section must be
* turned on. If you're calling this API using an invalid tour id, nothing will happen.
* @param {?} tourId
* @return {?}
*/
startTour(tourId) {
return this._callIntercom('startTour', tourId);
}
/**
* Private handler to run Intercom methods safely
* @private

@@ -254,3 +232,6 @@ * @param {?} fn

*/
callIntercom(fn, ...args) {
_callIntercom(fn, ...args) {
if (!isPlatformBrowser(this.platformId)) {
return;
}
if (((/** @type {?} */ (window))).Intercom) {

@@ -381,2 +362,2 @@ return ((/** @type {?} */ (window))).Intercom(fn, ...args);

}
//# sourceMappingURL=data:application/json;base64,{"version":3,"file":"intercom.js","sourceRoot":"ng://ng-intercom/","sources":["src/app/ng-intercom/intercom/intercom.ts"],"names":[],"mappings":"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","sourcesContent":["import { Inject, Injectable, PLATFORM_ID, Optional, isDevMode, Renderer2, RendererFactory2, ViewEncapsulation } from '@angular/core'\nimport { Router } from '@angular/router'\nimport { DOCUMENT, isPlatformBrowser } from '@angular/common'\n\nimport { IntercomConfig } from '../shared/intercom-config'\nimport { BootInput } from '../types/boot-input'\n\n/**\n * A provider with every Intercom.JS method\n */\n@Injectable()\nexport class Intercom {\n\n  private id: string\n\n  private renderer2: Renderer2\n\n  constructor(\n    @Inject(IntercomConfig) private config: IntercomConfig,\n    @Inject(PLATFORM_ID) protected platformId: Object,\n    @Optional() @Inject(Router) private router: Router,\n    private rendererFactory: RendererFactory2,\n    @Optional() @Inject(DOCUMENT) private document: any // Document\n\n  ) {\n    if (!isPlatformBrowser(this.platformId)) {\n      return\n    }\n\n    this.renderer2 = this.rendererFactory.createRenderer(this.document, {\n      id: '-1',\n      encapsulation: ViewEncapsulation.None,\n      styles: [],\n      data: {}\n    })\n\n    // Subscribe to router changes\n    if (config && config.updateOnRouterChange) {\n      this.router.events.subscribe(event => {\n        this.update()\n      })\n    }\n    else if (isDevMode()) {\n      console.warn(`\n      Common practice in single page applications is to update whenever the route changes.\n      ng-intercom supports this functionality out of the box just set 'updateOnRouterChange' to true in your Intercom Module config.\n       This warning will not appear in production, if you choose not to use router updating.\n     `)\n    }\n  }\n\n  /**\n   * If you'd like to control when Intercom is loaded, you can use the 'boot' method.\n   * This is useful in situations like a one-page Javascript based application where the user may not be logged in\n   * when the page loads. You call this method with the standard intercomSettings object.\n   */\n  public boot(intercomData?: BootInput): void {\n    if (!isPlatformBrowser(this.platformId)) {\n      return\n    }\n    const app_id = intercomData.app_id ? intercomData.app_id : this.config.appId\n    // Run load and attach to window\n    this.loadIntercom(this.config, (event?: Event) => {\n      // then boot the intercom js\n      const data = {\n        ...intercomData,\n        app_id\n      }\n\n      return this.callIntercom('boot', data)\n    })\n  }\n\n  /**\n   * If you have the Respond product (combined with another product like Engage)\n   * you should call the Intercom shutdown method to clear your users’ conversations anytime they logout\n   * of your application. Otherwise, the cookie we use to track who was most recently logged in on a given device\n   * or computer will keep these conversations in the Messenger for one week.\n   * This method will effectively clear out any user data that you have been passing through the JS API.\n   */\n  public shutdown(): void {\n    if (!isPlatformBrowser(this.platformId)) {\n      return\n    }\n\n    return this.callIntercom('shutdown')\n  }\n\n  /**\n   * Calling the update method without any other arguments will trigger the JavaScript to look for new messages\n   * that should be displayed to the current user (the one whose details are in the window.intercomSettings variable)\n   * and show them if they exist.\n   *\n   * Calling the update method with a JSON object of user details will update those fields on the current user\n   * in addition to logging an impression at the current URL and looking for new messages for the user.\n   */\n  public update(data?: any): void {\n    if (!isPlatformBrowser(this.platformId)) {\n      return\n    }\n\n    return this.callIntercom('update', data)\n\n  }\n\n  /**\n   * This will hide the main Messenger panel if it is open. It will not hide the Messenger Launcher.\n   */\n  public hide(): void {\n    if (!isPlatformBrowser(this.platformId)) {\n      return\n    }\n\n    return this.callIntercom('hide')\n  }\n\n  /**\n   * This will show the Messenger. If there are no conversations it will open with the new message view,\n   * if there are it will open with the message list.\n   *\n   * If a `message` parameter is supplied, it will automatically open a new message window, aliasing showNewMessage().\n   *\n   */\n  public show(message?: string): void {\n    if (!isPlatformBrowser(this.platformId)) {\n      return\n    }\n\n    if (message) {\n      return this.showNewMessage(message)\n    }\n    return this.callIntercom('show')\n\n  }\n\n  /**\n   * To open the message window with the message list you can call `showMessages()`.\n   */\n  public showMessages(): void {\n    if (!isPlatformBrowser(this.platformId)) {\n      return\n    }\n\n    return this.callIntercom('showMessages')\n  }\n\n  /**\n   * To open the message window with the new message view you can call showNewMessage().\n   *\n   * This function takes an optional parameter that can be used to pre-populate the message composer as shown below.\n   */\n  public showNewMessage(message?: string): void {\n    if (!isPlatformBrowser(this.platformId)) {\n      return\n    }\n    return this.callIntercom('showNewMessage', message)\n\n  }\n\n  /**\n   * You can submit an event using the trackEvent method.\n   * This will associate the event with the currently logged in user and send it to Intercom.\n   * The final parameter is a map that can be used to send optional metadata about the event.\n   *\n   * You can also add custom information to events in the form of event metadata.\n   */\n  public trackEvent(eventName: string, metadata?: any): void {\n    if (!isPlatformBrowser(this.platformId)) {\n      return\n    }\n    return this.callIntercom('trackEvent', eventName, metadata)\n  }\n\n\n  /**\n   * A visitor is someone who goes to your site but does not use the messenger.\n   * You can track these visitors via the visitor user_id.\n   * This user_id can be used to retrieve the visitor or lead through the REST API.\n   */\n  public getVisitorId(): string {\n    if (!isPlatformBrowser(this.platformId)) {\n      return\n    }\n\n    return this.callIntercom('getVisitorId')\n  }\n\n  /**\n   * Alias for getVisitorId()\n   * @alias getVisitorId()\n   * @readonly\n   */\n  get visitorId(): string {\n    if (!isPlatformBrowser(this.platformId)) {\n      return\n    }\n    return this.callIntercom('getVisitorId')\n  }\n\n  /**\n   * Gives you the ability to hook into the show event. Requires a function argument.\n   */\n  public onShow(handler: () => void): void {\n    if (!isPlatformBrowser(this.platformId)) {\n      return\n    }\n    return this.callIntercom('onShow', handler)\n  }\n\n  /**\n   * Gives you the ability to hook into the hide event. Requires a function argument.\n   */\n  public onHide(handler: () => void): void {\n    if (!isPlatformBrowser(this.platformId)) {\n      return\n    }\n    return this.callIntercom('onHide', handler)\n  }\n\n  /**\n   * This method allows you to register a function that will be called when the current number of unread messages changes.\n   */\n  public onUnreadCountChange(handler: (unreadCount?: number) => void): void {\n    if (!isPlatformBrowser(this.platformId)) {\n      return\n    }\n    return this.callIntercom('onUnreadCountChange', handler)\n  }\n\n  private callIntercom(fn: string, ...args) {\n    if ((<any>window).Intercom) {\n      return (<any>window).Intercom(fn, ...args)\n    }\n    return\n  }\n\n  injectIntercomScript(conf: IntercomConfig, afterInjectCallback: (ev: Event) => any): void {\n\n    if (!isPlatformBrowser(this.platformId)) {\n      return\n    }\n\n    // Set the window configuration to conf\n    (<any>window).intercomSettings = conf\n\n    // Create the intercom script in document\n    const s = this.document.createElement('script')\n    s.type = 'text/javascript'\n    s.async = true\n    s.src = `https://widget.intercom.io/widget/${this.id}`\n\n    if ((s as any).attachEvent) {\n      (s as any).attachEvent('onload', afterInjectCallback)\n    } else {\n      s.addEventListener('load', afterInjectCallback, false)\n    }\n\n    if (this.renderer2 && this.renderer2.appendChild) {\n      this.renderer2.appendChild(this.document.head, s)\n    }\n\n    (<any>window).Intercom('update', conf)\n  }\n\n  loadIntercom(config: IntercomConfig, afterLoadCallback: (ev?: Event) => any): void {\n    if (!isPlatformBrowser(this.platformId)) {\n      return\n    }\n\n    this.id = config.appId\n    const w = <any>window\n    const ic = w.Intercom\n\n    // Set window config for Intercom\n    w.intercomSettings = config\n\n    if (typeof ic === 'function') {\n      ic('reattach_activator')\n      ic('update', config)\n      afterLoadCallback()\n    } else {\n      const i: any = function () {\n        i.c(arguments)\n      }\n      i.q = []\n      i.c = function (args: any) {\n        i.q.push(args)\n      }\n      w.Intercom = i\n      this.injectIntercomScript(config, afterLoadCallback)\n    }\n\n  }\n}\n"]}
//# sourceMappingURL=data:application/json;base64,{"version":3,"file":"intercom.js","sourceRoot":"ng://ng-intercom/","sources":["src/app/ng-intercom/intercom/intercom.ts"],"names":[],"mappings":"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","sourcesContent":["import { Inject, Injectable, PLATFORM_ID, Optional, isDevMode, Renderer2, RendererFactory2, ViewEncapsulation } from '@angular/core'\nimport { Router } from '@angular/router'\nimport { DOCUMENT, isPlatformBrowser } from '@angular/common'\n\nimport { IntercomConfig } from '../shared/intercom-config'\nimport { BootInput } from '../types/boot-input'\n\n/**\n * A provider with every Intercom.JS method\n */\n@Injectable()\nexport class Intercom {\n\n  private id: string\n\n  private renderer2: Renderer2\n\n  constructor(\n    @Inject(IntercomConfig) private config: IntercomConfig,\n    @Inject(PLATFORM_ID) protected platformId: Object,\n    @Optional() @Inject(Router) private router: Router,\n    private rendererFactory: RendererFactory2,\n    @Optional() @Inject(DOCUMENT) private document: any // Document\n\n  ) {\n    if (!isPlatformBrowser(this.platformId)) {\n      return\n    }\n\n    this.renderer2 = this.rendererFactory.createRenderer(this.document, {\n      id: '-1',\n      encapsulation: ViewEncapsulation.None,\n      styles: [],\n      data: {}\n    })\n\n    // Subscribe to router changes\n    if (config && config.updateOnRouterChange) {\n      this.router.events.subscribe(event => {\n        this.update()\n      })\n    }\n    else if (isDevMode()) {\n      console.warn(`\n      Common practice in single page applications is to update whenever the route changes.\n      ng-intercom supports this functionality out of the box just set 'updateOnRouterChange' to true in your Intercom Module config.\n       This warning will not appear in production, if you choose not to use router updating.\n     `)\n    }\n  }\n\n  /**\n   * If you'd like to control when Intercom is loaded, you can use the 'boot' method.\n   * This is useful in situations like a one-page Javascript based application where the user may not be logged in\n   * when the page loads. You call this method with the standard intercomSettings object.\n   */\n  public boot(intercomData?: BootInput): void {\n    if (!isPlatformBrowser(this.platformId)) {\n      return\n    }\n    const app_id = intercomData.app_id ? intercomData.app_id : this.config.appId\n    // Run load and attach to window\n    this.loadIntercom(this.config, (event?: Event) => {\n      // then boot the intercom js\n      const data = {\n        ...intercomData,\n        app_id\n      }\n\n      return this._callIntercom('boot', data)\n    })\n  }\n\n  /**\n   * If you have the Respond product (combined with another product like Engage)\n   * you should call the Intercom shutdown method to clear your users’ conversations anytime they logout\n   * of your application. Otherwise, the cookie we use to track who was most recently logged in on a given device\n   * or computer will keep these conversations in the Messenger for one week.\n   * This method will effectively clear out any user data that you have been passing through the JS API.\n   */\n  public shutdown(): void {\n    return this._callIntercom('shutdown')\n  }\n\n  /**\n   * Calling the update method without any other arguments will trigger the JavaScript to look for new messages\n   * that should be displayed to the current user (the one whose details are in the window.intercomSettings variable)\n   * and show them if they exist.\n   *\n   * Calling the update method with a JSON object of user details will update those fields on the current user\n   * in addition to logging an impression at the current URL and looking for new messages for the user.\n   */\n  public update(data?: any): void {\n    return this._callIntercom('update', data)\n\n  }\n\n  /**\n   * This will hide the main Messenger panel if it is open. It will not hide the Messenger Launcher.\n   */\n  public hide(): void {\n    return this._callIntercom('hide')\n  }\n\n  /**\n   * This will show the Messenger. If there are no conversations it will open with the new message view,\n   * if there are it will open with the message list.\n   *\n   * If a `message` parameter is supplied, it will automatically open a new message window, aliasing showNewMessage().\n   *\n   */\n  public show(message?: string): void {\n    if (message) {\n      return this.showNewMessage(message)\n    }\n    return this._callIntercom('show')\n\n  }\n\n  /**\n   * To open the message window with the message list you can call `showMessages()`.\n   */\n  public showMessages(): void {\n    return this._callIntercom('showMessages')\n  }\n\n  /**\n   * To open the message window with the new message view you can call showNewMessage().\n   *\n   * This function takes an optional parameter that can be used to pre-populate the message composer as shown below.\n   */\n  public showNewMessage(message?: string): void {\n    return this._callIntercom('showNewMessage', message)\n\n  }\n\n  /**\n   * You can submit an event using the trackEvent method.\n   * This will associate the event with the currently logged in user and send it to Intercom.\n   * The final parameter is a map that can be used to send optional metadata about the event.\n   *\n   * You can also add custom information to events in the form of event metadata.\n   */\n  public trackEvent(eventName: string, metadata?: any): void {\n    return this._callIntercom('trackEvent', eventName, metadata)\n  }\n\n\n  /**\n   * A visitor is someone who goes to your site but does not use the messenger.\n   * You can track these visitors via the visitor user_id.\n   * This user_id can be used to retrieve the visitor or lead through the REST API.\n   */\n  public getVisitorId(): string {\n    return this._callIntercom('getVisitorId')\n  }\n\n  /**\n   * Alias for getVisitorId()\n   * @alias getVisitorId()\n   * @readonly\n   */\n  get visitorId(): string {\n    return this._callIntercom('getVisitorId')\n  }\n\n  /**\n   * Gives you the ability to hook into the show event. Requires a function argument.\n   */\n  public onShow(handler: () => void): void {\n    return this._callIntercom('onShow', handler)\n  }\n\n  /**\n   * Gives you the ability to hook into the hide event. Requires a function argument.\n   */\n  public onHide(handler: () => void): void {\n    return this._callIntercom('onHide', handler)\n  }\n\n  /**\n   * This method allows you to register a function that will be called when the current number of unread messages changes.\n   */\n  public onUnreadCountChange(handler: (unreadCount?: number) => void): void {\n    return this._callIntercom('onUnreadCountChange', handler)\n  }\n\n  /**\n   * If you would like to trigger a tour based on an action a user or visitor takes in your site or application, \n   * ou can use this API method. You need to call this method with the id of the tour you wish to show. The id of \n   * the tour can be found in the “Use tour everywhere” section of the tour editor.\n   *\n   * Please note that tours shown via this API must be published and the “Use tour everywhere” section must be \n   * turned on. If you're calling this API using an invalid tour id, nothing will happen.\n   */\n  public startTour(tourId: number): void {\n    return this._callIntercom('startTour', tourId)\n  }\n\n  /**\n   * Private handler to run Intercom methods safely\n   */\n  private _callIntercom(fn: string, ...args) {\n    if (!isPlatformBrowser(this.platformId)) {\n      return\n    }\n    if ((<any>window).Intercom) {\n      return (<any>window).Intercom(fn, ...args)\n    }\n    return\n  }\n\n  injectIntercomScript(conf: IntercomConfig, afterInjectCallback: (ev: Event) => any): void {\n\n    if (!isPlatformBrowser(this.platformId)) {\n      return\n    }\n\n    // Set the window configuration to conf\n    (<any>window).intercomSettings = conf\n\n    // Create the intercom script in document\n    const s = this.document.createElement('script')\n    s.type = 'text/javascript'\n    s.async = true\n    s.src = `https://widget.intercom.io/widget/${this.id}`\n\n    if ((s as any).attachEvent) {\n      (s as any).attachEvent('onload', afterInjectCallback)\n    } else {\n      s.addEventListener('load', afterInjectCallback, false)\n    }\n\n    if (this.renderer2 && this.renderer2.appendChild) {\n      this.renderer2.appendChild(this.document.head, s)\n    }\n\n    (<any>window).Intercom('update', conf)\n  }\n\n  loadIntercom(config: IntercomConfig, afterLoadCallback: (ev?: Event) => any): void {\n    if (!isPlatformBrowser(this.platformId)) {\n      return\n    }\n\n    this.id = config.appId\n    const w = <any>window\n    const ic = w.Intercom\n\n    // Set window config for Intercom\n    w.intercomSettings = config\n\n    if (typeof ic === 'function') {\n      ic('reattach_activator')\n      ic('update', config)\n      afterLoadCallback()\n    } else {\n      const i: any = function () {\n        i.c(arguments)\n      }\n      i.q = []\n      i.c = function (args: any) {\n        i.q.push(args)\n      }\n      w.Intercom = i\n      this.injectIntercomScript(config, afterLoadCallback)\n    }\n\n  }\n}\n"]}

@@ -82,3 +82,3 @@ /**

var data = tslib_1.__assign({}, intercomData, { app_id: app_id });
return _this.callIntercom('boot', data);
return _this._callIntercom('boot', data);
}));

@@ -110,6 +110,3 @@ };

function () {
if (!isPlatformBrowser(this.platformId)) {
return;
}
return this.callIntercom('shutdown');
return this._callIntercom('shutdown');
};

@@ -145,6 +142,3 @@ /**

function (data) {
if (!isPlatformBrowser(this.platformId)) {
return;
}
return this.callIntercom('update', data);
return this._callIntercom('update', data);
};

@@ -163,6 +157,3 @@ /**

function () {
if (!isPlatformBrowser(this.platformId)) {
return;
}
return this.callIntercom('hide');
return this._callIntercom('hide');
};

@@ -195,9 +186,6 @@ /**

function (message) {
if (!isPlatformBrowser(this.platformId)) {
return;
}
if (message) {
return this.showNewMessage(message);
}
return this.callIntercom('show');
return this._callIntercom('show');
};

@@ -216,6 +204,3 @@ /**

function () {
if (!isPlatformBrowser(this.platformId)) {
return;
}
return this.callIntercom('showMessages');
return this._callIntercom('showMessages');
};

@@ -242,6 +227,3 @@ /**

function (message) {
if (!isPlatformBrowser(this.platformId)) {
return;
}
return this.callIntercom('showNewMessage', message);
return this._callIntercom('showNewMessage', message);
};

@@ -276,6 +258,3 @@ /**

function (eventName, metadata) {
if (!isPlatformBrowser(this.platformId)) {
return;
}
return this.callIntercom('trackEvent', eventName, metadata);
return this._callIntercom('trackEvent', eventName, metadata);
};

@@ -300,6 +279,3 @@ /**

function () {
if (!isPlatformBrowser(this.platformId)) {
return;
}
return this.callIntercom('getVisitorId');
return this._callIntercom('getVisitorId');
};

@@ -319,6 +295,3 @@ Object.defineProperty(Intercom.prototype, "visitorId", {

function () {
if (!isPlatformBrowser(this.platformId)) {
return;
}
return this.callIntercom('getVisitorId');
return this._callIntercom('getVisitorId');
},

@@ -342,6 +315,3 @@ enumerable: true,

function (handler) {
if (!isPlatformBrowser(this.platformId)) {
return;
}
return this.callIntercom('onShow', handler);
return this._callIntercom('onShow', handler);
};

@@ -362,6 +332,3 @@ /**

function (handler) {
if (!isPlatformBrowser(this.platformId)) {
return;
}
return this.callIntercom('onHide', handler);
return this._callIntercom('onHide', handler);
};

@@ -382,8 +349,40 @@ /**

function (handler) {
if (!isPlatformBrowser(this.platformId)) {
return;
}
return this.callIntercom('onUnreadCountChange', handler);
return this._callIntercom('onUnreadCountChange', handler);
};
/**
* If you would like to trigger a tour based on an action a user or visitor takes in your site or application,
* ou can use this API method. You need to call this method with the id of the tour you wish to show. The id of
* the tour can be found in the “Use tour everywhere” section of the tour editor.
*
* Please note that tours shown via this API must be published and the “Use tour everywhere” section must be
* turned on. If you're calling this API using an invalid tour id, nothing will happen.
*/
/**
* If you would like to trigger a tour based on an action a user or visitor takes in your site or application,
* ou can use this API method. You need to call this method with the id of the tour you wish to show. The id of
* the tour can be found in the “Use tour everywhere” section of the tour editor.
*
* Please note that tours shown via this API must be published and the “Use tour everywhere” section must be
* turned on. If you're calling this API using an invalid tour id, nothing will happen.
* @param {?} tourId
* @return {?}
*/
Intercom.prototype.startTour = /**
* If you would like to trigger a tour based on an action a user or visitor takes in your site or application,
* ou can use this API method. You need to call this method with the id of the tour you wish to show. The id of
* the tour can be found in the “Use tour everywhere” section of the tour editor.
*
* Please note that tours shown via this API must be published and the “Use tour everywhere” section must be
* turned on. If you're calling this API using an invalid tour id, nothing will happen.
* @param {?} tourId
* @return {?}
*/
function (tourId) {
return this._callIntercom('startTour', tourId);
};
/**
* Private handler to run Intercom methods safely
*/
/**
* Private handler to run Intercom methods safely
* @private

@@ -394,3 +393,4 @@ * @param {?} fn

*/
Intercom.prototype.callIntercom = /**
Intercom.prototype._callIntercom = /**
* Private handler to run Intercom methods safely
* @private

@@ -406,2 +406,5 @@ * @param {?} fn

}
if (!isPlatformBrowser(this.platformId)) {
return;
}
if (((/** @type {?} */ (window))).Intercom) {

@@ -544,2 +547,2 @@ return ((/** @type {?} */ (window))).Intercom.apply(((/** @type {?} */ (window))), tslib_1.__spread([fn], args));

}
//# sourceMappingURL=data:application/json;base64,{"version":3,"file":"intercom.js","sourceRoot":"ng://ng-intercom/","sources":["src/app/ng-intercom/intercom/intercom.ts"],"names":[],"mappings":"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","sourcesContent":["import { Inject, Injectable, PLATFORM_ID, Optional, isDevMode, Renderer2, RendererFactory2, ViewEncapsulation } from '@angular/core'\nimport { Router } from '@angular/router'\nimport { DOCUMENT, isPlatformBrowser } from '@angular/common'\n\nimport { IntercomConfig } from '../shared/intercom-config'\nimport { BootInput } from '../types/boot-input'\n\n/**\n * A provider with every Intercom.JS method\n */\n@Injectable()\nexport class Intercom {\n\n  private id: string\n\n  private renderer2: Renderer2\n\n  constructor(\n    @Inject(IntercomConfig) private config: IntercomConfig,\n    @Inject(PLATFORM_ID) protected platformId: Object,\n    @Optional() @Inject(Router) private router: Router,\n    private rendererFactory: RendererFactory2,\n    @Optional() @Inject(DOCUMENT) private document: any // Document\n\n  ) {\n    if (!isPlatformBrowser(this.platformId)) {\n      return\n    }\n\n    this.renderer2 = this.rendererFactory.createRenderer(this.document, {\n      id: '-1',\n      encapsulation: ViewEncapsulation.None,\n      styles: [],\n      data: {}\n    })\n\n    // Subscribe to router changes\n    if (config && config.updateOnRouterChange) {\n      this.router.events.subscribe(event => {\n        this.update()\n      })\n    }\n    else if (isDevMode()) {\n      console.warn(`\n      Common practice in single page applications is to update whenever the route changes.\n      ng-intercom supports this functionality out of the box just set 'updateOnRouterChange' to true in your Intercom Module config.\n       This warning will not appear in production, if you choose not to use router updating.\n     `)\n    }\n  }\n\n  /**\n   * If you'd like to control when Intercom is loaded, you can use the 'boot' method.\n   * This is useful in situations like a one-page Javascript based application where the user may not be logged in\n   * when the page loads. You call this method with the standard intercomSettings object.\n   */\n  public boot(intercomData?: BootInput): void {\n    if (!isPlatformBrowser(this.platformId)) {\n      return\n    }\n    const app_id = intercomData.app_id ? intercomData.app_id : this.config.appId\n    // Run load and attach to window\n    this.loadIntercom(this.config, (event?: Event) => {\n      // then boot the intercom js\n      const data = {\n        ...intercomData,\n        app_id\n      }\n\n      return this.callIntercom('boot', data)\n    })\n  }\n\n  /**\n   * If you have the Respond product (combined with another product like Engage)\n   * you should call the Intercom shutdown method to clear your users’ conversations anytime they logout\n   * of your application. Otherwise, the cookie we use to track who was most recently logged in on a given device\n   * or computer will keep these conversations in the Messenger for one week.\n   * This method will effectively clear out any user data that you have been passing through the JS API.\n   */\n  public shutdown(): void {\n    if (!isPlatformBrowser(this.platformId)) {\n      return\n    }\n\n    return this.callIntercom('shutdown')\n  }\n\n  /**\n   * Calling the update method without any other arguments will trigger the JavaScript to look for new messages\n   * that should be displayed to the current user (the one whose details are in the window.intercomSettings variable)\n   * and show them if they exist.\n   *\n   * Calling the update method with a JSON object of user details will update those fields on the current user\n   * in addition to logging an impression at the current URL and looking for new messages for the user.\n   */\n  public update(data?: any): void {\n    if (!isPlatformBrowser(this.platformId)) {\n      return\n    }\n\n    return this.callIntercom('update', data)\n\n  }\n\n  /**\n   * This will hide the main Messenger panel if it is open. It will not hide the Messenger Launcher.\n   */\n  public hide(): void {\n    if (!isPlatformBrowser(this.platformId)) {\n      return\n    }\n\n    return this.callIntercom('hide')\n  }\n\n  /**\n   * This will show the Messenger. If there are no conversations it will open with the new message view,\n   * if there are it will open with the message list.\n   *\n   * If a `message` parameter is supplied, it will automatically open a new message window, aliasing showNewMessage().\n   *\n   */\n  public show(message?: string): void {\n    if (!isPlatformBrowser(this.platformId)) {\n      return\n    }\n\n    if (message) {\n      return this.showNewMessage(message)\n    }\n    return this.callIntercom('show')\n\n  }\n\n  /**\n   * To open the message window with the message list you can call `showMessages()`.\n   */\n  public showMessages(): void {\n    if (!isPlatformBrowser(this.platformId)) {\n      return\n    }\n\n    return this.callIntercom('showMessages')\n  }\n\n  /**\n   * To open the message window with the new message view you can call showNewMessage().\n   *\n   * This function takes an optional parameter that can be used to pre-populate the message composer as shown below.\n   */\n  public showNewMessage(message?: string): void {\n    if (!isPlatformBrowser(this.platformId)) {\n      return\n    }\n    return this.callIntercom('showNewMessage', message)\n\n  }\n\n  /**\n   * You can submit an event using the trackEvent method.\n   * This will associate the event with the currently logged in user and send it to Intercom.\n   * The final parameter is a map that can be used to send optional metadata about the event.\n   *\n   * You can also add custom information to events in the form of event metadata.\n   */\n  public trackEvent(eventName: string, metadata?: any): void {\n    if (!isPlatformBrowser(this.platformId)) {\n      return\n    }\n    return this.callIntercom('trackEvent', eventName, metadata)\n  }\n\n\n  /**\n   * A visitor is someone who goes to your site but does not use the messenger.\n   * You can track these visitors via the visitor user_id.\n   * This user_id can be used to retrieve the visitor or lead through the REST API.\n   */\n  public getVisitorId(): string {\n    if (!isPlatformBrowser(this.platformId)) {\n      return\n    }\n\n    return this.callIntercom('getVisitorId')\n  }\n\n  /**\n   * Alias for getVisitorId()\n   * @alias getVisitorId()\n   * @readonly\n   */\n  get visitorId(): string {\n    if (!isPlatformBrowser(this.platformId)) {\n      return\n    }\n    return this.callIntercom('getVisitorId')\n  }\n\n  /**\n   * Gives you the ability to hook into the show event. Requires a function argument.\n   */\n  public onShow(handler: () => void): void {\n    if (!isPlatformBrowser(this.platformId)) {\n      return\n    }\n    return this.callIntercom('onShow', handler)\n  }\n\n  /**\n   * Gives you the ability to hook into the hide event. Requires a function argument.\n   */\n  public onHide(handler: () => void): void {\n    if (!isPlatformBrowser(this.platformId)) {\n      return\n    }\n    return this.callIntercom('onHide', handler)\n  }\n\n  /**\n   * This method allows you to register a function that will be called when the current number of unread messages changes.\n   */\n  public onUnreadCountChange(handler: (unreadCount?: number) => void): void {\n    if (!isPlatformBrowser(this.platformId)) {\n      return\n    }\n    return this.callIntercom('onUnreadCountChange', handler)\n  }\n\n  private callIntercom(fn: string, ...args) {\n    if ((<any>window).Intercom) {\n      return (<any>window).Intercom(fn, ...args)\n    }\n    return\n  }\n\n  injectIntercomScript(conf: IntercomConfig, afterInjectCallback: (ev: Event) => any): void {\n\n    if (!isPlatformBrowser(this.platformId)) {\n      return\n    }\n\n    // Set the window configuration to conf\n    (<any>window).intercomSettings = conf\n\n    // Create the intercom script in document\n    const s = this.document.createElement('script')\n    s.type = 'text/javascript'\n    s.async = true\n    s.src = `https://widget.intercom.io/widget/${this.id}`\n\n    if ((s as any).attachEvent) {\n      (s as any).attachEvent('onload', afterInjectCallback)\n    } else {\n      s.addEventListener('load', afterInjectCallback, false)\n    }\n\n    if (this.renderer2 && this.renderer2.appendChild) {\n      this.renderer2.appendChild(this.document.head, s)\n    }\n\n    (<any>window).Intercom('update', conf)\n  }\n\n  loadIntercom(config: IntercomConfig, afterLoadCallback: (ev?: Event) => any): void {\n    if (!isPlatformBrowser(this.platformId)) {\n      return\n    }\n\n    this.id = config.appId\n    const w = <any>window\n    const ic = w.Intercom\n\n    // Set window config for Intercom\n    w.intercomSettings = config\n\n    if (typeof ic === 'function') {\n      ic('reattach_activator')\n      ic('update', config)\n      afterLoadCallback()\n    } else {\n      const i: any = function () {\n        i.c(arguments)\n      }\n      i.q = []\n      i.c = function (args: any) {\n        i.q.push(args)\n      }\n      w.Intercom = i\n      this.injectIntercomScript(config, afterLoadCallback)\n    }\n\n  }\n}\n"]}
//# sourceMappingURL=data:application/json;base64,{"version":3,"file":"intercom.js","sourceRoot":"ng://ng-intercom/","sources":["src/app/ng-intercom/intercom/intercom.ts"],"names":[],"mappings":"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","sourcesContent":["import { Inject, Injectable, PLATFORM_ID, Optional, isDevMode, Renderer2, RendererFactory2, ViewEncapsulation } from '@angular/core'\nimport { Router } from '@angular/router'\nimport { DOCUMENT, isPlatformBrowser } from '@angular/common'\n\nimport { IntercomConfig } from '../shared/intercom-config'\nimport { BootInput } from '../types/boot-input'\n\n/**\n * A provider with every Intercom.JS method\n */\n@Injectable()\nexport class Intercom {\n\n  private id: string\n\n  private renderer2: Renderer2\n\n  constructor(\n    @Inject(IntercomConfig) private config: IntercomConfig,\n    @Inject(PLATFORM_ID) protected platformId: Object,\n    @Optional() @Inject(Router) private router: Router,\n    private rendererFactory: RendererFactory2,\n    @Optional() @Inject(DOCUMENT) private document: any // Document\n\n  ) {\n    if (!isPlatformBrowser(this.platformId)) {\n      return\n    }\n\n    this.renderer2 = this.rendererFactory.createRenderer(this.document, {\n      id: '-1',\n      encapsulation: ViewEncapsulation.None,\n      styles: [],\n      data: {}\n    })\n\n    // Subscribe to router changes\n    if (config && config.updateOnRouterChange) {\n      this.router.events.subscribe(event => {\n        this.update()\n      })\n    }\n    else if (isDevMode()) {\n      console.warn(`\n      Common practice in single page applications is to update whenever the route changes.\n      ng-intercom supports this functionality out of the box just set 'updateOnRouterChange' to true in your Intercom Module config.\n       This warning will not appear in production, if you choose not to use router updating.\n     `)\n    }\n  }\n\n  /**\n   * If you'd like to control when Intercom is loaded, you can use the 'boot' method.\n   * This is useful in situations like a one-page Javascript based application where the user may not be logged in\n   * when the page loads. You call this method with the standard intercomSettings object.\n   */\n  public boot(intercomData?: BootInput): void {\n    if (!isPlatformBrowser(this.platformId)) {\n      return\n    }\n    const app_id = intercomData.app_id ? intercomData.app_id : this.config.appId\n    // Run load and attach to window\n    this.loadIntercom(this.config, (event?: Event) => {\n      // then boot the intercom js\n      const data = {\n        ...intercomData,\n        app_id\n      }\n\n      return this._callIntercom('boot', data)\n    })\n  }\n\n  /**\n   * If you have the Respond product (combined with another product like Engage)\n   * you should call the Intercom shutdown method to clear your users’ conversations anytime they logout\n   * of your application. Otherwise, the cookie we use to track who was most recently logged in on a given device\n   * or computer will keep these conversations in the Messenger for one week.\n   * This method will effectively clear out any user data that you have been passing through the JS API.\n   */\n  public shutdown(): void {\n    return this._callIntercom('shutdown')\n  }\n\n  /**\n   * Calling the update method without any other arguments will trigger the JavaScript to look for new messages\n   * that should be displayed to the current user (the one whose details are in the window.intercomSettings variable)\n   * and show them if they exist.\n   *\n   * Calling the update method with a JSON object of user details will update those fields on the current user\n   * in addition to logging an impression at the current URL and looking for new messages for the user.\n   */\n  public update(data?: any): void {\n    return this._callIntercom('update', data)\n\n  }\n\n  /**\n   * This will hide the main Messenger panel if it is open. It will not hide the Messenger Launcher.\n   */\n  public hide(): void {\n    return this._callIntercom('hide')\n  }\n\n  /**\n   * This will show the Messenger. If there are no conversations it will open with the new message view,\n   * if there are it will open with the message list.\n   *\n   * If a `message` parameter is supplied, it will automatically open a new message window, aliasing showNewMessage().\n   *\n   */\n  public show(message?: string): void {\n    if (message) {\n      return this.showNewMessage(message)\n    }\n    return this._callIntercom('show')\n\n  }\n\n  /**\n   * To open the message window with the message list you can call `showMessages()`.\n   */\n  public showMessages(): void {\n    return this._callIntercom('showMessages')\n  }\n\n  /**\n   * To open the message window with the new message view you can call showNewMessage().\n   *\n   * This function takes an optional parameter that can be used to pre-populate the message composer as shown below.\n   */\n  public showNewMessage(message?: string): void {\n    return this._callIntercom('showNewMessage', message)\n\n  }\n\n  /**\n   * You can submit an event using the trackEvent method.\n   * This will associate the event with the currently logged in user and send it to Intercom.\n   * The final parameter is a map that can be used to send optional metadata about the event.\n   *\n   * You can also add custom information to events in the form of event metadata.\n   */\n  public trackEvent(eventName: string, metadata?: any): void {\n    return this._callIntercom('trackEvent', eventName, metadata)\n  }\n\n\n  /**\n   * A visitor is someone who goes to your site but does not use the messenger.\n   * You can track these visitors via the visitor user_id.\n   * This user_id can be used to retrieve the visitor or lead through the REST API.\n   */\n  public getVisitorId(): string {\n    return this._callIntercom('getVisitorId')\n  }\n\n  /**\n   * Alias for getVisitorId()\n   * @alias getVisitorId()\n   * @readonly\n   */\n  get visitorId(): string {\n    return this._callIntercom('getVisitorId')\n  }\n\n  /**\n   * Gives you the ability to hook into the show event. Requires a function argument.\n   */\n  public onShow(handler: () => void): void {\n    return this._callIntercom('onShow', handler)\n  }\n\n  /**\n   * Gives you the ability to hook into the hide event. Requires a function argument.\n   */\n  public onHide(handler: () => void): void {\n    return this._callIntercom('onHide', handler)\n  }\n\n  /**\n   * This method allows you to register a function that will be called when the current number of unread messages changes.\n   */\n  public onUnreadCountChange(handler: (unreadCount?: number) => void): void {\n    return this._callIntercom('onUnreadCountChange', handler)\n  }\n\n  /**\n   * If you would like to trigger a tour based on an action a user or visitor takes in your site or application, \n   * ou can use this API method. You need to call this method with the id of the tour you wish to show. The id of \n   * the tour can be found in the “Use tour everywhere” section of the tour editor.\n   *\n   * Please note that tours shown via this API must be published and the “Use tour everywhere” section must be \n   * turned on. If you're calling this API using an invalid tour id, nothing will happen.\n   */\n  public startTour(tourId: number): void {\n    return this._callIntercom('startTour', tourId)\n  }\n\n  /**\n   * Private handler to run Intercom methods safely\n   */\n  private _callIntercom(fn: string, ...args) {\n    if (!isPlatformBrowser(this.platformId)) {\n      return\n    }\n    if ((<any>window).Intercom) {\n      return (<any>window).Intercom(fn, ...args)\n    }\n    return\n  }\n\n  injectIntercomScript(conf: IntercomConfig, afterInjectCallback: (ev: Event) => any): void {\n\n    if (!isPlatformBrowser(this.platformId)) {\n      return\n    }\n\n    // Set the window configuration to conf\n    (<any>window).intercomSettings = conf\n\n    // Create the intercom script in document\n    const s = this.document.createElement('script')\n    s.type = 'text/javascript'\n    s.async = true\n    s.src = `https://widget.intercom.io/widget/${this.id}`\n\n    if ((s as any).attachEvent) {\n      (s as any).attachEvent('onload', afterInjectCallback)\n    } else {\n      s.addEventListener('load', afterInjectCallback, false)\n    }\n\n    if (this.renderer2 && this.renderer2.appendChild) {\n      this.renderer2.appendChild(this.document.head, s)\n    }\n\n    (<any>window).Intercom('update', conf)\n  }\n\n  loadIntercom(config: IntercomConfig, afterLoadCallback: (ev?: Event) => any): void {\n    if (!isPlatformBrowser(this.platformId)) {\n      return\n    }\n\n    this.id = config.appId\n    const w = <any>window\n    const ic = w.Intercom\n\n    // Set window config for Intercom\n    w.intercomSettings = config\n\n    if (typeof ic === 'function') {\n      ic('reattach_activator')\n      ic('update', config)\n      afterLoadCallback()\n    } else {\n      const i: any = function () {\n        i.c(arguments)\n      }\n      i.q = []\n      i.c = function (args: any) {\n        i.q.push(args)\n      }\n      w.Intercom = i\n      this.injectIntercomScript(config, afterLoadCallback)\n    }\n\n  }\n}\n"]}

@@ -88,3 +88,3 @@ import { DOCUMENT, isPlatformBrowser } from '@angular/common';

const data = Object.assign({}, intercomData, { app_id });
return this.callIntercom('boot', data);
return this._callIntercom('boot', data);
}));

@@ -101,6 +101,3 @@ }

shutdown() {
if (!isPlatformBrowser(this.platformId)) {
return;
}
return this.callIntercom('shutdown');
return this._callIntercom('shutdown');
}

@@ -118,6 +115,3 @@ /**

update(data) {
if (!isPlatformBrowser(this.platformId)) {
return;
}
return this.callIntercom('update', data);
return this._callIntercom('update', data);
}

@@ -129,6 +123,3 @@ /**

hide() {
if (!isPlatformBrowser(this.platformId)) {
return;
}
return this.callIntercom('hide');
return this._callIntercom('hide');
}

@@ -145,9 +136,6 @@ /**

show(message) {
if (!isPlatformBrowser(this.platformId)) {
return;
}
if (message) {
return this.showNewMessage(message);
}
return this.callIntercom('show');
return this._callIntercom('show');
}

@@ -159,6 +147,3 @@ /**

showMessages() {
if (!isPlatformBrowser(this.platformId)) {
return;
}
return this.callIntercom('showMessages');
return this._callIntercom('showMessages');
}

@@ -173,6 +158,3 @@ /**

showNewMessage(message) {
if (!isPlatformBrowser(this.platformId)) {
return;
}
return this.callIntercom('showNewMessage', message);
return this._callIntercom('showNewMessage', message);
}

@@ -190,6 +172,3 @@ /**

trackEvent(eventName, metadata) {
if (!isPlatformBrowser(this.platformId)) {
return;
}
return this.callIntercom('trackEvent', eventName, metadata);
return this._callIntercom('trackEvent', eventName, metadata);
}

@@ -203,6 +182,3 @@ /**

getVisitorId() {
if (!isPlatformBrowser(this.platformId)) {
return;
}
return this.callIntercom('getVisitorId');
return this._callIntercom('getVisitorId');
}

@@ -216,6 +192,3 @@ /**

get visitorId() {
if (!isPlatformBrowser(this.platformId)) {
return;
}
return this.callIntercom('getVisitorId');
return this._callIntercom('getVisitorId');
}

@@ -228,6 +201,3 @@ /**

onShow(handler) {
if (!isPlatformBrowser(this.platformId)) {
return;
}
return this.callIntercom('onShow', handler);
return this._callIntercom('onShow', handler);
}

@@ -240,6 +210,3 @@ /**

onHide(handler) {
if (!isPlatformBrowser(this.platformId)) {
return;
}
return this.callIntercom('onHide', handler);
return this._callIntercom('onHide', handler);
}

@@ -252,8 +219,19 @@ /**

onUnreadCountChange(handler) {
if (!isPlatformBrowser(this.platformId)) {
return;
}
return this.callIntercom('onUnreadCountChange', handler);
return this._callIntercom('onUnreadCountChange', handler);
}
/**
* If you would like to trigger a tour based on an action a user or visitor takes in your site or application,
* ou can use this API method. You need to call this method with the id of the tour you wish to show. The id of
* the tour can be found in the “Use tour everywhere” section of the tour editor.
*
* Please note that tours shown via this API must be published and the “Use tour everywhere” section must be
* turned on. If you're calling this API using an invalid tour id, nothing will happen.
* @param {?} tourId
* @return {?}
*/
startTour(tourId) {
return this._callIntercom('startTour', tourId);
}
/**
* Private handler to run Intercom methods safely
* @private

@@ -264,3 +242,6 @@ * @param {?} fn

*/
callIntercom(fn, ...args) {
_callIntercom(fn, ...args) {
if (!isPlatformBrowser(this.platformId)) {
return;
}
if (((/** @type {?} */ (window))).Intercom) {

@@ -267,0 +248,0 @@ return ((/** @type {?} */ (window))).Intercom(fn, ...args);

@@ -95,3 +95,3 @@ import { __assign, __spread } from 'tslib';

var data = __assign({}, intercomData, { app_id: app_id });
return _this.callIntercom('boot', data);
return _this._callIntercom('boot', data);
}));

@@ -123,6 +123,3 @@ };

function () {
if (!isPlatformBrowser(this.platformId)) {
return;
}
return this.callIntercom('shutdown');
return this._callIntercom('shutdown');
};

@@ -158,6 +155,3 @@ /**

function (data) {
if (!isPlatformBrowser(this.platformId)) {
return;
}
return this.callIntercom('update', data);
return this._callIntercom('update', data);
};

@@ -176,6 +170,3 @@ /**

function () {
if (!isPlatformBrowser(this.platformId)) {
return;
}
return this.callIntercom('hide');
return this._callIntercom('hide');
};

@@ -208,9 +199,6 @@ /**

function (message) {
if (!isPlatformBrowser(this.platformId)) {
return;
}
if (message) {
return this.showNewMessage(message);
}
return this.callIntercom('show');
return this._callIntercom('show');
};

@@ -229,6 +217,3 @@ /**

function () {
if (!isPlatformBrowser(this.platformId)) {
return;
}
return this.callIntercom('showMessages');
return this._callIntercom('showMessages');
};

@@ -255,6 +240,3 @@ /**

function (message) {
if (!isPlatformBrowser(this.platformId)) {
return;
}
return this.callIntercom('showNewMessage', message);
return this._callIntercom('showNewMessage', message);
};

@@ -289,6 +271,3 @@ /**

function (eventName, metadata) {
if (!isPlatformBrowser(this.platformId)) {
return;
}
return this.callIntercom('trackEvent', eventName, metadata);
return this._callIntercom('trackEvent', eventName, metadata);
};

@@ -313,6 +292,3 @@ /**

function () {
if (!isPlatformBrowser(this.platformId)) {
return;
}
return this.callIntercom('getVisitorId');
return this._callIntercom('getVisitorId');
};

@@ -332,6 +308,3 @@ Object.defineProperty(Intercom.prototype, "visitorId", {

function () {
if (!isPlatformBrowser(this.platformId)) {
return;
}
return this.callIntercom('getVisitorId');
return this._callIntercom('getVisitorId');
},

@@ -355,6 +328,3 @@ enumerable: true,

function (handler) {
if (!isPlatformBrowser(this.platformId)) {
return;
}
return this.callIntercom('onShow', handler);
return this._callIntercom('onShow', handler);
};

@@ -375,6 +345,3 @@ /**

function (handler) {
if (!isPlatformBrowser(this.platformId)) {
return;
}
return this.callIntercom('onHide', handler);
return this._callIntercom('onHide', handler);
};

@@ -395,8 +362,40 @@ /**

function (handler) {
if (!isPlatformBrowser(this.platformId)) {
return;
}
return this.callIntercom('onUnreadCountChange', handler);
return this._callIntercom('onUnreadCountChange', handler);
};
/**
* If you would like to trigger a tour based on an action a user or visitor takes in your site or application,
* ou can use this API method. You need to call this method with the id of the tour you wish to show. The id of
* the tour can be found in the “Use tour everywhere” section of the tour editor.
*
* Please note that tours shown via this API must be published and the “Use tour everywhere” section must be
* turned on. If you're calling this API using an invalid tour id, nothing will happen.
*/
/**
* If you would like to trigger a tour based on an action a user or visitor takes in your site or application,
* ou can use this API method. You need to call this method with the id of the tour you wish to show. The id of
* the tour can be found in the “Use tour everywhere” section of the tour editor.
*
* Please note that tours shown via this API must be published and the “Use tour everywhere” section must be
* turned on. If you're calling this API using an invalid tour id, nothing will happen.
* @param {?} tourId
* @return {?}
*/
Intercom.prototype.startTour = /**
* If you would like to trigger a tour based on an action a user or visitor takes in your site or application,
* ou can use this API method. You need to call this method with the id of the tour you wish to show. The id of
* the tour can be found in the “Use tour everywhere” section of the tour editor.
*
* Please note that tours shown via this API must be published and the “Use tour everywhere” section must be
* turned on. If you're calling this API using an invalid tour id, nothing will happen.
* @param {?} tourId
* @return {?}
*/
function (tourId) {
return this._callIntercom('startTour', tourId);
};
/**
* Private handler to run Intercom methods safely
*/
/**
* Private handler to run Intercom methods safely
* @private

@@ -407,3 +406,4 @@ * @param {?} fn

*/
Intercom.prototype.callIntercom = /**
Intercom.prototype._callIntercom = /**
* Private handler to run Intercom methods safely
* @private

@@ -419,2 +419,5 @@ * @param {?} fn

}
if (!isPlatformBrowser(this.platformId)) {
return;
}
if (((/** @type {?} */ (window))).Intercom) {

@@ -421,0 +424,0 @@ return ((/** @type {?} */ (window))).Intercom.apply(((/** @type {?} */ (window))), __spread([fn], args));

@@ -1,1 +0,1 @@

{"__symbolic":"module","version":4,"metadata":{"Intercom":{"__symbolic":"class","decorators":[{"__symbolic":"call","expression":{"__symbolic":"reference","module":"@angular/core","name":"Injectable","line":10,"character":1}}],"members":{"__ctor__":[{"__symbolic":"constructor","parameterDecorators":[[{"__symbolic":"call","expression":{"__symbolic":"reference","module":"@angular/core","name":"Inject","line":18,"character":5},"arguments":[{"__symbolic":"reference","name":"IntercomConfig"}]}],[{"__symbolic":"call","expression":{"__symbolic":"reference","module":"@angular/core","name":"Inject","line":19,"character":5},"arguments":[{"__symbolic":"reference","module":"@angular/core","name":"PLATFORM_ID","line":19,"character":12}]}],[{"__symbolic":"call","expression":{"__symbolic":"reference","module":"@angular/core","name":"Optional","line":20,"character":5}},{"__symbolic":"call","expression":{"__symbolic":"reference","module":"@angular/core","name":"Inject","line":20,"character":17},"arguments":[{"__symbolic":"reference","module":"@angular/router","name":"Router","line":20,"character":24}]}],null,[{"__symbolic":"call","expression":{"__symbolic":"reference","module":"@angular/core","name":"Optional","line":22,"character":5}},{"__symbolic":"call","expression":{"__symbolic":"reference","module":"@angular/core","name":"Inject","line":22,"character":17},"arguments":[{"__symbolic":"reference","module":"@angular/common","name":"DOCUMENT","line":22,"character":24}]}]],"parameters":[{"__symbolic":"reference","name":"IntercomConfig"},{"__symbolic":"reference","name":"Object"},{"__symbolic":"reference","module":"@angular/router","name":"Router","line":20,"character":48},{"__symbolic":"reference","module":"@angular/core","name":"RendererFactory2","line":21,"character":29},{"__symbolic":"reference","name":"any"}]}],"boot":[{"__symbolic":"method"}],"shutdown":[{"__symbolic":"method"}],"update":[{"__symbolic":"method"}],"hide":[{"__symbolic":"method"}],"show":[{"__symbolic":"method"}],"showMessages":[{"__symbolic":"method"}],"showNewMessage":[{"__symbolic":"method"}],"trackEvent":[{"__symbolic":"method"}],"getVisitorId":[{"__symbolic":"method"}],"onShow":[{"__symbolic":"method"}],"onHide":[{"__symbolic":"method"}],"onUnreadCountChange":[{"__symbolic":"method"}],"callIntercom":[{"__symbolic":"method"}],"injectIntercomScript":[{"__symbolic":"method"}],"loadIntercom":[{"__symbolic":"method"}]}},"IntercomConfig":{"__symbolic":"class","decorators":[{"__symbolic":"call","expression":{"__symbolic":"reference","module":"@angular/core","name":"Injectable","line":2,"character":1}}],"members":{}},"IntercomHideDirective":{"__symbolic":"class","decorators":[{"__symbolic":"call","expression":{"__symbolic":"reference","module":"@angular/core","name":"Directive","line":5,"character":1},"arguments":[{"selector":"[intercomHide]"}]}],"members":{"intercomHide":[{"__symbolic":"property","decorators":[{"__symbolic":"call","expression":{"__symbolic":"reference","module":"@angular/core","name":"Input","line":9,"character":3}}]}],"__ctor__":[{"__symbolic":"constructor","parameters":[{"__symbolic":"reference","name":"Intercom"}]}],"onClick":[{"__symbolic":"method","decorators":[{"__symbolic":"call","expression":{"__symbolic":"reference","module":"@angular/core","name":"HostListener","line":15,"character":3},"arguments":["click"]}]}]}},"IntercomModule":{"__symbolic":"class","decorators":[{"__symbolic":"call","expression":{"__symbolic":"reference","module":"@angular/core","name":"NgModule","line":12,"character":1},"arguments":[{"imports":[{"__symbolic":"reference","module":"@angular/router","name":"RouterModule","line":14,"character":4}],"declarations":[{"__symbolic":"reference","name":"IntercomHideDirective"},{"__symbolic":"reference","name":"IntercomShowMessagesDirective"},{"__symbolic":"reference","name":"IntercomShowNewMessageDirective"},{"__symbolic":"reference","name":"IntercomShowDirective"},{"__symbolic":"reference","name":"IntercomShutdownDirective"},{"__symbolic":"reference","name":"IntercomTrackEventDirective"}],"exports":[{"__symbolic":"reference","name":"IntercomHideDirective"},{"__symbolic":"reference","name":"IntercomShowMessagesDirective"},{"__symbolic":"reference","name":"IntercomShowNewMessageDirective"},{"__symbolic":"reference","name":"IntercomShowDirective"},{"__symbolic":"reference","name":"IntercomShutdownDirective"},{"__symbolic":"reference","name":"IntercomTrackEventDirective"}],"providers":[{"__symbolic":"reference","name":"Intercom"},{"__symbolic":"reference","name":"IntercomConfig"}]}]}],"members":{},"statics":{"forRoot":{"__symbolic":"function","parameters":["config"],"value":{"ngModule":{"__symbolic":"reference","name":"IntercomModule"},"providers":[{"__symbolic":"reference","name":"Intercom"},{"provide":{"__symbolic":"reference","name":"IntercomConfig"},"useValue":{"__symbolic":"reference","name":"config"}}]}}}},"IntercomShowDirective":{"__symbolic":"class","decorators":[{"__symbolic":"call","expression":{"__symbolic":"reference","module":"@angular/core","name":"Directive","line":5,"character":1},"arguments":[{"selector":"[intercomShow]"}]}],"members":{"message":[{"__symbolic":"property","decorators":[{"__symbolic":"call","expression":{"__symbolic":"reference","module":"@angular/core","name":"Input","line":9,"character":3}}]}],"intercomShow":[{"__symbolic":"property","decorators":[{"__symbolic":"call","expression":{"__symbolic":"reference","module":"@angular/core","name":"Input","line":10,"character":3}}]}],"__ctor__":[{"__symbolic":"constructor","parameters":[{"__symbolic":"reference","name":"Intercom"}]}],"onClick":[{"__symbolic":"method","decorators":[{"__symbolic":"call","expression":{"__symbolic":"reference","module":"@angular/core","name":"HostListener","line":15,"character":3},"arguments":["click"]}]}]}},"IntercomShowMessagesDirective":{"__symbolic":"class","decorators":[{"__symbolic":"call","expression":{"__symbolic":"reference","module":"@angular/core","name":"Directive","line":5,"character":1},"arguments":[{"selector":"[intercomShowMessages]"}]}],"members":{"intercomShowMessages":[{"__symbolic":"property","decorators":[{"__symbolic":"call","expression":{"__symbolic":"reference","module":"@angular/core","name":"Input","line":9,"character":3}}]}],"__ctor__":[{"__symbolic":"constructor","parameters":[{"__symbolic":"reference","name":"Intercom"}]}],"onClick":[{"__symbolic":"method","decorators":[{"__symbolic":"call","expression":{"__symbolic":"reference","module":"@angular/core","name":"HostListener","line":14,"character":3},"arguments":["click"]}]}]}},"IntercomShowNewMessageDirective":{"__symbolic":"class","decorators":[{"__symbolic":"call","expression":{"__symbolic":"reference","module":"@angular/core","name":"Directive","line":5,"character":1},"arguments":[{"selector":"[intercomShowNewMessage]"}]}],"members":{"message":[{"__symbolic":"property","decorators":[{"__symbolic":"call","expression":{"__symbolic":"reference","module":"@angular/core","name":"Input","line":9,"character":3}}]}],"intercomShowNewMessage":[{"__symbolic":"property","decorators":[{"__symbolic":"call","expression":{"__symbolic":"reference","module":"@angular/core","name":"Input","line":10,"character":3}}]}],"__ctor__":[{"__symbolic":"constructor","parameters":[{"__symbolic":"reference","name":"Intercom"}]}],"onClick":[{"__symbolic":"method","decorators":[{"__symbolic":"call","expression":{"__symbolic":"reference","module":"@angular/core","name":"HostListener","line":15,"character":3},"arguments":["click"]}]}]}},"IntercomShutdownDirective":{"__symbolic":"class","decorators":[{"__symbolic":"call","expression":{"__symbolic":"reference","module":"@angular/core","name":"Directive","line":5,"character":1},"arguments":[{"selector":"[intercomShutdown]"}]}],"members":{"intercomShutdown":[{"__symbolic":"property","decorators":[{"__symbolic":"call","expression":{"__symbolic":"reference","module":"@angular/core","name":"Input","line":9,"character":3}}]}],"__ctor__":[{"__symbolic":"constructor","parameters":[{"__symbolic":"reference","name":"Intercom"}]}],"onClick":[{"__symbolic":"method","decorators":[{"__symbolic":"call","expression":{"__symbolic":"reference","module":"@angular/core","name":"HostListener","line":14,"character":3},"arguments":["click"]}]}]}},"IntercomTrackEventDirective":{"__symbolic":"class","decorators":[{"__symbolic":"call","expression":{"__symbolic":"reference","module":"@angular/core","name":"Directive","line":4,"character":1},"arguments":[{"selector":"[intercomTrackEvent]"}]}],"members":{"event":[{"__symbolic":"property","decorators":[{"__symbolic":"call","expression":{"__symbolic":"reference","module":"@angular/core","name":"Input","line":8,"character":3}}]}],"intercomTrackEvent":[{"__symbolic":"property","decorators":[{"__symbolic":"call","expression":{"__symbolic":"reference","module":"@angular/core","name":"Input","line":9,"character":3}}]}],"metadata":[{"__symbolic":"property","decorators":[{"__symbolic":"call","expression":{"__symbolic":"reference","module":"@angular/core","name":"Input","line":10,"character":3}}]}],"__ctor__":[{"__symbolic":"constructor","parameters":[{"__symbolic":"reference","name":"Intercom"}]}],"onClick":[{"__symbolic":"method","decorators":[{"__symbolic":"call","expression":{"__symbolic":"reference","module":"@angular/core","name":"HostListener","line":15,"character":3},"arguments":["click"]}]}]}}},"origins":{"Intercom":"./src/app/ng-intercom/intercom/intercom","IntercomConfig":"./src/app/ng-intercom/shared/intercom-config","IntercomHideDirective":"./src/app/ng-intercom/directives/hide.directive","IntercomModule":"./src/app/ng-intercom/intercom.module","IntercomShowDirective":"./src/app/ng-intercom/directives/show.directive","IntercomShowMessagesDirective":"./src/app/ng-intercom/directives/show-messages.directive","IntercomShowNewMessageDirective":"./src/app/ng-intercom/directives/show-new-message.directive","IntercomShutdownDirective":"./src/app/ng-intercom/directives/shutdown.directive","IntercomTrackEventDirective":"./src/app/ng-intercom/directives/track-event.directive"},"importAs":"ng-intercom"}
{"__symbolic":"module","version":4,"metadata":{"Intercom":{"__symbolic":"class","decorators":[{"__symbolic":"call","expression":{"__symbolic":"reference","module":"@angular/core","name":"Injectable","line":10,"character":1}}],"members":{"__ctor__":[{"__symbolic":"constructor","parameterDecorators":[[{"__symbolic":"call","expression":{"__symbolic":"reference","module":"@angular/core","name":"Inject","line":18,"character":5},"arguments":[{"__symbolic":"reference","name":"IntercomConfig"}]}],[{"__symbolic":"call","expression":{"__symbolic":"reference","module":"@angular/core","name":"Inject","line":19,"character":5},"arguments":[{"__symbolic":"reference","module":"@angular/core","name":"PLATFORM_ID","line":19,"character":12}]}],[{"__symbolic":"call","expression":{"__symbolic":"reference","module":"@angular/core","name":"Optional","line":20,"character":5}},{"__symbolic":"call","expression":{"__symbolic":"reference","module":"@angular/core","name":"Inject","line":20,"character":17},"arguments":[{"__symbolic":"reference","module":"@angular/router","name":"Router","line":20,"character":24}]}],null,[{"__symbolic":"call","expression":{"__symbolic":"reference","module":"@angular/core","name":"Optional","line":22,"character":5}},{"__symbolic":"call","expression":{"__symbolic":"reference","module":"@angular/core","name":"Inject","line":22,"character":17},"arguments":[{"__symbolic":"reference","module":"@angular/common","name":"DOCUMENT","line":22,"character":24}]}]],"parameters":[{"__symbolic":"reference","name":"IntercomConfig"},{"__symbolic":"reference","name":"Object"},{"__symbolic":"reference","module":"@angular/router","name":"Router","line":20,"character":48},{"__symbolic":"reference","module":"@angular/core","name":"RendererFactory2","line":21,"character":29},{"__symbolic":"reference","name":"any"}]}],"boot":[{"__symbolic":"method"}],"shutdown":[{"__symbolic":"method"}],"update":[{"__symbolic":"method"}],"hide":[{"__symbolic":"method"}],"show":[{"__symbolic":"method"}],"showMessages":[{"__symbolic":"method"}],"showNewMessage":[{"__symbolic":"method"}],"trackEvent":[{"__symbolic":"method"}],"getVisitorId":[{"__symbolic":"method"}],"onShow":[{"__symbolic":"method"}],"onHide":[{"__symbolic":"method"}],"onUnreadCountChange":[{"__symbolic":"method"}],"startTour":[{"__symbolic":"method"}],"_callIntercom":[{"__symbolic":"method"}],"injectIntercomScript":[{"__symbolic":"method"}],"loadIntercom":[{"__symbolic":"method"}]}},"IntercomConfig":{"__symbolic":"class","decorators":[{"__symbolic":"call","expression":{"__symbolic":"reference","module":"@angular/core","name":"Injectable","line":2,"character":1}}],"members":{}},"IntercomHideDirective":{"__symbolic":"class","decorators":[{"__symbolic":"call","expression":{"__symbolic":"reference","module":"@angular/core","name":"Directive","line":5,"character":1},"arguments":[{"selector":"[intercomHide]"}]}],"members":{"intercomHide":[{"__symbolic":"property","decorators":[{"__symbolic":"call","expression":{"__symbolic":"reference","module":"@angular/core","name":"Input","line":9,"character":3}}]}],"__ctor__":[{"__symbolic":"constructor","parameters":[{"__symbolic":"reference","name":"Intercom"}]}],"onClick":[{"__symbolic":"method","decorators":[{"__symbolic":"call","expression":{"__symbolic":"reference","module":"@angular/core","name":"HostListener","line":15,"character":3},"arguments":["click"]}]}]}},"IntercomModule":{"__symbolic":"class","decorators":[{"__symbolic":"call","expression":{"__symbolic":"reference","module":"@angular/core","name":"NgModule","line":12,"character":1},"arguments":[{"imports":[{"__symbolic":"reference","module":"@angular/router","name":"RouterModule","line":14,"character":4}],"declarations":[{"__symbolic":"reference","name":"IntercomHideDirective"},{"__symbolic":"reference","name":"IntercomShowMessagesDirective"},{"__symbolic":"reference","name":"IntercomShowNewMessageDirective"},{"__symbolic":"reference","name":"IntercomShowDirective"},{"__symbolic":"reference","name":"IntercomShutdownDirective"},{"__symbolic":"reference","name":"IntercomTrackEventDirective"}],"exports":[{"__symbolic":"reference","name":"IntercomHideDirective"},{"__symbolic":"reference","name":"IntercomShowMessagesDirective"},{"__symbolic":"reference","name":"IntercomShowNewMessageDirective"},{"__symbolic":"reference","name":"IntercomShowDirective"},{"__symbolic":"reference","name":"IntercomShutdownDirective"},{"__symbolic":"reference","name":"IntercomTrackEventDirective"}],"providers":[{"__symbolic":"reference","name":"Intercom"},{"__symbolic":"reference","name":"IntercomConfig"}]}]}],"members":{},"statics":{"forRoot":{"__symbolic":"function","parameters":["config"],"value":{"ngModule":{"__symbolic":"reference","name":"IntercomModule"},"providers":[{"__symbolic":"reference","name":"Intercom"},{"provide":{"__symbolic":"reference","name":"IntercomConfig"},"useValue":{"__symbolic":"reference","name":"config"}}]}}}},"IntercomShowDirective":{"__symbolic":"class","decorators":[{"__symbolic":"call","expression":{"__symbolic":"reference","module":"@angular/core","name":"Directive","line":5,"character":1},"arguments":[{"selector":"[intercomShow]"}]}],"members":{"message":[{"__symbolic":"property","decorators":[{"__symbolic":"call","expression":{"__symbolic":"reference","module":"@angular/core","name":"Input","line":9,"character":3}}]}],"intercomShow":[{"__symbolic":"property","decorators":[{"__symbolic":"call","expression":{"__symbolic":"reference","module":"@angular/core","name":"Input","line":10,"character":3}}]}],"__ctor__":[{"__symbolic":"constructor","parameters":[{"__symbolic":"reference","name":"Intercom"}]}],"onClick":[{"__symbolic":"method","decorators":[{"__symbolic":"call","expression":{"__symbolic":"reference","module":"@angular/core","name":"HostListener","line":15,"character":3},"arguments":["click"]}]}]}},"IntercomShowMessagesDirective":{"__symbolic":"class","decorators":[{"__symbolic":"call","expression":{"__symbolic":"reference","module":"@angular/core","name":"Directive","line":5,"character":1},"arguments":[{"selector":"[intercomShowMessages]"}]}],"members":{"intercomShowMessages":[{"__symbolic":"property","decorators":[{"__symbolic":"call","expression":{"__symbolic":"reference","module":"@angular/core","name":"Input","line":9,"character":3}}]}],"__ctor__":[{"__symbolic":"constructor","parameters":[{"__symbolic":"reference","name":"Intercom"}]}],"onClick":[{"__symbolic":"method","decorators":[{"__symbolic":"call","expression":{"__symbolic":"reference","module":"@angular/core","name":"HostListener","line":14,"character":3},"arguments":["click"]}]}]}},"IntercomShowNewMessageDirective":{"__symbolic":"class","decorators":[{"__symbolic":"call","expression":{"__symbolic":"reference","module":"@angular/core","name":"Directive","line":5,"character":1},"arguments":[{"selector":"[intercomShowNewMessage]"}]}],"members":{"message":[{"__symbolic":"property","decorators":[{"__symbolic":"call","expression":{"__symbolic":"reference","module":"@angular/core","name":"Input","line":9,"character":3}}]}],"intercomShowNewMessage":[{"__symbolic":"property","decorators":[{"__symbolic":"call","expression":{"__symbolic":"reference","module":"@angular/core","name":"Input","line":10,"character":3}}]}],"__ctor__":[{"__symbolic":"constructor","parameters":[{"__symbolic":"reference","name":"Intercom"}]}],"onClick":[{"__symbolic":"method","decorators":[{"__symbolic":"call","expression":{"__symbolic":"reference","module":"@angular/core","name":"HostListener","line":15,"character":3},"arguments":["click"]}]}]}},"IntercomShutdownDirective":{"__symbolic":"class","decorators":[{"__symbolic":"call","expression":{"__symbolic":"reference","module":"@angular/core","name":"Directive","line":5,"character":1},"arguments":[{"selector":"[intercomShutdown]"}]}],"members":{"intercomShutdown":[{"__symbolic":"property","decorators":[{"__symbolic":"call","expression":{"__symbolic":"reference","module":"@angular/core","name":"Input","line":9,"character":3}}]}],"__ctor__":[{"__symbolic":"constructor","parameters":[{"__symbolic":"reference","name":"Intercom"}]}],"onClick":[{"__symbolic":"method","decorators":[{"__symbolic":"call","expression":{"__symbolic":"reference","module":"@angular/core","name":"HostListener","line":14,"character":3},"arguments":["click"]}]}]}},"IntercomTrackEventDirective":{"__symbolic":"class","decorators":[{"__symbolic":"call","expression":{"__symbolic":"reference","module":"@angular/core","name":"Directive","line":4,"character":1},"arguments":[{"selector":"[intercomTrackEvent]"}]}],"members":{"event":[{"__symbolic":"property","decorators":[{"__symbolic":"call","expression":{"__symbolic":"reference","module":"@angular/core","name":"Input","line":8,"character":3}}]}],"intercomTrackEvent":[{"__symbolic":"property","decorators":[{"__symbolic":"call","expression":{"__symbolic":"reference","module":"@angular/core","name":"Input","line":9,"character":3}}]}],"metadata":[{"__symbolic":"property","decorators":[{"__symbolic":"call","expression":{"__symbolic":"reference","module":"@angular/core","name":"Input","line":10,"character":3}}]}],"__ctor__":[{"__symbolic":"constructor","parameters":[{"__symbolic":"reference","name":"Intercom"}]}],"onClick":[{"__symbolic":"method","decorators":[{"__symbolic":"call","expression":{"__symbolic":"reference","module":"@angular/core","name":"HostListener","line":15,"character":3},"arguments":["click"]}]}]}}},"origins":{"Intercom":"./src/app/ng-intercom/intercom/intercom","IntercomConfig":"./src/app/ng-intercom/shared/intercom-config","IntercomHideDirective":"./src/app/ng-intercom/directives/hide.directive","IntercomModule":"./src/app/ng-intercom/intercom.module","IntercomShowDirective":"./src/app/ng-intercom/directives/show.directive","IntercomShowMessagesDirective":"./src/app/ng-intercom/directives/show-messages.directive","IntercomShowNewMessageDirective":"./src/app/ng-intercom/directives/show-new-message.directive","IntercomShutdownDirective":"./src/app/ng-intercom/directives/shutdown.directive","IntercomTrackEventDirective":"./src/app/ng-intercom/directives/track-event.directive"},"importAs":"ng-intercom"}
{
"name": "ng-intercom",
"version": "8.0.0-beta.1",
"version": "8.0.0",
"license": "MIT",

@@ -78,3 +78,3 @@ "repository": {

"ng-packagr": "^4.7.0",
"node-sass": "^4.11.0",
"node-sass": "^4.12.0",
"npm-run-all": "^4.1.5",

@@ -81,0 +81,0 @@ "protractor": "^5.4.2",

@@ -94,5 +94,17 @@ import { RendererFactory2 } from '@angular/core';

onUnreadCountChange(handler: (unreadCount?: number) => void): void;
private callIntercom;
/**
* If you would like to trigger a tour based on an action a user or visitor takes in your site or application,
* ou can use this API method. You need to call this method with the id of the tour you wish to show. The id of
* the tour can be found in the “Use tour everywhere” section of the tour editor.
*
* Please note that tours shown via this API must be published and the “Use tour everywhere” section must be
* turned on. If you're calling this API using an invalid tour id, nothing will happen.
*/
startTour(tourId: number): void;
/**
* Private handler to run Intercom methods safely
*/
private _callIntercom;
injectIntercomScript(conf: IntercomConfig, afterInjectCallback: (ev: Event) => any): void;
loadIntercom(config: IntercomConfig, afterLoadCallback: (ev?: Event) => any): void;
}

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

SocketSocket SOC 2 Logo

Product

  • Package Alerts
  • Integrations
  • Docs
  • Pricing
  • FAQ
  • Roadmap
  • Changelog

Packages

npm

Stay in touch

Get open source security insights delivered straight into your inbox.


  • Terms
  • Privacy
  • Security

Made with ⚡️ by Socket Inc