import {VideoPlayer} from '@primer/react-brand'
Videos with important visual information must include an audio description to ensure that the content is accessible to all users.
The audio description can be provided as part of the existing soundtrack, or via a link to an alternate audio-described version.
The VideoPlayer
component exposes a useVideo
hook that can be used to control the video programmatically. To use the hook, the VideoPlayer
component must be wrapped in a VideoPlayer.Provider
component.
Full documentation for the useVideo
hook can be found below.
The useVideo
context provides a comprehensive API for managing video playback, volume, closed captioning, and fullscreen mode.
The context can be accessed by using the useVideo
hook in any component that is a child of VideoPlayer.Provider
.
Below is a detailed description of each property and method available in the useVideo
context.
Name | Type | Description |
---|---|---|
ref | RefObject<HTMLVideoElement> | A reference to the video element. |
isPlaying | boolean | Indicates if the video is currently playing. |
volume | number | The current volume of the video, ranging from 0 to 1. |
isMuted | boolean | Indicates if the video is currently muted. |
volumeBeforeMute | number | The volume of the video before it was muted, allowing for easy unmuting to the previous level. |
duration | number | The total duration of the video in seconds. |
ccEnabled | boolean | Indicates if closed captions are enabled. |
isFullScreen | boolean | Indicates if the video is currently in fullscreen mode. |
play | () => void | Plays the video. |
pause | () => void | Pauses the video. |
togglePlaying | () => void | Toggles between playing and pausing the video. |
setVolume | (volumeValOrFn: SetStateAction<number>) => void | Sets the volume of the video. |
mute | () => void | Mutes the video. |
unmute | () => void | Unmutes the video. |
toggleMute | () => void | Toggles between muting and unmuting the video. |
setDuration | (duration: number) => void | Sets the duration of the video. |
seekToPercent | (percent: number) => void | Seeks the video to a specific percentage of its duration. |
seek | (secondsValOrFn: SetStateAction<number>) => void | Seeks the video to an absolute time, or to a relative time if passed a function. |
enableCC | () => void | Enables closed captions. |
disableCC | () => void | Disables closed captions. |
toggleCC | () => void | Toggles closed captions on and off. |
enterFullScreen | () => void | Enters fullscreen mode. |
exitFullScreen | () => void | Exits fullscreen mode. |
toggleFullScreen | () => void | Toggles between entering and exiting fullscreen mode. |
VideoPlayer
provides a React alternative to the native HTML <video />
.
Name | Type | Default | Required | Description |
---|---|---|---|---|
children | React.ReactNode , React.ReactNode[] | true | Takes <VideoPlayer.Source> and <VideoPlayer.Track> elements | |
title | string | true | Sets the title of the video | |
visuallyHiddenTitle | boolean | false | Visually hides the title of the video in the upper-left corner | |
showBranding | boolean | true | false | Displays GitHub branding next to video title |
poster | string | false | Sets an image as the starting frame for the video element | |
className | string | false | Sets a custom class on the <video> element | |
showControlsWhenPaused | boolean | true | false | Show the video controls when paused |
showPlayPauseButton | boolean | true | false | Show the play button control |
showSeekControl | boolean | true | false | Show the seek control |
showCCButton | boolean | true | false | Show the closed caption toggle control |
showMuteButton | boolean | true | false | Show the mute button control |
showVolumeControl | boolean | true | false | Show the volume control |
showFullScreenButton | boolean | true | false | Show the full screen button control |
The component API supports all standard HTML attribute props, while providing some additional behavior as described above.
VideoPlayer.Source
provides a React alternative to the native HTML <source />
. The component API supports all standard HTML attribute props.
VideoPlayer.Track
provides a React alternative to the native HTML <track />
.
Name | Type | Default | Required | Description |
---|---|---|---|---|
kind | 'subtitles' , 'captions' , 'descriptions' , 'chapters' , 'metadata' | 'captions' | false | Sets how the text track is meant to be used |
The component API supports all standard HTML attribute props, while providing some additional behavior as described above.
VideoPlayer.Provider
can be used in conjunction with the useVideo
hook to enable programmatic access to features such as video playback, volume, closed captioning, and fullscreen mode.