// Package imports // import React from 'react'; import ImmutablePropTypes from 'react-immutable-proptypes'; import PropTypes from 'prop-types'; import { defineMessages, injectIntl, FormattedMessage } from 'react-intl'; // Mastodon imports // import IconButton from '../../../mastodon/components/icon_button'; import { isIOS } from '../../../mastodon/is_mobile'; const messages = defineMessages({ toggle_sound: { id: 'video_player.toggle_sound', defaultMessage: 'Toggle sound' }, toggle_visible: { id: 'video_player.toggle_visible', defaultMessage: 'Toggle visibility' }, expand_video: { id: 'video_player.expand', defaultMessage: 'Expand video' }, }); @injectIntl export default class StatusVideoPlayer extends React.PureComponent { static propTypes = { media: ImmutablePropTypes.map.isRequired, letterbox: PropTypes.bool, fullwidth: PropTypes.bool, height: PropTypes.number, sensitive: PropTypes.bool, intl: PropTypes.object.isRequired, autoplay: PropTypes.bool, onOpenVideo: PropTypes.func.isRequired, }; static defaultProps = { height: 110, }; state = { visible: !this.props.sensitive, preview: true, muted: true, hasAudio: true, videoError: false, }; handleClick = () => { this.setState({ muted: !this.state.muted }); } handleVideoClick = (e) => { e.stopPropagation(); const node = this.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, }); } handleExpand = () => { this.video.pause(); this.props.onOpenVideo(this.props.media, this.video.currentTime); } 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 }); } } handleVideoError = () => { this.setState({ videoError: true }); } componentDidMount () { if (!this.video) { return; } this.video.addEventListener('loadeddata', this.handleLoadedData); this.video.addEventListener('error', this.handleVideoError); } componentDidUpdate () { if (!this.video) { return; } this.video.addEventListener('loadeddata', this.handleLoadedData); this.video.addEventListener('error', this.handleVideoError); } componentWillUnmount () { if (!this.video) { return; } this.video.removeEventListener('loadeddata', this.handleLoadedData); this.video.removeEventListener('error', this.handleVideoError); } render () { const { media, intl, letterbox, fullwidth, height, sensitive, autoplay } = this.props; let spoilerButton = (