mirror of
https://gitcode.com/GitHub_Trending/ji/jitsi-meet.git
synced 2025-12-30 03:12:29 +00:00
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.
69 lines
1.8 KiB
JavaScript
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
|
|
};
|