UI & Layout
useFullscreen
About
Use Fullscreen API to make beautiful and immersive experience. Present desired content using the entire user's screen. Commonly used in browser games or other applications using canvases.
Example
Arguments
An object with the following optional properties:
| Argument value | Type | Description | 
|---|---|---|
| options.target | React.RefObject<Element> | React's ref to DOM node which should be present in fullscreen mode | 
| options.onChange | (event: Event) => void | Callback function to be called on fullscreenchangeevent | 
| options.onError | (event: Event) => void | Callback function to be called on fullscreenerrorevent | 
| options.requestFullscreenOptions | FullscreenOptions | requestFullscreenoptions as defined here | 
If the target property is not specified, the whole document will be rendered in fullscreen mode.
Returns
Returns an object with following properties:
| Property Name | Type | Description | 
|---|---|---|
| isFullscreenAvailable | boolean | Whether the Fullscreen APIis available | 
| isFullscreenEnabled | boolean | Whether the fullscreen is enabled | 
| fullscreenElement | `Element | null` | 
| enableFullscreen | () => Promise<void> | Enable the fullscreen | 
| disableFullscreen | () => Promise<void> | Disable the fullscreen | 
| toggleFullscreen | () => Promise<void> | Toggle the fullscreen | 
Sidenote
- Before using Fullscreen API, one should check if it is available using isFullscreenAvailableproperty. Otherwise, all method calls will result in an error.
- If the target is an <iframe>, it must have theallowfullscreenattribute applied to it.
- All methods should be called while responding to a user interaction or a device orientation change. Otherwise, such operations will result in an error (eg., you cannot enable the fullscreen on component render using the useEffecthook).