92 changed files with 1208 additions and 1308 deletions
@ -1,34 +1,34 @@
@@ -1,34 +1,34 @@
|
||||
import { ReactNode, useCallback, useState } from "react"; |
||||
|
||||
import { Transition } from "@/components/Transition"; |
||||
import { useIsMobile } from "@/hooks/useIsMobile"; |
||||
import { AirplayAction } from "@/video/components/actions/AirplayAction"; |
||||
import { BackdropAction } from "@/video/components/actions/BackdropAction"; |
||||
import { CastingTextAction } from "@/video/components/actions/CastingTextAction"; |
||||
import { ChromecastAction } from "@/video/components/actions/ChromecastAction"; |
||||
import { FullscreenAction } from "@/video/components/actions/FullscreenAction"; |
||||
import { HeaderAction } from "@/video/components/actions/HeaderAction"; |
||||
import { KeyboardShortcutsAction } from "@/video/components/actions/KeyboardShortcutsAction"; |
||||
import { LoadingAction } from "@/video/components/actions/LoadingAction"; |
||||
import { MiddlePauseAction } from "@/video/components/actions/MiddlePauseAction"; |
||||
import { MobileCenterAction } from "@/video/components/actions/MobileCenterAction"; |
||||
import { PageTitleAction } from "@/video/components/actions/PageTitleAction"; |
||||
import { PauseAction } from "@/video/components/actions/PauseAction"; |
||||
import { PictureInPictureAction } from "@/video/components/actions/PictureInPictureAction"; |
||||
import { ProgressAction } from "@/video/components/actions/ProgressAction"; |
||||
import { SeriesSelectionAction } from "@/video/components/actions/SeriesSelectionAction"; |
||||
import { ShowTitleAction } from "@/video/components/actions/ShowTitleAction"; |
||||
import { SkipTimeAction } from "@/video/components/actions/SkipTimeAction"; |
||||
import { TimeAction } from "@/video/components/actions/TimeAction"; |
||||
import { VolumeAction } from "@/video/components/actions/VolumeAction"; |
||||
import { VideoPlayerError } from "@/video/components/parts/VideoPlayerError"; |
||||
import { PopoutProviderAction } from "@/video/components/popouts/PopoutProviderAction"; |
||||
import { AirplayAction } from "@/_oldvideo/components/actions/AirplayAction"; |
||||
import { BackdropAction } from "@/_oldvideo/components/actions/BackdropAction"; |
||||
import { CastingTextAction } from "@/_oldvideo/components/actions/CastingTextAction"; |
||||
import { ChromecastAction } from "@/_oldvideo/components/actions/ChromecastAction"; |
||||
import { FullscreenAction } from "@/_oldvideo/components/actions/FullscreenAction"; |
||||
import { HeaderAction } from "@/_oldvideo/components/actions/HeaderAction"; |
||||
import { KeyboardShortcutsAction } from "@/_oldvideo/components/actions/KeyboardShortcutsAction"; |
||||
import { LoadingAction } from "@/_oldvideo/components/actions/LoadingAction"; |
||||
import { MiddlePauseAction } from "@/_oldvideo/components/actions/MiddlePauseAction"; |
||||
import { MobileCenterAction } from "@/_oldvideo/components/actions/MobileCenterAction"; |
||||
import { PageTitleAction } from "@/_oldvideo/components/actions/PageTitleAction"; |
||||
import { PauseAction } from "@/_oldvideo/components/actions/PauseAction"; |
||||
import { PictureInPictureAction } from "@/_oldvideo/components/actions/PictureInPictureAction"; |
||||
import { ProgressAction } from "@/_oldvideo/components/actions/ProgressAction"; |
||||
import { SeriesSelectionAction } from "@/_oldvideo/components/actions/SeriesSelectionAction"; |
||||
import { ShowTitleAction } from "@/_oldvideo/components/actions/ShowTitleAction"; |
||||
import { SkipTimeAction } from "@/_oldvideo/components/actions/SkipTimeAction"; |
||||
import { TimeAction } from "@/_oldvideo/components/actions/TimeAction"; |
||||
import { VolumeAction } from "@/_oldvideo/components/actions/VolumeAction"; |
||||
import { VideoPlayerError } from "@/_oldvideo/components/parts/VideoPlayerError"; |
||||
import { PopoutProviderAction } from "@/_oldvideo/components/popouts/PopoutProviderAction"; |
||||
import { |
||||
VideoPlayerBase, |
||||
VideoPlayerBaseProps, |
||||
} from "@/video/components/VideoPlayerBase"; |
||||
import { useVideoPlayerDescriptor } from "@/video/state/hooks"; |
||||
import { useControls } from "@/video/state/logic/controls"; |
||||
} from "@/_oldvideo/components/VideoPlayerBase"; |
||||
import { useVideoPlayerDescriptor } from "@/_oldvideo/state/hooks"; |
||||
import { useControls } from "@/_oldvideo/state/logic/controls"; |
||||
import { Transition } from "@/components/Transition"; |
||||
import { useIsMobile } from "@/hooks/useIsMobile"; |
||||
|
||||
import { CaptionRendererAction } from "./actions/CaptionRendererAction"; |
||||
import { DividerAction } from "./actions/DividerAction"; |
||||
@ -1,10 +1,10 @@
@@ -1,10 +1,10 @@
|
||||
import { useRef } from "react"; |
||||
|
||||
import { CastingInternal } from "@/video/components/internal/CastingInternal"; |
||||
import { WrapperRegisterInternal } from "@/video/components/internal/WrapperRegisterInternal"; |
||||
import { VideoErrorBoundary } from "@/video/components/parts/VideoErrorBoundary"; |
||||
import { useInterface } from "@/video/state/logic/interface"; |
||||
import { useMeta } from "@/video/state/logic/meta"; |
||||
import { CastingInternal } from "@/_oldvideo/components/internal/CastingInternal"; |
||||
import { WrapperRegisterInternal } from "@/_oldvideo/components/internal/WrapperRegisterInternal"; |
||||
import { VideoErrorBoundary } from "@/_oldvideo/components/parts/VideoErrorBoundary"; |
||||
import { useInterface } from "@/_oldvideo/state/logic/interface"; |
||||
import { useMeta } from "@/_oldvideo/state/logic/meta"; |
||||
|
||||
import { MetaAction } from "./actions/MetaAction"; |
||||
import ThumbnailGeneratorInternal from "./internal/ThumbnailGeneratorInternal"; |
||||
@ -1,9 +1,9 @@
@@ -1,9 +1,9 @@
|
||||
import { useCallback } from "react"; |
||||
|
||||
import { useVideoPlayerDescriptor } from "@/_oldvideo/state/hooks"; |
||||
import { useControls } from "@/_oldvideo/state/logic/controls"; |
||||
import { useMisc } from "@/_oldvideo/state/logic/misc"; |
||||
import { Icons } from "@/components/Icon"; |
||||
import { useVideoPlayerDescriptor } from "@/video/state/hooks"; |
||||
import { useControls } from "@/video/state/logic/controls"; |
||||
import { useMisc } from "@/video/state/logic/misc"; |
||||
|
||||
import { VideoPlayerIconButton } from "../parts/VideoPlayerIconButton"; |
||||
|
||||
@ -1,9 +1,9 @@
@@ -1,9 +1,9 @@
|
||||
import React, { useCallback, useEffect, useRef, useState } from "react"; |
||||
|
||||
import { useVideoPlayerDescriptor } from "@/video/state/hooks"; |
||||
import { useControls } from "@/video/state/logic/controls"; |
||||
import { useInterface } from "@/video/state/logic/interface"; |
||||
import { useMediaPlaying } from "@/video/state/logic/mediaplaying"; |
||||
import { useVideoPlayerDescriptor } from "@/_oldvideo/state/hooks"; |
||||
import { useControls } from "@/_oldvideo/state/logic/controls"; |
||||
import { useInterface } from "@/_oldvideo/state/logic/interface"; |
||||
import { useMediaPlaying } from "@/_oldvideo/state/logic/mediaplaying"; |
||||
|
||||
interface BackdropActionProps { |
||||
children?: React.ReactNode; |
||||
@ -1,8 +1,8 @@
@@ -1,8 +1,8 @@
|
||||
import { useTranslation } from "react-i18next"; |
||||
|
||||
import { useVideoPlayerDescriptor } from "@/_oldvideo/state/hooks"; |
||||
import { useMisc } from "@/_oldvideo/state/logic/misc"; |
||||
import { Icon, Icons } from "@/components/Icon"; |
||||
import { useVideoPlayerDescriptor } from "@/video/state/hooks"; |
||||
import { useMisc } from "@/video/state/logic/misc"; |
||||
|
||||
export function CastingTextAction() { |
||||
const { t } = useTranslation(); |
||||
@ -1,9 +1,9 @@
@@ -1,9 +1,9 @@
|
||||
import { useCallback, useEffect, useRef, useState } from "react"; |
||||
|
||||
import { VideoPlayerIconButton } from "@/_oldvideo/components/parts/VideoPlayerIconButton"; |
||||
import { useVideoPlayerDescriptor } from "@/_oldvideo/state/hooks"; |
||||
import { useMisc } from "@/_oldvideo/state/logic/misc"; |
||||
import { Icons } from "@/components/Icon"; |
||||
import { VideoPlayerIconButton } from "@/video/components/parts/VideoPlayerIconButton"; |
||||
import { useVideoPlayerDescriptor } from "@/video/state/hooks"; |
||||
import { useMisc } from "@/video/state/logic/misc"; |
||||
|
||||
interface Props { |
||||
className?: string; |
||||
@ -1,6 +1,6 @@
@@ -1,6 +1,6 @@
|
||||
import { useVideoPlayerDescriptor } from "@/_oldvideo/state/hooks"; |
||||
import { useMeta } from "@/_oldvideo/state/logic/meta"; |
||||
import { MWMediaType } from "@/backend/metadata/types/mw"; |
||||
import { useVideoPlayerDescriptor } from "@/video/state/hooks"; |
||||
import { useMeta } from "@/video/state/logic/meta"; |
||||
|
||||
export function DividerAction() { |
||||
const descriptor = useVideoPlayerDescriptor(); |
||||
@ -1,10 +1,10 @@
@@ -1,10 +1,10 @@
|
||||
import { useCallback } from "react"; |
||||
|
||||
import { useVideoPlayerDescriptor } from "@/_oldvideo/state/hooks"; |
||||
import { useControls } from "@/_oldvideo/state/logic/controls"; |
||||
import { useInterface } from "@/_oldvideo/state/logic/interface"; |
||||
import { Icons } from "@/components/Icon"; |
||||
import { canFullscreen } from "@/utils/detectFeatures"; |
||||
import { useVideoPlayerDescriptor } from "@/video/state/hooks"; |
||||
import { useControls } from "@/video/state/logic/controls"; |
||||
import { useInterface } from "@/video/state/logic/interface"; |
||||
|
||||
import { VideoPlayerIconButton } from "../parts/VideoPlayerIconButton"; |
||||
|
||||
@ -1,6 +1,6 @@
@@ -1,6 +1,6 @@
|
||||
import { VideoPlayerHeader } from "@/video/components/parts/VideoPlayerHeader"; |
||||
import { useVideoPlayerDescriptor } from "@/video/state/hooks"; |
||||
import { useMeta } from "@/video/state/logic/meta"; |
||||
import { VideoPlayerHeader } from "@/_oldvideo/components/parts/VideoPlayerHeader"; |
||||
import { useVideoPlayerDescriptor } from "@/_oldvideo/state/hooks"; |
||||
import { useMeta } from "@/_oldvideo/state/logic/meta"; |
||||
|
||||
interface Props { |
||||
onClick?: () => void; |
||||
@ -1,12 +1,12 @@
@@ -1,12 +1,12 @@
|
||||
import { useEffect, useRef } from "react"; |
||||
|
||||
import { getPlayerState } from "@/_oldvideo/state/cache"; |
||||
import { useVideoPlayerDescriptor } from "@/_oldvideo/state/hooks"; |
||||
import { useControls } from "@/_oldvideo/state/logic/controls"; |
||||
import { useInterface } from "@/_oldvideo/state/logic/interface"; |
||||
import { useMediaPlaying } from "@/_oldvideo/state/logic/mediaplaying"; |
||||
import { useProgress } from "@/_oldvideo/state/logic/progress"; |
||||
import { useVolumeControl } from "@/hooks/useVolumeToggle"; |
||||
import { getPlayerState } from "@/video/state/cache"; |
||||
import { useVideoPlayerDescriptor } from "@/video/state/hooks"; |
||||
import { useControls } from "@/video/state/logic/controls"; |
||||
import { useInterface } from "@/video/state/logic/interface"; |
||||
import { useMediaPlaying } from "@/video/state/logic/mediaplaying"; |
||||
import { useProgress } from "@/video/state/logic/progress"; |
||||
|
||||
export function KeyboardShortcutsAction() { |
||||
const descriptor = useVideoPlayerDescriptor(); |
||||
@ -1,7 +1,7 @@
@@ -1,7 +1,7 @@
|
||||
import { useVideoPlayerDescriptor } from "@/_oldvideo/state/hooks"; |
||||
import { useMediaPlaying } from "@/_oldvideo/state/logic/mediaplaying"; |
||||
import { useMisc } from "@/_oldvideo/state/logic/misc"; |
||||
import { Spinner } from "@/components/layout/Spinner"; |
||||
import { useVideoPlayerDescriptor } from "@/video/state/hooks"; |
||||
import { useMediaPlaying } from "@/video/state/logic/mediaplaying"; |
||||
import { useMisc } from "@/video/state/logic/misc"; |
||||
|
||||
export function LoadingAction() { |
||||
const descriptor = useVideoPlayerDescriptor(); |
||||
@ -1,13 +1,16 @@
@@ -1,13 +1,16 @@
|
||||
import { useEffect } from "react"; |
||||
|
||||
import { useVideoPlayerDescriptor } from "@/video/state/hooks"; |
||||
import { useVideoPlayerDescriptor } from "@/_oldvideo/state/hooks"; |
||||
import { |
||||
VideoMediaPlayingEvent, |
||||
useMediaPlaying, |
||||
} from "@/video/state/logic/mediaplaying"; |
||||
import { useMeta } from "@/video/state/logic/meta"; |
||||
import { VideoProgressEvent, useProgress } from "@/video/state/logic/progress"; |
||||
import { VideoPlayerMeta } from "@/video/state/types"; |
||||
} from "@/_oldvideo/state/logic/mediaplaying"; |
||||
import { useMeta } from "@/_oldvideo/state/logic/meta"; |
||||
import { |
||||
VideoProgressEvent, |
||||
useProgress, |
||||
} from "@/_oldvideo/state/logic/progress"; |
||||
import { VideoPlayerMeta } from "@/_oldvideo/state/types"; |
||||
|
||||
export type WindowMeta = { |
||||
media: VideoPlayerMeta; |
||||
@ -1,9 +1,9 @@
@@ -1,9 +1,9 @@
|
||||
import { useCallback } from "react"; |
||||
|
||||
import { useVideoPlayerDescriptor } from "@/_oldvideo/state/hooks"; |
||||
import { useControls } from "@/_oldvideo/state/logic/controls"; |
||||
import { useMediaPlaying } from "@/_oldvideo/state/logic/mediaplaying"; |
||||
import { Icon, Icons } from "@/components/Icon"; |
||||
import { useVideoPlayerDescriptor } from "@/video/state/hooks"; |
||||
import { useControls } from "@/video/state/logic/controls"; |
||||
import { useMediaPlaying } from "@/video/state/logic/mediaplaying"; |
||||
|
||||
export function MiddlePauseAction() { |
||||
const descriptor = useVideoPlayerDescriptor(); |
||||
@ -1,10 +1,10 @@
@@ -1,10 +1,10 @@
|
||||
import { PauseAction } from "@/video/components/actions/PauseAction"; |
||||
import { PauseAction } from "@/_oldvideo/components/actions/PauseAction"; |
||||
import { |
||||
SkipTimeBackwardAction, |
||||
SkipTimeForwardAction, |
||||
} from "@/video/components/actions/SkipTimeAction"; |
||||
import { useVideoPlayerDescriptor } from "@/video/state/hooks"; |
||||
import { useMediaPlaying } from "@/video/state/logic/mediaplaying"; |
||||
} from "@/_oldvideo/components/actions/SkipTimeAction"; |
||||
import { useVideoPlayerDescriptor } from "@/_oldvideo/state/hooks"; |
||||
import { useMediaPlaying } from "@/_oldvideo/state/logic/mediaplaying"; |
||||
|
||||
export function MobileCenterAction() { |
||||
const descriptor = useVideoPlayerDescriptor(); |
||||
@ -1,6 +1,6 @@
@@ -1,6 +1,6 @@
|
||||
import { Helmet } from "react-helmet"; |
||||
|
||||
import { useVideoPlayerDescriptor } from "@/video/state/hooks"; |
||||
import { useVideoPlayerDescriptor } from "@/_oldvideo/state/hooks"; |
||||
|
||||
import { useCurrentSeriesEpisodeInfo } from "../hooks/useCurrentSeriesEpisodeInfo"; |
||||
|
||||
@ -1,9 +1,9 @@
@@ -1,9 +1,9 @@
|
||||
import { useCallback } from "react"; |
||||
|
||||
import { useVideoPlayerDescriptor } from "@/_oldvideo/state/hooks"; |
||||
import { useControls } from "@/_oldvideo/state/logic/controls"; |
||||
import { useMediaPlaying } from "@/_oldvideo/state/logic/mediaplaying"; |
||||
import { Icons } from "@/components/Icon"; |
||||
import { useVideoPlayerDescriptor } from "@/video/state/hooks"; |
||||
import { useControls } from "@/video/state/logic/controls"; |
||||
import { useMediaPlaying } from "@/video/state/logic/mediaplaying"; |
||||
|
||||
import { VideoPlayerIconButton } from "../parts/VideoPlayerIconButton"; |
||||
|
||||
@ -1,14 +1,14 @@
@@ -1,14 +1,14 @@
|
||||
import { useCallback } from "react"; |
||||
import { useTranslation } from "react-i18next"; |
||||
|
||||
import { useVideoPlayerDescriptor } from "@/_oldvideo/state/hooks"; |
||||
import { useControls } from "@/_oldvideo/state/logic/controls"; |
||||
import { Icons } from "@/components/Icon"; |
||||
import { useIsMobile } from "@/hooks/useIsMobile"; |
||||
import { |
||||
canPictureInPicture, |
||||
canWebkitPictureInPicture, |
||||
} from "@/utils/detectFeatures"; |
||||
import { useVideoPlayerDescriptor } from "@/video/state/hooks"; |
||||
import { useControls } from "@/video/state/logic/controls"; |
||||
|
||||
import { VideoPlayerIconButton } from "../parts/VideoPlayerIconButton"; |
||||
|
||||
@ -1,15 +1,15 @@
@@ -1,15 +1,15 @@
|
||||
import { useCallback, useEffect, useRef, useState } from "react"; |
||||
|
||||
import { getPlayerState } from "@/_oldvideo/state/cache"; |
||||
import { useVideoPlayerDescriptor } from "@/_oldvideo/state/hooks"; |
||||
import { useControls } from "@/_oldvideo/state/logic/controls"; |
||||
import { useProgress } from "@/_oldvideo/state/logic/progress"; |
||||
import { |
||||
MouseActivity, |
||||
makePercentage, |
||||
makePercentageString, |
||||
useProgressBar, |
||||
} from "@/hooks/useProgressBar"; |
||||
import { getPlayerState } from "@/video/state/cache"; |
||||
import { useVideoPlayerDescriptor } from "@/video/state/hooks"; |
||||
import { useControls } from "@/video/state/logic/controls"; |
||||
import { useProgress } from "@/video/state/logic/progress"; |
||||
|
||||
import ThumbnailAction from "./ThumbnailAction"; |
||||
|
||||
@ -1,13 +1,13 @@
@@ -1,13 +1,13 @@
|
||||
import { useTranslation } from "react-i18next"; |
||||
|
||||
import { VideoPlayerIconButton } from "@/_oldvideo/components/parts/VideoPlayerIconButton"; |
||||
import { useVideoPlayerDescriptor } from "@/_oldvideo/state/hooks"; |
||||
import { useControls } from "@/_oldvideo/state/logic/controls"; |
||||
import { useInterface } from "@/_oldvideo/state/logic/interface"; |
||||
import { useMeta } from "@/_oldvideo/state/logic/meta"; |
||||
import { MWMediaType } from "@/backend/metadata/types/mw"; |
||||
import { Icons } from "@/components/Icon"; |
||||
import { FloatingAnchor } from "@/components/popout/FloatingAnchor"; |
||||
import { VideoPlayerIconButton } from "@/video/components/parts/VideoPlayerIconButton"; |
||||
import { useVideoPlayerDescriptor } from "@/video/state/hooks"; |
||||
import { useControls } from "@/video/state/logic/controls"; |
||||
import { useInterface } from "@/video/state/logic/interface"; |
||||
import { useMeta } from "@/video/state/logic/meta"; |
||||
|
||||
interface Props { |
||||
className?: string; |
||||
@ -1,12 +1,12 @@
@@ -1,12 +1,12 @@
|
||||
import { useTranslation } from "react-i18next"; |
||||
|
||||
import { VideoPlayerIconButton } from "@/_oldvideo/components/parts/VideoPlayerIconButton"; |
||||
import { useVideoPlayerDescriptor } from "@/_oldvideo/state/hooks"; |
||||
import { useControls } from "@/_oldvideo/state/logic/controls"; |
||||
import { useInterface } from "@/_oldvideo/state/logic/interface"; |
||||
import { Icons } from "@/components/Icon"; |
||||
import { FloatingAnchor } from "@/components/popout/FloatingAnchor"; |
||||
import { useIsMobile } from "@/hooks/useIsMobile"; |
||||
import { VideoPlayerIconButton } from "@/video/components/parts/VideoPlayerIconButton"; |
||||
import { useVideoPlayerDescriptor } from "@/video/state/hooks"; |
||||
import { useControls } from "@/video/state/logic/controls"; |
||||
import { useInterface } from "@/video/state/logic/interface"; |
||||
|
||||
interface Props { |
||||
className?: string; |
||||
@ -1,4 +1,4 @@
@@ -1,4 +1,4 @@
|
||||
import { useVideoPlayerDescriptor } from "@/video/state/hooks"; |
||||
import { useVideoPlayerDescriptor } from "@/_oldvideo/state/hooks"; |
||||
|
||||
import { useCurrentSeriesEpisodeInfo } from "../hooks/useCurrentSeriesEpisodeInfo"; |
||||
|
||||
@ -1,7 +1,7 @@
@@ -1,7 +1,7 @@
|
||||
import { useVideoPlayerDescriptor } from "@/_oldvideo/state/hooks"; |
||||
import { useControls } from "@/_oldvideo/state/logic/controls"; |
||||
import { useProgress } from "@/_oldvideo/state/logic/progress"; |
||||
import { Icons } from "@/components/Icon"; |
||||
import { useVideoPlayerDescriptor } from "@/video/state/hooks"; |
||||
import { useControls } from "@/video/state/logic/controls"; |
||||
import { useProgress } from "@/video/state/logic/progress"; |
||||
|
||||
import { VideoPlayerIconButton } from "../parts/VideoPlayerIconButton"; |
||||
|
||||
@ -1,10 +1,10 @@
@@ -1,10 +1,10 @@
|
||||
import { RefObject, useMemo } from "react"; |
||||
|
||||
import { useVideoPlayerDescriptor } from "@/_oldvideo/state/hooks"; |
||||
import { VideoProgressEvent } from "@/_oldvideo/state/logic/progress"; |
||||
import { useSource } from "@/_oldvideo/state/logic/source"; |
||||
import { Icon, Icons } from "@/components/Icon"; |
||||
import { formatSeconds } from "@/utils/formatSeconds"; |
||||
import { useVideoPlayerDescriptor } from "@/video/state/hooks"; |
||||
import { VideoProgressEvent } from "@/video/state/logic/progress"; |
||||
import { useSource } from "@/video/state/logic/source"; |
||||
|
||||
const THUMBNAIL_HEIGHT = 100; |
||||
function position( |
||||
@ -1,13 +1,13 @@
@@ -1,13 +1,13 @@
|
||||
import { useTranslation } from "react-i18next"; |
||||
|
||||
import { useVideoPlayerDescriptor } from "@/_oldvideo/state/hooks"; |
||||
import { useControls } from "@/_oldvideo/state/logic/controls"; |
||||
import { useInterface } from "@/_oldvideo/state/logic/interface"; |
||||
import { useMediaPlaying } from "@/_oldvideo/state/logic/mediaplaying"; |
||||
import { useProgress } from "@/_oldvideo/state/logic/progress"; |
||||
import { VideoPlayerTimeFormat } from "@/_oldvideo/state/types"; |
||||
import { useIsMobile } from "@/hooks/useIsMobile"; |
||||
import { formatSeconds } from "@/utils/formatSeconds"; |
||||
import { useVideoPlayerDescriptor } from "@/video/state/hooks"; |
||||
import { useControls } from "@/video/state/logic/controls"; |
||||
import { useInterface } from "@/video/state/logic/interface"; |
||||
import { useMediaPlaying } from "@/video/state/logic/mediaplaying"; |
||||
import { useProgress } from "@/video/state/logic/progress"; |
||||
import { VideoPlayerTimeFormat } from "@/video/state/types"; |
||||
|
||||
function durationExceedsHour(secs: number): boolean { |
||||
return secs > 60 * 60; |
||||
@ -1,7 +1,7 @@
@@ -1,7 +1,7 @@
|
||||
import { useVideoPlayerDescriptor } from "@/_oldvideo/state/hooks"; |
||||
import { useInterface } from "@/_oldvideo/state/logic/interface"; |
||||
import { useMediaPlaying } from "@/_oldvideo/state/logic/mediaplaying"; |
||||
import { Icon, Icons } from "@/components/Icon"; |
||||
import { useVideoPlayerDescriptor } from "@/video/state/hooks"; |
||||
import { useInterface } from "@/video/state/logic/interface"; |
||||
import { useMediaPlaying } from "@/video/state/logic/mediaplaying"; |
||||
|
||||
export function VolumeAdjustedAction() { |
||||
const descriptor = useVideoPlayerDescriptor(); |
||||
@ -1,11 +1,11 @@
@@ -1,11 +1,11 @@
|
||||
import { useTranslation } from "react-i18next"; |
||||
|
||||
import { useVideoPlayerDescriptor } from "@/_oldvideo/state/hooks"; |
||||
import { useMeta } from "@/_oldvideo/state/logic/meta"; |
||||
import { useSource } from "@/_oldvideo/state/logic/source"; |
||||
import { MWStreamType } from "@/backend/helpers/streams"; |
||||
import { Icons } from "@/components/Icon"; |
||||
import { normalizeTitle } from "@/utils/normalizeTitle"; |
||||
import { useVideoPlayerDescriptor } from "@/video/state/hooks"; |
||||
import { useMeta } from "@/video/state/logic/meta"; |
||||
import { useSource } from "@/video/state/logic/source"; |
||||
|
||||
import { PopoutListAction } from "../../popouts/PopoutUtils"; |
||||
|
||||
@ -1,5 +1,5 @@
@@ -1,5 +1,5 @@
|
||||
import { useVideoPlayerDescriptor } from "@/video/state/hooks"; |
||||
import { useSource } from "@/video/state/logic/source"; |
||||
import { useVideoPlayerDescriptor } from "@/_oldvideo/state/hooks"; |
||||
import { useSource } from "@/_oldvideo/state/logic/source"; |
||||
|
||||
export function QualityDisplayAction() { |
||||
const descriptor = useVideoPlayerDescriptor(); |
||||
@ -1,10 +1,10 @@
@@ -1,10 +1,10 @@
|
||||
import { useEffect } from "react"; |
||||
|
||||
import { useVideoPlayerDescriptor } from "@/_oldvideo/state/hooks"; |
||||
import { useControls } from "@/_oldvideo/state/logic/controls"; |
||||
import { VideoPlayerMeta } from "@/_oldvideo/state/types"; |
||||
import { MWCaption } from "@/backend/helpers/streams"; |
||||
import { MWSeasonWithEpisodeMeta } from "@/backend/metadata/types/mw"; |
||||
import { useVideoPlayerDescriptor } from "@/video/state/hooks"; |
||||
import { useControls } from "@/video/state/logic/controls"; |
||||
import { VideoPlayerMeta } from "@/video/state/types"; |
||||
|
||||
interface MetaControllerProps { |
||||
data?: VideoPlayerMeta; |
||||
@ -1,12 +1,12 @@
@@ -1,12 +1,12 @@
|
||||
import throttle from "lodash.throttle"; |
||||
import { useEffect, useMemo, useRef } from "react"; |
||||
|
||||
import { useVideoPlayerDescriptor } from "@/_oldvideo/state/hooks"; |
||||
import { useControls } from "@/_oldvideo/state/logic/controls"; |
||||
import { useMediaPlaying } from "@/_oldvideo/state/logic/mediaplaying"; |
||||
import { useMisc } from "@/_oldvideo/state/logic/misc"; |
||||
import { useProgress } from "@/_oldvideo/state/logic/progress"; |
||||
import { useQueryParams } from "@/hooks/useQueryParams"; |
||||
import { useVideoPlayerDescriptor } from "@/video/state/hooks"; |
||||
import { useControls } from "@/video/state/logic/controls"; |
||||
import { useMediaPlaying } from "@/video/state/logic/mediaplaying"; |
||||
import { useMisc } from "@/video/state/logic/misc"; |
||||
import { useProgress } from "@/video/state/logic/progress"; |
||||
|
||||
interface Props { |
||||
startAt?: number; |
||||
@ -1,8 +1,8 @@
@@ -1,8 +1,8 @@
|
||||
import { useEffect, useRef } from "react"; |
||||
import { useHistory } from "react-router-dom"; |
||||
|
||||
import { useVideoPlayerDescriptor } from "@/video/state/hooks"; |
||||
import { useMeta } from "@/video/state/logic/meta"; |
||||
import { useVideoPlayerDescriptor } from "@/_oldvideo/state/hooks"; |
||||
import { useMeta } from "@/_oldvideo/state/logic/meta"; |
||||
|
||||
interface SeriesControllerProps { |
||||
onSelect?: (state: { episodeId?: string; seasonId?: string }) => void; |
||||
@ -1,8 +1,8 @@
@@ -1,8 +1,8 @@
|
||||
import { useMemo } from "react"; |
||||
import { useTranslation } from "react-i18next"; |
||||
|
||||
import { useMeta } from "@/_oldvideo/state/logic/meta"; |
||||
import { MWMediaType } from "@/backend/metadata/types/mw"; |
||||
import { useMeta } from "@/video/state/logic/meta"; |
||||
|
||||
export function useCurrentSeriesEpisodeInfo(descriptor: string) { |
||||
const meta = useMeta(descriptor); |
||||
@ -1,6 +1,6 @@
@@ -1,6 +1,6 @@
|
||||
import { useMemo } from "react"; |
||||
|
||||
import { useMisc } from "@/video/state/logic/misc"; |
||||
import { useMisc } from "@/_oldvideo/state/logic/misc"; |
||||
|
||||
export function useInitialized(descriptor: string): { initialized: boolean } { |
||||
const misc = useMisc(descriptor); |
||||
@ -1,8 +1,8 @@
@@ -1,8 +1,8 @@
|
||||
import { useEffect, useRef } from "react"; |
||||
import { useHistory, useLocation } from "react-router-dom"; |
||||
|
||||
import { ControlMethods, useControls } from "@/video/state/logic/controls"; |
||||
import { useInterface } from "@/video/state/logic/interface"; |
||||
import { ControlMethods, useControls } from "@/_oldvideo/state/logic/controls"; |
||||
import { useInterface } from "@/_oldvideo/state/logic/interface"; |
||||
|
||||
function syncRouteToPopout( |
||||
location: ReturnType<typeof useLocation>, |
||||
@ -1,11 +1,14 @@
@@ -1,11 +1,14 @@
|
||||
import { useEffect, useMemo, useRef } from "react"; |
||||
|
||||
import { getPlayerState } from "@/_oldvideo/state/cache"; |
||||
import { useVideoPlayerDescriptor } from "@/_oldvideo/state/hooks"; |
||||
import { updateMisc, useMisc } from "@/_oldvideo/state/logic/misc"; |
||||
import { createCastingStateProvider } from "@/_oldvideo/state/providers/castingStateProvider"; |
||||
import { |
||||
setProvider, |
||||
unsetStateProvider, |
||||
} from "@/_oldvideo/state/providers/utils"; |
||||
import { useChromecastAvailable } from "@/hooks/useChromecastAvailable"; |
||||
import { getPlayerState } from "@/video/state/cache"; |
||||
import { useVideoPlayerDescriptor } from "@/video/state/hooks"; |
||||
import { updateMisc, useMisc } from "@/video/state/logic/misc"; |
||||
import { createCastingStateProvider } from "@/video/state/providers/castingStateProvider"; |
||||
import { setProvider, unsetStateProvider } from "@/video/state/providers/utils"; |
||||
|
||||
export function CastingInternal() { |
||||
const descriptor = useVideoPlayerDescriptor(); |
||||
@ -1,11 +1,11 @@
@@ -1,11 +1,11 @@
|
||||
import Hls from "hls.js"; |
||||
import { RefObject, useCallback, useEffect, useRef, useState } from "react"; |
||||
import { RefObject, useCallback, useEffect, useRef } from "react"; |
||||
|
||||
import { getPlayerState } from "@/_oldvideo/state/cache"; |
||||
import { useVideoPlayerDescriptor } from "@/_oldvideo/state/hooks"; |
||||
import { updateSource, useSource } from "@/_oldvideo/state/logic/source"; |
||||
import { Thumbnail } from "@/_oldvideo/state/types"; |
||||
import { MWStreamType } from "@/backend/helpers/streams"; |
||||
import { getPlayerState } from "@/video/state/cache"; |
||||
import { useVideoPlayerDescriptor } from "@/video/state/hooks"; |
||||
import { updateSource, useSource } from "@/video/state/logic/source"; |
||||
import { Thumbnail } from "@/video/state/types"; |
||||
|
||||
async function* generate( |
||||
videoRef: RefObject<HTMLVideoElement>, |
||||
@ -1,10 +1,13 @@
@@ -1,10 +1,13 @@
|
||||
import { useEffect, useMemo, useRef } from "react"; |
||||
|
||||
import { useVideoPlayerDescriptor } from "@/video/state/hooks"; |
||||
import { useMediaPlaying } from "@/video/state/logic/mediaplaying"; |
||||
import { useMisc } from "@/video/state/logic/misc"; |
||||
import { setProvider, unsetStateProvider } from "@/video/state/providers/utils"; |
||||
import { createVideoStateProvider } from "@/video/state/providers/videoStateProvider"; |
||||
import { useVideoPlayerDescriptor } from "@/_oldvideo/state/hooks"; |
||||
import { useMediaPlaying } from "@/_oldvideo/state/logic/mediaplaying"; |
||||
import { useMisc } from "@/_oldvideo/state/logic/misc"; |
||||
import { |
||||
setProvider, |
||||
unsetStateProvider, |
||||
} from "@/_oldvideo/state/providers/utils"; |
||||
import { createVideoStateProvider } from "@/_oldvideo/state/providers/videoStateProvider"; |
||||
|
||||
interface Props { |
||||
autoPlay?: boolean; |
||||
@ -1,8 +1,8 @@
@@ -1,8 +1,8 @@
|
||||
import { useEffect } from "react"; |
||||
|
||||
import { getPlayerState } from "@/video/state/cache"; |
||||
import { useVideoPlayerDescriptor } from "@/video/state/hooks"; |
||||
import { updateMisc } from "@/video/state/logic/misc"; |
||||
import { getPlayerState } from "@/_oldvideo/state/cache"; |
||||
import { useVideoPlayerDescriptor } from "@/_oldvideo/state/hooks"; |
||||
import { updateMisc } from "@/_oldvideo/state/logic/misc"; |
||||
|
||||
export function WrapperRegisterInternal(props: { |
||||
wrapper: HTMLDivElement | null; |
||||
@ -1,11 +1,11 @@
@@ -1,11 +1,11 @@
|
||||
import { ReactNode } from "react"; |
||||
|
||||
import { useVideoPlayerDescriptor } from "@/_oldvideo/state/hooks"; |
||||
import { useError } from "@/_oldvideo/state/logic/error"; |
||||
import { useMeta } from "@/_oldvideo/state/logic/meta"; |
||||
import { IconPatch } from "@/components/buttons/IconPatch"; |
||||
import { Icons } from "@/components/Icon"; |
||||
import { Title } from "@/components/text/Title"; |
||||
import { useVideoPlayerDescriptor } from "@/video/state/hooks"; |
||||
import { useError } from "@/video/state/logic/error"; |
||||
import { useMeta } from "@/video/state/logic/meta"; |
||||
|
||||
import { VideoPlayerHeader } from "./VideoPlayerHeader"; |
||||
|
||||
@ -1,8 +1,8 @@
@@ -1,8 +1,8 @@
|
||||
import { useEffect, useRef } from "react"; |
||||
|
||||
import { useVideoPlayerDescriptor } from "@/video/state/hooks"; |
||||
import { useControls } from "@/video/state/logic/controls"; |
||||
import { useInterface } from "@/video/state/logic/interface"; |
||||
import { useVideoPlayerDescriptor } from "@/_oldvideo/state/hooks"; |
||||
import { useControls } from "@/_oldvideo/state/logic/controls"; |
||||
import { useInterface } from "@/_oldvideo/state/logic/interface"; |
||||
|
||||
interface Props { |
||||
children?: React.ReactNode; |
||||
@ -1,13 +1,13 @@
@@ -1,13 +1,13 @@
|
||||
import { useTranslation } from "react-i18next"; |
||||
|
||||
import { useVideoPlayerDescriptor } from "@/_oldvideo/state/hooks"; |
||||
import { useControls } from "@/_oldvideo/state/logic/controls"; |
||||
import { useMediaPlaying } from "@/_oldvideo/state/logic/mediaplaying"; |
||||
import { Icon, Icons } from "@/components/Icon"; |
||||
import { FloatingCardView } from "@/components/popout/FloatingCard"; |
||||
import { FloatingView } from "@/components/popout/FloatingView"; |
||||
import { Slider } from "@/components/Slider"; |
||||
import { useFloatingRouter } from "@/hooks/useFloatingRouter"; |
||||
import { useVideoPlayerDescriptor } from "@/video/state/hooks"; |
||||
import { useControls } from "@/video/state/logic/controls"; |
||||
import { useMediaPlaying } from "@/video/state/logic/mediaplaying"; |
||||
|
||||
import { PopoutListEntry, PopoutSection } from "./PopoutUtils"; |
||||
|
||||
@ -1,8 +1,8 @@
@@ -1,8 +1,8 @@
|
||||
import { ReactNode, useEffect, useRef } from "react"; |
||||
|
||||
import { getPlayerState } from "@/video/state/cache"; |
||||
import { useVideoPlayerDescriptor } from "@/video/state/hooks"; |
||||
import { updateInterface } from "@/video/state/logic/interface"; |
||||
import { getPlayerState } from "@/_oldvideo/state/cache"; |
||||
import { useVideoPlayerDescriptor } from "@/_oldvideo/state/hooks"; |
||||
import { updateInterface } from "@/_oldvideo/state/logic/interface"; |
||||
|
||||
interface Props { |
||||
for: string; |
||||
@ -1,13 +1,13 @@
@@ -1,13 +1,13 @@
|
||||
import { useCallback } from "react"; |
||||
|
||||
import { useSyncPopouts } from "@/_oldvideo/components/hooks/useSyncPopouts"; |
||||
import { EpisodeSelectionPopout } from "@/_oldvideo/components/popouts/EpisodeSelectionPopout"; |
||||
import { SettingsPopout } from "@/_oldvideo/components/popouts/SettingsPopout"; |
||||
import { useVideoPlayerDescriptor } from "@/_oldvideo/state/hooks"; |
||||
import { useControls } from "@/_oldvideo/state/logic/controls"; |
||||
import { useInterface } from "@/_oldvideo/state/logic/interface"; |
||||
import { PopoutFloatingCard } from "@/components/popout/FloatingCard"; |
||||
import { FloatingContainer } from "@/components/popout/FloatingContainer"; |
||||
import { useSyncPopouts } from "@/video/components/hooks/useSyncPopouts"; |
||||
import { EpisodeSelectionPopout } from "@/video/components/popouts/EpisodeSelectionPopout"; |
||||
import { SettingsPopout } from "@/video/components/popouts/SettingsPopout"; |
||||
import { useVideoPlayerDescriptor } from "@/video/state/hooks"; |
||||
import { useControls } from "@/video/state/logic/controls"; |
||||
import { useInterface } from "@/video/state/logic/interface"; |
||||
|
||||
function ShowPopout(props: { popoutId: string | null; onClose: () => void }) { |
||||
const popoutMap = { |
||||
@ -1,11 +1,11 @@
@@ -1,11 +1,11 @@
|
||||
import { CaptionsSelectionAction } from "@/_oldvideo/components/actions/list-entries/CaptionsSelectionAction"; |
||||
import { DownloadAction } from "@/_oldvideo/components/actions/list-entries/DownloadAction"; |
||||
import { PlaybackSpeedSelectionAction } from "@/_oldvideo/components/actions/list-entries/PlaybackSpeedSelectionAction"; |
||||
import { SourceSelectionAction } from "@/_oldvideo/components/actions/list-entries/SourceSelectionAction"; |
||||
import { FloatingCardView } from "@/components/popout/FloatingCard"; |
||||
import { FloatingDragHandle } from "@/components/popout/FloatingDragHandle"; |
||||
import { FloatingView } from "@/components/popout/FloatingView"; |
||||
import { useFloatingRouter } from "@/hooks/useFloatingRouter"; |
||||
import { CaptionsSelectionAction } from "@/video/components/actions/list-entries/CaptionsSelectionAction"; |
||||
import { DownloadAction } from "@/video/components/actions/list-entries/DownloadAction"; |
||||
import { PlaybackSpeedSelectionAction } from "@/video/components/actions/list-entries/PlaybackSpeedSelectionAction"; |
||||
import { SourceSelectionAction } from "@/video/components/actions/list-entries/SourceSelectionAction"; |
||||
|
||||
import { CaptionSelectionPopout } from "./CaptionSelectionPopout"; |
||||
import { CaptionSettingsPopout } from "./CaptionSettingsPopout"; |
||||
@ -1,7 +1,10 @@
@@ -1,7 +1,10 @@
|
||||
import { updateInterface } from "@/video/state/logic/interface"; |
||||
import { updateMeta } from "@/video/state/logic/meta"; |
||||
import { updateProgress } from "@/video/state/logic/progress"; |
||||
import { VideoPlayerMeta, VideoPlayerTimeFormat } from "@/video/state/types"; |
||||
import { updateInterface } from "@/_oldvideo/state/logic/interface"; |
||||
import { updateMeta } from "@/_oldvideo/state/logic/meta"; |
||||
import { updateProgress } from "@/_oldvideo/state/logic/progress"; |
||||
import { |
||||
VideoPlayerMeta, |
||||
VideoPlayerTimeFormat, |
||||
} from "@/_oldvideo/state/types"; |
||||
|
||||
import { getPlayerState } from "../cache"; |
||||
import { VideoPlayerStateController } from "../providers/providerTypes"; |
||||
@ -1,8 +1,8 @@
@@ -1,8 +1,8 @@
|
||||
import { resetForSource } from "@/video/state/init"; |
||||
import { updateMediaPlaying } from "@/video/state/logic/mediaplaying"; |
||||
import { updateMisc } from "@/video/state/logic/misc"; |
||||
import { updateProgress } from "@/video/state/logic/progress"; |
||||
import { VideoPlayerState } from "@/video/state/types"; |
||||
import { resetForSource } from "@/_oldvideo/state/init"; |
||||
import { updateMediaPlaying } from "@/_oldvideo/state/logic/mediaplaying"; |
||||
import { updateMisc } from "@/_oldvideo/state/logic/misc"; |
||||
import { updateProgress } from "@/_oldvideo/state/logic/progress"; |
||||
import { VideoPlayerState } from "@/_oldvideo/state/types"; |
||||
|
||||
export function resetStateForSource(descriptor: string, s: VideoPlayerState) { |
||||
const state = s; |
||||
@ -1,4 +1,4 @@
@@ -1,4 +1,4 @@
|
||||
import { updateMisc } from "@/video/state/logic/misc"; |
||||
import { updateMisc } from "@/_oldvideo/state/logic/misc"; |
||||
|
||||
import { VideoPlayerStateProvider } from "./providerTypes"; |
||||
import { getPlayerState } from "../cache"; |
||||
@ -0,0 +1,2 @@
@@ -0,0 +1,2 @@
|
||||
export * from "./atoms"; |
||||
export * from "./base/Container"; |
||||
@ -0,0 +1 @@
@@ -0,0 +1 @@
|
||||
export * from "./pause"; |
||||
@ -0,0 +1,3 @@
@@ -0,0 +1,3 @@
|
||||
export function Pause() { |
||||
return <button type="button" />; |
||||
} |
||||
@ -0,0 +1,9 @@
@@ -0,0 +1,9 @@
|
||||
import { ReactNode } from "react"; |
||||
|
||||
export interface PlayerProps { |
||||
children?: ReactNode; |
||||
} |
||||
|
||||
export function Container(props: PlayerProps) { |
||||
return <div>{props.children}</div>; |
||||
} |
||||
@ -0,0 +1 @@
@@ -0,0 +1 @@
|
||||
export * as Player from "./Player"; |
||||
@ -0,0 +1,3 @@
@@ -0,0 +1,3 @@
|
||||
export function VideoContainer() { |
||||
return <div />; |
||||
} |
||||
@ -0,0 +1,9 @@
@@ -0,0 +1,9 @@
|
||||
import { Player } from "@/components/player"; |
||||
|
||||
export function PlayerView() { |
||||
return ( |
||||
<Player.Container> |
||||
<Player.Pause /> |
||||
</Player.Container> |
||||
); |
||||
} |
||||
@ -1,113 +1,5 @@
@@ -1,113 +1,5 @@
|
||||
import { useCallback, useState } from "react"; |
||||
import { Helmet } from "react-helmet"; |
||||
|
||||
import { MWStreamQuality, MWStreamType } from "@/backend/helpers/streams"; |
||||
import { DetailedMeta } from "@/backend/metadata/getmeta"; |
||||
import { MWMediaType } from "@/backend/metadata/types/mw"; |
||||
import { Button } from "@/components/Button"; |
||||
import { Dropdown } from "@/components/Dropdown"; |
||||
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"; |
||||
|
||||
interface VideoData { |
||||
streamUrl: string; |
||||
type: MWStreamType; |
||||
} |
||||
|
||||
const testData: VideoData = { |
||||
streamUrl: |
||||
"http://commondatastorage.googleapis.com/gtv-videos-bucket/sample/BigBuckBunny.mp4", |
||||
type: MWStreamType.MP4, |
||||
}; |
||||
const testMeta: DetailedMeta = { |
||||
imdbId: "", |
||||
tmdbId: "", |
||||
meta: { |
||||
id: "hello-world", |
||||
title: "Big Buck Bunny", |
||||
type: MWMediaType.MOVIE, |
||||
seasons: undefined, |
||||
year: "2000", |
||||
}, |
||||
}; |
||||
import { PlayerView } from "@/views/PlayerView"; |
||||
|
||||
export default function VideoTesterView() { |
||||
const [video, setVideo] = useState<VideoData | null>(null); |
||||
const [videoType, setVideoType] = useState<MWStreamType>(MWStreamType.MP4); |
||||
const [url, setUrl] = useState(""); |
||||
|
||||
const playVideo = useCallback( |
||||
(streamUrl: string) => { |
||||
setVideo({ |
||||
streamUrl, |
||||
type: videoType, |
||||
}); |
||||
}, |
||||
[videoType] |
||||
); |
||||
|
||||
if (video) { |
||||
return ( |
||||
<div className="fixed left-0 top-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} |
||||
type={videoType} |
||||
quality={MWStreamQuality.QUNKNOWN} |
||||
captions={[]} |
||||
/> |
||||
</VideoPlayer> |
||||
</div> |
||||
); |
||||
} |
||||
|
||||
return ( |
||||
<div className="py-64"> |
||||
<Navigation /> |
||||
<ThinContainer classNames="flex items-start flex-col space-y-4"> |
||||
<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> |
||||
<div className="mb-4 flex gap-4"> |
||||
<input |
||||
type="text" |
||||
placeholder="stream url here..." |
||||
value={url} |
||||
onChange={(e) => setUrl(e.target.value)} |
||||
/> |
||||
<Button onClick={() => playVideo(url)}>Play video</Button> |
||||
</div> |
||||
<Button |
||||
onClick={() => |
||||
setVideo({ |
||||
streamUrl: testData.streamUrl, |
||||
type: testData.type, |
||||
}) |
||||
} |
||||
> |
||||
Play default video |
||||
</Button> |
||||
</ThinContainer> |
||||
</div> |
||||
); |
||||
return <PlayerView />; |
||||
} |
||||
|
||||
Loading…
Reference in new issue