#
ComeChat
You have an option of loading the Chat Widget in:
- Embedded Layout
- Docked Layout
#
Embedded Layout
Embedded Layout
You may simply copy-paste the code below to run the Chat Widget in Embedded Layout
<html>
<head>
<script defer src="https://widget-js.cometchat.io/v3/cometchatwidget.js"></script>
</head>
<body>
<div id="cometchat"></div>
<script>
window.addEventListener('DOMContentLoaded', (event) => {
CometChatWidget.init({
"appID": "APP_ID",
"appRegion": "APP_REGION",
}).then(response => {
console.log("Initialization completed successfully");
//You can now call login function.
CometChatWidget.login({
"uid": "UID"
}).then(response => {
CometChatWidget.launch({
"widgetID": "WIDGET_ID",
"target": "#cometchat",
"roundedCorners": "true",
"height": "600px",
"width": "800px",
"defaultID": 'superhero1', //default UID (user) or GUID (group) to show,
"defaultType": 'user' //user or group
});
}, error => {
console.log("User login failed with error:", error);
//Check the reason for error and take appropriate action.
});
}, error => {
console.log("Initialization failed with error:", error);
//Check the reason for error and take appropriate action.
});
});
</script>
</body>
</html>
To launch an Embedded Widget, pass a configuration object to launch
method with the following keys:
#
Docked Layout
Docked Layout
You may simply copy-paste the code below to run the Chat Widget in Docked Layout
<html>
<head>
<script defer src="https://widget-js.cometchat.io/v3/cometchatwidget.js"></script>
</head>
<body>
<script>
window.addEventListener('DOMContentLoaded', (event) => {
CometChatWidget.init({
"appID": "APP_ID",
"appRegion": "APP_REGION",
"authKey": "AUTH_KEY"
}).then(response => {
console.log("Initialization completed successfully");
//You can now call login function.
CometChatWidget.login({
"uid": "UID"
}).then(response => {
CometChatWidget.launch({
"widgetID": "WIDGET_ID",
"docked": "true",
"alignment": "left", //left or right
"roundedCorners": "true",
"height": "450px",
"width": "400px",
"defaultID": 'superhero1', //default UID (user) or GUID (group) to show,
"defaultType": 'user' //user or group
});
}, error => {
console.log("User login failed with error:", error);
//Check the reason for error and take appropriate action.
});
}, error => {
console.log("Initialization failed with error:", error);
//Check the reason for error and take appropriate action.
});
});
</body>
</html>
Copy
Please note that the above execution is taking place on |
To launch a Docked widget, pass a configuration object to the launch method with the following keys:
As mentioned earlier, this launch method can be called multiple times. By modifying the keys in the above configuration object.
Make sure you specify a different and unique |
#
Advanced Features
#
Open or close chat window
Chat window of docked layout can be opened/closed using the below method. This method can be triggered on the click event of any element of your webpage.
Javascript
xxxxxxxxxx
CometChatWidget.openOrCloseChat(FLAG); //true or false
Copy
It takes the following parameters:
| Parameter | Description | Type | | --- | --- | --- | | FLAG | Value could be true or false _ _true will open the chat window
false will close the chat window.
| Required |
#
Chat with a particular user
This method will open a particular user chat window. This method can be triggered by the click event of any element of your webpage.
Javascript
xxxxxxxxxx
CometChatWidget.chatWithUser(UID);
Copy
It takes the following parameters:
#
Chat with a particular group
This method will open a particular group chat window. This method can be triggered by the click event of any element of your webpage.
Javascript
xxxxxxxxxx
CometChatWidget.chatWithGroup(GUID);
Copy
It takes the following parameters:
#
Initiate calls with a particular user
This method will initiate a call with the user. This method can be triggered by the click event of any element of your web page.
Javascript
xxxxxxxxxx
CometChatWidget.callUser(UID);
Copy
#
It takes the following parameters:
#
Initiate calls with a particular group
This method will initiate a call with the group. This method can be triggered by the click event of any element of your web page.
Javascript
xxxxxxxxxx
CometChatWidget.callGroup(GUID);
Copy
It takes the following parameters:
#
Message Listener
We have provided a callback that is fired every time a message is received. You can use this to show Custom Notifications on your website or perform some other custom action as per your requirement.
Javascript
xxxxxxxxxx
CometChatWidget.launch({
// Embedded or Docked layout configuration
}).then(response => {
// OPTIONAL: This is called in the success callback of launch method
CometChatWidget.on("onMessageReceived", (message) => {
console.log("CometChatWidget onMessageReceived", message);
});
});
Copy
#
Chat open state listener
We have provided a callback that is fired every time the docked layout of the chat widget is in an open state. You can use this to perform some custom action as per your requirement.
Javascript
xxxxxxxxxx
CometChatWidget.launch({
// Embedded or Docked layout configuration
}).then(response => {
// OPTIONAL: This is called in the success callback of launch method
CometChatWidget.on("openChat", (args) => {
console.log("CometChatWidget Chat is open", args);
});
});
Copy
#
Chat closed state listener
We have provided a callback that is fired every time the docked layout of the chat widget is in a closed state. You can use this to perform some custom action as per your requirement.
Javascript
xxxxxxxxxx
CometChatWidget.launch({
// Embedded or Docked layout configuration
}).then(response => {
// OPTIONAL: This is called in the success callback of launch method
CometChatWidget.on("closeChat", (args) => {
console.log("CometChatWidget Chat is closed", args);
});
});
Copy
#
Click listener
We have provided a callback that is fired every time a user or group is clicked on the sidebar. You can use this to perform some custom action as per your requirement.
Javascript
xxxxxxxxxx
CometChatWidget.launch({
// Embedded or Docked layout configuration
}).then(response => {
// OPTIONAL: This is called in the success callback of launch method
CometChatWidget.on("onItemClick", (args) => {
console.log("CometChatWidget user/group is clicked", args);
});
});
Copy
#
Localization
With language localization, our Chat Widget adapts to the language of a specific country or region. Chat Widget allows you to detect the language of your users based on their browser settings and set the language of the widget accordingly. Currently, we support the following 12 languages for localization:
- English (en, en-US, en-GB)
- Chinese (zh, zh-TW)
- Spanish (es)
- Hindi (hi)
- Russian (ru)
- Arabic (ar)
- Portuguese (pt)
- Malay (ms)
- French (fr)
- German (de)
- Swedish (sv)
- Lithuanian (lt)
- Hungarian (hu)
Javascript
xxxxxxxxxx
CometChatWidget.localize(LANGUAGE_CODE);
Copy
It takes the following parameters:
#
User/Group Management
#
Create a user on-the-fly
This saves you the hassle of creating users beforehand from the CometChat Pro Dashboard. In order to create a user on-the-fly, you can call the createOrUpdateUser()
method on the CometChatWidget class.
It might happen that the user already exists. In that case, this method updates the user details. It can be used to change the user's name on-the-fly.
The method is as follows:
Javascript
xxxxxxxxxx
CometChatWidget.init({
appID: 'APP_ID',
appRegion: 'APP_REGION',
authKey: 'AUTH_KEY',
}).then((response) => {
/**
* Create user once initialization is successful
*/
const user = new CometChatWidget.CometChat.User(UID);
user.setName(NAME);
user.setAvatar(AVATAR_URL);
user.setLink(PROFILE_LINK);
CometChatWidget.createOrUpdateUser(user).then((user) => {
// Proceed with user login
CometChatWidget.login({
uid: UID,
}).then((loggedInUser) => {
// Proceed with launching your Chat Widget
CometChatWidget.launch({
// Embedded or docked layout configuration
})
});
});
});
Copy
It takes a configuration object with the following keys:
#
Create a group on-the-fly
This saves you the hassle of creating groups beforehand from the CometChat Pro Dashboard. In order to create a group on-the-fly, you can call the createOrUpdateGroup()
method on the CometChatWidget class.
It might happen that the group already exists. In that case, this method updates the group details. It can be used to change the group's name and type on the fly.
Javascript
xxxxxxxxxx
CometChatWidget.init({
appID: 'APP_ID',
appRegion: 'APP_REGION',
authKey: 'AUTH_KEY',
}).then((response) => {
CometChatWidget.login({
uid: "UID",
}).then((loggedInUser) => {
/**
* Create group once your user has logged in.
*/
const group = new CometChatWidget.CometChat.Group(GUID, GROUP_NAME, GROUP_TYPE, PASSWORD);
group.setIcon(ICON_URL);
CometChatWidget.createOrUpdateGroup(group).then(group => {
// Proceed with launch
CometChatWidget.launch({
// Embedded or docked layout configuration
})
});
});
});
Copy
It takes a configuration object with the following keys:
| Parameter | Description | Type | | --- | --- | --- | | GUID | The group will be created with the mentioned ID | Required | | GROUP_NAME | The name associated with the group being created | Required | | GROUP_TYPE | The type of group that you want to create. Type of the group can be:
- Public
- Password
- Private
| Required | | PASSWORD | The group password when groupType is set to 'Password' | Required | | ICON_URL | An URL to group icon | Optional |
#
User Logout
When your user logs out from the website, you can also log out the user from Chat Widget by calling the logout()
method of the CometChatWidget
class.
Javascript
xxxxxxxxxx
CometChatWidget.logout().then(response => {
// User successfully logged out.
// Perform any clean up if required.
});
Copy
#
Security Measures using Auth Token
If you wish to manage the Auth Key and generate Auth Token from your server application. We recommended you follow the below steps.
Please open this document - https://www.cometchat.com/docs/chat-apis/ref#createuser and refer to this Post API call (https://api-us.cometchat.io/v3.0/users) to create users and generate Auth token
You may then use the generated Auth Token and pass it to the login method below to log in to the user
The below code can be copy-pasted to launch your chat widget using Auth Token
Replace APP_ID, APP_REGION, AUTH_TOKEN, WIDGET_ID with your CometChat App ID, Region, Auth Token, and Widget ID in the below code. Replace UID with id of the user you want to login with. |
Embedded layout
Docked layout
xxxxxxxxxx
<html>
<head>
<script defer src="https://widget-js.cometchat.io/v3/cometchatwidget.js"></script>
</head>
<body>
<div id="cometchat"></div>
<script>
window.addEventListener('DOMContentLoaded', (event) => {
CometChatWidget.init({
"appID": "APP_ID",
"appRegion": "APP_REGION",
}).then(response => {
console.log("Initialization completed successfully");
//You can now call login function.
CometChatWidget.login({
"authToken": "AUTH_TOKEN"
}).then(response => {
CometChatWidget.launch({
"widgetID": "WIDGET_ID",
"target": "#cometchat",
"roundedCorners": "true",
"height": "600px",
"width": "800px",
"defaultID": 'superhero1', //default UID (user) or GUID (group) to show,
"defaultType": 'user' //user or group
});
}, error => {
console.log("User login failed with error:", error);
//Check the reason for error and take appropriate action.
});
}, error => {
console.log("Initialization failed with error:", error);
//Check the reason for error and take appropriate action.
});
});
</script>
</body>
</html>
Copy
To launch an embedded/docked widget, pass a configuration object to the launch method with the following keys: