Ecosyste.ms: Awesome
An open API service indexing awesome lists of open source software.
https://github.com/souporserious/react-media-player
React audio and video player.
https://github.com/souporserious/react-media-player
Last synced: 7 days ago
JSON representation
React audio and video player.
- Host: GitHub
- URL: https://github.com/souporserious/react-media-player
- Owner: souporserious
- License: isc
- Created: 2015-07-09T04:08:25.000Z (over 9 years ago)
- Default Branch: master
- Last Pushed: 2023-11-13T02:59:31.000Z (about 1 year ago)
- Last Synced: 2024-11-30T15:08:32.501Z (14 days ago)
- Language: JavaScript
- Homepage: https://souporserious.github.io/react-media-player/
- Size: 64.2 MB
- Stars: 471
- Watchers: 18
- Forks: 100
- Open Issues: 44
-
Metadata Files:
- Readme: README.md
- Changelog: CHANGELOG.md
- License: LICENSE
Awesome Lists containing this project
README
## React Media Player
Components and decorators to help build video & audio players in React. Supports
HTML5, Youtube, and Vimeo media types.## Install
`npm install react-media-player --save`
```html
(UMD library exposed as `ReactMediaPlayer`)
```
## `Media` component
A special wrapper component that collects information from the `Player`
component and passes down the proper props to `withMediaProps` decorator.## `Player` component
This is another special component that renders your player and communicates with
the `Media` wrapper.#### `src`: PropTypes.string.isRequired
This is the source of the media you want to play. Currently supporting Youtube,
Vimeo, and any HTML5 compatible video or audio.#### `vendor`: PropTypes.oneOf(['youtube', 'vimeo', 'audio', 'video'])
Explicitly choose which internal component to render for the player. If nothing
is set, the library does its best to determine what player to render based on
the source passed in.#### `autoPlay`: PropTypes.bool
Autoplay media when the component is mounted or `src` changes.
#### `loop`: PropTypes.bool
Loop the current `src` indefinitely.
#### `useAudioObject`: PropTypes.bool
When playing HTML5 `audio`, it will construct audio using the
[`Audio`](https://developer.mozilla.org/en-US/docs/Web/API/HTMLAudioElement#Constructor)
class instead of rendering an element to the page.#### `connectSource`: PropTypes.func(source, audioContext)
A chance to connect a series of
[`AudioNode`[s]](https://developer.mozilla.org/en-US/docs/Web/API/AudioNode)
when using the `audio` vendor. Must return a new audio node that will be
connected to `audioContext.destination` internally.#### `onPlay`: PropTypes.func
Callback when media starts playing.
#### `onPause`: PropTypes.func
Callback when media has been paused.
#### `onError`:PropTypes.func
Callback when an error occurs.
#### `onDuration`: PropTypes.func
Callback when the duration of the media has been calculated.
#### `onProgress`: PropTypes.func
Callback when media starts downloading.
#### `onTimeUpdate`: PropTypes.func
Callback when media time has changed.
#### `onMute`: PropTypes.func
Callback when the player has been muted.
#### `onVolumeChange`: PropTypes.func
Callback when the player volume has changed.
```js
import React, { Component } from 'react'
import { Media, Player, controls } from 'react-media-player'
const { PlayPause, MuteUnmute } = controlsclass MediaPlayer extends Component {
render() {
return (
)
}
}
```
## `withMediaProps` decorator props exposed under `this.props.media`
Passes down helpful state information and methods to build custom media player
controls. Please note that children must be wrapped in the `Media` component.#### `currentTime`: PropTypes.number
#### `progress`: PropTypes.number
#### `duration`: PropTypes.number
#### `volume`: PropTypes.number
#### `isLoading`: PropTypes.bool
#### `isPlaying`: PropTypes.bool
#### `isMuted`: PropTypes.bool
#### `isFullscreen`: PropTypes.bool
#### `play`: PropTypes.func
#### `pause`: PropTypes.func
#### `playPause`: PropTypes.func
#### `stop`: PropTypes.func
#### `seekTo`: PropTypes.func
#### `mute`: PropTypes.func
#### `muteUnmute`: PropTypes.func
#### `setVolume`: PropTypes.func
#### `fullscreen`: PropTypes.func
```js
import React, { Component } from 'react'
import { withMediaProps } from 'react-media-player'class CustomPlayPause extends Component {
shouldComponentUpdate({ media }) {
return this.props.media.isPlaying !== media.isPlaying
}_handlePlayPause = () => {
this.props.media.playPause()
}render() {
const { className, style, media } = this.props
return (
{media.isPlaying ? 'Pause' : 'Play'}
)
}
}export default withMediaProps(CustomPlayPause)
``````js
import React from 'react'
import CustomPlayPause from './CustomPlayPause'function App() {
return (
)
}export default App
```
## `utils.keyboardControls`
A special function that will provide keyboard support to the media player.
```js
import React, { Component } from 'react'
import { Media, Player, controls, utils } from 'react-media-player'
const {
PlayPause,
CurrentTime,
Progress,
SeekBar,
Duration,
MuteUnmute,
Volume,
Fullscreen,
} = controls
const { keyboardControls } = utilsclass MediaPlayer extends Component {
render() {
const { Player, keyboardControls } = this.props
return (
{mediaProps => (
)}
)
}
}
```
## `utils.formatTime`
A helper function to format time.
```js
import React, { Component } from 'react'
import { withMediaProps, utils } from 'react-media-player'
const { formatTime } = utilsclass CurrentTime extends Component {
shouldComponentUpdate({ media }) {
return this.props.media.currentTime !== media.currentTime
}render() {
const { className, style, media } = this.props
return (
)
}
}export default withMediaProps(CurrentTime)
```
## Running Locally
clone repo
`git clone [email protected]:souporserious/react-media-player.git`
move into folder
`cd ~/react-media-player`
install dependencies
`npm install`
run dev mode
`npm run dev`
open your browser and visit: `http://localhost:8080/`