From 102ce87bb00d6979276652363788e807b318a818 Mon Sep 17 00:00:00 2001 From: Robin Townsend Date: Tue, 13 Dec 2022 18:20:13 -0500 Subject: [PATCH] Hide controls completely in picture-in-picture view This is to prepare for upcoming design changes to the picture-in-picture view in Element Web. --- src/room/InCallView.tsx | 70 ++++++++++++++++++++++++----------------- 1 file changed, 42 insertions(+), 28 deletions(-) diff --git a/src/room/InCallView.tsx b/src/room/InCallView.tsx index 431d8b0..8f8dc6c 100644 --- a/src/room/InCallView.tsx +++ b/src/room/InCallView.tsx @@ -246,22 +246,23 @@ export function InCallView({ return tileDescriptors; }, [client, participants, userMediaFeeds, activeSpeaker, screenshareFeeds]); + const reducedControls = boundsValid && bounds.width <= 400; + const noControls = reducedControls && bounds.height <= 400; + // The maximised participant: either the participant that the user has // manually put in fullscreen, or the focused (active) participant if the // window is too small to show everyone const maximisedParticipant = useMemo( () => fullscreenParticipant ?? - (boundsValid && bounds.height <= 400 && bounds.width <= 400 + (noControls ? items.find((item) => item.focused) ?? items.find((item) => item.callFeed) ?? null : null), - [fullscreenParticipant, boundsValid, bounds, items] + [fullscreenParticipant, noControls, items] ); - const reducedControls = boundsValid && bounds.width <= 400; - const renderAvatar = useCallback( (roomMember: RoomMember, width: number, height: number) => { const avatarUrl = roomMember.getMxcAvatarUrl(); @@ -347,6 +348,42 @@ export function InCallView({ [styles.maximised]: maximisedParticipant, }); + let footer: JSX.Element | null; + + if (noControls) { + footer = null; + } else if (reducedControls) { + footer = ( +
+ + + +
+ ); + } else { + footer = ( +
+ + + {canScreenshare && !hideScreensharing && !isSafari && ( + + )} + + +
+ ); + } + return (