import ImmutablePropTypes from 'react-immutable-proptypes'; import PureRenderMixin from 'react-addons-pure-render-mixin'; import IconButton from './icon_button'; import { defineMessages, injectIntl, FormattedMessage } from 'react-intl'; const messages = defineMessages({ toggle_sound: { id: 'video_player.toggle_sound', defaultMessage: 'Toggle sound' }, toggle_visible: { id: 'video_player.toggle_visible', defaultMessage: 'Toggle visibility' } }); const videoStyle = { position: 'relative', zIndex: '1', width: '100%', height: '100%', objectFit: 'cover', top: '50%', transform: 'translateY(-50%)' }; const muteStyle = { position: 'absolute', top: '10px', right: '10px', opacity: '0.8', zIndex: '5' }; const spoilerStyle = { marginTop: '8px', textAlign: 'center', height: '100%', cursor: 'pointer', display: 'flex', alignItems: 'center', justifyContent: 'center', flexDirection: 'column', position: 'relative' }; const spoilerSpanStyle = { display: 'block', fontSize: '14px' }; const spoilerSubSpanStyle = { display: 'block', fontSize: '11px', fontWeight: '500' }; const spoilerButtonStyle = { position: 'absolute', top: '6px', left: '8px', zIndex: '100' }; const VideoPlayer = React.createClass({ propTypes: { media: ImmutablePropTypes.map.isRequired, width: React.PropTypes.number, height: React.PropTypes.number, sensitive: React.PropTypes.bool, intl: React.PropTypes.object.isRequired, autoplay: React.PropTypes.bool }, getDefaultProps () { return { width: 239, height: 110 }; }, getInitialState () { return { visible: !this.props.sensitive, preview: true, muted: true, hasAudio: true }; }, mixins: [PureRenderMixin], handleClick () { this.setState({ muted: !this.state.muted }); }, handleVideoClick (e) { e.stopPropagation(); const node = ReactDOM.findDOMNode(this).querySelector('video'); if (node.paused) { node.play(); } else { node.pause(); } }, handleOpen () { this.setState({ preview: !this.state.preview }); }, handleVisibility () { this.setState({ visible: !this.state.visible, preview: true }); }, setRef (c) { this.video = c; }, handleLoadedData () { if (('WebkitAppearance' in document.documentElement.style && this.video.audioTracks.length === 0) || this.video.mozHasAudio === false) { this.setState({ hasAudio: false }); } }, componentDidMount () { if (!this.video) { return; } this.video.addEventListener('loadeddata', this.handleLoadedData); }, componentDidUpdate () { if (!this.video) { return; } this.video.addEventListener('loadeddata', this.handleLoadedData); }, componentWillUnmount () { if (!this.video) { return; } this.video.removeEventListener('loadeddata', this.handleLoadedData); }, render () { const { media, intl, width, height, sensitive, autoplay } = this.props; let spoilerButton = (
); let muteButton = ''; if (this.state.hasAudio) { muteButton = (
); } if (!this.state.visible) { if (sensitive) { return (
{spoilerButton}
); } else { return (
{spoilerButton}
); } } if (this.state.preview && !autoplay) { return (
{spoilerButton}
); } return (
{spoilerButton} {muteButton}
); } }); export default injectIntl(VideoPlayer);