movie-web/src/views/developer/VideoTesterView.tsx

113 lines
3.2 KiB
TypeScript
Raw Normal View History

2023-02-22 19:02:23 +01:00
import { MWStreamQuality, MWStreamType } from "@/backend/helpers/streams";
import { DetailedMeta } from "@/backend/metadata/getmeta";
import { MWMediaType } from "@/backend/metadata/types";
import { Button } from "@/components/Button";
2023-02-22 20:26:19 +01:00
import { Dropdown } from "@/components/Dropdown";
2023-02-22 19:02:23 +01:00
import { Navigation } from "@/components/layout/Navigation";
import { ThinContainer } from "@/components/layout/ThinContainer";
import { MetaController } from "@/video/components/controllers/MetaController";
import { SourceController } from "@/video/components/controllers/SourceController";
import { VideoPlayer } from "@/video/components/VideoPlayer";
import { useCallback, useState } from "react";
import { Helmet } from "react-helmet";
interface VideoData {
streamUrl: string;
2023-02-22 20:26:19 +01:00
type: MWStreamType;
2023-02-22 19:02:23 +01:00
}
const testData: VideoData = {
streamUrl:
"http://commondatastorage.googleapis.com/gtv-videos-bucket/sample/BigBuckBunny.mp4",
2023-02-22 20:26:19 +01:00
type: MWStreamType.MP4,
2023-02-22 19:02:23 +01:00
};
const testMeta: DetailedMeta = {
imdbId: "",
tmdbId: "",
meta: {
id: "hello-world",
title: "Big Buck Bunny",
type: MWMediaType.MOVIE,
seasons: undefined,
year: "2000",
},
};
2023-03-26 10:41:39 +03:00
export default function VideoTesterView() {
2023-02-22 19:02:23 +01:00
const [video, setVideo] = useState<VideoData | null>(null);
2023-02-22 20:26:19 +01:00
const [videoType, setVideoType] = useState<MWStreamType>(MWStreamType.MP4);
2023-02-22 19:02:23 +01:00
const [url, setUrl] = useState("");
2023-02-22 20:26:19 +01:00
const playVideo = useCallback(
(streamUrl: string) => {
setVideo({
streamUrl,
type: videoType,
});
},
[videoType]
);
2023-02-22 19:02:23 +01:00
if (video) {
return (
<div className="fixed top-0 left-0 h-[100dvh] w-screen">
<Helmet>
<html data-full="true" />
</Helmet>
<VideoPlayer includeSafeArea autoPlay onGoBack={() => setVideo(null)}>
<MetaController
data={{
captions: [],
meta: testMeta,
}}
linkedCaptions={[]}
/>
<SourceController
source={video.streamUrl}
2023-03-22 12:38:12 +03:00
type={videoType}
quality={MWStreamQuality.QUNKNOWN}
2023-04-06 01:49:33 +03:00
captions={[]}
2023-02-22 19:02:23 +01:00
/>
</VideoPlayer>
</div>
);
}
return (
2023-02-22 20:26:19 +01:00
<div className="py-64">
2023-02-22 19:02:23 +01:00
<Navigation />
<ThinContainer classNames="flex items-start flex-col space-y-4">
2023-02-22 20:26:19 +01:00
<div className="w-48">
<Dropdown
options={[
{ id: MWStreamType.MP4, name: "Mp4" },
{ id: MWStreamType.HLS, name: "hls/m3u8" },
]}
selectedItem={{ id: videoType, name: videoType }}
setSelectedItem={(a) => setVideoType(a.id as MWStreamType)}
/>
</div>
2023-02-22 19:02:23 +01:00
<div className="mb-4 flex gap-4">
<input
type="text"
2023-02-22 20:26:19 +01:00
placeholder="stream url here..."
2023-02-22 19:02:23 +01:00
value={url}
onChange={(e) => setUrl(e.target.value)}
/>
<Button onClick={() => playVideo(url)}>Play video</Button>
</div>
2023-02-22 20:26:19 +01:00
<Button
onClick={() =>
setVideo({
streamUrl: testData.streamUrl,
type: testData.type,
})
}
>
2023-02-22 19:02:23 +01:00
Play default video
</Button>
</ThinContainer>
</div>
);
}