An Angular.js wrapper for


An Angular.js wrapper for providing a simple and familiar API for Angular Developer. I also added a asynchronous loading option $intercomProvider.asyncLoading(true) to allow anyone to quickly drop in and start using Intercom. This is great for startups who need a quick and easy way to interact with their customers

#How do I add this to my project? You can download angular-intercom by:

  • (prefered) Using bower and running bower install angular-intercom --save
  • Using npm and running npm install angular-intercom --save
  • Downloading it manually by clicking here to download development (unminified) (minified)
  • CDN


Here is a simple Example App which allows you to include your own app_id to test. Below is a quick start guide. Use either $intercom or Intercom service depending on your preference and opinions.

<!-- I'm using angular 1.3.8+ but any version should work -->
<script src=""></script>
You can include Intercom's script manually just make sure you add your app_id
<script async defer src="<%= INTERCOM_APPID %>"></script>
Or you can include Intercom sdk as you normally would
(function(){var w=window;var ic=w.Intercom;if(typeof ic==="function"){ic('reattach_activator');ic('update',intercomSettings);}else{var d=document;var i=function(){i.c(arguments)};i.q=[];i.c=function(args){i.q.push(args)};w.Intercom=i;function l(){var s=d.createElement('script');s.type='text/javascript';s.async=true;
s.src='<%= INSERT APP_ID HERE %>';
var x=d.getElementsByTagName('script')[0];x.parentNode.insertBefore(s,x);}if(w.attachEvent){w.attachEvent('onload',l);}else{w.addEventListener('load',l,false);}}})()
Or you can ask the module to load the script for you (see below) 
<!-- include this module after angular.js -->
<script src="app/bower_components/angular-intercom/angular-intercom.js"></script>
  angular.module('intercomApp', [
    'ngIntercom' // or you can use 'angular-intercom'
  .value('fakeUser', {
    email: '',
    name: 'John Doe',
    created_at: 1234567890,
    user_id: '9876'
  // inject your app_id anyway you like 
  .constant('INTERCOM_APPID', 'd0idn8ii')
  // Configure your $intercom module with appID 
  .config(function($intercomProviderINTERCOM_APPID) {
    // Either include your app_id here or later on boot 
    // you can include the Intercom's script yourself or use the built in async loading feature 
  .run(function($intercomfakeUser) {
    // boot $intercom after you have user data usually after auth success 
    $intercom.boot(fakeUser); // app_id not required if set in .config() block
  //                                       Intercom // you may use Intercom rather than $intercom 
  .controller('MainCtrl', function($scope$intercomfakeUser) {
    $scope.user = fakeUser;
    // Register listeners to $intercom using '.$on()' rather than '.on()' to trigger a safe $apply on $rootScope 
    $intercom.$on('show', function() {
      $scope.showing = true; // currently Intercom onShow callback isn't working
    $intercom.$on('hide', function() {
      $scope.showing = false;
    $ = function() {
    $scope.hide = function() {
    $scope.update = function(user) {

What is Intercom? An entirely new way to connect with your customers. Intercom shows you who is using your product and makes it easy to personally communicate with them through targeted, behavior-driven email and in-app messages.


Please see changelog for recent updates