1
0
Fork 0
mirror of https://github.com/sussy-code/smov.git synced 2025-01-08 17:27:40 +01:00
smov/src/components/VideoElement.js

45 lines
1.4 KiB
JavaScript
Raw Normal View History

2021-07-14 00:31:37 +02:00
import React from 'react'
import Hls from 'hls.js'
import './VideoElement.css'
2021-07-15 18:07:40 +02:00
import { VideoPlaceholder } from './VideoPlaceholder'
2021-07-14 00:31:37 +02:00
// streamUrl: string
2021-07-15 00:09:42 +02:00
// loading: boolean
export function VideoElement({ streamUrl, loading }) {
2021-07-14 00:31:37 +02:00
const videoRef = React.useRef(null);
2021-07-14 01:17:34 +02:00
const [error, setError] = React.useState(false);
2021-07-14 00:31:37 +02:00
React.useEffect(() => {
2021-07-14 01:17:34 +02:00
setError(false)
2021-07-15 00:09:42 +02:00
if (!videoRef || !videoRef.current || !streamUrl || streamUrl.length === 0 || loading) return;
2021-07-14 00:31:37 +02:00
const hls = new Hls();
if (!Hls.isSupported() && videoRef.current.canPlayType('application/vnd.apple.mpegurl')) {
videoRef.current.src = streamUrl;
return;
} else if (!Hls.isSupported()) {
2021-07-14 01:17:34 +02:00
setError(true)
return;
2021-07-14 00:31:37 +02:00
}
hls.attachMedia(videoRef.current);
hls.loadSource(streamUrl);
2021-07-15 00:09:42 +02:00
}, [videoRef, streamUrl, loading])
// TODO make better loading/error/empty state
2021-07-14 00:31:37 +02:00
2021-07-14 01:17:34 +02:00
if (error)
2021-07-15 18:07:40 +02:00
return (<VideoPlaceholder className="videoElementText">Your browser is not supported</VideoPlaceholder>)
2021-07-14 01:17:34 +02:00
2021-07-15 00:09:42 +02:00
if (loading)
2021-07-15 18:07:40 +02:00
return <VideoPlaceholder>Loading episode</VideoPlaceholder>
2021-07-15 00:09:42 +02:00
if (!streamUrl || streamUrl.length === 0)
2021-07-15 18:07:40 +02:00
return <videoPlaceholder>No video selected</videoPlaceholder>
2021-07-15 00:09:42 +02:00
2021-07-14 00:31:37 +02:00
return (
<video className="videoElement" ref={videoRef} controls autoPlay />
)
}