Chat Widget
The ConnectyCube Web Chat Widget is designed to simplify the process of adding chat functionality to your Web apps. This widget offers an out-of-the-box solution for embedding chat features - such as instant messaging, user presence, and file sharing - without the overhead of building a complete chat system from scratch. Key benefits include:
- Easy integration: plug the widget into your existing Web projects.
- Customizable interface: adjust the look and feel to match your brand.
- Real-time messaging: leverage ConnectyCube’s reliable backend for instant communication.
- Responsive design: works seamlessly on both desktop and mobile devices.
- Modular and extensible: adapt the widget to your unique requirements.
Demo
https://connectycube-chat-widget.onrender.comSplit-view mode
data:image/s3,"s3://crabby-images/76e8b/76e8bdbf967c91509f4988a8b6727cd0f5139c1a" alt="ConnectyCube chat widget, split view image demo"
Single-view mode
data:image/s3,"s3://crabby-images/af723/af7236690f1dc00c7143b6fb088885f1fc856bc2" alt="ConnectyCube chat widget, single view image demo"
Installation
npm install @connectycube/chat-widget
// or
yarn add @connectycube/chat-widget
Add the following scripts on your html page somewhere in head
element:
<script src="https://unpkg.com/react@18/umd/react.production.min.js" crossorigin></script><script src="https://unpkg.com/react-dom@18/umd/react-dom.production.min.js" crossorigin></script><script src="https://unpkg.com/connectycube@4/dist/connectycube.min.js"></script><script src="https://unpkg.com/@connectycube/chat-widget@latest/dist/index.umd.js"></script>
Display widget
Before you start
Before you start, make sure:
- You have access to your ConnectyCube account. If you don’t have an account, sign up here.
- An app created in ConnectyCube dashboard. Once logged into your ConnectyCube account, create a new application and make a note of the app credentials (App ID and Auth Key) that you’ll need for authentication.
React
Import and place the following component in your app:
import ConnectyCubeChatWidget from "@connectycube/chat-widget";
...
<ConnectyCubeChatWidget appId="123" authKey="11111111-2222-3333-4444-55555555" userId="45" userName="Samuel" showOnlineUsersTab={false} splitView={true}/>
// userName - how other users will see your user name// userId - a User Id from your system
See chat widget code samples as a reference for faster integration.
Vanilla JS
Place the following script in your app:
<!doctype html><html lang="en"> <head> <!-- ... --> </head> <body> <!-- ... --> <!-- @connectycube/chat-widget - start --> <script src="https://unpkg.com/react@18/umd/react.production.min.js" crossorigin></script> <script src="https://unpkg.com/react-dom@18/umd/react-dom.production.min.js" crossorigin></script> <script src="https://unpkg.com/connectycube@4/dist/connectycube.min.js"></script> <script src="https://unpkg.com/@connectycube/chat-widget@latest/dist/index.umd.js"></script> <script> const chatWidgetContainer = document.createElement('div'); chatWidgetContainer.id = 'ConnectyCube_chat-widget'; document.body.appendChild(chatWidgetContainer); const props = { appId: 123, authKey: '11111111-2222-3333-4444-55555555', userId: '45', // a User Id from your system userName: 'Samuel', // how other users will see your user name showOnlineUsersTab: false, splitView: true, }; ReactDOM.createRoot(chatWidgetContainer).render(React.createElement(ConnectyCubeChatWidget, props)); </script> <!-- @connectycube/chat-widget - end --> </body></html>
See chat widget code samples as a reference for faster integration.
Props
Prop Name | Type | Description | Default Value |
---|---|---|---|
appId | number | string | The ConnectyCube Application ID | |
authKey | string | The ConnectyCube Authentication Key | |
config | object | (Optional) Configuration options for ConnectyCube SDK | |
userId | string | A User Id from your system | |
userName | string | User name. This is how other users will see your user name | |
userAvatar | string | (Optional) User Avatar URL | |
userProfileLink | string | (Optional) User profile link URL | |
muted | boolean | (Optional) Do not play sound on incoming message | false |
splitView | boolean | (Optional) Displays the chats in split view or single view | false |
showOnlineUsersTab | boolean | (Optional) Displays users tab with the list of online users | false |
buttonTitle | string | (Optional) The text displayed on the chat button | Chat |
buttonStyle | React.CSSProperties | (Optional) Inline styles for the button | |
portalStyle | React.CSSProperties | (Optional) Inline styles for the portal | |
badgeStyle | React.CSSProperties | (Optional) Inline styles for the badge | |
buttonClassName | string | (Optional) CSS class or Tailwind CSS classes for the button | |
portalClassName | string | (Optional) CSS class or Tailwind CSS classes for the chat | |
badgeClassName | string | (Optional) CSS class or Tailwind CSS classes for the badge | |
quickActions | object | (Optional) Configuration for quick actions dialog. See QuickActions | |
translation | string | (Optional) Specifies the language for the chat widget. See Supported Translations | en |
hideNewChatButton | boolean | (Optional) Allows to hide the chat creation button | false |
hideWidgetButton | boolean | (Optional) Allows to hide the button that opens/hides the chat widget | false |
open | boolean | (Optional) To control the visibility state of the chat widget | false |
onOpenChange | (open: boolean) => void | (Optional) Callback function to get update about chat widget visibility | |
onUnreadCountChange | (count: boolean) => void | (Optional) Callback function to get update about unread messages count |
Quick Actions
Prop Name | Type | Description | Default Value |
---|---|---|---|
title | string | (Optional) Title for the quick actions section | |
description | string | (Optional) Description for the quick actions | |
actions | string[] | List of action strings |
data:image/s3,"s3://crabby-images/23435/2343598efb90826df958833d4b3d19f42e5f0e4c" alt="ConnectyCube chat widget, Quick Actions demo"
Supported Translations
Language Code | Language |
---|---|
en | English |
el | Greek |
ua | Ukrainian |
Recipes
Split view
<ConnectyCubeChatWidget ... splitView={true}/>
const props = { ... splitView: true,};
Single view
<ConnectyCubeChatWidget ... splitView={false}/>
const props = { ... splitView: false,};
Show online users tab
<ConnectyCubeChatWidget ... showOnlineUsersTab={true}/>
const props = { ... showOnlineUsersTab: true,};
Display Chat button bottom left
<ConnectyCubeChatWidget ... buttonClassName={"left-2 right-auto"} portalClassName={"left-2 right-auto"}/>
const props = { ... buttonClassName: "left-2 right-auto", portalClassName: "left-2 right-auto"};
Code samples
See chat widget code samples as a reference for faster integration.
Changelog
https://github.com/ConnectyCube/connectycube-chat-widget-samples/blob/main/CHANGELOG.md