import Box from '@mui/material/Box/Box'; import Fade from '@mui/material/Fade/Fade'; import React, { useRef, type FC, useEffect, useState } from 'react'; import RemotePlayButton from 'apps/experimental/components/AppToolbar/RemotePlayButton'; import SyncPlayButton from 'apps/experimental/components/AppToolbar/SyncPlayButton'; import AppToolbar from 'components/toolbar/AppToolbar'; import ViewManagerPage from 'components/viewManager/ViewManagerPage'; import { EventType } from 'types/eventType'; import Events, { type Event } from 'utils/events'; /** * Video player page component that renders mui controls for the top controls and the legacy view for everything else. */ const VideoPage: FC = () => { const documentRef = useRef(document); const [ isVisible, setIsVisible ] = useState(true); const onShowVideoOsd = (_e: Event, isShowing: boolean) => { setIsVisible(isShowing); }; useEffect(() => { const doc = documentRef.current; if (doc) Events.on(doc, EventType.SHOW_VIDEO_OSD, onShowVideoOsd); return () => { if (doc) Events.off(doc, EventType.SHOW_VIDEO_OSD, onShowVideoOsd); }; }, []); return ( <> } /> ); }; export default VideoPage;