Message List
Overview
MessageList
is a Composite Component that displays a list of messages and effectively manages real-time operations. It includes various types of messages such as Text Messages, Media Messages, Stickers, and more.
MessageList
is primarily a list of the base component MessageBubble. The MessageBubble Component is utilized to create different types of chat bubbles depending on the message type.
data:image/s3,"s3://crabby-images/e24c3/e24c3ac4a424fb2bfc9bc82832173b5dfd49e70d" alt="Image"
Usage
Integration
The following code snippet illustrates how you can directly incorporate the MessageList component into your layout.xml
file.
- XML
<com.cometchat.chatuikit.messagelist.CometChatMessageList
android:id="@+id/message_list"
android:layout_width="match_parent"
android:layout_height="match_parent"
android:layout_marginStart="16dp"
android:layout_marginEnd="16dp"
android:background="@android:color/transparent" />
Simply adding the MessageList
component to the layout will only display the loading indicator. To fetch messages for a specific entity, you need to supplement it with User
or Group
Object.
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. onThreadRepliesClick
onThreadRepliesClick
is triggered when you click on the threaded message bubble.
The onThreadRepliesClick
action doesn't have a predefined behavior. You can override this action using the following code snippet.
- Java
- Kotlin
cometchatMessageList.setOnThreadRepliesClick((context, baseMessage, cometchatMessageTemplate) -> {
});
cometchatMessageList.onThreadRepliesClick =
ThreadReplyClick { context, baseMessage, cometchatMessageTemplate -> }
2. onError
This action doesn't change the behavior of the component but rather listens for any errors that occur in the MessageList component.
- Java
- Kotlin
cometchatMessageList.setOnError(new OnError() {
@Override
public void onError(CometChatException e) {
//Your Exception Handling code.
}
});
cometchatMessageList.setOnError(object : OnError {
override fun onError(e: CometChatException) {
// Your Exception Handling code.
}
})
setOnLoad
Invoked when the list is successfully fetched and loaded, helping track component readiness.
- Java
- Kotlin
cometchatMessageList.setOnLoad(list -> {
});
cometchatMessageList.setOnLoad(object : OnLoad<BaseMessage?> {
override fun onLoad(list: MutableList<BaseMessage?>?) {
}
})
setOnEmpty
Called when the list is empty, enabling custom handling such as showing a placeholder message.
- Java
- Kotlin
cometchatMessageList.setOnEmpty(() -> {
});
cometchatMessageList.setOnEmpty{
}
onReactionLongClick
Function triggered when a user long presses on a reaction pill, allowing developers to override the default behavior.
- Java
- Kotlin
cometchatMessageList.setOnReactionLongClick((emoji, baseMessage) -> {
});
cometchatMessageList.onReactionLongClick = OnReactionLongClick { emoji, baseMessage -> }
onAddMoreReactionsClick
Function triggered when a user clicks on the 'Add More Reactions' button, allowing developers to handle this action.
- Java
- Kotlin
cometchatMessageList.setOnAddMoreReactionsClick(baseMessage -> {
});
cometchatMessageList.onAddMoreReactionsClick =
OnAddMoreReactionsClick {
}
onReactionClick
Function triggered when a reaction is clicked, enabling developers to customize reaction interactions.
- Java
- Kotlin
cometchatMessageList.setOnReactionClick((emoji, baseMessage) -> {
});
cometchatMessageList.onReactionClick = OnReactionClick { emoji, baseMessage -> }
setOnReactionListItemClick
Function triggered when a reaction list item is clicked, allowing developers to override its behavior in CometChatReactionsList.
- Java
- Kotlin
cometchatMessageList.setOnReactionListItemClick((reaction, message) -> {
});
cometchatMessageList.onReactionListItemClick =
OnReactionListItemClick { reaction, message -> }
Filters
You can adjust the MessagesRequestBuilder
in the MessageList Component to customize your message list. Numerous options are available to alter the builder to meet your specific needs. For additional details on MessagesRequestBuilder
, please visit MessagesRequestBuilder.
In the example below, we are applying a filter to the messages based on a search substring and for a specific user. This means that only messages that contain the search term and are associated with the specified user will be displayed
- Java
- Kotlin
MessagesRequest.MessagesRequestBuilder messagesRequest = new MessagesRequest.MessagesRequestBuilder()
.setSearchKeyword("your search keyword")
.setUID("user uid");
messageList.setMessagesRequestBuilder(messagesRequest);
val messagesRequest = MessagesRequest.MessagesRequestBuilder()
.setSearchKeyword("your search keyword")
.setUID("user uid")
.build()
messageList.messagesRequestBuilder = messagesRequest
The following parameters in messageRequestBuilder will always be altered inside the message list
- UID
- GUID
- types
- categories
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 MessageList Component does not emit any events of its own.
Customization
To fit your app's design requirements, you can customize the appearance of the conversation 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.
data:image/s3,"s3://crabby-images/7f195/7f1952016470c33de74e801277aa19266f88fa70" alt="Image"
<style name="CustomOutgoingMessageBubbleStyle" parent="CometChatOutgoingMessageBubbleStyle">
<item name="cometchatMessageBubbleBackgroundColor">#F76808</item>
</style>
<style name="CustomCometChatMessageListStyle" parent="CometChatMessageListStyle">
<item name="cometchatMessageListBackgroundColor">#FEEDE1</item>
<item name="cometchatMessageListOutgoingMessageBubbleStyle">@style/CustomOutgoingMessageBubbleStyle</item>
</style>
- Java
- Kotlin
cometChatMessageList.setStyle(R.style.CustomCometChatMessageListStyle);
cometChatMessageList.setStyle(R.style.CustomCometChatMessageListStyle);
To know more such attributes, visit the attributes file.
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.
- Java
- Kotlin
CometChatMessageList cometChatMessageList = findViewById(R.id.message_list);
cometChatMessageList.setUser(user);
cometChatMessageList.hideError(true);
cometChatMessageList.hideReceipt(true);
val cometChatMessageList = findViewById<CometChatMessageList>(R.id.message_list)
cometChatMessageList.setUser(user)
cometChatMessageList.hideError(true)
cometChatMessageList.hideReceipt(true)
Below is a list of customizations along with corresponding code snippets
data:image/s3,"s3://crabby-images/e24c3/e24c3ac4a424fb2bfc9bc82832173b5dfd49e70d" alt="Image"
Property | Description | Code |
---|---|---|
setUser | Used to pass user object of which header specific details will be shown | .setUser(user); |
setGroup | Used to pass group object of which header specific details will be shown | .setGroup(Group); |
setAlignment | used to set the alignmet of messages in CometChatMessageList. It can be either leftAligned or standard | .setAlignment(UIKitConstants.MessageListAlignment); |
setErrorStateVisibility | used to toggle visibility of error state in MessageList | .setErrorStateVisibility(View.GONE); |
disableSoundForMessages | used to enable/disable sound for incoming/outgoing messages , default false | .disableSoundForMessages(false); |
setCustomSoundForMessages | used to set custom sound for outgoing message | .setCustomSoundForMessages(@RawRes resource); |
setAvatarVisibility | used to toggle visibility for avatar | .setAvatarVisibility(View.GONE); |
scrollToBottomOnNewMessage | should scroll to bottom on new message? , by default false | .scrollToBottomOnNewMessage(true); |
setReceiptsVisibility | Used to control visibility of read receipts without disabling the functionality of marking messages as read and delivered. | .setReceiptsVisibility(View.GONE); |
setQuickReactions | The list of quick reactions to be set.This list will replace the predefined set of reactions | .setQuickReactions(Arrays.asList("👻","😈","🙀","🤡","❤️"); |
setStickyDateVisibility | used to toggle visibility for sticky header | .setStickyDateVisibility(View.GONE); |
replyInThreadOptionVisibility | used to toggle visibility for thread option | .replyInThreadOptionVisibility(View.GONE); |
translateMessageOptionVisibility | used to toggle visibility for translate option | .translateMessageOptionVisibility(View.GONE); |
editMessageOptionVisibility | used to toggle visibility for edit option | .editMessageOptionVisibility(View.GONE); |
deleteMessageOptionVisibility | used to toggle visibility for delete option | .deleteMessageOptionVisibility(View.GONE); |
setMessageReactionOptionVisibility | used to toggle visibility for reaction option | .setMessageReactionOptionVisibility(View.GONE); |
messagePrivatelyOptionVisibility | used to toggle visibility for private option | .messagePrivatelyOptionVisibility(View.GONE); |
copyMessageOptionVisibility | used to toggle visibility for copy option | .copyMessageOptionVisibility(View.GONE); |
messageInfoOptionVisibility | used to toggle visibility for info option | .messageInfoOptionVisibility(View.GONE); |
groupActionMessageVisibility | used to toggle visibility for action message option | .groupActionMessageVisibility(View.GONE); |
enableConversationStarters | Controls whether conversation starters are generated in new conversations | .enableConversationStarters(true); |
enableSmartReplies | Enables smart replies for quick responses | .enableSmartReplies(true); |
smartRepliesKeywords | Defines specific keywords in an incoming message that will trigger Smart Replies. | .setAISmartRepliesKeywords(Arrays.asList("hello", "hi", "how are you", "good morning", "good evening", "good night")); |
smartRepliesDelayDuration | Sets the delay time before Smart Replies are fetched and displayed after a message is received. | .smartRepliesDelayDuration(5000); |
Advance
For advanced-level customization, you can set custom views to the component. This lets you tailor each aspect of the component to fit your exact needs and application aesthetics. You can create and define your views, layouts, and UI elements and then incorporate those into the component.
SetTemplate
CometChatMessageTemplate is a pre-defined structure for creating message views that can be used as a starting point or blueprint for creating message views often known as message bubbles. For more information, you can refer to CometChatMessageTemplate.
setDateFormat
Specifies a custom format for displaying sticky date separators in the chat.
Use Cases:
- Customize date formats to match regional preferences.
- Use relative formats like "Yesterday" instead of full dates.
- Highlight weekend conversations with different styles.
- Java
- Kotlin
messageList.setDateFormat(new SimpleDateFormat("MMM dd, yyyy",Locale.getDefault()));
messageList.setDateFormat(SimpleDateFormat("MMM dd, yyyy",Locale.getDefault()))
setTimeFormat
Defines the format in which time appears for each message bubble.
Use Cases:
- Use 12-hour or 24-hour formats based on user preference.
- Display relative time ("Just now", "5 min ago").
- Add AM/PM indicators for clarity.
- Java
- Kotlin
messageList.setTimeFormat(new SimpleDateFormat("hh:mm a",Locale.getDefault()));
messageList.setTimeFormat(SimpleDateFormat("hh:mm a",Locale.getDefault()))
setLoadingView
Customizes the loading indicator when messages are being fetched.
Use Cases:
- Show a spinner or skeleton loader for smooth UX.
- Display a "Fetching messages..." text.
- Java
- Kotlin
cometchatMessageList.setLoadingView(R.layout.your_loading_view);
cometchatMessageList.loadingView = R.layout.your_loading_view
setEmptyView
Defines a custom view to be displayed when no messages are available.
Use Cases:
- Show a friendly message like "No messages yet. Start the conversation!".
- Java
- Kotlin
cometchatMessageList.setEmptyView(R.layout.your_empty_view);
cometchatMessageList.emptyView = R.layout.your_empty_view
setErrorView
Custom error state view displayed when fetching messages fails.
Use Cases:
- Show a retry button when an error occurs.
- Display a friendly message like "Couldn't load messages. Check your connection.".
- Java
- Kotlin
cometchatMessageList.setErrorView(R.layout.your_empty_view);
cometchatMessageList.errorView = R.layout.your_error_view
setTextFormatters
Assigns the list of text formatters. If the provided list is not null, it sets the list. Otherwise, it assigns the default text formatters retrieved from the data source. To configure the existing Mentions look and feel check out MentionsFormatter Guide Example
data:image/s3,"s3://crabby-images/b5844/b58445c1c2ffb027e85b17e12c0027b217207691" alt="Image"
<style name="CustomIncomingMessageBubbleMentionStyle" parent="CometChatIncomingBubbleMentionsStyle">
<item name="cometchatMentionTextAppearance">?attr/cometchatTextAppearanceBodyRegular</item>
<item name="cometchatMentionTextColor">#D6409F</item>
<item name="cometchatMentionBackgroundColor">#D6409F</item>
<item name="cometchatSelfMentionTextColor">#30A46C</item>
<item name="cometchatSelfMentionTextAppearance">?attr/cometchatTextAppearanceBodyRegular</item>
<item name="cometchatSelfMentionBackgroundColor">#30A46C</item>
</style>
<style name="CustomOutgoingMessageBubbleMentionStyle" parent="CometChatOutgoingBubbleMentionsStyle">
<item name="cometchatMentionTextAppearance">?attr/cometchatTextAppearanceBodyRegular</item>
<item name="cometchatMentionTextColor">#FFFFFF</item>
<item name="cometchatMentionBackgroundColor">#F9F8FD</item>
<item name="cometchatSelfMentionTextColor">#30A46C</item>
<item name="cometchatSelfMentionTextAppearance">?attr/cometchatTextAppearanceBodyRegular</item>
<item name="cometchatSelfMentionBackgroundColor">#30A46C</item>
</style>
- Java
- Kotlin
// Initialize CometChatMentionsFormatter
CometChatMentionsFormatter mentionFormatter = new CometChatMentionsFormatter(context);
//set style to customize bubble mention text
mentionFormatter.setOutgoingBubbleMentionTextStyle(context, R.style.CustomOutgoingMessageBubbleMentionStyle);
mentionFormatter.setIncomingBubbleMentionTextStyle(context, R.style.CustomIncomingMessageBubbleMentionStyle);
// This can be passed as an array of formatter in CometChatMessageList by using setTextFormatters method.
List<CometChatTextFormatter> textFormatters = new ArrayList<>();
textFormatters.add(mentionFormatter);
messageList.setTextFormatters(textFormatters);
// Initialize CometChatMentionsFormatter
val mentionFormatter = CometChatMentionsFormatter(context)
//set style to customize bubble mention text
mentionFormatter.setOutgoingBubbleMentionTextStyle(context, R.style.CustomOutgoingMessageBubbleMentionStyle)
mentionFormatter.setIncomingBubbleMentionTextStyle(context, R.style.CustomIncomingMessageBubbleMentionStyle)
// This can be passed as an array of formatter in CometChatMessageList by using setTextFormatters method.
val textFormatters: MutableList<CometChatTextFormatter> = ArrayList()
textFormatters.add(mentionFormatter)
messageList.setTextFormatters(textFormatters)
setHeaderView
This method allows you to set a custom header view for the message list. By providing a View object, you can customize the appearance and content of the header displayed at the top of the message list.
Use Cases:
- Add a custom branding/logo to the chat.
- Display chat status ("John is typing...").
- Show last seen status.
- Java
- Kotlin
cometChatMessageList.setHeaderView(view);
cometChatMessageList.setHeaderView(view)
Example
data:image/s3,"s3://crabby-images/5176d/5176d0f9e0169f9ad27bab7c6b339f2f4bda498e" alt="Image"
<?xml version="1.0" encoding="utf-8"?>
<LinearLayout xmlns:android="http://schemas.android.com/apk/res/android"
xmlns:app="http://schemas.android.com/apk/res-auto"
android:layout_width="match_parent"
android:layout_height="wrap_content"
android:background="#EDEAFA"
android:orientation="horizontal">
<com.google.android.material.card.MaterialCardView
android:layout_width="wrap_content"
android:layout_height="wrap_content"
android:layout_marginStart="@dimen/cometchat_margin_4"
android:layout_marginTop="@dimen/cometchat_margin_1"
android:layout_marginBottom="@dimen/cometchat_margin_1"
android:elevation="0dp"
app:cardCornerRadius="@dimen/cometchat_radius_max"
app:cardElevation="0dp"
app:strokeColor="?attr/cometchatStrokeColorLight"
app:strokeWidth="1dp">
<LinearLayout
android:layout_width="wrap_content"
android:layout_height="wrap_content"
android:layout_marginStart="@dimen/cometchat_padding_3"
android:layout_marginTop="@dimen/cometchat_padding_1"
android:layout_marginEnd="@dimen/cometchat_padding_3"
android:layout_marginBottom="@dimen/cometchat_padding_1"
android:gravity="center_vertical"
android:orientation="horizontal">
<ImageView
android:layout_width="20dp"
android:layout_height="@dimen/cometchat_20dp"
android:src="@drawable/cometchat_ic_file_upload"
app:tint="?attr/cometchatPrimaryColor" />
<TextView
android:layout_width="wrap_content"
android:layout_height="wrap_content"
android:layout_marginStart="@dimen/cometchat_margin_1"
android:text="Notes"
android:textAppearance="?attr/cometchatTextAppearanceCaption1Regular"
android:textColor="?attr/cometchatPrimaryColor" />
</LinearLayout>
</com.google.android.material.card.MaterialCardView>
<com.google.android.material.card.MaterialCardView
android:layout_width="wrap_content"
android:layout_height="wrap_content"
android:layout_marginStart="@dimen/cometchat_margin_4"
android:layout_marginTop="@dimen/cometchat_margin_1"
android:layout_marginBottom="@dimen/cometchat_margin_1"
android:elevation="0dp"
app:cardCornerRadius="@dimen/cometchat_radius_max"
app:cardElevation="0dp"
app:strokeColor="?attr/cometchatStrokeColorLight"
app:strokeWidth="1dp">
<LinearLayout
android:layout_width="wrap_content"
android:layout_height="wrap_content"
android:layout_marginStart="@dimen/cometchat_padding_3"
android:layout_marginTop="@dimen/cometchat_padding_1"
android:layout_marginEnd="@dimen/cometchat_padding_3"
android:layout_marginBottom="@dimen/cometchat_padding_1"
android:gravity="center_vertical"
android:orientation="horizontal">
<ImageView
android:layout_width="20dp"
android:layout_height="@dimen/cometchat_20dp"
android:src="@drawable/src_icons_pin"
app:tint="?attr/cometchatPrimaryColor" />
<TextView
android:layout_width="wrap_content"
android:layout_height="wrap_content"
android:layout_marginStart="@dimen/cometchat_margin_1"
android:text="Pinned Messages"
android:textAppearance="?attr/cometchatTextAppearanceCaption1Regular"
android:textColor="?attr/cometchatPrimaryColor" />
</LinearLayout>
</com.google.android.material.card.MaterialCardView>
<com.google.android.material.card.MaterialCardView
android:layout_width="wrap_content"
android:layout_height="wrap_content"
android:layout_marginStart="@dimen/cometchat_margin_4"
android:layout_marginTop="@dimen/cometchat_margin_1"
android:layout_marginBottom="@dimen/cometchat_margin_1"
android:elevation="0dp"
app:cardCornerRadius="@dimen/cometchat_radius_max"
app:cardElevation="0dp"
app:strokeColor="?attr/cometchatStrokeColorLight"
app:strokeWidth="1dp">
<LinearLayout
android:layout_width="wrap_content"
android:layout_height="wrap_content"
android:layout_marginStart="@dimen/cometchat_padding_3"
android:layout_marginTop="@dimen/cometchat_padding_1"
android:layout_marginEnd="@dimen/cometchat_padding_3"
android:layout_marginBottom="@dimen/cometchat_padding_1"
android:gravity="center_vertical"
android:orientation="horizontal">
<ImageView
android:layout_width="20dp"
android:layout_height="@dimen/cometchat_20dp"
android:src="@drawable/cometchat_link_file_icon"
app:tint="?attr/cometchatPrimaryColor" />
<TextView
android:layout_width="wrap_content"
android:layout_height="wrap_content"
android:layout_marginStart="@dimen/cometchat_margin_1"
android:text="Saved Links"
android:textAppearance="?attr/cometchatTextAppearanceCaption1Regular"
android:textColor="?attr/cometchatPrimaryColor" />
</LinearLayout>
</com.google.android.material.card.MaterialCardView>
</LinearLayout>
- Java
- Kotlin
cometChatMessageList.setHeaderView(View.inflate(getContext(), R.layout.custom_header_layout, null));
cometChatMessageList.setHeaderView(View.inflate(context, R.layout.custom_header_layout, null))
setFooterView
This method allows you to set a custom footer view for the message list. By providing a View object, you can customize the appearance and content of the footer displayed at the bottom of the message list.
Use Cases:
- Add quick reply buttons.
- Display typing indicators ("John is typing...").
- Show a disclaimer or privacy notice.
- Java
- Kotlin
cometChatMessageList.setFooterView(view);
cometChatMessageList.setFooterView(view)
Example
data:image/s3,"s3://crabby-images/81098/8109824ab7a8e9082dd21eedccc9759025712bf2" alt="Image"
<?xml version="1.0" encoding="utf-8"?>
<LinearLayout xmlns:android="http://schemas.android.com/apk/res/android"
xmlns:app="http://schemas.android.com/apk/res-auto"
android:layout_width="match_parent"
android:layout_height="wrap_content"
android:background="#EDEAFA"
android:orientation="horizontal">
<com.google.android.material.card.MaterialCardView
android:layout_width="wrap_content"
android:layout_height="wrap_content"
android:layout_marginStart="@dimen/cometchat_margin_4"
android:layout_marginTop="@dimen/cometchat_margin_1"
android:layout_marginBottom="@dimen/cometchat_margin_1"
android:elevation="0dp"
app:cardCornerRadius="@dimen/cometchat_radius_max"
app:cardElevation="0dp"
app:strokeColor="?attr/cometchatStrokeColorLight"
app:strokeWidth="1dp">
<LinearLayout
android:layout_width="wrap_content"
android:layout_height="wrap_content"
android:layout_marginStart="@dimen/cometchat_padding_3"
android:layout_marginTop="@dimen/cometchat_padding_1"
android:layout_marginEnd="@dimen/cometchat_padding_3"
android:layout_marginBottom="@dimen/cometchat_padding_1"
android:gravity="center_vertical"
android:orientation="horizontal">
<ImageView
android:layout_width="20dp"
android:layout_height="@dimen/cometchat_20dp"
android:src="@drawable/cometchat_ic_file_upload"
app:tint="?attr/cometchatPrimaryColor" />
<TextView
android:layout_width="wrap_content"
android:layout_height="wrap_content"
android:layout_marginStart="@dimen/cometchat_margin_1"
android:text="Notes"
android:textAppearance="?attr/cometchatTextAppearanceCaption1Regular"
android:textColor="?attr/cometchatPrimaryColor" />
</LinearLayout>
</com.google.android.material.card.MaterialCardView>
<com.google.android.material.card.MaterialCardView
android:layout_width="wrap_content"
android:layout_height="wrap_content"
android:layout_marginStart="@dimen/cometchat_margin_4"
android:layout_marginTop="@dimen/cometchat_margin_1"
android:layout_marginBottom="@dimen/cometchat_margin_1"
android:elevation="0dp"
app:cardCornerRadius="@dimen/cometchat_radius_max"
app:cardElevation="0dp"
app:strokeColor="?attr/cometchatStrokeColorLight"
app:strokeWidth="1dp">
<LinearLayout
android:layout_width="wrap_content"
android:layout_height="wrap_content"
android:layout_marginStart="@dimen/cometchat_padding_3"
android:layout_marginTop="@dimen/cometchat_padding_1"
android:layout_marginEnd="@dimen/cometchat_padding_3"
android:layout_marginBottom="@dimen/cometchat_padding_1"
android:gravity="center_vertical"
android:orientation="horizontal">
<ImageView
android:layout_width="20dp"
android:layout_height="@dimen/cometchat_20dp"
android:src="@drawable/src_icons_pin"
app:tint="?attr/cometchatPrimaryColor" />
<TextView
android:layout_width="wrap_content"
android:layout_height="wrap_content"
android:layout_marginStart="@dimen/cometchat_margin_1"
android:text="Pinned Messages"
android:textAppearance="?attr/cometchatTextAppearanceCaption1Regular"
android:textColor="?attr/cometchatPrimaryColor" />
</LinearLayout>
</com.google.android.material.card.MaterialCardView>
<com.google.android.material.card.MaterialCardView
android:layout_width="wrap_content"
android:layout_height="wrap_content"
android:layout_marginStart="@dimen/cometchat_margin_4"
android:layout_marginTop="@dimen/cometchat_margin_1"
android:layout_marginBottom="@dimen/cometchat_margin_1"
android:elevation="0dp"
app:cardCornerRadius="@dimen/cometchat_radius_max"
app:cardElevation="0dp"
app:strokeColor="?attr/cometchatStrokeColorLight"
app:strokeWidth="1dp">
<LinearLayout
android:layout_width="wrap_content"
android:layout_height="wrap_content"
android:layout_marginStart="@dimen/cometchat_padding_3"
android:layout_marginTop="@dimen/cometchat_padding_1"
android:layout_marginEnd="@dimen/cometchat_padding_3"
android:layout_marginBottom="@dimen/cometchat_padding_1"
android:gravity="center_vertical"
android:orientation="horizontal">
<ImageView
android:layout_width="20dp"
android:layout_height="@dimen/cometchat_20dp"
android:src="@drawable/cometchat_link_file_icon"
app:tint="?attr/cometchatPrimaryColor" />
<TextView
android:layout_width="wrap_content"
android:layout_height="wrap_content"
android:layout_marginStart="@dimen/cometchat_margin_1"
android:text="Saved Links"
android:textAppearance="?attr/cometchatTextAppearanceCaption1Regular"
android:textColor="?attr/cometchatPrimaryColor" />
</LinearLayout>
</com.google.android.material.card.MaterialCardView>
</LinearLayout>
- Java
- Kotlin
cometChatMessageList.setFooterView(View.inflate(getContext(), R.layout.custom_footer_layout, null));
cometChatMessageList.setFooterView(View.inflate(context, R.layout.custom_footer_layout, null))