spee.ch/react/containers/PublishThumbnailInput/view.jsx

118 lines
3.6 KiB
React
Raw Normal View History

2018-01-04 23:14:03 +01:00
import React from 'react';
2018-01-17 19:49:57 +01:00
class PublishThumbnailInput extends React.Component {
2018-01-11 02:41:17 +01:00
constructor (props) {
super(props);
this.state = {
2018-03-01 06:25:51 +01:00
videoSource : null,
error : null,
sliderMinRange: 1,
sliderMaxRange: null,
sliderValue : null,
2018-03-01 02:28:47 +01:00
};
2018-03-01 06:25:51 +01:00
this.handleSliderChange = this.handleSliderChange.bind(this);
this.handleVideoLoadedData = this.handleVideoLoadedData.bind(this);
this.setThumbnailWithSnapshot = this.setThumbnailWithSnapshot.bind(this);
2018-01-11 02:41:17 +01:00
}
2018-02-06 03:14:12 +01:00
componentDidMount () {
2018-03-01 06:25:51 +01:00
this.setThumbnailClaimAndUrl();
this.setVideoSource();
2018-02-06 03:14:12 +01:00
}
2018-03-01 06:25:51 +01:00
setThumbnailClaimAndUrl () {
const { claim, host, thumbnailChannel } = this.props;
const url = `${host}/${thumbnailChannel}/${claim}-thumb.png`;
this.props.onThumbnailChange(`${claim}-thumb`, url);
2018-01-17 21:54:26 +01:00
}
2018-03-01 06:25:51 +01:00
setVideoSource () {
const { file } = this.props;
const previewReader = new FileReader();
previewReader.readAsDataURL(file);
previewReader.onloadend = () => {
this.setState({videoSource: previewReader.result});
};
2018-01-11 02:41:17 +01:00
}
2018-03-01 06:25:51 +01:00
handleVideoLoadedData (event) {
const duration = event.target.duration;
// set the slider
this.setState({
sliderMaxRange: duration * 100,
sliderValue : duration * 100 / 2,
2018-01-11 02:41:17 +01:00
});
2018-03-01 06:25:51 +01:00
// update the current time of the video
let video = document.getElementById('video-thumb-player');
video.currentTime = duration / 2;
2018-01-11 02:41:17 +01:00
}
2018-03-01 06:25:51 +01:00
handleSliderChange (event) {
const value = parseInt(event.target.value);
// update the slider value
this.setState({
sliderValue: value,
});
// update the current time of the video
let video = document.getElementById('video-thumb-player');
video.currentTime = value / 100;
2018-02-06 03:14:12 +01:00
}
2018-03-01 06:25:51 +01:00
setThumbnailWithSnapshot () {
// take a snapshot
const snapshot = this.takeSnapShot();
// set the thumbnail in redux store
if (snapshot) this.props.onThumbnailFileSelect(snapshot);
2018-02-06 03:14:12 +01:00
}
2018-03-01 06:25:51 +01:00
takeSnapShot () {
let video = document.getElementById('video-thumb-player');
let canvas = document.createElement('canvas');
canvas.width = video.videoWidth;
canvas.height = video.videoHeight;
canvas.getContext('2d').drawImage(video, 0, 0, canvas.width, canvas.height);
const imageDataUrl = canvas.toDataURL();
const success = imageDataUrl.length > 1000;
if (!success) {
this.setState({error: 'error taking snapshot'});
return false;
}
return imageDataUrl;
2018-01-11 02:41:17 +01:00
}
2018-01-04 23:14:03 +01:00
render () {
2018-03-01 06:25:51 +01:00
const { error, videoSource, sliderMinRange, sliderMaxRange, sliderValue } = this.state;
2018-01-04 23:14:03 +01:00
return (
2018-01-11 21:51:38 +01:00
<div>
2018-02-06 03:14:12 +01:00
<div>
2018-03-01 06:25:51 +01:00
{ error ? (
<p className='info-message--failure'>{error}</p>
) : (
<p className='info-message'>Use slider to set thumbnail:</p>
)}
<video
id='video-thumb-player'
preload='metadata'
muted
style={{display: 'none'}}
playsInline
onLoadedData={this.handleVideoLoadedData}
src={videoSource}
onTimeUpdate={this.setThumbnailWithSnapshot}
/>
{
sliderValue ? (
<div className='slide-container'>
<input
type='range'
min={sliderMinRange}
max={sliderMaxRange}
value={sliderValue}
className='slider'
onChange={this.handleSliderChange}
/>
</div>
) : (
<p>loading slider... </p>
)
}
2018-01-11 02:41:17 +01:00
</div>
2018-01-04 23:14:03 +01:00
</div>
);
}
}
2018-01-17 19:49:57 +01:00
export default PublishThumbnailInput;