Wrapper component for wavesurfer.js. Includes support for the Timeline and Regions.
import React from 'react';
import ReactDOM from 'react-dom';
import Wavesurfer from 'react-wavesurfer';
class MyComponent extends React.Component {
constructor(props) {
super(props);
this.state = {
playing: false,
pos: 0
};
this.handleTogglePlay = this.handleTogglePlay.bind(this);
this.handlePosChange = this.handlePosChange.bind(this);
}
handleTogglePlay() {
this.setState({
playing: !this.state.playing
});
}
handlePosChange(e) {
this.setState({
pos: e.originalArgs[0]
});
}
render() {
return (
<div>
<Wavesurfer
audioFile={'path/to/audio/file.mp3'}
pos={this.state.pos}
onPosChange={this.handlePosChange}
playing={this.state.playing}
/>
</div>
);
}
}
For more advanced examples check the example directory.
The base component includes core wavesurfer.js features without plugins. Any plugin components should be included as child components of the base component.
starts/stops playback
0-1
position of playback in seconds
the audio to render
The instantiation options for wavesurfer. See documentation of wavesurfer.js. The defaults values are the default values of wavesurfer.js
Is basically called on audioprocess
and seek
events and consolidates the received time formats into the same type of argument object as the onAudioprocess
callback (time in seconds, not as a relative value):
{
wavesurfer: wavesurferInstance,
originalArgs: [playBackPositionInSecs]
}
This is necessary to fix any inconsistencies between WebAudio and MediaElement APIs.
Callbacks passed in as props, which are fired when the event on the underlying wavesurfer.js instance is fired.
Possible callback prop names are: onAudioprocess
, onError
, onFinish
, onLoading
, onMouseup
, onPause
, onPlay
, onReady
, onScroll
, onSeek
, onZoom
The callbacks receive an object as parameter:
{
wavesurfer: wavesurferInstance,
originalArgs: [originalArgs]
}
An object of region config objects which have the form:
// ...
uniqueKey: {
id: uniqueKey
start: startInSeconds
end: endInSeconds
},
// ...
Callbacks for the events the region plugin adds to the wavesurfer.js instance: onRegionIn
, onRegionOut
, onRegionMouseenter
, onRegionMouseleave
, onRegionClick
, onRegionDblclick
, onRegionUpdated
, onRegionUpdateEnd
, onRegionRemoved
, onRegionPlay
They receive an object as parameter which has the same form as the base component callbacks.
Callbacks for the events fired on the single region instances. The Prop names are prefixed with Single
, the available props are:
onSingleRegionIn
, onSingleRegionOut
, onSingleRegionRemove
, onSingleRegionUpdate
, onSingleRegionClick
, onSingleRegionDbclick
, onSingleRegionOver
, onSingleRegionLeave
They receive an object as parameter which has the same form as the other callbacks, but also includes a reference to the region which fired the event:
{
wavesurfer: wavesurferInstance,
originalArgs: [originalArgs],
region: regionInstance
}
An object containing configuration for the timeline plugin. (See the wavesurfer.js timeline example for information about available options.
Note: the options container
and wavesurfer
need not be set, this is done by the plugin component.
npm run start
– Start development server (webpack-dev-server) atlocalhost:8080/webpack-dev-server
npm run lint
– Lint code (is done while running start task too)npm run build
– Lint and build distributable files
Please make sure your code passes the linting task before submitting a pull request.