Mercurial > libervia-desktop-kivy
diff libervia/desktop_kivy/plugins/plugin_wid_calls.py @ 512:644a8d165e5a
plugin calls: use the new binding feature of webrtc module:
the new binding feature is used to update the "Desktop" button if sharing is cancelled by
user, or stopped somehow.
rel 434
author | Goffi <goffi@goffi.org> |
---|---|
date | Thu, 18 Jan 2024 23:31:29 +0100 |
parents | 97ab236e8f20 |
children | d78728d7fd6a |
line wrap: on
line diff
--- a/libervia/desktop_kivy/plugins/plugin_wid_calls.py Tue Jan 16 15:00:23 2024 +0100 +++ b/libervia/desktop_kivy/plugins/plugin_wid_calls.py Thu Jan 18 23:31:29 2024 +0100 @@ -106,7 +106,7 @@ PROXIED_PROPERTIES = { 'audio_muted', 'callee', 'desktop_sharing', 'sid', 'video_muted', 'desktop_sharing_data' } - PROXIED_METHODS = {'answer_call', 'end_call', 'on_accepted_call', 'on_ice_candidates_new', 'setup_call', 'start_pipeline'} + PROXIED_METHODS = {'answer_call', 'bind', 'end_call', 'on_accepted_call', 'on_ice_candidates_new', 'setup_call', 'start_pipeline'} def __init__(self, parent_calls: "Calls", profile: str) -> None: self.parent_calls = parent_calls @@ -243,6 +243,7 @@ if buf is not None and mapinfo is not None: buf.unmap(mapinfo) + class WindowSelectButton(Button): pass @@ -301,6 +302,9 @@ ) self.header_input_add_extra(call_btn) self.webrtc = WebRTC(self, self.profile) + self.webrtc.bind( + desktop_sharing=partial(setattr, self, "desktop_sharing") + ) self.previous_fullscreen = None self.reset_instance() @@ -419,7 +423,10 @@ if self.desktop_sharing: self.desktop_sharing = False else: - DesktopScreenDialog(self).open() + if display_servers.detect() == display_servers.X11: + DesktopScreenDialog(self).open() + else: + self.desktop_sharing = True def on_desktop_sharing(self, instance, active: bool) -> None: self.webrtc.desktop_sharing = active