1
0
mirror of https://gitlab.com/comunic/comunicmobile synced 2024-11-22 12:59:21 +00:00

Handles remove message events

This commit is contained in:
Pierre HUBERT 2020-04-19 14:29:01 +02:00
parent 88ba2d303e
commit 909e68e7bb
5 changed files with 28 additions and 7 deletions

View File

@ -333,6 +333,11 @@ class ConversationsHelper {
await _conversationMessagesDatabaseHelper.insertOrUpdate(msg); await _conversationMessagesDatabaseHelper.insertOrUpdate(msg);
} }
/// Remove a message from the database
Future<void> removeMessage(int msgID) async {
await _conversationMessagesDatabaseHelper.delete(msgID);
}
/// Update a message content /// Update a message content
Future<bool> updateMessage(int id, String newContent) async { Future<bool> updateMessage(int id, String newContent) async {
final response = await APIRequest( final response = await APIRequest(
@ -355,8 +360,7 @@ class ConversationsHelper {
if (response.code != 200) return false; if (response.code != 200) return false;
// Delete the message locally return true;
return await _conversationMessagesDatabaseHelper.delete(id);
} }
/// Register a conversation : ask the server to notify about updates to the /// Register a conversation : ask the server to notify about updates to the

View File

@ -60,6 +60,12 @@ class UpdatedConversationMessageEvent {
UpdatedConversationMessageEvent(this.msg); UpdatedConversationMessageEvent(this.msg);
} }
/// Deleted conversation message
class DeletedConversationMessageEvent {
final ConversationMessage msg;
DeletedConversationMessageEvent(this.msg);
}
class EventsHelper { class EventsHelper {
static EventBus _mgr = EventBus(); static EventBus _mgr = EventBus();

View File

@ -150,6 +150,12 @@ class WebSocketHelper {
ConversationsHelper.apiToConversationMessage(msg.data))); ConversationsHelper.apiToConversationMessage(msg.data)));
break; break;
// Deleted a conversation message
case "deleted_conv_message":
EventsHelper.emit(DeletedConversationMessageEvent(
ConversationsHelper.apiToConversationMessage(msg.data)));
break;
default: default:
throw Exception("Unknown message type: ${msg.title}"); throw Exception("Unknown message type: ${msg.title}");
} }

View File

@ -54,4 +54,7 @@ class ConversationMessagesList extends ListBase<ConversationMessage> {
final index = this.indexWhere((t) => t.id == msg.id); final index = this.indexWhere((t) => t.id == msg.id);
if (index >= 0) this[index] = msg; if (index >= 0) this[index] = msg;
} }
/// Remove a message from this list
void removeMsg(int id) => removeWhere((f) => f.id == id);
} }

View File

@ -98,6 +98,13 @@ class _ConversationScreenState extends SafeState<ConversationScreen> {
setState(() => _messages.replace(ev.msg)); setState(() => _messages.replace(ev.msg));
} }
}); });
this.listen<DeletedConversationMessageEvent>((ev) async {
if (ev.msg.conversationID == widget.conversationID) {
await _conversationsHelper.removeMessage(ev.msg.id);
setState(() => _messages.removeMsg(ev.msg.id));
}
});
} }
/// Free resources when this conversation widget is no longer required /// Free resources when this conversation widget is no longer required
@ -450,10 +457,5 @@ class _ConversationScreenState extends SafeState<ConversationScreen> {
// Execute the request // Execute the request
if (!await _conversationsHelper.deleteMessage(message.id)) if (!await _conversationsHelper.deleteMessage(message.id))
showSimpleSnack(context, tr("Could not delete conversation message!")); showSimpleSnack(context, tr("Could not delete conversation message!"));
// Remove the message from the list
setState(() {
_messages.remove(message);
});
} }
} }