1
0
mirror of https://github.com/ascribe/onion.git synced 2024-11-15 09:35:10 +01:00
onion/js/components/ascribe_media/resource_viewer.js

88 lines
2.3 KiB
JavaScript
Raw Normal View History

2015-05-27 17:34:15 +02:00
import React from 'react';
import InjectInHeadMixin from '../../mixins/inject_in_head_mixin';
/**
* This is the component that implements display-specific functionality.
*
* ResourceViewer handles the following mimetypes:
* - image
* - video
* - audio
* - pdf
* - other
*/
2015-06-03 16:53:27 +02:00
let Image = React.createClass({
render() {
return (<img className="img-responsive" src={this.props.preview} />);
}
});
let Video = React.createClass({
2015-05-27 17:34:15 +02:00
propTypes: {
2015-06-03 16:53:27 +02:00
preview: React.PropTypes.string.isRequired,
url: React.PropTypes.string.isRequired,
extraData: React.PropTypes.array.isRequired
2015-05-27 17:34:15 +02:00
},
mixins: [InjectInHeadMixin],
2015-06-03 16:53:27 +02:00
getInitialState() {
return { ready: false };
},
2015-05-27 17:34:15 +02:00
componentDidMount() {
2015-06-03 16:53:27 +02:00
this.inject('http://code.jquery.com/jquery-2.1.4.min.js')
.then(() =>
Promise.all([
this.inject('https://cdnjs.cloudflare.com/ajax/libs/mediaelement/2.17.0/mediaelement-and-player.min.js'),
this.inject('https://cdnjs.cloudflare.com/ajax/libs/mediaelement/2.17.0/mediaelementplayer.min.css')
]).then(() => { this.setState({ready: true}); }));
},
render() {
if (this.state.ready) {
return (
<video poster={this.props.preview} controls="controls" preload="none">
{this.props.extraData.map((data, i) =>
<source key={i} type={'video/' + data.type} src={data.url} />
)}
</video>
);
} else {
return(
<Image src={this.props.preview} />
);
}
}
});
let resourceMap = {
'image': Image,
'video': Video
}
let ResourceViewer = React.createClass({
propTypes: {
mimetype: React.PropTypes.oneOf(['image', 'video', 'audio', 'pdf', 'other']).isRequired,
preview: React.PropTypes.string.isRequired,
url: React.PropTypes.string.isRequired
2015-05-27 17:34:15 +02:00
},
render() {
2015-06-03 16:53:27 +02:00
let Component = resourceMap[this.props.mimetype] || Image;
2015-05-27 17:34:15 +02:00
return (
2015-06-03 16:53:27 +02:00
<div className="media">
<Component preview={this.props.preview}
url={this.props.url}
extraData={this.props.extraData} />
2015-05-27 17:34:15 +02:00
</div>
);
}
});
export default ResourceViewer;