// APIs for normalizing fullscreen operations. Note that Edge uses // the WebKit-prefixed APIs currently (as of Edge 16). export const isFullscreen = () => document.fullscreenElement || document.webkitFullscreenElement || document.mozFullScreenElement; export const exitFullscreen = () => { if (document.exitFullscreen) { document.exitFullscreen(); } else if (document.webkitExitFullscreen) { document.webkitExitFullscreen(); } else if (document.mozCancelFullScreen) { document.mozCancelFullScreen(); } }; export const requestFullscreen = el => { if (el.requestFullscreen) { el.requestFullscreen(); } else if (el.webkitRequestFullscreen) { el.webkitRequestFullscreen(); } else if (el.mozRequestFullScreen) { el.mozRequestFullScreen(); } }; export const attachFullscreenListener = (listener) => { if ('onfullscreenchange' in document) { document.addEventListener('fullscreenchange', listener); } else if ('onwebkitfullscreenchange' in document) { document.addEventListener('webkitfullscreenchange', listener); } else if ('onmozfullscreenchange' in document) { document.addEventListener('mozfullscreenchange', listener); } }; export const detachFullscreenListener = (listener) => { if ('onfullscreenchange' in document) { document.removeEventListener('fullscreenchange', listener); } else if ('onwebkitfullscreenchange' in document) { document.removeEventListener('webkitfullscreenchange', listener); } else if ('onmozfullscreenchange' in document) { document.removeEventListener('mozfullscreenchange', listener); } };