From d6dbb318bf0708e80a123caf0f25e650fcbe0624 Mon Sep 17 00:00:00 2001 From: =?UTF-8?q?=C5=A0imon=20Brandner?= Date: Wed, 17 Nov 2021 14:37:56 +0100 Subject: [PATCH] Allow for call upgrades MIME-Version: 1.0 Content-Type: text/plain; charset=UTF-8 Content-Transfer-Encoding: 8bit Signed-off-by: Šimon Brandner --- src/components/views/voip/CallView.tsx | 33 ++++++++++++++------------ 1 file changed, 18 insertions(+), 15 deletions(-) diff --git a/src/components/views/voip/CallView.tsx b/src/components/views/voip/CallView.tsx index 746731e7bfd7..4fb36d411938 100644 --- a/src/components/views/voip/CallView.tsx +++ b/src/components/views/voip/CallView.tsx @@ -347,35 +347,38 @@ export default class CallView extends React.Component { }; private renderCallControls(): JSX.Element { - // We don't support call upgrades (yet) so hide the video mute button in voice calls - const vidMuteButtonShown = this.props.call.hasLocalUserMediaVideoTrack; + const { call, pipMode } = this.props; + const { primaryFeed, callState, micMuted, vidMuted, screensharing, sidebarShown } = this.state; + + // If SDPStreamMetadata isn't supported don't show video mute button in voice calls + const vidMuteButtonShown = call.opponentSupportsSDPStreamMetadata() || call.hasLocalUserMediaVideoTrack; // Screensharing is possible, if we can send a second stream and // identify it using SDPStreamMetadata or if we can replace the already // existing usermedia track by a screensharing track. We also need to be // connected to know the state of the other side const screensharingButtonShown = ( - (this.props.call.opponentSupportsSDPStreamMetadata() || this.props.call.hasLocalUserMediaVideoTrack) && - this.props.call.state === CallState.Connected + (call.opponentSupportsSDPStreamMetadata() || call.hasLocalUserMediaVideoTrack) && + call.state === CallState.Connected ); // To show the sidebar we need secondary feeds, if we don't have them, // we can hide this button. If we are in PiP, sidebar is also hidden, so // we can hide the button too const sidebarButtonShown = ( - this.state.primaryFeed?.purpose === SDPStreamMetadataPurpose.Screenshare || - this.props.call.isScreensharing() + primaryFeed?.purpose === SDPStreamMetadataPurpose.Screenshare || + call.isScreensharing() ); // The dial pad & 'more' button actions are only relevant in a connected call - const contextMenuButtonShown = this.state.callState === CallState.Connected; + const contextMenuButtonShown = callState === CallState.Connected; const dialpadButtonShown = ( - this.state.callState === CallState.Connected && - this.props.call.opponentSupportsDTMF() + callState === CallState.Connected && + call.opponentSupportsDTMF() ); return ( { onVidMuteClick: this.onVidMuteClick, }} buttonsState={{ - micMuted: this.state.micMuted, - vidMuted: this.state.vidMuted, - sidebarShown: this.state.sidebarShown, - screensharing: this.state.screensharing, + micMuted: micMuted, + vidMuted: vidMuted, + sidebarShown: sidebarShown, + screensharing: screensharing, }} buttonsVisibility={{ vidMute: vidMuteButtonShown,