Skip to content

Commit

Permalink
Fix fullscreen on safari (#136)
Browse files Browse the repository at this point in the history
Co-authored-by: Jannis Mattheis <[email protected]>
  • Loading branch information
tomonsoejang and jmattheis authored Aug 11, 2022
1 parent 39662ee commit 3fad376
Showing 1 changed file with 25 additions and 5 deletions.
30 changes: 25 additions & 5 deletions ui/src/Room.tsx
Original file line number Diff line number Diff line change
@@ -1,4 +1,4 @@
import React from 'react';
import React, {useCallback} from 'react';
import {Badge, IconButton, Paper, Theme, Tooltip, Typography} from '@mui/material';
import CancelPresentationIcon from '@mui/icons-material/CancelPresentation';
import PresentToAllIcon from '@mui/icons-material/PresentToAll';
Expand Down Expand Up @@ -33,6 +33,24 @@ const flags = (user: RoomUser) => {
return ` (${result.join(', ')})`;
};

interface FullScreenHTMLVideoElement extends HTMLVideoElement {
msRequestFullscreen?: () => void;
mozRequestFullScreen?: () => void;
webkitRequestFullscreen?: () => void;
}

const requestFullscreen = (element: FullScreenHTMLVideoElement | null) => {
if (element?.requestFullscreen) {
element.requestFullscreen();
} else if (element?.mozRequestFullScreen) {
element.mozRequestFullScreen();
} else if (element?.msRequestFullscreen) {
element.msRequestFullscreen();
} else if (element?.webkitRequestFullscreen) {
element.webkitRequestFullscreen();
}
};

export const Room = ({
state,
share,
Expand All @@ -51,10 +69,12 @@ export const Room = ({
const [showControl, setShowControl] = React.useState(true);
const [hoverControl, setHoverControl] = React.useState(false);
const [selectedStream, setSelectedStream] = React.useState<string | typeof HostStream>();
const [videoElement, setVideoElement] = React.useState<HTMLVideoElement | null>(null);
const [videoElement, setVideoElement] = React.useState<FullScreenHTMLVideoElement | null>(null);

useShowOnMouseMovement(setShowControl);

const handleFullscreen = useCallback(() => requestFullscreen(videoElement), [videoElement]);

React.useEffect(() => {
if (selectedStream === HostStream && state.hostStream) {
return;
Expand Down Expand Up @@ -103,10 +123,10 @@ export const Room = ({
'f',
() => {
if (selectedStream) {
videoElement?.requestFullscreen();
handleFullscreen();
}
},
[videoElement, selectedStream]
[handleFullscreen, selectedStream]
);
useHotkeys('c', copyLink);
useHotkeys(
Expand Down Expand Up @@ -226,7 +246,7 @@ export const Room = ({
</Tooltip>
<Tooltip title="Fullscreen" arrow>
<IconButton
onClick={() => videoElement?.requestFullscreen()}
onClick={() => handleFullscreen()}
disabled={!selectedStream}
size="large"
>
Expand Down

0 comments on commit 3fad376

Please sign in to comment.