Retrieve List of Conversations
In other words, as a logged-in user, how do I retrieve the latest conversations that I’ve been a part of? To fetch the list of conversations, you can use theConversationsRequest
class. To use this class i.e. to create an object of the ConversationsRequest
class, you need to use the ConversationsRequestBuilder
class. The ConversationsRequestBuilder
class allows you to set the parameters based on which the conversations are to be fetched.
The ConversationsRequestBuilder
class allows you to set the below parameters:
Set Limit
This method sets the limit i.e. the number of conversations that should be fetched in a single iteration.A Maximum of only 50 Conversations can be fetched at once. If you want to fetch more conversation, you can use the fetchNext() on the same conversationsRequest Object
Set Conversation Type
This method can be used to fetch user or group conversations specifically. TheconversationType
variable can hold one of the below two values: a. CometChat.conversationType.user(user) - Only fetches user conversation. b. CometChat.conversationType.group(group)- Only fetches group conversations.
If none is set, the list of conversations will include both user and group conversations.
With User and Group Tags
This method can be used to fetch the user/group tags in theConversation
Object. By default the value is false.
Set User Tags
This method fetches user conversations that have the specified tags.Set Group Tags
This method fetches group conversations that have the specified tags.With Tags
This method makes sure that the tags associated with the conversations are returned along with the other details of the conversations. The default value for this parameter isfalse
Set Tags
This method helps you fetch the conversations based on the specified tags.Include Blocked Users
This method helps you fetch the conversations of users whom the logged-in user has blocked.With Blocked Info
This method can be used to fetch the blocked information of the blocked user in the ConversationWith object.Search Conversations
This method helps you search a conversation based on User or Group name.This feature is only available with
Conversation & Advanced Search
. The Conversation & Advanced Search
is only available in Advanced
& Custom
plans. If you’re already on one of these plans, please enable the Conversation & Advanced Search
from CometChat Dashboard (Open your app, navigate to Chats -> Settings -> General Configuration)Unread Conversations
This method helps you fetch unread conversations.This feature is only available with
Conversation & Advanced Search
. The Conversation & Advanced Search
is only available in Advanced
& Custom
plans. If you’re already on one of these plans, please enable the Conversation & Advanced Search
from CometChat Dashboard (Open your app, navigate to Chats -> Settings -> General Configuration)build()
method to get the object of the ConversationsRequest
class.
Once you have the object of the ConversationsRequest
class, you need to call the fetchNext()
method. Calling this method will return a list of Conversation
objects containing X number of users depending on the limit set.
Conversation
object consists of the below fields:
Field | Information |
---|---|
conversationId | id of the conversation |
conversationType | type of conversation (user/group) |
lastMessage | last message in the conversation |
conversationWith | User or Group object containing the details |
unreadMessageCount | unread message count for the conversation |
unreadMentionsCount | count of unread mentions in the conversation |
lastReadMessageId | ID of the last read message in the conversation |
Tag Conversation
In other words, as a logged-in user, how do I tag a conversation? To tag a specific conversation, you can use thetagConversation()
method. The tagConversation()
method accepts three parameters.
-
conversationWith
: UID/GUID of the user/group whose conversation you want to fetch. -
conversationType
: TheconversationType
variable can hold one of the below two values:- user - Only fetches user conversation.
- group - Only fetches group conversations.
-
tags
: Thetags
variable will be a list of tags you want to add to a conversation.
The tags for conversations are one-way. This means that if user A tags a conversation with user B, that tag will be applied to that conversation only for user A.
Retrieve Single Conversation
In other words, as a logged-in user, how do I retrieve a specific conversation? To fetch a specific conversation, you can use thegetConversation
method. The getConversation
method accepts two parameters.
conversationWith
: UID/GUID of the user/group whose conversation you want to fetch.conversationType
: TheconversationType
variable can hold one of the below two values:
- user - Only fetches user conversation.
- group - Only fetches group conversations.
Get Conversation From Message
For real-time events, you will always receive Message objects and not conversation objects. Thus, you will need a mechanism to convert the Message object to theConversation
object. You can use the getConversationFromMessage(BaseMessage message)
of the CometChatHelper
class.
While converting a
Message
object to a Conversation
object, the unreadMessageCount
will not be available in the Conversation
object. As this is for real-time events, the unread message count needs to be managed in your client-side code.