import React from 'react'; import PropTypes from 'prop-types'; import { isIOS } from 'soapbox/is_mobile'; export default class ExtendedVideoPlayer extends React.PureComponent { static propTypes = { src: PropTypes.string.isRequired, alt: PropTypes.string, width: PropTypes.number, height: PropTypes.number, time: PropTypes.number, controls: PropTypes.bool.isRequired, muted: PropTypes.bool.isRequired, onClick: PropTypes.func, }; handleLoadedData = () => { if (this.props.time) { this.video.currentTime = this.props.time; } } componentDidMount() { this.video.addEventListener('loadeddata', this.handleLoadedData); } componentWillUnmount() { this.video.removeEventListener('loadeddata', this.handleLoadedData); } setRef = (c) => { this.video = c; } handleClick = e => { e.stopPropagation(); const handler = this.props.onClick; if (handler) handler(); } render() { const { src, muted, controls, alt } = this.props; const conditionalAttributes = {}; if (isIOS()) { conditionalAttributes.playsInline = '1'; } return (
); } }