Files
jitsi-meet/react/features/base/media/components/web/Video.js
Lyubomir Marinov d55e0f70d9 Import jitsi/jitsi-meet-react#2f23d98
As an intermediate step on the path to merging jitsi-meet and
jitsi-meet-react, import the whole source code of jitsi-meet-react as it
stands at
2f23d98424
i.e. the lastest master at the time of this import. No modifications are
applied to the imported source code in order to preserve a complete
snapshot of it in the repository of jitsi-meet and, thus, facilitate
comparison later on. Consequently, the source code of jitsi-meet and/or
jitsi-meet-react may not work. For example, jitsi-meet's jshint may be
unable to parse jitsi-meet-react's source code.
2016-10-12 10:31:52 -05:00

69 lines
1.8 KiB
JavaScript

import React, { Component } from 'react';
import { styles } from './styles';
/**
* Web version of Audio component.
* @extends Component
*/
export class Video extends Component {
/**
* Implements React's {@link Component#render()}.
*
* @inheritdoc
* @returns {ReactElement|null}
*/
render() {
const stream = this.props.stream;
if (stream) {
// TODO URL.releaseObjectURL on componentDid/WillUnmount
const src = URL.createObjectURL(stream);
const style
= this.props.mirror ? styles.mirroredVideo : styles.video;
return (
<video
autoPlay = { true }
muted = { this.props.muted }
onPlaying = { this.props.onPlaying }
src = { src }
style = { style } />
);
}
return null;
}
/**
* Implements shouldComponentUpdate of React Component. We don't update
* component if stream has not changed.
*
* @inheritdoc
* @param {Object} nextProps - Props that component is going to receive.
* @returns {boolean}
*/
shouldComponentUpdate(nextProps) {
return (nextProps.stream || {}).id !== (this.props.stream || {}).id;
}
}
/**
* Video component's property types.
*
* @static
*/
Video.propTypes = {
mirror: React.PropTypes.bool,
muted: React.PropTypes.bool,
onPlaying: React.PropTypes.func,
stream: React.PropTypes.object,
/**
* Not used on Web. Introduced for the benefit of React Native. For more
* details, refer to the zOrder property of the Video class for React
* Native (i.e. ../native/Video.js).
*/
zOrder: React.PropTypes.number
};