pleroma/app/soapbox/components/extended_video_player.js

71 lines
1.5 KiB
JavaScript
Raw Normal View History

2020-03-27 13:59:38 -07:00
import PropTypes from 'prop-types';
import React from 'react';
2020-05-28 15:52:07 -07:00
import { isIOS } from 'soapbox/is_mobile';
2020-03-27 13:59:38 -07:00
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() {
2020-03-27 13:59:38 -07:00
this.video.addEventListener('loadeddata', this.handleLoadedData);
}
componentWillUnmount() {
2020-03-27 13:59:38 -07:00
this.video.removeEventListener('loadeddata', this.handleLoadedData);
}
setRef = (c) => {
this.video = c;
}
handleClick = e => {
e.stopPropagation();
const handler = this.props.onClick;
if (handler) handler();
}
render() {
2020-03-27 13:59:38 -07:00
const { src, muted, controls, alt } = this.props;
const conditionalAttributes = {};
2020-03-27 13:59:38 -07:00
if (isIOS()) {
2020-04-14 11:44:40 -07:00
conditionalAttributes.playsInline = '1';
2020-03-27 13:59:38 -07:00
}
return (
<div className='extended-video-player'>
<video
ref={this.setRef}
src={src}
autoPlay
role='button'
tabIndex='0'
aria-label={alt}
title={alt}
muted={muted}
controls={controls}
loop={!controls}
onClick={this.handleClick}
{...conditionalAttributes}
/>
</div>
);
}
}