Skip to main content
Version: v4

Reaction List

Overview

The Reaction List component provides a comprehensive display of reactions associated with a message, showcasing which reactions were made by individual users. Additionaly, users can interact with the list to remove their own reactions.

Image

Usage

Integration

The following code snippet illustrates how you can directly incorporate the Reactions list component into your app.

import { CometChat } from '@cometchat/chat-sdk-javascript';
import { CometChatReactionList, ReactionListStyle } from '@cometchat/chat-uikit-react'
import React from 'react'
import { createComponent } from "@lit-labs/react";

const ReactionListDemo = () => {
const [message, setmessage] = React.useState<CometChat.BaseMessage | undefined>();


React.useEffect(() => {
CometChat.getMessageDetails(message-id).then((message) => {
setmessage(message);
})
}, []);

const ReactionList = createComponent({
tagName: "cometchat-reaction-list",
elementClass: CometChatReactionList,
react: React,
});

const reactionListStyle = new ReactionListStyle({
background:'#9a41fa',
border:'2px solid #6e2eb3',
borderRadius:'20px',
activeEmojiBackground:'#d4b2f7',
subtitleTextColor:'#f4ebff',
})
return (
<>
{
message &&
<div style={{marginTop:'500px', marginLeft:'300px'}}>
<ReactionList
messageObject={message}
reactionListStyle={reactionListStyle}
/>
</div>
}
</>
)
}

export default ReactionListDemo;

Actions

Actions dictate how a component functions. They are divided into two types: Predefined and User-defined. You can override either type, allowing you to tailor the behavior of the component to fit your specific needs.

1. reactionItemClicked

The reactionItemClicked event gets activated when a user clicks on a reaction item within the CometChat Reaction List component. This event provides a way to capture and respond to user interactions with specific reactions.

import { CometChat } from '@cometchat/chat-sdk-javascript';
import { CometChatReactionList } from '@cometchat/chat-uikit-react'
import React from 'react'
import { createComponent } from "@lit-labs/react";

const ReactionListDemo = () => {
const [message, setmessage] = React.useState<CometChat.BaseMessage | undefined>();


React.useEffect(() => {
CometChat.getMessageDetails(message-id).then((message) => {
setmessage(message);
})
}, []);

const ReactionList = createComponent({
tagName: "cometchat-reaction-list",
elementClass: CometChatReactionList,
react: React,
});

const getOnReactionItemClicked = () =>{
console.log("Your custom reaction item click actions");
}
return (
<>
{
message &&
<div style={{marginTop:'500px', marginLeft:'300px'}}>
<ReactionList
messageObject={message}
reactionItemClicked={getOnReactionItemClicked}
/>
</div>
}
</>
)
}

export default ReactionListDemo;

Filters

Filters allow you to customize the data displayed in a list within a Component. You can filter the list based on your specific criteria, allowing for a more customized. Filters can be applied using RequestBuilders of Chat SDK.

You can adjust the ReactionsRequestBuilder in the Reaction list Component to customize your Reaction list. Numerous options are available to alter the builder to meet your specific needs. For additional details on ReactionsRequestBuilder, please visit ReactionsRequestBuilder.

In the example below, we demonstrate the application of a filter to the reactions list. This filter allows you to specify a limit of the users who have reacted to the perticular message.

Image
import { CometChat } from '@cometchat/chat-sdk-javascript';
import { CometChatReactionList } from '@cometchat/chat-uikit-react'
import React from 'react'
import { createComponent } from "@lit-labs/react";

const ReactionListDemo = () => {
const [message, setmessage] = React.useState<CometChat.BaseMessage | undefined>();


React.useEffect(() => {
CometChat.getMessageDetails(message-id).then((message) => {
setmessage(message);
})
}, []);

const ReactionList = createComponent({
tagName: "cometchat-reaction-list",
elementClass: CometChatReactionList,
react: React,
});
return (
<>
{
message &&
<div style={{marginTop:'500px', marginLeft:'300px'}}>
<ReactionList
messageObject={message}
reactionsRequestBuilder={new CometChat.ReactionsRequestBuilder().setLimit(2)}
/>
</div>
}
</>
)
}

export default ReactionListDemo;

Events

Events are emitted by a Component. By using event you can extend existing functionality. Being global events, they can be applied in Multiple Locations and are capable of being Added or Removed.

The Reactions list component does not produce any events.

Customization

To fit your app's design requirements, you can customize the appearance of the Reaction List component. We provide exposed methods that allow you to modify the experience and behavior according to your specific needs.

Style

Using Style you can customize the look and feel of the component in your app, These parameters typically control elements such as the color, size, shape, and fonts used within the component.

1. reactionListStyle

To customize the appearance, you can assign a reactionListStyle object to the Reactions List component.

Example

In this example, we are employing the reactionListStyle.

import { CometChat } from '@cometchat/chat-sdk-javascript';
import { CometChatReactionList, ReactionListStyle } from '@cometchat/chat-uikit-react'
import React from 'react'
import { createComponent } from "@lit-labs/react";

const ReactionListDemo = () => {
const [message, setmessage] = React.useState<CometChat.BaseMessage | undefined>();


React.useEffect(() => {
CometChat.getMessageDetails(message-id).then((message) => {
setmessage(message);
})
}, []);

const ReactionList = createComponent({
tagName: "cometchat-reaction-list",
elementClass: CometChatReactionList,
react: React,
});

const reactionListStyle = new ReactionListStyle({
background:'#9a41fa',
border:'2px solid #6e2eb3',
borderRadius:'20px',
activeEmojiBackground:'#d4b2f7',
subtitleTextColor:'#f4ebff',
})
return (
<>
{
message &&
<div style={{marginTop:'500px', marginLeft:'300px'}}>
<ReactionList
messageObject={message}
reactionListStyle={reactionListStyle}
/>
</div>
}
</>
)
}

export default ReactionListDemo;
Image

List of properties exposed by ReactionsListStyle

PropertyDescriptionCode
borderUsed to set borderborder?: string,
borderRadiusUsed to set border radiusborderRadius?: string;
backgroundUsed to set background colourbackground?: string;
heightUsed to set heightheight?: string;
widthUsed to set widthwidth?: string;
sliderEmojiFontused to set the font of slider emojisliderEmojiFont?: string;
sliderEmojiCountFontused to set the font of the slider emoji countsliderEmojiCountFont?: string;
sliderEmojiCountColorused to set the color of the slider emoji countsliderEmojiCountColor?: string;
activeEmojiBackgroundused to set the active emoji backgroundactiveEmojiBackground?: string;
loadingIconTintused to set the loading icon colorloadingIconTint?: string;
errorIconTintused to set the error icon colorerrorIconTint?: string;
tailViewFontused to set the tail view fonttailViewFont?: string;
subtitleTextFontused to set the subtitle text fontsubtitleTextFont?: string;
subtitleTextColorused to set the subtitle text colorsubtitleTextColor?: string;
dividerTintused to set the divider colordividerTint?: string;

2. Avatar Style

If you want to apply customized styles to the Avatar component within the Reaction List Component, you can use the following code snippet. For more information you can refer Avatar Styles.

import { CometChat } from '@cometchat/chat-sdk-javascript';
import { CometChatReactionList, AvatarStyle } from '@cometchat/chat-uikit-react'
import React from 'react'
import { createComponent } from "@lit-labs/react";

const ReactionListDemo = () => {
const [message, setmessage] = React.useState<CometChat.BaseMessage | undefined>();


React.useEffect(() => {
CometChat.getMessageDetails(message-id).then((message) => {
setmessage(message);
})
}, []);

const ReactionList = createComponent({
tagName: "cometchat-reaction-list",
elementClass: CometChatReactionList,
react: React,
});

const avatarStyle = new AvatarStyle({
width: "100%",
height: "100%",
border: "1px solid blue",
backgroundColor:"gray",
borderRadius:"20px"
});
return (
<>
{
message &&
<div style={{marginTop:'500px', marginLeft:'300px'}}>
<ReactionList
messageObject={message}
avatarStyle={avatarStyle}
/>
</div>
}
</>
)
}

export default ReactionListDemo;
3. ListItem Style

If you want to apply customized styles to the ListItemStyle component within the Reaction List Component, you can use the following code snippet. For more information, you can refer ListItem Styles.

import { CometChat } from '@cometchat/chat-sdk-javascript';
import { CometChatReactionList, ListItemStyle } from '@cometchat/chat-uikit-react'
import React from 'react'
import { createComponent } from "@lit-labs/react";

const ReactionListDemo = () => {
const [message, setmessage] = React.useState<CometChat.BaseMessage | undefined>();


React.useEffect(() => {
CometChat.getMessageDetails(message-id).then((message) => {
setmessage(message);
})
}, []);

const ReactionList = createComponent({
tagName: "cometchat-reaction-list",
elementClass: CometChatReactionList,
react: React,
});

const listItemStyle = new ListItemStyle({
background: "transparent",
padding:"5px",
border:"1px solid #e9b8f5",
titleColor:"#8830f2",
borderRadius:"20px",
width:"100% !important"
});
return (
<>
{
message &&
<div style={{marginTop:'500px', marginLeft:'300px'}}>
<ReactionList
messageObject={message}
listItemStyle={listItemStyle}
/>
</div>
}
</>
)
}

export default ReactionListDemo;

Functionality

These are a set of small functional customizations that allow you to fine-tune the overall experience of the component. With these, you can change text, set custom icons, and toggle the visibility of UI elements.

import { CometChat } from '@cometchat/chat-sdk-javascript';
import { CometChatReactionList } from '@cometchat/chat-uikit-react'
import React from 'react'
import { createComponent } from "@lit-labs/react";

const ReactionListDemo = () => {
const [message, setmessage] = React.useState<CometChat.BaseMessage | undefined>();


React.useEffect(() => {
CometChat.getMessageDetails(message-id).then((message) => {
setmessage(message);
})
}, []);

const ReactionList = createComponent({
tagName: "cometchat-reaction-list",
elementClass: CometChatReactionList,
react: React,
});
return (
<>
{
message &&
<div style={{marginTop:'500px', marginLeft:'300px'}}>
<ReactionList
messageObject={message}
loadingIconURL="your custom loading icon url"
errorIconURL="your custom error icon url"
/>
</div>
}
</>
)
}

export default ReactionListDemo;

Below is a customizations list along with corresponding code snippets

PropertyDescriptionCode
loadingIconURLused to set the custom loading iconloadingIconURL="your custom loading icon url"
errorIconURLused to set the error iconerrorIconURL="your custom error icon url"