gab-social/app/javascript/gabsocial/components/extended_video_player.js

66 lines
1.5 KiB
JavaScript
Raw Normal View History

import React from 'react'
import PropTypes from 'prop-types'
class ExtendedVideoPlayer extends React.PureComponent {
handleLoadedData = () => {
if (this.props.time) {
2020-05-02 02:25:55 -04:00
this.video.currentTime = this.props.time
}
}
componentDidMount () {
2020-05-02 02:25:55 -04:00
this.video.addEventListener('loadeddata', this.handleLoadedData)
}
componentWillUnmount () {
2020-05-02 02:25:55 -04:00
this.video.removeEventListener('loadeddata', this.handleLoadedData)
}
setRef = (c) => {
2020-05-02 02:25:55 -04:00
this.video = c
}
handleClick = e => {
2020-05-02 02:25:55 -04:00
e.stopPropagation()
const handler = this.props.onClick
if (handler) handler()
}
render () {
2020-05-02 02:25:55 -04:00
const { src, muted, controls, alt } = this.props
2020-04-11 18:29:19 -04:00
return (
<div className={[_s.d, _s.w100PC, _s.h100PC, _s.aiCenter, _s.jcCenter].join(' ')}>
<video
className={[_s.d, _s.maxW100PC, _s.maxH100PC].join(' ')}
playsInline
ref={this.setRef}
src={src}
role='button'
tabIndex='0'
aria-label={alt}
title={alt}
muted={muted}
controls={controls}
loop={!controls}
onClick={this.handleClick}
/>
</div>
2020-05-02 02:25:55 -04:00
)
}
}
ExtendedVideoPlayer.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,
}
export default ExtendedVideoPlayer