Files
filestash/client/pages/viewerpage/audioplayer.js

104 lines
3.6 KiB
JavaScript

import React from 'react';
import WaveSurfer from 'wavesurfer.js';
import { MenuBar } from './menubar';
import { NgIf, Icon } from '../../components/'
export class AudioPlayer extends React.Component {
constructor(props){
super(props);
this.state = {
wafesurfer: null,
loading: true,
isPlaying: true,
error: null
}
this.toggle = this.toggle.bind(this);
window.addEventListener('keypress', this.toggle);
}
componentDidMount(){
let $el = document.querySelector('.player');
var wavesurfer = WaveSurfer.create({
container: '#waveform',
waveColor: '#323639',
progressColor: '#6f6f6f',
cursorColor: '#323639',
cursorWidth: 2,
height: 250,
barWidth: 1
});
this.setState({wavesurfer: wavesurfer});
wavesurfer.on('ready', () => {
this.setState({loading: false});
if(this.state.isPlaying === true){
wavesurfer.play();
}
});
wavesurfer.on('error', (err) => {
this.setState({error: err, loading: false});
});
wavesurfer.load(this.props.data);
}
componentWillUnmount(){
if(this.state.wavesurfer){
this.state.wavesurfer.destroy();
}
window.removeEventListener('keypress', this.toggle);
}
toggle(){
if(this.state.isPlaying === true){
this.setState({isPlaying: false});
this.state.wavesurfer.pause();
}else{
this.setState({isPlaying: true});
this.state.wavesurfer.play();
}
}
onPlay(e){
e.preventDefault();
e.stopPropagation();
this.setState({isPlaying: true})
this.state.wavesurfer.play();
}
onPause(e){
e.preventDefault();
e.stopPropagation();
this.setState({isPlaying: false});
this.state.wavesurfer.pause();
}
render(){
return (
<div style={{height: '100%'}}>
<MenuBar title={this.props.filename} download={this.props.data} />
<div style={{textAlign: 'center', background: '#525659', height: '100%', overflow: 'hidden', padding: '20px', boxSizing: 'border-box'}}>
<NgIf cond={this.state.error !== null} style={{color: 'white', marginTop: '30px'}}>
{this.state.error}
</NgIf>
<NgIf cond={this.state.error === null}>
<NgIf cond={this.state.loading === true}>
<Icon name="loading" />
</NgIf>
<div style={{background: '#f1f1f1', boxShadow: 'rgba(0, 0, 0, 0.14) 0px 4px 5px 0px, rgba(0, 0, 0, 0.12) 0px 1px 10px 0px, rgba(0, 0, 0, 0.2) 0px 2px 4px -1px', opacity: this.state.loading? '0' : '1', position: 'relative'}}>
<div style={{position: 'absolute', top: '10px', right: '10px', zIndex: '2', height: '30px'}}>
<NgIf cond={this.state.isPlaying === false} style={{display: 'inline'}}>
<span style={{cursor: 'pointer'}} onClick={this.onPlay.bind(this)}><Icon name="play"/></span>
</NgIf>
<NgIf cond={this.state.isPlaying === true} style={{display: 'inline'}}>
<span style={{cursor: 'pointer'}} onClick={this.onPause.bind(this)}><Icon name="pause"/></span>
</NgIf>
</div>
<div id="waveform"></div>
</div>
</NgIf>
</div>
</div>
)
}
}