Add, remove, and fetch message reactions in real-time using the CometChat React Native SDK. Includes listener events and helper methods for updating UI.
Use this file to discover all available pages before exploring further.
AI Integration Quick Reference
let messageId = "MESSAGE_ID";// Add a reactionawait CometChat.addReaction(messageId, "😊");// Remove a reactionawait CometChat.removeReaction(messageId, "😊");// Fetch reactions for a messageconst request = new CometChat.ReactionsRequestBuilder() .setMessageId(messageId).setLimit(10).build();const reactions = await request.fetchNext();// Listen for reaction eventsCometChat.addMessageListener("LISTENER_ID", new CometChat.MessageListener({ onMessageReactionAdded: (reaction) => {}, onMessageReactionRemoved: (reaction) => {}}));
Reactions let users respond to messages with emoji. You can add or remove reactions, fetch all reactions on a message, listen for reaction events in real time, and update your UI when reactions change.Reactions work on text messages, media messages, and custom messages.
Call getReactedByMe() on any ReactionCount object to check whether the logged-in user has reacted with that particular emoji. Returns true if they have, false otherwise.
TypeScript
JavaScript
let reactions:CometChat.ReactionCount[] = message.getReactions();reactions.forEach((reaction:CometChat.ReactionCount) => { reaction.getReactedByMe(); //Returns true if logged-in user reacted on that message, otherwise false})
let reactions = message.getReactions();reactions.forEach((reaction) => { reaction.getReactedByMe(); //Returns true if logged-in user reacted on that message, otherwise false})
To get the full list of who reacted with what on a specific message, use ReactionsRequestBuilder. You can paginate through results with fetchNext() and fetchPrevious() (max 100 per request).
Builder Method
Description
setMessageId(value)
The message ID to fetch reactions for. Required.
setReaction(value)
Filter to a specific emoji (e.g., "😊"). When set, only reactions matching this emoji are returned.
setLimit(value)
Number of reactions to fetch per request. Max 100.
let listenerID:string = "UNIQUE_LISTENER_ID";CometChat.removeMessageListener(listenerID);
let listenerID = "UNIQUE_LISTENER_ID";CometChat.removeMessageListener(listenerID);
Always remove listeners when they’re no longer needed (e.g., on component unmount or screen navigation). In React Native, place this in a cleanup function inside useEffect or in componentWillUnmount. Failing to remove listeners can cause memory leaks and duplicate event handling.
When a user adds or removes a reaction, you will receive a real-time event. Once you receive the real time event you would want to update the message with the latest reaction information. To do so you can use the updateMessageWithReactionInfo() method.The updateMessageWithReactionInfo() method provides a seamless way to update the reactions on a message instance (BaseMessage) in real-time. This method ensures that when a reaction is added or removed from a message, the BaseMessage object’s getReactions() property reflects this change immediately.When you receive a real-time reaction event (MessageReaction), call the updateMessageWithReactionInfo() method, passing the BaseMessage instance (message), event data (MessageReaction) and reaction event action type (CometChat.REACTION_ACTION.REACTION_ADDED or CometChat.REACTION_ACTION.REACTION_REMOVED) that corresponds to the message being reacted to.
TypeScript
JavaScript
// The message to which the reaction is relatedlet message: CometChat.BaseMessage = ...;// The reaction event data received in real-timelet messageReaction: CometChat.MessageReaction = ...;// The received reaction event real-time action typelet action: CometChat.REACTION_ACTION = CometChat.REACTION_ACTION.REACTION_ADDED;let modifiedBaseMessage = CometChat.CometChatHelper.updateMessageWithReactionInfo(message,messageReaction,action);
// The message to which the reaction is relatedlet message = ...;// The reaction event data received in real-timelet messageReaction = ...;// The received reaction event real-time action typelet action = CometChat.REACTION_ACTION.REACTION_ADDED;let modifiedBaseMessage = CometChat.CometChatHelper.updateMessageWithReactionInfo(message,messageReaction,action);
On success, this method returns a BaseMessage object. After calling this method, use modifiedBaseMessage.getReactions() to get the latest reactions and refresh your UI.
Parameter
Type
Description
message
BaseMessage
The message object to update
messageReaction
MessageReaction
The reaction event received from the listener
action
REACTION_ACTION
CometChat.REACTION_ACTION.REACTION_ADDED or CometChat.REACTION_ACTION.REACTION_REMOVED