diff options
author | Anmol <godofwaranmol@gmail.com> | 2020-04-22 23:34:03 +0530 |
---|---|---|
committer | GitHub <noreply@github.com> | 2020-04-22 20:04:03 +0200 |
commit | 2631a9bdbaf9a40f329f05c55c6e2ea38efeb10c (patch) | |
tree | dfe6b0b3a390457b1c7d125b81a5c1d10019281c /main/src/ui/notifications.vala | |
parent | 51a23728694a3f1312cc9396fc093ca178457c3c (diff) | |
download | dino-2631a9bdbaf9a40f329f05c55c6e2ea38efeb10c.tar.gz dino-2631a9bdbaf9a40f329f05c55c6e2ea38efeb10c.zip |
voice handling in moderated groups (#788)
Diffstat (limited to 'main/src/ui/notifications.vala')
-rw-r--r-- | main/src/ui/notifications.vala | 23 |
1 files changed, 23 insertions, 0 deletions
diff --git a/main/src/ui/notifications.vala b/main/src/ui/notifications.vala index 7b45a46e..dc73bda5 100644 --- a/main/src/ui/notifications.vala +++ b/main/src/ui/notifications.vala @@ -43,6 +43,7 @@ public class Notifications : Object { stream_interactor.get_module(NotificationEvents.IDENTITY).notify_subscription_request.connect(notify_subscription_request); stream_interactor.get_module(NotificationEvents.IDENTITY).notify_connection_error.connect(notify_connection_error); stream_interactor.get_module(NotificationEvents.IDENTITY).notify_muc_invite.connect(on_invite_received); + stream_interactor.get_module(NotificationEvents.IDENTITY).notify_voice_request.connect(on_voice_request_received); } private async void notify_content_item(ContentItem content_item, Conversation conversation) { @@ -140,6 +141,28 @@ public class Notifications : Object { notification.add_button_with_target_value(_("Accept"), "app.open-muc-join", group_conversation.id); GLib.Application.get_default().send_notification(null, notification); } + + private async void on_voice_request_received(Account account, Jid room_jid, Jid from_jid, string? nick, string? role, string? label) { + Conversation? direct_conversation = stream_interactor.get_module(ConversationManager.IDENTITY).get_conversation(room_jid, account, Conversation.Type.GROUPCHAT); + if (direct_conversation == null) return; + string display_name = Util.get_participant_display_name(stream_interactor, direct_conversation, from_jid); + string display_room = room_jid.bare_jid.to_string(); + Notification notification = new Notification(_("Permission request")); + string body = _("%s requests the permission to write in %s").printf(display_name, display_room); + notification.set_body(body); + + try { + Cairo.ImageSurface jid_avatar = (yield Util.get_conversation_avatar_drawer(stream_interactor, direct_conversation)).size(40, 40).draw_image_surface(); + notification.set_icon(get_pixbuf_icon(jid_avatar)); + } catch (Error e) { } + + Conversation group_conversation = stream_interactor.get_module(ConversationManager.IDENTITY).create_conversation(room_jid, account, Conversation.Type.GROUPCHAT); + group_conversation.nickname = nick; + notification.set_default_action_and_target_value("app.accept-voice-request", new Variant.int32(group_conversation.id)); + notification.add_button_with_target_value(_("Deny"), "app.deny-voice-request", group_conversation.id); + notification.add_button_with_target_value(_("Accept"), "app.accept-voice-request", group_conversation.id); + GLib.Application.get_default().send_notification(null, notification); + } private Icon get_pixbuf_icon(Cairo.ImageSurface surface) throws Error { Gdk.Pixbuf avatar = Gdk.pixbuf_get_from_surface(surface, 0, 0, surface.get_width(), surface.get_height()); |