Once authenticated, users can send or receive messages, which are tied to the Conversation
The Conversation is created by calling stringeeClient.createConversation(options, participants):
_stringeeClient.createConversation(options, participants).then((ressult) {
debugPrint('createConversation: message - ${result['message']}');
if (result['status']) {
StringeeConversation conversation = result['body'];
}
});
In which:
options: StringeeConversationOption to use when constructing this conversation, for example:
StringeeConversationOption options = StringeeConversationOption(isGroup: false, isDistinct: false);
participants: List of StringeeUser.
To create the 1-1 conversation, you must pass only one user to participants, isGroup = false, for example:
List<StringeeUser> participants = new List();
StringeeUser user = StringeeUser('participant's id');
participants.add(user);
StringeeConversationOption options = StringeeConversationOption(isGroup: false, isDistinct: true);
The 1-1 conversation is the distinct conversation by default. You can not add participants to the 1-1 conversation.
If you pass participants with more than one user, the conversation is created as the group conversation.
To create the group conversation, you pass isGroup = true or participants with more than one user:
List<StringeeUser> participants = new List();
participants.add(StringeeUser('participant's id'));
participants.add(StringeeUser('participant2's id'));
ConversationOption options = ConversationOption(isGroup: false, isDistinct: false);
You can add/remove participants to/from a Conversation.
If a Conversation is created as a distinct conversation, it's unique on Stringee server. This means, multiple users independently create the distinct conversations with the same set of users, the server will automatically merge the conversations.
Once a distinct conversation has been created between User A and User B, any further attempts by either of these users to create the new distinct conversation with these participants will get resolved to the existing conversation.
Conversations are created as the non-distinct conversations by default.
Creating a distinct StringeeConversationOption by set isDistinct option:
Conversations are stored on Stringee server and cached on Local Database as well. You can get conversations as follows:
To get local conversations, you call stringeeClient.getLocalConversations():
_stringeeClient.getLocalConversations().then((result) {
debugPrint('getLocalConversations: message - ${result['message']}');
if (result['status']) {
List<StringeeConversation> conversations = result['body'];
}
});
To get lastest conversations from Stringee server, you call stringeeClient.getLastConversations(count, callback):
_stringeeClient.getLastConversation(count).then((result) {
debugPrint('getLocalConversations: message - ${result['message']}');
if (result['status']) {
List<StringeeConversation> conversations = result['body'];
}
});
In which:
To get a list of conversations which have updated time greater than a datetime from server, you call:
_stringeeClient.getConversationsAfter(count, datetime).then((result) {
debugPrint('getConversationsAfter: message - ${result['message']}');
if (result['status']) {
List<StringeeConversation> conversations = result['body'];
}
});
In which:
To get a list of conversations which have updated time smaller than datetime from server, you call:
_stringeeClient.getConversationsBefore(count, datetime).then((result) {
debugPrint('getConversationsBefore: message - ${result['message']}');
if (result['status']) {
List<StringeeConversation> conversations = result['body'];
}
});
In which:
Participants in the conversation. Any participant can add users into the conversation or leave from the conversation. Only the participant who created the conversation can remove other participants from the conversation:
List<StringeeUser> users = new List();
users.add(StringeeUser('parrticipant's id));
users.add(StringeeUser('parrticipant's id'));
/// Add
_conversation.addParticipants(List<StringeeUser> participant).then((result) {
debugPrint('addParticipants: message - ${result['message']}');
});
/// Remove
_conversation.removeParticipants(List<StringeeUser> participant).then((result) {
debugPrint('removeParticipants: message - ${result['message']}');
});
To leave from the conversation, you remove yourself from the conversation.
In case conversation is the 1-1 conversation, you can delete the conversation by calling:
_conversation.delete().then((value) {
debugPrint('delete: message - ${result['message']}');
});
In case conversation is the group conversation, you must leave from the conversation before deleting.