
Security News
Deno 2.2 Improves Dependency Management and Expands Node.js Compatibility
Deno 2.2 enhances Node.js compatibility, improves dependency management, adds OpenTelemetry support, and expands linting and task automation for developers.
react-live-chat-loader
Advanced tools
Implement live chat in your react app without taking a performance hit.
An npm module that allows you to mitigate the negative performance and user
experience impact of chat tools. react-live-chat-loader
shows a fake widget
until the page has become idle or users are ready to interact with chat. Currently works with Intercom, Help Scout and Messenger.
Made by the team at ♠ Calibre, your performance companion.
Chat widgets rely heavily on JavaScript which comes at a cost. Given the significant impact that comes from the download, parse, compile and execution of chat JavaScript, React Live Chat Loader implements a "fake", fast loading button and waits for one of the following events before loading the actual widget:
Under the hood React Live Chat Loader makes use of requestIdleCallback
to
track how long the page has been idle for and checks if the user is on a slow
connection (using navigator.connection.effectiveType
) or has data-saver enabled
(using navigator.connection.saveData
) to prevent loading.
To download react-live-chat-loader run:
npm install --save react-live-chat-loader
Or if you're using yarn, run:
yarn add react-live-chat-loader
To allow you to trigger a single live chat within your application, React Live
Chat Loader has a Context Provider
which should be added at the root level of
your application.
You pass your providerKey
and provider
to the LiveChatLoaderProvider
.
For example, to add a LiveChatLoaderProvider
for Help Scout you would do the
following:
import { LiveChatLoaderProvider } from 'react-live-chat-loader'
export default class App extends React.Component {
/* ... */
render() {
return (
<LiveChatLoaderProvider providerKey="asdjkasl123123" provider="helpScout">
/* ... */
</LiveChatLoaderProvider>
)
}
}
You can then include the relevant chat where you would like it to appear.
For example, for Help Scout you would import the HelpScout
component and add it
to your application:
import { HelpScout } from 'react-live-chat-loader'
export default class Index extends React.Component {
/* ... */
render() {
return (
<>
/* ... */
<HelpScout />
</>
)
}
}
To display chat from a custom button you can import the useChat
hook which has the current state of the chat and a function to load the
chat.
import { useChat } from 'react-live-chat-loader'
export const LoadChatButton = () => {
const [state, loadChat] = useChat()
return <button onClick={loadChat}>Load Chat</button>
}
You can pass the following props to the LiveChatLoaderProvider
provider:
provider
: Choose from helpScout
or intercom
(see below)providerKey
: Provider API Key (see below)idlePeriod
: How long to wait in ms before loading the provider. Default is
2000
. Set to 0
to never load. This value is used in a setTimeout
in
browsers that don't support requestIdleCallback
.Currently there are two supported providers:
To use Help Scout import the LiveChatLoaderProvider
and set the provider
prop
as helpScout
and the providerKey
prop as your Beacon API Key.
Then import the HelpScout
component.
import { LiveChatLoaderProvider, HelpScout } from 'react-live-chat-loader'
export default class App extends React.Component {
render() {
return (
<LiveChatLoaderProvider providerKey="asdjkasl123123" provider="helpScout">
/* ... */
<HelpScout />
</LiveChatLoaderProvider>
)
}
}
You can customise the Help Scout beacon by passing the following props to the
HelpScout
component:
color
: The background color of the beaconicon
: Choose from message
, antenna
, search
, question
, beacon
zIndex
: Changes the CSS index value of how the Beacon relates to other objectshorizontalPosition
: Choose from left
or right
Currently the Help Scout component only supports the icon button style.
To use Intercom import the LiveChatLoaderProvider
and set the provider
prop
as intercom
and the providerKey
prop as your Intercom App ID.
Then import the Intercom
component.
import { LiveChatLoaderProvider, Intercom } from 'react-live-chat-loader'
export default class App extends React.Component {
render() {
return (
<LiveChatLoaderProvider providerKey="asd239" provider="intercom">
/* ... */
<Intercom />
</LiveChatLoaderProvider>
)
}
}
You can customise the color of the Intercom widget by passing a color
prop to
the Intercom
component.
To use Messenger, import the LiveChatLoaderProvider
and then set the provider
prop as messenger
and the providerKey
prop as your Facebook Page ID.
If you are using other Facebook features like share, you should set the appID
prop as your Facebook App ID as the Customer Chat SDK includes all the features that Facebook provide.
You can optionally set the locale
prop, the default value is en_US
.
Then import the Messenger
component.
import { LiveChatLoaderProvider, Messenger } from 'react-live-chat-loader'
export default class App extends React.Component {
render() {
return (
<LiveChatLoaderProvider
provider="messenger"
providerKey="111222333444555"
appID="111222333444555"
locale="en_US"
>
/* ... */
<Messenger />
</LiveChatLoaderProvider>
)
}
}
For a list of locale option values, refer to Facebook Localization documentation.
You can customise the Messenger widget by passing the following props to the
Messenger
component:
color
: The theme color of the widgetloggedInGreeting
: The greeting text that will be displayed if the user is currently logged in to Facebook.loggedOutGreeting
: The greeting text that will be displayed if the user is
currently not logged in to Facebook.greetingDialogDisplay
: Sets how the greeting dialog will be displayed.greetingDialogDelay
: Sets the number of seconds of delay before the greeting dialog is shown after the plugin is loaded.For a list of options, refer to Facebook Customer Chat Plugin documentation.
Please note: Facebook Messenger will not load on localhost and you will need to configure your domain through the setup wizard in Facebook for it to load correctly.
To contribute a new provider, follow these steps:
Create a new provider file at src/providers/providerName.js
using the
following as a template:
const domain = 'https://provider.domain.com'
const loadScript = () => {
// Detect the provider is already loaded and return early
if (alreadyLoaded) return
// Call provider script here
}
const load = ({ providerKey }) => {
loadScript()
// Initialise provider script
}
const open = () => // Open provider
const close = () => // Close provider
export default {
domain,
load,
open,
close
}
The provider must export the following:
domain
: A string of the domain where the provider script is loaded from
that will be used in a preconnect
link.load
: Function which when called will load and initialize the provider
script. It should accept props and use the providerKey
as the app_id
or
api_key
. For consistency, it should call a loadScript
function.open
: Function which when called will open the provider chat.close
: Function which when called will close the provider chat.Import the new file in src/providers/index.js
and add it to Providers
.
The name of this file will be the providerKey
used in the
LiveChatLoaderProvider
.
Create a new component in src/Components/ProviderName/index.js
which
replicates the chat widget, using the following as a template:
import React from 'react'
import { useChat } from '../../'
import STATES from '../../utils/states'
const styles = {
// Add widget styles here
button: {
// Add button styles here
}
}
const Provider = ({ color }) => {
const [state, loadChat] = useChat({ loadWhenIdle: true })
if (state === STATES.COMPLETE) return null
return (
<div>
<button
onClick={() => loadChat({ open: true })}
onMouseEnter={() => loadChat({ open: false })}
style={{
...styles.button,
backgroundColor: color
}}
>
Button
</button>
</div>
)
}
Provider.defaultProps = {
color: '#976ad4'
}
export default Provider
Do not worry about loading animations as the widget
will be shown instantly on page load. Increase the z-index
by 1
so the fake
widget sits immediately above the chat widget that is being replaced.
Export the component from src/index.js
Add your new provider to this README under Supported Providers.
Thanks goes to these wonderful people (emoji key):
Kevin Peng 💻 | Ash Kyd 📖 | Jeff Reiner 📖 |
This project follows the all-contributors specification. Contributions of any kind welcome!
FAQs
Implement live chat in your react app without taking a performance hit.
The npm package react-live-chat-loader receives a total of 9,293 weekly downloads. As such, react-live-chat-loader popularity was classified as popular.
We found that react-live-chat-loader demonstrated a healthy version release cadence and project activity because the last version was released less than a year ago. It has 0 open source maintainers collaborating on the project.
Did you know?
Socket for GitHub automatically highlights issues in each pull request and monitors the health of all your open source dependencies. Discover the contents of your packages and block harmful activity before you install or update your dependencies.
Security News
Deno 2.2 enhances Node.js compatibility, improves dependency management, adds OpenTelemetry support, and expands linting and task automation for developers.
Security News
React's CRA deprecation announcement sparked community criticism over framework recommendations, leading to quick updates acknowledging build tools like Vite as valid alternatives.
Security News
Ransomware payment rates hit an all-time low in 2024 as law enforcement crackdowns, stronger defenses, and shifting policies make attacks riskier and less profitable.