6.0.2 • Published 9 months ago

@capacitor-community/intercom v6.0.2

Weekly downloads
717
License
MIT
Repository
github
Last release
9 months ago

Sponsors

Maintainers

MaintainerGitHubSocial
Stewan Silvastewones@stewones

Installation

Using npm:

npm install @capacitor-community/intercom

Using yarn:

yarn add @capacitor-community/intercom

Sync native files:

npx cap sync

Usage

import { Intercom } from '@capacitor-community/intercom';
import { PushNotifications } from '@capacitor/push-notifications';

// Register for push notifications from Intercom
PushNotifications.register();

// Register an indetified user
Intercom.registerIdentifiedUser({ userId: 123456 });
Intercom.registerIdentifiedUser({ email: 'test@example.com' });
Intercom.registerIdentifiedUser({ userId: 123456, email: 'test@example.com' });

// Register a log event
Intercom.logEvent({ name: 'my-event', data: { pi: 3.14 } });

// Display the message composer
Intercom.displayMessageComposer({ message: 'Hello there!' });

// Identity Verification
// https://developers.intercom.com/installing-intercom/docs/ios-identity-verification
Intercom.setUserHash({ hmac: 'xyz' });

iOS setup

  • ionic start my-cap-app --capacitor
  • cd my-cap-app
  • npm install —-save @capacitor-community/intercom
  • mkdir www && touch www/index.html
  • npx cap add ios
  • add intercom keys to capacitor's configuration file
{
 …
  "plugins": {
   "Intercom": {
      "iosApiKey": "ios_sdk-xxx",
      "iosAppId": "yyy"
    }
  }
…
}
  • npx cap open ios
  • sign your app at xcode (general tab)

Tip: every time you change a native code you may need to clean up the cache (Product > Clean build folder) and then run the app again.

Android setup

  • ionic start my-cap-app --capacitor
  • cd my-cap-app
  • npm install —-save @capacitor-community/intercom
  • mkdir www && touch www/index.html
  • npx cap add android
  • add intercom keys to capacitor's configuration file
{
 …
  "plugins": {
   "Intercom": {
      "androidApiKey": "android_sdk-xxx",
      "androidAppId": "yyy"
    }
  }
…
}
  • npx cap open android

Now you should be set to go. Try to run your client using ionic cap run android --livereload.

Tip: every time you change a native code you may need to clean up the cache (Build > Clean Project | Build > Rebuild Project) and then run the app again.

API

loadWithKeys(...)

loadWithKeys(options: { appId?: string; apiKeyIOS?: string; apiKeyAndroid?: string; }) => any
ParamType
options{ appId?: string; apiKeyIOS?: string; apiKeyAndroid?: string; }

Returns: any


registerIdentifiedUser(...)

registerIdentifiedUser(options: { userId?: string; email?: string; }) => any
ParamType
options{ userId?: string; email?: string; }

Returns: any


registerUnidentifiedUser()

registerUnidentifiedUser() => any

Returns: any


updateUser(...)

updateUser(options: IntercomUserUpdateOptions) => any
ParamType
optionsIntercomUserUpdateOptions

Returns: any


logout()

logout() => any

Returns: any


logEvent(...)

logEvent(options: { name: string; data?: any; }) => any
ParamType
options{ name: string; data?: any; }

Returns: any


displayMessenger()

displayMessenger() => any

Returns: any


displayMessageComposer(...)

displayMessageComposer(options: { message: string; }) => any
ParamType
options{ message: string; }

Returns: any


displayHelpCenter()

displayHelpCenter() => any

Returns: any


hideMessenger()

hideMessenger() => any

Returns: any


displayLauncher()

displayLauncher() => any

Returns: any


hideLauncher()

hideLauncher() => any

Returns: any


displayInAppMessages()

displayInAppMessages() => any

Returns: any


hideInAppMessages()

hideInAppMessages() => any

Returns: any


displayCarousel(...)

displayCarousel(options: { carouselId: string; }) => any
ParamType
options{ carouselId: string; }

Returns: any


setUserHash(...)

setUserHash(options: { hmac: string; }) => any
ParamType
options{ hmac: string; }

Returns: any


setBottomPadding(...)

setBottomPadding(options: { value: string; }) => any
ParamType
options{ value: string; }

Returns: any


sendPushTokenToIntercom(...)

sendPushTokenToIntercom(options: { value: string; }) => any
ParamType
options{ value: string; }

Returns: any


receivePush(...)

receivePush(notification: IntercomPushNotificationData) => any
ParamType
notificationIntercomPushNotificationData

Returns: any


displayArticle(...)

displayArticle(options: { articleId: string; }) => any
ParamType
options{ articleId: string; }

Returns: any


addListener(...)

addListener(eventName: 'windowDidShow', listenerFunc: () => void) => any
ParamType
eventName"windowDidShow"
listenerFunc() => void

Returns: any


addListener(...)

addListener(eventName: 'windowDidHide', listenerFunc: () => void) => any
ParamType
eventName"windowDidHide"
listenerFunc() => void

Returns: any


removeAllListeners()

removeAllListeners() => any

Returns: any


Interfaces

IntercomUserUpdateOptions

PropType
userIdstring
emailstring
namestring
phonestring
languageOverridestring
customAttributes{ key: string: any; }

IntercomPushNotificationData

PropType
conversation_idstring
messagestring
bodystring
author_namestring
image_urlstring
app_namestring
receiverstring
conversation_part_typestring
intercom_push_typestring
uristring
push_only_conversation_idstring
instance_idstring
titlestring
prioritynumber

PluginListenerHandle

PropType
remove() => any

Notice 🚀

We're starting fresh under an official org. If you were using the previous npm package capacitor-intercom, please update your package.json to @capacitor-community/intercom. Check out changelog for more info.

Breaking changes from Capacitor v2 to v3

  • UserUpdateOptions option type becomes IntercomUserUpdateOptions
  • IntercomPlugin configuration key becomes Intercom
  • android-apiKey config key becomes androidApiKey
  • android-appId config key becomes androidAppId
  • ios-apiKey config key becomes iosApiKey
  • ios-appId config key becomes iosAppId
  • Switch from CAPBridge to ApplicationDelegateProxy in application events
  • remove the whole onCreate initialization from your app's MainActivity.java
 public class MainActivity extends BridgeActivity {
-    @Override
-    public void onCreate(Bundle savedInstanceState) {
-        super.onCreate(savedInstanceState);
-
-        // Initializes the Bridge
-        this.init(savedInstanceState, new ArrayList<Class<? extends Plugin>>() {{
-            // Additional plugins you've installed go here
-            add(IntercomPlugin.class);
-        }});
-    }
 }

License

MIT

Example

Contributors ✨

Thanks goes to these wonderful people (emoji key):

This project follows the all-contributors specification. Contributions of any kind welcome!

6.0.1

9 months ago

6.0.2

9 months ago

6.0.0

1 year ago

5.0.1

1 year ago

5.0.0

2 years ago

4.0.1

3 years ago

4.0.2

3 years ago

4.0.0

3 years ago

4.0.0-0

3 years ago

3.0.3

3 years ago

3.0.2

3 years ago

3.0.1

4 years ago

3.0.0

4 years ago

2.0.1

4 years ago

2.0.0

4 years ago

1.1.0

5 years ago

1.0.3

5 years ago

1.0.2

5 years ago

1.0.1

5 years ago

1.0.0

5 years ago