1
0
mirror of https://github.com/ascribe/onion.git synced 2025-01-03 10:25:08 +01:00

Add videojs and styles

This commit is contained in:
vrde 2015-07-02 17:10:32 +02:00
parent 3556e8c3c2
commit 7f8a36b99a
2 changed files with 86 additions and 8 deletions

View File

@ -73,22 +73,27 @@ let Video = React.createClass({
}, },
componentDidMount() { componentDidMount() {
this.inject('https://code.jquery.com/jquery-2.1.4.min.js') Promise.all([
.then(() => this.inject('//vjs.zencdn.net/4.12/video-js.css'),
Promise.all([ this.inject('//vjs.zencdn.net/4.12/video.js')
this.inject('https://cdnjs.cloudflare.com/ajax/libs/mediaelement/2.17.0/mediaelement-and-player.min.js'), ]).then(this.ready);
this.inject('https://cdnjs.cloudflare.com/ajax/libs/mediaelement/2.17.0/mediaelementplayer.min.css') },
]).then(this.ready));
componentDidUpdate() {
if (this.state.ready && !this.state.videojs) {
window.videojs(React.findDOMNode(this.refs.video));
}
}, },
ready() { ready() {
this.setState({ready: true}); this.setState({ready: true, videojs: false});
}, },
render() { render() {
if (this.state.ready) { if (this.state.ready) {
return ( return (
<video poster={this.props.preview} controls="controls" preload="none"> <video ref="video" className="video-js vjs-default-skin" poster={this.props.preview}
controls preload="none" width="auto" height="auto">
{this.props.extraData.map((data, i) => {this.props.extraData.map((data, i) =>
<source key={i} type={'video/' + data.type} src={data.url} /> <source key={i} type={'video/' + data.type} src={data.url} />
)} )}

View File

@ -14,5 +14,78 @@
font-size: 500%; font-size: 500%;
color: #cccccc; color: #cccccc;
} }
.video-js,
.vjs-poster {
background-color: transparent;
}
.video-js .vjs-tech {
position: relative;
}
.vjs-fullscreen {
padding-top: 0px;
}
.vjs-default-skin .vjs-play-progress,
.vjs-default-skin .vjs-volume-level {
background: $ascribe-color-full;
}
.vjs-default-skin .vjs-big-play-button {
border-radius: 6px;
-o-border-radius: 6px;
-moz-border-radius: 6px;
-webkit-border-radius: 6px;
box-shadow: none;
-o-box-shadow: none;
-moz-box-shadow: none;
-webkit-box-shadow: none;
width: 100px;
height: 60px;
top: 50%;
left: 50%;
margin: -30px -50px;
border: none;
background-color: rgba(0,0,0,.8);
}
.vjs-default-skin:hover .vjs-big-play-button,
.vjs-default-skin .vjs-big-play-button:focus {
border-color: #fff;
background-color: rgba(0,0,0,.9);
box-shadow: none;
-o-box-shadow: none;
-moz-box-shadow: none;
-webkit-box-shadow: none;
transition: all 0s;
-o-transition: all 0s;
-moz-transition: all 0s;
-webkit-transition: all 0s;
}
.vjs-default-skin .vjs-big-play-button:before {
line-height: 60px;
}
.vjs-default-skin .vjs-slider-handle:before,
.vjs-default-skin .vjs-big-play-button:before {
text-shadow: none;
}
.vjs-default-skin .vjs-volume-bar {
height: .5em;
}
.vjs-default-skin .vjs-control-bar {
background-color: rgba(0,0,0,.7);
}
} }