![Oracle Drags Its Feet in the JavaScript Trademark Dispute](https://cdn.sanity.io/images/cgdhsj6q/production/919c3b22c24f93884c548d60cbb338e819ff2435-1024x1024.webp?w=400&fit=max&auto=format)
Security News
Oracle Drags Its Feet in the JavaScript Trademark Dispute
Oracle seeks to dismiss fraud claims in the JavaScript trademark dispute, delaying the case and avoiding questions about its right to the name.
react-media-player
Advanced tools
Components and decorators to help build video & audio players in React. Supports HTML5, Youtube, and Vimeo media types.
npm install react-media-player --save
<script src="https://unpkg.com/react-media-player/dist/react-media-player.js"></script>
(UMD library exposed as `ReactMediaPlayer`)
Media
componentA special wrapper component that collects information from the Player
component and passes down the proper props to withMediaProps
decorator.
Player
componentThis is another special component that renders your player and communicates with
the Media
wrapper.
src
: PropTypes.string.isRequiredThis 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.boolAutoplay media when the component is mounted or src
changes.
loop
: PropTypes.boolLoop the current src
indefinitely.
useAudioObject
: PropTypes.boolWhen playing HTML5 audio
, it will construct audio using the
Audio
class instead of rendering an element to the page.
connectSource
: PropTypes.func(source, audioContext)A chance to connect a series of
AudioNode
[s]
when using the audio
vendor. Must return a new audio node that will be
connected to audioContext.destination
internally.
onPlay
: PropTypes.funcCallback when media starts playing.
onPause
: PropTypes.funcCallback when media has been paused.
onError
:PropTypes.funcCallback when an error occurs.
onDuration
: PropTypes.funcCallback when the duration of the media has been calculated.
onProgress
: PropTypes.funcCallback when media starts downloading.
onTimeUpdate
: PropTypes.funcCallback when media time has changed.
onMute
: PropTypes.funcCallback when the player has been muted.
onVolumeChange
: PropTypes.funcCallback when the player volume has changed.
import React, { Component } from 'react'
import { Media, Player, controls } from 'react-media-player'
const { PlayPause, MuteUnmute } = controls
class MediaPlayer extends Component {
render() {
return (
<Media>
<div className="media">
<div className="media-player">
<Player src="http://www.youtube.com/embed/h3YVKTxTOgU" />
</div>
<div className="media-controls">
<PlayPause />
<MuteUnmute />
</div>
</div>
</Media>
)
}
}
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.numberprogress
: PropTypes.numberduration
: PropTypes.numbervolume
: PropTypes.numberisLoading
: PropTypes.boolisPlaying
: PropTypes.boolisMuted
: PropTypes.boolisFullscreen
: PropTypes.boolplay
: PropTypes.funcpause
: PropTypes.funcplayPause
: PropTypes.funcstop
: PropTypes.funcseekTo
: PropTypes.funcmute
: PropTypes.funcmuteUnmute
: PropTypes.funcsetVolume
: PropTypes.funcfullscreen
: PropTypes.funcimport 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 (
<button
type="button"
className={className}
style={style}
onClick={this._handlePlayPause}
>
{media.isPlaying ? 'Pause' : 'Play'}
</button>
)
}
}
export default withMediaProps(CustomPlayPause)
import React from 'react'
import CustomPlayPause from './CustomPlayPause'
function App() {
return (
<Media>
<CustomPlayPause />
<Player src="https://youtu.be/VOyYwzkQB98" />
</Media>
)
}
export default App
utils.keyboardControls
A special function that will provide keyboard support to the media player.
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 } = utils
class MediaPlayer extends Component {
render() {
const { Player, keyboardControls } = this.props
return (
<Media>
{mediaProps => (
<div
className="media"
onKeyDown={keyboardControls.bind(null, mediaProps)}
>
<Player src="against-them-all.mp3" className="media-player" />
<div className="media-controls">
<PlayPause />
<CurrentTime />
<Progress />
<SeekBar />
<Duration />
<MuteUnmute />
<Volume />
<Fullscreen />
</div>
</div>
)}
</Media>
)
}
}
utils.formatTime
A helper function to format time.
import React, { Component } from 'react'
import { withMediaProps, utils } from 'react-media-player'
const { formatTime } = utils
class CurrentTime extends Component {
shouldComponentUpdate({ media }) {
return this.props.media.currentTime !== media.currentTime
}
render() {
const { className, style, media } = this.props
return (
<time className={className} style={style}>
{formatTime(media.currentTime)}
</time>
)
}
}
export default withMediaProps(CurrentTime)
clone repo
git clone git@github.com: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/
0.7.9
Fix build
FAQs
React media player.
The npm package react-media-player receives a total of 0 weekly downloads. As such, react-media-player popularity was classified as not popular.
We found that react-media-player demonstrated a not healthy version release cadence and project activity because the last version was released a year ago. It has 1 open source maintainer collaborating on the project.
Did you know?
Socket for GitHub automatically highlights issues in each pull request and monitors the health of all your open source dependencies. Discover the contents of your packages and block harmful activity before you install or update your dependencies.
Security News
Oracle seeks to dismiss fraud claims in the JavaScript trademark dispute, delaying the case and avoiding questions about its right to the name.
Security News
The Linux Foundation is warning open source developers that compliance with global sanctions is mandatory, highlighting legal risks and restrictions on contributions.
Security News
Maven Central now validates Sigstore signatures, making it easier for developers to verify the provenance of Java packages.