Easy to use React Hook for Intercom.
- No need to mess with
index.html
, the Intercom script snippet is injected automatically - Configurable in React, defaults to global window settings
- Automatically reboots when app id or user changes
- Exposes the standard Intercom Javascript API
- Full Typescript definitions
# npm
$ npm install @reclaim-ai/react-intercom-hook
# yarn
$ yarn add @reclaim-ai/react-intercom-hook
- Initialize Intercom by passing in settings somewhere near the root of your app, usually
App.tsx
orApp.jsx
.
// App.tsx
import React from 'react';
import useIntercom from '@reclaim-ai/react-intercom-hook';
const App: React.FC = () => {
// Configure and initialize Intercom by passing a settings argument
const intercom = useIntercom({
app_id: INTERCOM_APP_ID, // app_id is required
// ... all other settings are optional
});
return (
// ...
);
}
- Include without arguments in any child component to interact with Intercom.
// AppRouter.tsx
import React, { useEffect } from 'react';
import useIntercom from '@reclaim-ai/react-intercom-hook';
import { BrowserRouter as Router, useLocation } from "react-router-dom";
const AppRouter: React.FC = () => {
// Call with no arguments to get the current instance of Intercom
const intercom = useIntercom();
const location = useLocation();
useEffect(() => {
// Track route changes
intercom('update');
}, [intercom, location]);
return (
// ...
);
}