Overview
TheCometChatReactions component is designed to visually represent the reactions received by a message. Each reaction appears in a horizontal alignment beneath the message to indicate which emojis users have used to react.
The number of visible reactions depends on the width of the view. For example, if a message has 5 reactions but the CometChatReactions view can only accommodate 4 reactions within its width, the first three reactions will be displayed visibly. Additionally, an element will be added at the end of the row to indicate the number of other unique reactions that are not immediately visible. This element informs users of the total count of different reactions beyond those initially shown.

Usage
Integration
TheCometChatReactions component is a standard UIView that displays a list of reactions as its children. In the provided UI example, it is utilized within the footer view of the CometChatMessageBubble. However, it is versatile and can be incorporated anywhere a UIView can be placed. The minimum requirement for this component to function is to provide the reactions to display, which can be passed using the baseMessage property.
Swift
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. onReactionsPressed
TheonReactionsPressed event is triggered when a user interacts with a reaction by pressing it, typically to indicate a response or provide feedback.
- Swift
onReactionsPressed action.

Swift
Filters
Filters empower you to customize the displayed data within a component’s list by applying specific criteria. This capability allows for a more tailored and personalized view of the content. Filters are implemented using RequestBuilders of Chat SDK. TheReactions component does not provide any exposed filtering options.
Events
Events are triggered by a component, enabling you to enhance its functionality. These events are global in scope, making them applicable across multiple areas of your application, and they can be added or removed as required. TheReactions component does not provide any available events.
Customization
For customization aligned with your app’s design, you can adjust the appearance of the Reaction component using our accessible methods. These methods enable you to tailor the experience and behavior to suit your specific needs.Style
Through Style, you can customize the visual presentation of the component in your app. This includes controlling elements such as color, size, shape, and fonts to achieve the desired look and feel.1. Reactions Style
The ReactionsStyle class encapsulates properties that facilitate customization of the CometChatReactions component’s visual appearance.- Swift
reactionsStyle to customize the appearance.

Swift
| Property | Description | Code |
|---|---|---|
| Background Color | Sets the background color | .set(background: UIColor) |
| Corner Radiu | Sets the corner radius | .set(cornerRadius: CometChatCornerStyle) |
| Border Width | Sets the width of the border | .set(borderWidth: CGFloat) |
| Border Color | Sets the color of the border | .set(borderColor: UIColor) |
| Emoji Font | Sets the font for all emojis | .set(emojiFont: UIFont) |
| Count Color | Sets the text color for emojis count | .set(countColor: UIColor) |
| Count Font | Sets the font for emojis count | .set(countFont: UIFont) |
| Active Reaction Font | Sets the font for emojis i.e. reacted by the loggedIn user | .set(activeReactionFont: UIFont) |
| Active Reaction TextColor | Sets the text colour for emojis i.e. reacted by the loggedIn user | .set(activeReactionTextColor: UIColor) |
| Active Reaction Background Color | Sets the background color for emojis i.e. reacted by the loggedIn user | .set(activeReactionBackgroundColor: UIColor) |
| Active Reaction Border Color | Sets the border colour for emojis i.e. reacted by the loggedIn user | .set(activeReactionBorderColor: UIColor) |
| Active Reaction Border Width | Sets the border width for emojis i.e. reacted by the loggedIn user | .set(activeReactionBorderWidth: CGFloat) |
| Active Reaction Corner Radius | Sets the corner radius for emojis i.e. reacted by the loggedIn user | .set(activeReactionCornerRadius: CometChatCornerStyle) |
| Reaction Font | Sets the Font for emojis i.e. not reacted by the loggedIn user | .set(reactionfont: CGFloat) |
| Reaction Text Color | Sets the text colour for emojis i.e. not reacted by the loggedIn user | .set(reactionTextColor: UIColor) |
| Reaction Background Color | Sets the background colour for emojis i.e. not reacted by the loggedIn user | .set(reactionBackgroundColor: UIColor) |
| Reaction Border Color | Sets the border colour for emojis i.e. not reacted by the loggedIn user | .set(reactionBorderColor: UIColor) |
| Reaction Corner Radiusr | Sets the text color for the subtitle | .set(reactionCornerRadius: CometChatCornerStyle) |
| Reaction Border Width | Sets the border width for emojis i.e. not reacted by the loggedIn user | .set(reactionBorderWidth: CGFloat) |
Functionality
These functional customizations provide ways to enhance the component’s overall experience. They allow for text modification, custom icon setting, and UI element visibility toggling.- Swift
| Property | Description | Code |
|---|---|---|
| onReactionsLongPressed | This callback is triggered when a user long-presses a reaction. | (( reaction: ReactionCount, baseMessage: BaseMessage?) -> ())? |
| onReactionsPressed | This call back get trigger when a add reaction button is clicked. | (( reaction: ReactionCount, baseMessage: BaseMessage?) -> ())? |
| configuration | Used to customize configuration for CometChatReactions.. | ReactionsConfiguration |
Configuration
Configurations offer the ability to customize the properties of each component within a Composite Component.On Reactions Pressed
If you want to customize the properties of the ReactiononReactionsPressed Component inside Reactions Component, you need use the ReactionsConfiguration object.
- Swift
Swift

Swift
ReactionsConfigurations.
On Reactions LongPressed
If you want to customize the properties of the ReactiononReactionsLongPressed Component inside Reactions Component, you need use the ReactionsConfiguration object.
- Swift
Swift

- Swift
Custom_alert_View.Swift
ReactionsConfigurations
Swift
ReactionsConfigurations.