1
0
Fork 0
mirror of https://github.com/sussy-code/smov.git synced 2024-12-22 14:57:40 +01:00
smov/src/components/video/controls/FullscreenControl.tsx

29 lines
786 B
TypeScript
Raw Normal View History

2023-01-09 21:51:24 +01:00
import { Icons } from "@/components/Icon";
2023-01-08 16:23:42 +01:00
import { useCallback } from "react";
2023-01-09 21:51:24 +01:00
import { VideoPlayerIconButton } from "../parts/VideoPlayerIconButton";
2023-01-08 16:23:42 +01:00
import { useVideoPlayerState } from "../VideoContext";
2023-01-10 01:01:51 +01:00
import { canFullscreen } from "../hooks/fullscreen";
2023-01-09 21:51:24 +01:00
interface Props {
className?: string;
}
export function FullscreenControl(props: Props) {
2023-01-08 16:23:42 +01:00
const { videoState } = useVideoPlayerState();
2023-01-08 13:15:32 +01:00
2023-01-08 16:23:42 +01:00
const handleClick = useCallback(() => {
if (videoState.isFullscreen) videoState.exitFullscreen();
else videoState.enterFullscreen();
}, [videoState]);
2023-01-08 13:15:32 +01:00
if (!canFullscreen) return null;
2023-01-08 16:23:42 +01:00
return (
2023-01-09 21:51:24 +01:00
<VideoPlayerIconButton
className={props.className}
2023-01-08 16:23:42 +01:00
onClick={handleClick}
2023-01-09 21:51:24 +01:00
icon={videoState.isFullscreen ? Icons.COMPRESS : Icons.EXPAND}
/>
2023-01-08 16:23:42 +01:00
);
2023-01-08 13:15:32 +01:00
}