react-helios 2.4.0 → 2.5.0
This diff represents the content of publicly available package versions that have been released to one of the supported registries. The information contained in this diff is provided for informational purposes only and reflects changes between package versions as they appear in their respective public registries.
- package/README.md +177 -71
- package/dist/index.d.mts +34 -52
- package/dist/index.d.ts +34 -52
- package/dist/index.js +2 -2
- package/dist/index.js.map +1 -1
- package/dist/index.mjs +2 -2
- package/dist/index.mjs.map +1 -1
- package/dist/styles.css +135 -0
- package/package.json +5 -3
- package/dist/index.css +0 -2
- package/dist/index.css.map +0 -1
package/dist/index.d.ts
CHANGED
|
@@ -101,39 +101,36 @@ interface ControlBarItem {
|
|
|
101
101
|
title?: string;
|
|
102
102
|
onClick: () => void;
|
|
103
103
|
}
|
|
104
|
-
interface
|
|
105
|
-
src: string;
|
|
106
|
-
poster?: string;
|
|
104
|
+
interface VideoPlayerOptions {
|
|
107
105
|
autoplay?: boolean;
|
|
108
106
|
muted?: boolean;
|
|
109
107
|
loop?: boolean;
|
|
110
|
-
controls?: boolean;
|
|
111
108
|
preload?: "none" | "metadata" | "auto";
|
|
112
109
|
playbackRates?: PlaybackRate[];
|
|
113
|
-
className?: string;
|
|
114
110
|
enableHLS?: boolean;
|
|
111
|
+
hlsConfig?: Partial<HlsConfig>;
|
|
115
112
|
enablePreview?: boolean;
|
|
116
|
-
/**
|
|
117
|
-
* URL to a WebVTT thumbnail track for sprite-sheet preview on the progress bar.
|
|
118
|
-
*
|
|
119
|
-
* The VTT file should map time ranges to sprite-sheet coordinates using the
|
|
120
|
-
* standard `#xywh=x,y,w,h` fragment format:
|
|
121
|
-
*
|
|
122
|
-
* ```
|
|
123
|
-
* WEBVTT
|
|
124
|
-
*
|
|
125
|
-
* 00:00:00.000 --> 00:00:05.000
|
|
126
|
-
* https://cdn.example.com/thumbs/storyboard0.jpg#xywh=0,0,160,90
|
|
127
|
-
* ```
|
|
128
|
-
*
|
|
129
|
-
* When provided, hovering the progress bar shows a thumbnail instead of
|
|
130
|
-
* requiring a second video decode. If omitted, only the timestamp tooltip
|
|
131
|
-
* is shown.
|
|
132
|
-
*/
|
|
133
113
|
thumbnailVtt?: string;
|
|
134
|
-
|
|
114
|
+
autoHideControls?: boolean;
|
|
135
115
|
subtitles?: SubtitleTrack[];
|
|
136
116
|
crossOrigin?: "anonymous" | "use-credentials";
|
|
117
|
+
logo?: string | ReactNode;
|
|
118
|
+
audioSrc?: string;
|
|
119
|
+
showAudioButton?: boolean;
|
|
120
|
+
audioModeIcon?: ReactNode;
|
|
121
|
+
videoModeIcon?: ReactNode;
|
|
122
|
+
/**
|
|
123
|
+
* Custom content shown in audio mode when no `poster` is provided.
|
|
124
|
+
* Replaces the default animated-gradient + waveform fallback entirely.
|
|
125
|
+
* The `logo` prop is still rendered on top of this if also provided.
|
|
126
|
+
*/
|
|
127
|
+
audioModeFallback?: ReactNode;
|
|
128
|
+
/** Label shown next to the icon when in video mode (click → switches to audio). Default: "Audio" */
|
|
129
|
+
audioModeLabel?: string;
|
|
130
|
+
/** Label shown next to the icon when in audio mode (click → switches to video). Default: "Video" */
|
|
131
|
+
videoModeLabel?: string;
|
|
132
|
+
defaultAudioMode?: boolean;
|
|
133
|
+
audioBandwidthThreshold?: number;
|
|
137
134
|
onPlay?: () => void;
|
|
138
135
|
onPause?: () => void;
|
|
139
136
|
onEnded?: () => void;
|
|
@@ -142,37 +139,17 @@ interface VideoPlayerProps {
|
|
|
142
139
|
onDurationChange?: (duration: number) => void;
|
|
143
140
|
onBuffering?: (isBuffering: boolean) => void;
|
|
144
141
|
onTheaterModeChange?: (isTheater: boolean) => void;
|
|
145
|
-
/**
|
|
146
|
-
* Image URL or ReactNode shown as artwork in audio mode.
|
|
147
|
-
* Priority: `poster` prop → `logo` string/ReactNode → waveform-only.
|
|
148
|
-
* If a string URL is provided the image is rendered white-normalised (filter invert)
|
|
149
|
-
* so it stands out on the dark background.
|
|
150
|
-
*/
|
|
151
|
-
logo?: string | ReactNode;
|
|
152
|
-
/**
|
|
153
|
-
* Show the headphones / audio-mode toggle button in the control bar.
|
|
154
|
-
* @default true
|
|
155
|
-
*/
|
|
156
|
-
showAudioButton?: boolean;
|
|
157
|
-
/**
|
|
158
|
-
* Start the player in audio-only mode on mount.
|
|
159
|
-
* @default false
|
|
160
|
-
*/
|
|
161
|
-
defaultAudioMode?: boolean;
|
|
162
|
-
/**
|
|
163
|
-
* Bandwidth threshold in **Kbps**. When the measured download speed falls below
|
|
164
|
-
* this value the player automatically switches to audio mode.
|
|
165
|
-
* Use the exported `AUDIO_BANDWIDTH_THRESHOLDS` presets for convenience.
|
|
166
|
-
* Set to `0` to disable automatic switching.
|
|
167
|
-
* Only applies to HLS streams (where hls.js measures real segment bandwidth).
|
|
168
|
-
* @default 300 (AUDIO_BANDWIDTH_THRESHOLDS.POOR)
|
|
169
|
-
*/
|
|
170
|
-
audioBandwidthThreshold?: number;
|
|
171
|
-
/** Fired whenever audio mode is toggled — either automatically or by the user. */
|
|
172
142
|
onAudioModeChange?: (isAudio: boolean) => void;
|
|
173
143
|
contextMenuItems?: ContextMenuItem[];
|
|
174
144
|
controlBarItems?: ControlBarItem[];
|
|
175
145
|
}
|
|
146
|
+
interface VideoPlayerProps {
|
|
147
|
+
src: string;
|
|
148
|
+
poster?: string;
|
|
149
|
+
className?: string;
|
|
150
|
+
controls?: boolean;
|
|
151
|
+
options?: VideoPlayerOptions;
|
|
152
|
+
}
|
|
176
153
|
|
|
177
154
|
declare const VideoPlayer: react__default.ForwardRefExoticComponent<VideoPlayerProps & react__default.RefAttributes<VideoPlayerRef>>;
|
|
178
155
|
|
|
@@ -192,12 +169,17 @@ interface ControlsProps {
|
|
|
192
169
|
isTheaterMode: boolean;
|
|
193
170
|
isAudioMode: boolean;
|
|
194
171
|
showAudioButton: boolean;
|
|
172
|
+
audioModeIcon?: ReactNode;
|
|
173
|
+
videoModeIcon?: ReactNode;
|
|
174
|
+
audioModeLabel?: string;
|
|
175
|
+
videoModeLabel?: string;
|
|
195
176
|
isLive: boolean;
|
|
196
177
|
qualityLevels: HLSQualityLevel[];
|
|
197
178
|
currentQualityLevel: number;
|
|
198
179
|
controlBarItems?: ControlBarItem[];
|
|
180
|
+
autoHideControls: boolean;
|
|
199
181
|
}
|
|
200
|
-
declare const Controls: react__default.
|
|
182
|
+
declare const Controls: react__default.NamedExoticComponent<ControlsProps>;
|
|
201
183
|
|
|
202
184
|
interface TimeDisplayProps {
|
|
203
185
|
videoRef: React.RefObject<HTMLVideoElement | null>;
|
|
@@ -339,4 +321,4 @@ declare function parseThumbnailVtt(text: string, baseUrl?: string): ThumbnailCue
|
|
|
339
321
|
*/
|
|
340
322
|
declare function findThumbnailCue(cues: ThumbnailCue[], time: number): ThumbnailCue | null;
|
|
341
323
|
|
|
342
|
-
export { AUDIO_BANDWIDTH_THRESHOLDS, type BufferedRange, type ContextMenuItem, type ControlBarItem, index as ControlElements, Controls, type HLSQualityLevel, type PlaybackRate, type PlayerState, type SubtitleTrack, type ThumbnailCue, type VideoError, type VideoErrorCode, VideoPlayer, type VideoPlayerProps, type VideoPlayerRef, findThumbnailCue, formatTime, getMimeType, isHLSUrl, parseThumbnailVtt };
|
|
324
|
+
export { AUDIO_BANDWIDTH_THRESHOLDS, type BufferedRange, type ContextMenuItem, type ControlBarItem, index as ControlElements, Controls, type HLSQualityLevel, type PlaybackRate, type PlayerState, type SubtitleTrack, type ThumbnailCue, type VideoError, type VideoErrorCode, VideoPlayer, type VideoPlayerOptions, type VideoPlayerProps, type VideoPlayerRef, findThumbnailCue, formatTime, getMimeType, isHLSUrl, parseThumbnailVtt };
|
package/dist/index.js
CHANGED
|
@@ -1,4 +1,4 @@
|
|
|
1
|
-
'use strict';var St=require('react'),ye=require('hls.js'),jsxRuntime=require('react/jsx-runtime');function _interopDefault(e){return e&&e.__esModule?e:{default:e}}var St__default=/*#__PURE__*/_interopDefault(St);var ye__default=/*#__PURE__*/_interopDefault(ye);var nt=Object.defineProperty;var ot=(t,e)=>{for(var c in e)nt(t,c,{get:e[c],enumerable:true});};function oe(t){if(!Number.isFinite(t)||t<0)return "0:00";let e=Math.floor(t),c=Math.floor(e/3600),s=Math.floor(e%3600/60),o=e%60;return c>0?`${c}:${String(s).padStart(2,"0")}:${String(o).padStart(2,"0")}`:`${s}:${String(o).padStart(2,"0")}`}function be(t){try{return new URL(t,"https://x").pathname.toLowerCase().endsWith(".m3u8")||/\/hls\//i.test(t)||/\/stream\.m3u8/i.test(t)}catch{return t.toLowerCase().includes(".m3u8")}}function it(t){if(be(t))return "application/x-mpegURL";let e=t.toLowerCase().split("?")[0];return e.endsWith(".mp4")?"video/mp4":e.endsWith(".webm")?"video/webm":e.endsWith(".ogv")||e.endsWith(".ogg")?"video/ogg":e.endsWith(".mov")?"video/quicktime":"video/mp4"}function Ae(t){return t.map((e,c)=>({id:c,height:e.height??0,width:e.width??0,bitrate:e.bitrate??0,name:e.height?`${e.height}p`:`Level ${c+1}`}))}var lt={isPlaying:false,currentTime:0,duration:0,volume:1,isMuted:false,playbackRate:1,isFullscreen:false,isPictureInPicture:false,isTheaterMode:false,isAudioMode:false,isBuffering:false,bufferedRanges:[],error:null,isLive:false,qualityLevels:[],currentQualityLevel:-1};function Ie(t,e,c={}){let s=St.useRef(null),o=St.useRef(null),g=St.useRef(1),u=St.useRef(0),a=St.useRef(c);a.current=c;let[x,d]=St.useState({...lt,isMuted:c.muted??false,volume:c.muted?0:1,isAudioMode:c.defaultAudioMode??false}),k=St.useRef(x);k.current=x;let w=St.useRef([]),B=St.useRef(false),T=St.useRef(false),p=St.useRef(null);St.useEffect(()=>{let r=t.current;if(!r||(s.current&&(s.current.destroy(),s.current=null),u.current=0,w.current=[],B.current=false,T.current=false,p.current&&(clearTimeout(p.current),p.current=null),d(f=>({...f,currentTime:0,duration:0,error:null,isBuffering:false,isLive:false,qualityLevels:[],currentQualityLevel:-1,isAudioMode:a.current.defaultAudioMode??false})),!e))return;let l=a.current;if(l.enableHLS!==false&&be(e)){if(r.canPlayType("application/vnd.apple.mpegurl"))r.src=e,r.load(),l.autoplay&&r.play().catch(()=>{});else if(ye__default.default.isSupported()){let f=new ye__default.default({autoStartLoad:true,startLevel:-1,capLevelToPlayerSize:true,capLevelOnFPSDrop:true,enableWorker:true,maxBufferLength:30,maxMaxBufferLength:600,maxBufferSize:6e7,liveBackBufferLength:30,liveSyncDurationCount:3,...l.hlsConfig});f.attachMedia(r),f.loadSource(e),f.on(ye.Events.MANIFEST_PARSED,(m,v)=>{let E=Ae(v.levels);d(D=>({...D,qualityLevels:E,currentQualityLevel:-1})),a.current.autoplay&&r.play().catch(()=>{});}),f.on(ye.Events.LEVEL_SWITCHED,(m,v)=>{d(E=>({...E,currentQualityLevel:v.level}));}),f.on(ye.Events.FRAG_LOADED,()=>{let m=a.current.audioBandwidthThreshold??300;if(!m||T.current)return;let v=f.bandwidthEstimate/1e3;if(v<=0)return;let E=w.current;if(E.push(v),E.length>5&&E.shift(),E.length<3)return;let D=E.reduce((n,i)=>n+i,0)/E.length;d(n=>!n.isAudioMode&&D<m?(B.current=true,a.current.onAudioModeChange?.(true),{...n,isAudioMode:true}):n.isAudioMode&&B.current&&D>m*1.5?(B.current=false,a.current.onAudioModeChange?.(false),{...n,isAudioMode:false}):n);});let h=3;f.on(ye.Events.ERROR,(m,v)=>{if(!v.fatal){console.warn("[hls] non-fatal:",v.details);return}switch(v.type){case ye__default.default.ErrorTypes.NETWORK_ERROR:if(u.current<h){u.current+=1;let E=1e3*u.current;console.warn(`[hls] network error \u2013 retry ${u.current}/${h} in ${E}ms`),setTimeout(()=>{s.current===f&&f.startLoad();},E);}else {let E={code:"HLS_NETWORK_ERROR",message:"Failed to load stream after multiple retries."};d(D=>({...D,error:E})),a.current.onError?.(E);}break;case ye__default.default.ErrorTypes.MEDIA_ERROR:console.warn("[hls] media error \u2013 recovering"),f.recoverMediaError();break;default:{f.destroy(),s.current=null;let E={code:"HLS_FATAL_ERROR",message:"An unrecoverable HLS error occurred."};d(D=>({...D,error:E})),a.current.onError?.(E);break}}}),s.current=f;}}else r.src=e,r.load(),l.autoplay&&r.play().catch(()=>{});return ()=>{s.current&&(s.current.destroy(),s.current=null),p.current&&(clearTimeout(p.current),p.current=null);}},[e,t]),St.useEffect(()=>{let r=t.current;if(!r)return;a.current.muted&&(r.muted=true),a.current.loop&&(r.loop=true);let l=()=>{d(P=>({...P,isPlaying:true})),a.current.onPlay?.();},f=()=>{d(P=>({...P,isPlaying:false})),a.current.onPause?.();},h=()=>{d(P=>({...P,isPlaying:false})),a.current.onEnded?.();},m=()=>{a.current.onTimeUpdate?.(r.currentTime);},v=()=>{let P=r.duration,te=!Number.isFinite(P);d(ge=>({...ge,duration:te?0:P,isLive:te})),te||a.current.onDurationChange?.(P);},E=()=>{let P=r.volume;P>0&&!r.muted&&(g.current=P),d(te=>({...te,volume:P,isMuted:r.muted||P===0}));},D=()=>{d(P=>({...P,playbackRate:r.playbackRate}));},n=()=>{let P=r.error;if(!P)return;let ge={code:{1:"MEDIA_ERR_ABORTED",2:"MEDIA_ERR_NETWORK",3:"MEDIA_ERR_DECODE",4:"MEDIA_ERR_SRC_NOT_SUPPORTED"}[P.code]??"UNKNOWN",message:P.message||"Unknown media error"};d(rt=>({...rt,error:ge})),a.current.onError?.(ge);},i=()=>{d(P=>({...P,isBuffering:true})),a.current.onBuffering?.(true);},b=()=>{d(P=>({...P,isBuffering:false})),a.current.onBuffering?.(false);},y=()=>d(P=>({...P,isBuffering:false})),F=()=>{},Y=()=>{let P=!!(document.fullscreenElement||document.webkitFullscreenElement);d(te=>({...te,isFullscreen:P}));},ae=()=>{d(P=>({...P,isPictureInPicture:document.pictureInPictureElement===r}));};return r.addEventListener("play",l),r.addEventListener("pause",f),r.addEventListener("ended",h),r.addEventListener("timeupdate",m),r.addEventListener("durationchange",v),r.addEventListener("volumechange",E),r.addEventListener("ratechange",D),r.addEventListener("error",n),r.addEventListener("waiting",i),r.addEventListener("canplay",b),r.addEventListener("playing",y),r.addEventListener("progress",F),document.addEventListener("fullscreenchange",Y),document.addEventListener("webkitfullscreenchange",Y),r.addEventListener("enterpictureinpicture",ae),r.addEventListener("leavepictureinpicture",ae),()=>{r.removeEventListener("play",l),r.removeEventListener("pause",f),r.removeEventListener("ended",h),r.removeEventListener("timeupdate",m),r.removeEventListener("durationchange",v),r.removeEventListener("volumechange",E),r.removeEventListener("ratechange",D),r.removeEventListener("error",n),r.removeEventListener("waiting",i),r.removeEventListener("canplay",b),r.removeEventListener("playing",y),r.removeEventListener("progress",F),document.removeEventListener("fullscreenchange",Y),document.removeEventListener("webkitfullscreenchange",Y),r.removeEventListener("enterpictureinpicture",ae),r.removeEventListener("leavepictureinpicture",ae);}},[t]);let R=St.useCallback(async()=>{let r=t.current;if(r)try{await r.play();}catch(l){l instanceof Error&&l.name!=="AbortError"&&console.error("[player] play() failed:",l);}},[t]),V=St.useCallback(()=>{t.current?.pause();},[t]),O=St.useCallback(r=>{let l=t.current;l&&(l.currentTime=Math.max(0,Math.min(r,l.duration||r)));},[t]),M=St.useCallback(r=>{let l=t.current;if(!l)return;let f=Math.max(0,Math.min(r,1));f>0&&(g.current=f),l.volume=f,l.muted=f===0;},[t]),L=St.useCallback(()=>{let r=t.current;if(r)if(r.muted||r.volume===0){let l=g.current>0?g.current:1;r.volume=l,r.muted=false;}else g.current=r.volume,r.muted=true;},[t]),I=St.useCallback(r=>{let l=t.current;l&&(l.playbackRate=r);},[t]),C=St.useCallback(r=>{let l=s.current;l&&(l.currentLevel=r,d(f=>({...f,currentQualityLevel:r})));},[]),W=St.useCallback(()=>{let r=s.current,l=t.current;if(!r||!l)return;let f=r.liveSyncPosition;f!=null&&Number.isFinite(f)&&(l.currentTime=f);},[t]),X=St.useCallback(async()=>{let r=t.current;if(!r)return;let l=o.current??r.parentElement;if(l)try{!document.fullscreenElement&&!document.webkitFullscreenElement?l.requestFullscreen?await l.requestFullscreen():l.webkitRequestFullscreen?.():document.exitFullscreen?await document.exitFullscreen():document.webkitExitFullscreen?.();}catch(f){console.error("[player] fullscreen toggle failed:",f);}},[t]),j=St.useCallback(async()=>{let r=t.current;if(r)try{document.pictureInPictureElement?await document.exitPictureInPicture():await r.requestPictureInPicture();}catch(l){console.error("[player] PiP toggle failed:",l);}},[t]),H=St.useCallback(()=>{let r=!k.current.isTheaterMode;d(l=>({...l,isTheaterMode:r})),a.current.onTheaterModeChange?.(r);},[]),G=St.useCallback(()=>{p.current&&clearTimeout(p.current),B.current=false,T.current=true,p.current=setTimeout(()=>{T.current=false,w.current=[];},6e4);let r=!k.current.isAudioMode;d(l=>({...l,isAudioMode:r})),a.current.onAudioModeChange?.(r);},[]),Z=St.useCallback(()=>{let r=t.current,l=r?.currentTime??0,f=[];if(r)for(let h=0;h<r.buffered.length;h++)f.push({start:r.buffered.start(h),end:r.buffered.end(h)});return {...k.current,currentTime:l,bufferedRanges:f}},[t]),ee=St.useCallback(()=>t.current??null,[t]),ne=St.useMemo(()=>({play:R,pause:V,seek:O,setVolume:M,toggleMute:L,setPlaybackRate:I,setQualityLevel:C,seekToLive:W,toggleFullscreen:X,togglePictureInPicture:j,toggleTheaterMode:H,toggleAudioMode:G,getState:Z,getVideoElement:ee}),[R,V,O,M,L,I,C,W,X,j,H,G,Z,ee]);return {state:x,ref:ne,hlsRef:s,fullscreenContainerRef:o}}var Ke={};ot(Ke,{ControlElements:()=>q,FullscreenButton:()=>pe,PauseButton:()=>me,PiPButton:()=>ve,PlayButton:()=>de,ProgressBar:()=>Le,SettingsMenu:()=>xe,TheaterButton:()=>fe,TimeDisplay:()=>Te,VolumeControl:()=>Pe});var de=St.memo(({onClick:t})=>jsxRuntime.jsx("button",{onClick:t,className:"controlButton","aria-label":"Play",title:"Play (Space)",children:jsxRuntime.jsx("svg",{width:"20",height:"20",viewBox:"0 0 24 24",fill:"currentColor",children:jsxRuntime.jsx("path",{d:"M8 5v14l11-7z"})})}));de.displayName="PlayButton";var me=St.memo(({onClick:t})=>jsxRuntime.jsx("button",{onClick:t,className:"controlButton","aria-label":"Pause",title:"Pause (Space)",children:jsxRuntime.jsx("svg",{width:"20",height:"20",viewBox:"0 0 24 24",fill:"currentColor",children:jsxRuntime.jsx("path",{d:"M6 4h4v16H6V4zm8 0h4v16h-4V4z"})})}));me.displayName="PauseButton";var pe=St.memo(({onClick:t,isFullscreen:e=false})=>jsxRuntime.jsx("button",{onClick:t,className:"controlButton","aria-label":e?"Exit Fullscreen":"Fullscreen",title:e?"Exit Fullscreen (F)":"Fullscreen (F)",children:jsxRuntime.jsx("svg",{width:"20",height:"20",viewBox:"0 0 24 24",fill:"currentColor",children:e?jsxRuntime.jsx("path",{d:"M5 16h3v3h2v-5H5v2zm3-8H5v2h5V5H8v3zm6 11h2v-3h3v-2h-5v5zm2-11V5h-2v5h5V8h-3z"}):jsxRuntime.jsx("path",{d:"M7 14H5v5h5v-2H7v-3zm-2-4h2V7h3V5H5v5zm12 7h-3v2h5v-5h-2v3zM14 5v2h3v3h2V5h-5z"})})}));pe.displayName="FullscreenButton";var ve=St.memo(({onClick:t,isPiP:e=false})=>jsxRuntime.jsx("button",{onClick:t,className:"controlButton","aria-label":e?"Exit Picture-in-Picture":"Picture-in-Picture",title:e?"Exit Picture-in-Picture (P)":"Picture-in-Picture (P)",children:jsxRuntime.jsx("svg",{width:"20",height:"20",viewBox:"0 0 24 24",fill:"currentColor",children:jsxRuntime.jsx("path",{d:"M19 11h-8v6h8v-6zm4 8V4.98C23 3.88 22.1 3 21 3H3c-1.1 0-2 .88-2 1.98V19c0 1.1.9 2 2 2h18c1.1 0 2-.9 2-2zm-2 .02H3V5h18v14.02z"})})}));ve.displayName="PiPButton";var fe=St.memo(({onClick:t,isTheater:e=false})=>jsxRuntime.jsx("button",{onClick:t,className:"controlButton","aria-label":e?"Exit Theater Mode":"Theater Mode",title:e?"Exit Theater Mode (T)":"Theater Mode (T)",children:jsxRuntime.jsx("svg",{width:"20",height:"20",viewBox:"0 0 24 24",fill:"currentColor",children:e?jsxRuntime.jsx("path",{d:"M19 7H5c-1.1 0-2 .9-2 2v6c0 1.1.9 2 2 2h14c1.1 0 2-.9 2-2V9c0-1.1-.9-2-2-2zm0 8H5V9h14v6z"}):jsxRuntime.jsx("path",{d:"M21 3H3c-1.1 0-2 .9-2 2v14c0 1.1.9 2 2 2h18c1.1 0 2-.9 2-2V5c0-1.1-.9-2-2-2zm0 16H3V5h18v14z"})})}));fe.displayName="TheaterButton";var Oe=St.memo(({volume:t,isMuted:e,onVolumeChange:c,onToggleMute:s})=>{let[o,g]=St.useState(false),u=e?0:t,a=u*100,x=St.useMemo(()=>`linear-gradient(to right, #60a5fa 0%, #60a5fa ${a}%, rgba(255,255,255,0.3) ${a}%, rgba(255,255,255,0.3) 100%)`,[a]);return jsxRuntime.jsxs("div",{className:"volumeContainer",onMouseEnter:()=>g(true),onMouseLeave:()=>g(false),children:[jsxRuntime.jsx("button",{onClick:s,className:"controlButton","aria-label":e?"Unmute":"Mute",title:e?"Unmute (M)":"Mute (M)",children:jsxRuntime.jsx("svg",{width:"20",height:"20",viewBox:"0 0 24 24",fill:"currentColor",children:u===0?jsxRuntime.jsx("path",{d:"M16.5 12c0-1.77-1.02-3.29-2.5-4.03v2.21l2.45 2.45c.03-.2.05-.41.05-.63zm2.5 0c0 .94-.2 1.82-.54 2.64l1.51 1.51C23.16 14.42 24 13.3 24 12c0-4.28-2.99-7.86-7-8.77v2.06c2.89.86 5 3.54 5 6.71zM4.27 3L3 4.27 7.73 9H3v6h4l5 5v-6.73l4.25 4.25c-.67.52-1.42.93-2.25 1.18v2.06c1.38-.31 2.63-.95 3.69-1.81L19.73 21 21 19.73l-9-9L4.27 3zM12 4L9.91 6.09 12 8.18V4z"}):u<.5?jsxRuntime.jsx("path",{d:"M7 9v6h4l5 5V4l-5 5H7z"}):jsxRuntime.jsx("path",{d:"M3 9v6h4l5 5V4L7 9H3zm13.5 3c0-1.77-1.02-3.29-2.5-4.03v8.05c1.48-.73 2.5-2.25 2.5-4.02zM14 3.23v2.06c2.89.86 5 3.54 5 6.71s-2.11 5.85-5 6.71v2.06c4.01-.91 7-4.49 7-8.77s-2.99-7.86-7-8.77z"})})}),o&&jsxRuntime.jsx("input",{type:"range",min:"0",max:"100",value:a,onChange:d=>c(Number(d.target.value)/100),className:"volumeSlider",style:{background:x},"aria-label":"Volume","aria-valuenow":Math.round(a)})]})});Oe.displayName="VolumeControl";var Pe=Oe;function Fe(t){let e=t.trim().split(":");return e.length===3?+e[0]*3600+ +e[1]*60+parseFloat(e[2]):+e[0]*60+parseFloat(e[1])}function pt(t,e){if(/^https?:\/\//i.test(e))return e;try{return new URL(e,t).href}catch{return e}}function ke(t,e=""){let c=[],s=t.replace(/\r\n/g,`
|
|
1
|
+
'use strict';var Dt=require('react'),Ee=require('hls.js'),jsxRuntime=require('react/jsx-runtime');function _interopDefault(e){return e&&e.__esModule?e:{default:e}}var Dt__default=/*#__PURE__*/_interopDefault(Dt);var Ee__default=/*#__PURE__*/_interopDefault(Ee);var ot=Object.defineProperty;var it=(n,t)=>{for(var r in t)ot(n,r,{get:t[r],enumerable:true});};function se(n){if(!Number.isFinite(n)||n<0)return "0:00";let t=Math.floor(n),r=Math.floor(t/3600),s=Math.floor(t%3600/60),a=t%60;return r>0?`${r}:${String(s).padStart(2,"0")}:${String(a).padStart(2,"0")}`:`${s}:${String(a).padStart(2,"0")}`}function ye(n){try{return new URL(n,"https://x").pathname.toLowerCase().endsWith(".m3u8")||/\/hls\//i.test(n)||/\/stream\.m3u8/i.test(n)}catch{return n.toLowerCase().includes(".m3u8")}}function at(n){if(ye(n))return "application/x-mpegURL";let t=n.toLowerCase().split("?")[0];return t.endsWith(".mp4")?"video/mp4":t.endsWith(".webm")?"video/webm":t.endsWith(".ogv")||t.endsWith(".ogg")?"video/ogg":t.endsWith(".mov")?"video/quicktime":"video/mp4"}function Oe(n){return n.map((t,r)=>({id:r,height:t.height??0,width:t.width??0,bitrate:t.bitrate??0,name:t.height?`${t.height}p`:`Level ${r+1}`}))}var ut={isPlaying:false,currentTime:0,duration:0,volume:1,isMuted:false,playbackRate:1,isFullscreen:false,isPictureInPicture:false,isTheaterMode:false,isAudioMode:false,isBuffering:false,bufferedRanges:[],error:null,isLive:false,qualityLevels:[],currentQualityLevel:-1};function _e(n,t,r={}){let s=Dt.useRef(null),a=Dt.useRef(null),p=Dt.useRef(1),u=Dt.useRef(0),l=Dt.useRef(r);l.current=r;let[L,c]=Dt.useState({...ut,isMuted:r.muted??false,volume:r.muted?0:1,isAudioMode:r.defaultAudioMode??false}),C=Dt.useRef(L);C.current=L;let k=Dt.useRef([]),R=Dt.useRef(false),T=Dt.useRef(false),m=Dt.useRef(null);Dt.useEffect(()=>{let e=n.current;if(!e||(s.current&&(s.current.destroy(),s.current=null),u.current=0,k.current=[],R.current=false,T.current=false,m.current&&(clearTimeout(m.current),m.current=null),c(v=>({...v,currentTime:0,duration:0,error:null,isBuffering:false,isLive:false,qualityLevels:[],currentQualityLevel:-1,isAudioMode:l.current.defaultAudioMode??false})),!t))return;let d=l.current;if(d.enableHLS!==false&&ye(t)){if(e.canPlayType("application/vnd.apple.mpegurl"))e.src=t,e.load(),d.autoplay&&e.play().catch(()=>{});else if(Ee__default.default.isSupported()){let v=new Ee__default.default({autoStartLoad:true,startLevel:-1,capLevelToPlayerSize:true,capLevelOnFPSDrop:true,enableWorker:true,maxBufferLength:30,maxMaxBufferLength:600,maxBufferSize:6e7,liveBackBufferLength:30,liveSyncDurationCount:3,...d.hlsConfig});v.attachMedia(e),v.loadSource(t),v.on(Ee.Events.MANIFEST_PARSED,(O,o)=>{let i=Oe(o.levels);c(f=>({...f,qualityLevels:i,currentQualityLevel:-1})),l.current.autoplay&&e.play().catch(()=>{});}),v.on(Ee.Events.LEVEL_SWITCHED,(O,o)=>{c(i=>({...i,currentQualityLevel:o.level}));}),v.on(Ee.Events.FRAG_LOADED,()=>{let O=l.current.audioBandwidthThreshold??300;if(!O||T.current)return;let o=v.bandwidthEstimate/1e3;if(o<=0)return;let i=k.current;if(i.push(o),i.length>5&&i.shift(),i.length<3)return;let f=i.reduce((y,S)=>y+S,0)/i.length;c(y=>!y.isAudioMode&&f<O?(R.current=true,l.current.onAudioModeChange?.(true),{...y,isAudioMode:true}):y.isAudioMode&&R.current&&f>O*1.5?(R.current=false,l.current.onAudioModeChange?.(false),{...y,isAudioMode:false}):y);});let V=3;v.on(Ee.Events.ERROR,(O,o)=>{if(!o.fatal){console.warn("[hls] non-fatal:",o.details);return}switch(o.type){case Ee__default.default.ErrorTypes.NETWORK_ERROR:if(u.current<V){u.current+=1;let i=1e3*u.current;console.warn(`[hls] network error \u2013 retry ${u.current}/${V} in ${i}ms`),setTimeout(()=>{s.current===v&&v.startLoad();},i);}else {let i={code:"HLS_NETWORK_ERROR",message:"Failed to load stream after multiple retries."};c(f=>({...f,error:i})),l.current.onError?.(i);}break;case Ee__default.default.ErrorTypes.MEDIA_ERROR:console.warn("[hls] media error \u2013 recovering"),v.recoverMediaError();break;default:{v.destroy(),s.current=null;let i={code:"HLS_FATAL_ERROR",message:"An unrecoverable HLS error occurred."};c(f=>({...f,error:i})),l.current.onError?.(i);break}}}),s.current=v;}}else e.src=t,e.load(),d.autoplay&&e.play().catch(()=>{});return ()=>{s.current&&(s.current.destroy(),s.current=null),m.current&&(clearTimeout(m.current),m.current=null);}},[t,n]),Dt.useEffect(()=>{let e=n.current;if(!e)return;l.current.muted&&(e.muted=true),l.current.loop&&(e.loop=true);let d=()=>{c(b=>({...b,isPlaying:true})),l.current.onPlay?.();},v=()=>{c(b=>({...b,isPlaying:false})),l.current.onPause?.();},V=()=>{c(b=>({...b,isPlaying:false})),l.current.onEnded?.();},O=()=>{l.current.onTimeUpdate?.(e.currentTime);},o=()=>{let b=e.duration,z=!Number.isFinite(b);c(j=>({...j,duration:z?0:b,isLive:z})),z||l.current.onDurationChange?.(b);},i=()=>{let b=e.volume;b>0&&!e.muted&&(p.current=b),c(z=>({...z,volume:b,isMuted:e.muted||b===0}));},f=()=>{c(b=>({...b,playbackRate:e.playbackRate}));},y=()=>{let b=e.error;if(!b)return;let j={code:{1:"MEDIA_ERR_ABORTED",2:"MEDIA_ERR_NETWORK",3:"MEDIA_ERR_DECODE",4:"MEDIA_ERR_SRC_NOT_SUPPORTED"}[b.code]??"UNKNOWN",message:b.message||"Unknown media error"};c(ae=>({...ae,error:j})),l.current.onError?.(j);},S=()=>{c(b=>({...b,isBuffering:true})),l.current.onBuffering?.(true);},h=()=>{c(b=>({...b,isBuffering:false})),l.current.onBuffering?.(false);},E=()=>c(b=>({...b,isBuffering:false})),g=()=>{let b=!!(document.fullscreenElement||document.webkitFullscreenElement);c(z=>({...z,isFullscreen:b}));},A=()=>{c(b=>({...b,isPictureInPicture:document.pictureInPictureElement===e}));};return e.addEventListener("play",d),e.addEventListener("pause",v),e.addEventListener("ended",V),e.addEventListener("timeupdate",O),e.addEventListener("durationchange",o),e.addEventListener("volumechange",i),e.addEventListener("ratechange",f),e.addEventListener("error",y),e.addEventListener("waiting",S),e.addEventListener("canplay",h),e.addEventListener("playing",E),document.addEventListener("fullscreenchange",g),document.addEventListener("webkitfullscreenchange",g),e.addEventListener("enterpictureinpicture",A),e.addEventListener("leavepictureinpicture",A),()=>{e.removeEventListener("play",d),e.removeEventListener("pause",v),e.removeEventListener("ended",V),e.removeEventListener("timeupdate",O),e.removeEventListener("durationchange",o),e.removeEventListener("volumechange",i),e.removeEventListener("ratechange",f),e.removeEventListener("error",y),e.removeEventListener("waiting",S),e.removeEventListener("canplay",h),e.removeEventListener("playing",E),document.removeEventListener("fullscreenchange",g),document.removeEventListener("webkitfullscreenchange",g),e.removeEventListener("enterpictureinpicture",A),e.removeEventListener("leavepictureinpicture",A);}},[n]);let B=Dt.useCallback(async()=>{let e=n.current;if(e)try{await e.play();}catch(d){d instanceof Error&&d.name!=="AbortError"&&console.error("[player] play() failed:",d);}},[n]),I=Dt.useCallback(()=>{n.current?.pause();},[n]),_=Dt.useCallback(e=>{let d=n.current;d&&(d.currentTime=Math.max(0,Math.min(e,d.duration||e)));},[n]),P=Dt.useCallback(e=>{let d=n.current;if(!d)return;let v=Math.max(0,Math.min(e,1));v>0&&(p.current=v),d.volume=v,d.muted=v===0;},[n]),x=Dt.useCallback(()=>{let e=n.current;if(e)if(e.muted||e.volume===0){let d=p.current>0?p.current:1;e.volume=d,e.muted=false;}else p.current=e.volume,e.muted=true;},[n]),D=Dt.useCallback(e=>{let d=n.current;d&&(d.playbackRate=e);},[n]),N=Dt.useCallback(e=>{let d=s.current;d&&(d.currentLevel=e,c(v=>({...v,currentQualityLevel:e})));},[]),ne=Dt.useCallback(()=>{let e=s.current,d=n.current;if(!e||!d)return;let v=e.liveSyncPosition;v!=null&&Number.isFinite(v)&&(d.currentTime=v);},[n]),Z=Dt.useCallback(async()=>{let e=n.current;if(!e)return;let d=a.current??e.parentElement;if(d)try{!document.fullscreenElement&&!document.webkitFullscreenElement?d.requestFullscreen?await d.requestFullscreen():d.webkitRequestFullscreen?.():document.exitFullscreen?await document.exitFullscreen():document.webkitExitFullscreen?.();}catch(v){console.error("[player] fullscreen toggle failed:",v);}},[n]),X=Dt.useCallback(async()=>{let e=n.current;if(e)try{document.pictureInPictureElement?await document.exitPictureInPicture():await e.requestPictureInPicture();}catch(d){console.error("[player] PiP toggle failed:",d);}},[n]),M=Dt.useCallback(()=>{let e=!C.current.isTheaterMode;c(d=>({...d,isTheaterMode:e})),l.current.onTheaterModeChange?.(e);},[]),G=Dt.useCallback(()=>{m.current&&clearTimeout(m.current),R.current=false,T.current=true,m.current=setTimeout(()=>{T.current=false,k.current=[];},6e4);let e=!C.current.isAudioMode;c(d=>({...d,isAudioMode:e})),l.current.onAudioModeChange?.(e);},[]),U=Dt.useCallback(()=>{let e=n.current,d=e?.currentTime??0,v=[];if(e)for(let V=0;V<e.buffered.length;V++)v.push({start:e.buffered.start(V),end:e.buffered.end(V)});return {...C.current,currentTime:d,bufferedRanges:v}},[n]),ee=Dt.useCallback(()=>n.current??null,[n]),ie=Dt.useMemo(()=>({play:B,pause:I,seek:_,setVolume:P,toggleMute:x,setPlaybackRate:D,setQualityLevel:N,seekToLive:ne,toggleFullscreen:Z,togglePictureInPicture:X,toggleTheaterMode:M,toggleAudioMode:G,getState:U,getVideoElement:ee}),[B,I,_,P,x,D,N,ne,Z,X,M,G,U,ee]);return {state:L,ref:ie,hlsRef:s,fullscreenContainerRef:a}}var Ge={};it(Ge,{ControlElements:()=>Q,FullscreenButton:()=>ve,PauseButton:()=>pe,PiPButton:()=>he,PlayButton:()=>fe,ProgressBar:()=>Pe,SettingsMenu:()=>Te,TheaterButton:()=>ge,TimeDisplay:()=>ke,VolumeControl:()=>Le});var fe=Dt.memo(({onClick:n})=>jsxRuntime.jsx("button",{onClick:n,className:"controlButton","aria-label":"Play",title:"Play (Space)",children:jsxRuntime.jsx("svg",{width:"20",height:"20",viewBox:"0 0 24 24",fill:"currentColor",children:jsxRuntime.jsx("path",{d:"M8 5v14l11-7z"})})}));fe.displayName="PlayButton";var pe=Dt.memo(({onClick:n})=>jsxRuntime.jsx("button",{onClick:n,className:"controlButton","aria-label":"Pause",title:"Pause (Space)",children:jsxRuntime.jsx("svg",{width:"20",height:"20",viewBox:"0 0 24 24",fill:"currentColor",children:jsxRuntime.jsx("path",{d:"M6 4h4v16H6V4zm8 0h4v16h-4V4z"})})}));pe.displayName="PauseButton";var ve=Dt.memo(({onClick:n,isFullscreen:t=false})=>jsxRuntime.jsx("button",{onClick:n,className:"controlButton","aria-label":t?"Exit Fullscreen":"Fullscreen",title:t?"Exit Fullscreen (F)":"Fullscreen (F)",children:jsxRuntime.jsx("svg",{width:"20",height:"20",viewBox:"0 0 24 24",fill:"currentColor",children:t?jsxRuntime.jsx("path",{d:"M5 16h3v3h2v-5H5v2zm3-8H5v2h5V5H8v3zm6 11h2v-3h3v-2h-5v5zm2-11V5h-2v5h5V8h-3z"}):jsxRuntime.jsx("path",{d:"M7 14H5v5h5v-2H7v-3zm-2-4h2V7h3V5H5v5zm12 7h-3v2h5v-5h-2v3zM14 5v2h3v3h2V5h-5z"})})}));ve.displayName="FullscreenButton";var he=Dt.memo(({onClick:n,isPiP:t=false})=>jsxRuntime.jsx("button",{onClick:n,className:"controlButton","aria-label":t?"Exit Picture-in-Picture":"Picture-in-Picture",title:t?"Exit Picture-in-Picture (P)":"Picture-in-Picture (P)",children:jsxRuntime.jsx("svg",{width:"20",height:"20",viewBox:"0 0 24 24",fill:"currentColor",children:jsxRuntime.jsx("path",{d:"M19 11h-8v6h8v-6zm4 8V4.98C23 3.88 22.1 3 21 3H3c-1.1 0-2 .88-2 1.98V19c0 1.1.9 2 2 2h18c1.1 0 2-.9 2-2zm-2 .02H3V5h18v14.02z"})})}));he.displayName="PiPButton";var ge=Dt.memo(({onClick:n,isTheater:t=false})=>jsxRuntime.jsx("button",{onClick:n,className:"controlButton","aria-label":t?"Exit Theater Mode":"Theater Mode",title:t?"Exit Theater Mode (T)":"Theater Mode (T)",children:jsxRuntime.jsx("svg",{width:"20",height:"20",viewBox:"0 0 24 24",fill:"currentColor",children:t?jsxRuntime.jsx("path",{d:"M19 7H5c-1.1 0-2 .9-2 2v6c0 1.1.9 2 2 2h14c1.1 0 2-.9 2-2V9c0-1.1-.9-2-2-2zm0 8H5V9h14v6z"}):jsxRuntime.jsx("path",{d:"M21 3H3c-1.1 0-2 .9-2 2v14c0 1.1.9 2 2 2h18c1.1 0 2-.9 2-2V5c0-1.1-.9-2-2-2zm0 16H3V5h18v14z"})})}));ge.displayName="TheaterButton";var ze=Dt.memo(({volume:n,isMuted:t,onVolumeChange:r,onToggleMute:s})=>{let[a,p]=Dt.useState(false),u=t?0:n,l=u*100,L=Dt.useMemo(()=>`linear-gradient(to right, #60a5fa 0%, #60a5fa ${l}%, rgba(255,255,255,0.3) ${l}%, rgba(255,255,255,0.3) 100%)`,[l]);return jsxRuntime.jsxs("div",{className:"volumeContainer",onMouseEnter:()=>p(true),onMouseLeave:()=>p(false),children:[jsxRuntime.jsx("button",{onClick:s,className:"controlButton","aria-label":t?"Unmute":"Mute",title:t?"Unmute (M)":"Mute (M)",children:jsxRuntime.jsx("svg",{width:"20",height:"20",viewBox:"0 0 24 24",fill:"currentColor",children:u===0?jsxRuntime.jsx("path",{d:"M16.5 12c0-1.77-1.02-3.29-2.5-4.03v2.21l2.45 2.45c.03-.2.05-.41.05-.63zm2.5 0c0 .94-.2 1.82-.54 2.64l1.51 1.51C23.16 14.42 24 13.3 24 12c0-4.28-2.99-7.86-7-8.77v2.06c2.89.86 5 3.54 5 6.71zM4.27 3L3 4.27 7.73 9H3v6h4l5 5v-6.73l4.25 4.25c-.67.52-1.42.93-2.25 1.18v2.06c1.38-.31 2.63-.95 3.69-1.81L19.73 21 21 19.73l-9-9L4.27 3zM12 4L9.91 6.09 12 8.18V4z"}):u<.5?jsxRuntime.jsx("path",{d:"M7 9v6h4l5 5V4l-5 5H7z"}):jsxRuntime.jsx("path",{d:"M3 9v6h4l5 5V4L7 9H3zm13.5 3c0-1.77-1.02-3.29-2.5-4.03v8.05c1.48-.73 2.5-2.25 2.5-4.02zM14 3.23v2.06c2.89.86 5 3.54 5 6.71s-2.11 5.85-5 6.71v2.06c4.01-.91 7-4.49 7-8.77s-2.99-7.86-7-8.77z"})})}),a&&jsxRuntime.jsx("input",{type:"range",min:"0",max:"100",value:l,onChange:c=>r(Number(c.target.value)/100),className:"volumeSlider",style:{background:L},"aria-label":"Volume","aria-valuenow":Math.round(l)})]})});ze.displayName="VolumeControl";var Le=ze;function $e(n){let t=n.trim().split(":");return t.length===3?+t[0]*3600+ +t[1]*60+parseFloat(t[2]):+t[0]*60+parseFloat(t[1])}function pt(n,t){if(/^https?:\/\//i.test(t))return t;try{return new URL(t,n).href}catch{return t}}function Re(n,t=""){let r=[],s=n.replace(/\r\n/g,`
|
|
2
2
|
`).split(`
|
|
3
|
-
`),o=0;for(;o<s.length;){let g=s[o].trim();if(g.includes("-->")){let u=g.indexOf("-->"),a=Fe(g.slice(0,u)),x=Fe(g.slice(u+3));for(o++;o<s.length&&!s[o].trim();)o++;if(o<s.length){let d=s[o].trim(),k=d.lastIndexOf("#xywh="),w=d,B=0,T=0,p=160,R=90;if(k!==-1){w=d.slice(0,k);let V=d.slice(k+6).split(",").map(Number);B=V[0]??0,T=V[1]??0,p=V[2]??160,R=V[3]??90;}c.push({start:a,end:x,url:pt(e,w),x:B,y:T,w:p,h:R});}}o++;}return c}function we(t,e){if(!t.length)return null;let c=0,s=t.length-1;for(;c<=s;){let o=c+s>>1;if(t[o].end<=e)c=o+1;else if(t[o].start>e)s=o-1;else return t[o]}return null}var _e=St.memo(({videoRef:t,playerRef:e,enablePreview:c=true,thumbnailVtt:s})=>{let o=St.useRef(null),g=St.useRef(null),u=St.useRef(null),a=St.useRef(null),x=St.useRef(null),d=St.useRef(null),k=St.useRef(null),[w,B]=St.useState([]),T=St.useRef(false),p=St.useRef(0),R=St.useRef(0),V=St.useRef(null),O=St.useRef([]),M=St.useRef(null);St.useEffect(()=>{let n=()=>{M.current=null;};return window.addEventListener("resize",n,{passive:true}),()=>window.removeEventListener("resize",n)},[]);let L=St.useCallback(()=>(!M.current&&o.current&&(M.current=o.current.getBoundingClientRect()),M.current),[]);St.useEffect(()=>{if(!s){O.current=[];return}let n=false;return fetch(s).then(i=>i.text()).then(i=>{n||(O.current=ke(i,s));}).catch(()=>{n||(O.current=[]);}),()=>{n=true;}},[s]),St.useEffect(()=>{let n=t.current;if(!n)return;let i=()=>{let b=isFinite(n.duration)?n.duration:0,y=n.currentTime,F=b>0?y/b*100:0;g.current&&(g.current.style.width=`${F}%`),u.current&&(u.current.style.left=`${F}%`),o.current&&(o.current.setAttribute("aria-valuenow",String(Math.round(y))),o.current.setAttribute("aria-valuemax",String(Math.round(b))),o.current.setAttribute("aria-valuetext",oe(y)));};return n.addEventListener("timeupdate",i),n.addEventListener("durationchange",i),n.addEventListener("seeked",i),i(),()=>{n.removeEventListener("timeupdate",i),n.removeEventListener("durationchange",i),n.removeEventListener("seeked",i);}},[t]),St.useEffect(()=>{let n=t.current;if(!n)return;let i=()=>{let b=[];for(let y=0;y<n.buffered.length;y++)b.push({start:n.buffered.start(y),end:n.buffered.end(y)});B(b);};return n.addEventListener("progress",i),()=>n.removeEventListener("progress",i)},[t]);let I=St.useCallback(()=>{T.current=true,u.current?.classList.add("dragging");},[]),C=St.useCallback(()=>{T.current=false,u.current?.classList.remove("dragging");},[]),W=St.useCallback(()=>{c&&(M.current=null,a.current&&(a.current.style.display="block"),d.current&&(d.current.style.display="block"));},[c]),X=St.useCallback(()=>{a.current&&(a.current.style.display="none"),d.current&&(d.current.style.display="none");},[]),j=St.useCallback(n=>{if(!k.current||!O.current.length)return;let i=we(O.current,n);if(V.current=i,!i)return;let b=k.current;b.style.backgroundImage=`url(${i.url})`,b.style.backgroundPosition=`-${i.x}px -${i.y}px`,b.style.width=`${i.w}px`,b.style.height=`${i.h}px`;},[]),H=St.useCallback(n=>{let i=L(),b=t.current?.duration;return !i||i.width===0||!b||!isFinite(b)?0:Math.max(0,Math.min(n-i.left,i.width))/i.width*b},[L,t]),G=St.useCallback(n=>{let i=L();return i?Math.max(0,Math.min(n-i.left,i.width)):0},[L]),Z=St.useCallback(n=>{let i=t.current;if(!i)return;let b=i.currentTime,y=isFinite(i.duration)?i.duration:0;switch(n.key){case "ArrowLeft":case "ArrowRight":{n.preventDefault(),n.nativeEvent.stopImmediatePropagation();let F=n.shiftKey?10:5;e.seek(n.key==="ArrowLeft"?Math.max(0,b-F):Math.min(y,b+F));break}case "Home":n.preventDefault(),n.nativeEvent.stopImmediatePropagation(),e.seek(0);break;case "End":y>0&&(n.preventDefault(),n.nativeEvent.stopImmediatePropagation(),e.seek(y));break}},[t,e]),ee=St.useCallback(n=>{let i=H(n.clientX),b=G(n.clientX);if(p.current=b,R.current=i,d.current&&(d.current.style.left=`${b}px`),x.current&&(x.current.textContent=oe(i)),j(i),a.current){let y=a.current.offsetWidth,F=L()?.width??0,Y=y/2,ae=Math.max(Y,Math.min(b,F-Y));a.current.style.left=`${ae}px`;}T.current&&e.seek(i);},[e,j,H,G,L]),ne=St.useCallback(()=>{W();},[W]),r=St.useCallback(()=>{X(),C();},[X,C]),l=St.useCallback(n=>{n.preventDefault(),I(),e.seek(H(n.clientX));},[I,H,e]),f=St.useCallback(()=>C(),[C]),h=St.useCallback(n=>{T.current||e.seek(H(n.clientX));},[H,e]);St.useEffect(()=>{let n=o.current;if(!n)return;let i=b=>{T.current&&b.preventDefault();};return n.addEventListener("touchmove",i,{passive:false}),()=>n.removeEventListener("touchmove",i)},[]);let m=St.useCallback(n=>{M.current=null,I(),e.seek(H(n.touches[0].clientX));},[I,H,e]),v=St.useCallback(n=>{T.current&&e.seek(H(n.touches[0].clientX));},[H,e]),E=St.useCallback(()=>C(),[C]);St.useEffect(()=>{let n=()=>C();return window.addEventListener("mouseup",n),()=>window.removeEventListener("mouseup",n)},[C]);let D=St.useMemo(()=>{let n=t.current,i=n&&isFinite(n.duration)?n.duration:0;return i<=0||!w.length?null:w.map((b,y)=>{let F=b.start/i*100,Y=(b.end-b.start)/i*100;return jsxRuntime.jsx("div",{className:"bufferedSegment",style:{left:`${F}%`,width:`${Y}%`}},y)})},[w,t]);return jsxRuntime.jsxs("div",{ref:o,className:"progressContainer",onMouseMove:ee,onMouseEnter:ne,onMouseLeave:r,onMouseDown:l,onMouseUp:f,onClick:h,onTouchStart:m,onTouchMove:v,onTouchEnd:E,onKeyDown:Z,role:"slider","aria-label":"Video progress","aria-valuemin":0,"aria-valuemax":0,"aria-valuenow":0,"aria-valuetext":"0:00",tabIndex:0,children:[c&&jsxRuntime.jsxs("div",{ref:a,className:"previewTooltip",style:{left:0,display:"none"},"aria-hidden":"true",children:[s&&jsxRuntime.jsx("div",{ref:k,className:"previewThumbnail"}),jsxRuntime.jsx("div",{ref:x,className:"previewTime"})]}),jsxRuntime.jsxs("div",{className:"progressBackground",children:[D,jsxRuntime.jsx("div",{ref:g,className:"progressFilled",style:{width:"0%"}}),c&&jsxRuntime.jsx("div",{ref:d,className:"hoverIndicator",style:{left:0,display:"none"},"aria-hidden":"true"})]}),jsxRuntime.jsx("div",{ref:u,className:"scrubHandle",style:{left:"0%"},"aria-hidden":"true"})]})});_e.displayName="ProgressBar";var Le=_e;var qe=St.memo(({currentRate:t,playbackRates:e,onRateChange:c,qualityLevels:s=[],currentQualityLevel:o=-1,onQualityChange:g})=>{let[u,a]=St.useState(false),[x,d]=St.useState("speed"),k=St.useRef(null),w=s.length>0&&!!g;St.useEffect(()=>{let p=R=>{k.current&&!k.current.contains(R.target)&&a(false);};return u&&document.addEventListener("mousedown",p),()=>document.removeEventListener("mousedown",p)},[u]);let B=St.useMemo(()=>[...s].sort((p,R)=>R.bitrate-p.bitrate),[s]),T=St.useMemo(()=>o===-1?"Auto":s.find(p=>p.id===o)?.name??"Auto",[s,o]);return jsxRuntime.jsxs("div",{ref:k,className:"settingsContainer",children:[jsxRuntime.jsx("button",{onClick:()=>a(p=>!p),className:"controlButton","aria-label":"Settings",title:"Settings","aria-expanded":u,children:jsxRuntime.jsx("svg",{width:"20",height:"20",viewBox:"0 0 24 24",fill:"currentColor",children:jsxRuntime.jsx("path",{d:"M19.14 12.94c.04-.3.06-.61.06-.94s-.02-.64-.07-.94l2.03-1.58a.49.49 0 0 0 .12-.61l-1.92-3.32a.49.49 0 0 0-.59-.22l-2.39.96a7.02 7.02 0 0 0-1.62-.94l-.36-2.54a.484.484 0 0 0-.48-.41h-3.84c-.24 0-.43.17-.47.41l-.36 2.54a6.88 6.88 0 0 0-1.61.94l-2.39-.96a.488.488 0 0 0-.59.22L2.74 8.87a.48.48 0 0 0 .12.61l2.03 1.58c-.05.3-.09.63-.09.94s.02.64.07.94l-2.03 1.58a.49.49 0 0 0-.12.61l1.92 3.32c.12.22.37.29.59.22l2.39-.96c.5.38 1.03.7 1.62.94l.36 2.54c.05.24.24.41.48.41h3.84c.24 0 .44-.17.47-.41l.36-2.54a6.88 6.88 0 0 0 1.61-.94l2.39.96c.22.08.47 0 .59-.22l1.92-3.32a.47.47 0 0 0-.12-.61l-2.01-1.58zM12 15.6A3.6 3.6 0 0 1 8.4 12 3.6 3.6 0 0 1 12 8.4a3.6 3.6 0 0 1 3.6 3.6 3.6 3.6 0 0 1-3.6 3.6z"})})}),u&&jsxRuntime.jsxs("div",{className:"settingsDropdown",role:"menu",children:[w&&jsxRuntime.jsxs("div",{className:"settingsTabs",children:[jsxRuntime.jsx("button",{className:`settingsTab${x==="speed"?" active":""}`,onClick:()=>d("speed"),children:"Speed"}),jsxRuntime.jsx("button",{className:`settingsTab${x==="quality"?" active":""}`,onClick:()=>d("quality"),children:"Quality"})]}),(!w||x==="speed")&&jsxRuntime.jsxs("div",{children:[!w&&jsxRuntime.jsx("div",{className:"settingsPanelLabel",children:"Playback Speed"}),e.map(p=>jsxRuntime.jsx("button",{onClick:()=>{c(p),a(false);},className:`settingsOption${t===p?" active":""}`,role:"menuitemradio","aria-checked":t===p,children:p===1?"Normal":`${p}\xD7`},p))]}),w&&x==="quality"&&jsxRuntime.jsxs("div",{children:[jsxRuntime.jsxs("button",{onClick:()=>{g(-1),a(false);},className:`settingsOption${o===-1?" active":""}`,role:"menuitemradio","aria-checked":o===-1,children:["Auto ",o===-1&&T!=="Auto"?`(${T})`:""]}),B.map(p=>jsxRuntime.jsxs("button",{onClick:()=>{g(p.id),a(false);},className:`settingsOption${o===p.id?" active":""}`,role:"menuitemradio","aria-checked":o===p.id,children:[p.name,p.bitrate>0&&jsxRuntime.jsxs("span",{className:"settingsOptionBadge",children:[Math.round(p.bitrate/1e3)," kbps"]})]},p.id))]})]})]})});qe.displayName="SettingsMenu";var xe=qe;var We=St.memo(({videoRef:t,isLive:e=false})=>{let c=St.useRef(null),s=St.useRef(null);return St.useEffect(()=>{let o=t.current;if(!o)return;let g=()=>{c.current&&(c.current.textContent=oe(o.currentTime));},u=()=>{if(s.current){let a=isFinite(o.duration)?o.duration:0;s.current.textContent=` / ${oe(a)}`;}};return o.addEventListener("timeupdate",g),o.addEventListener("durationchange",u),o.addEventListener("seeked",g),g(),u(),()=>{o.removeEventListener("timeupdate",g),o.removeEventListener("durationchange",u),o.removeEventListener("seeked",g);}},[t,e]),e?jsxRuntime.jsx("span",{className:"timeDisplay",style:{opacity:.7},children:jsxRuntime.jsx("span",{ref:c,children:"0:00"})}):jsxRuntime.jsxs("span",{className:"timeDisplay",children:[jsxRuntime.jsx("span",{ref:c,children:"0:00"}),jsxRuntime.jsx("span",{ref:s,style:{opacity:.6},children:" / 0:00"})]})});We.displayName="TimeDisplay";var Te=We;var q={PlayButton:de,PauseButton:me,FullscreenButton:pe,PiPButton:ve,TheaterButton:fe,VolumeControl:Pe,ProgressBar:Le,SettingsMenu:xe,TimeDisplay:Te};var Re=({videoRef:t,playerRef:e,playerContainerRef:c,playbackRates:s,enablePreview:o,thumbnailVtt:g,isPlaying:u,volume:a,isMuted:x,playbackRate:d,isFullscreen:k,isPictureInPicture:w,isTheaterMode:B,isAudioMode:T,showAudioButton:p,isLive:R,qualityLevels:V,currentQualityLevel:O,controlBarItems:M})=>{let L=St.useRef(null),[I,C]=St.useState(true),W=St.useRef({isPlaying:u,volume:a,isMuted:x,isLive:R});W.current={isPlaying:u,volume:a,isMuted:x,isLive:R},St.useEffect(()=>{if(!u){C(true),L.current&&clearTimeout(L.current);return}let m=()=>{C(true),L.current&&clearTimeout(L.current),L.current=setTimeout(()=>C(false),3e3);},v=c.current;return v&&(v.addEventListener("mousemove",m),v.addEventListener("mouseenter",m),v.addEventListener("mouseleave",()=>{L.current&&clearTimeout(L.current);}),v.addEventListener("touchstart",m,{passive:true})),m(),()=>{v&&(v.removeEventListener("mousemove",m),v.removeEventListener("mouseenter",m),v.removeEventListener("mouseleave",()=>{}),v.removeEventListener("touchstart",m)),L.current&&clearTimeout(L.current);}},[u,c]),St.useEffect(()=>{let m=v=>{if(!c.current?.contains(document.activeElement))return;let E=v.target;if(E.tagName==="INPUT"||E.tagName==="TEXTAREA"||E.isContentEditable)return;let{isPlaying:D,volume:n,isLive:i}=W.current,b=t.current?.currentTime??0,y=t.current?.duration??0;switch(v.code){case "Space":case "KeyK":v.preventDefault(),D?e.pause():e.play();break;case "ArrowLeft":v.preventDefault(),e.seek(Math.max(0,b-5));break;case "ArrowRight":v.preventDefault(),e.seek(Math.min(y||1/0,b+5));break;case "ArrowUp":v.preventDefault(),e.setVolume(Math.min(1,n+.1));break;case "ArrowDown":v.preventDefault(),e.setVolume(Math.max(0,n-.1));break;case "KeyM":v.preventDefault(),e.toggleMute();break;case "KeyF":v.preventDefault(),e.toggleFullscreen();break;case "KeyP":v.preventDefault(),e.togglePictureInPicture();break;case "KeyT":v.preventDefault(),e.toggleTheaterMode();break;case "KeyL":v.preventDefault(),i&&e.seekToLive();break;case "Digit0":case "Digit1":case "Digit2":case "Digit3":case "Digit4":case "Digit5":case "Digit6":case "Digit7":case "Digit8":case "Digit9":{v.preventDefault();let F=Number(v.code.replace("Digit",""))*10;e.seek(y/100*F);break}}};return window.addEventListener("keydown",m),()=>window.removeEventListener("keydown",m)},[e,c,t]);let X=St.useCallback(()=>e.play(),[e]),j=St.useCallback(()=>e.pause(),[e]),H=St.useCallback(m=>e.setVolume(m),[e]),G=St.useCallback(()=>e.toggleMute(),[e]),Z=St.useCallback(m=>e.setPlaybackRate(m),[e]),ee=St.useCallback(m=>e.setQualityLevel(m),[e]),ne=St.useCallback(()=>e.togglePictureInPicture(),[e]),r=St.useCallback(()=>e.toggleTheaterMode(),[e]),l=St.useCallback(()=>e.toggleAudioMode(),[e]),f=St.useCallback(()=>e.toggleFullscreen(),[e]),h=St.useCallback(()=>e.seekToLive(),[e]);return jsxRuntime.jsx("div",{style:{position:"absolute",inset:0,display:"flex",flexDirection:"column",justifyContent:"flex-end",opacity:I?1:0,transition:"opacity 0.3s",pointerEvents:"none"},children:jsxRuntime.jsxs("div",{style:{background:"linear-gradient(to top, rgba(0,0,0,0.75) 0%, rgba(0,0,0,0.2) 60%, transparent 100%)",padding:"48px 12px 12px",pointerEvents:I?"auto":"none"},role:"region","aria-label":"Video player controls",children:[jsxRuntime.jsx(q.ProgressBar,{videoRef:t,playerRef:e,enablePreview:o,thumbnailVtt:g}),jsxRuntime.jsxs("div",{style:{display:"flex",alignItems:"center",gap:4,marginTop:4},children:[u?jsxRuntime.jsx(q.PauseButton,{onClick:j}):jsxRuntime.jsx(q.PlayButton,{onClick:X}),jsxRuntime.jsx(q.VolumeControl,{volume:a,isMuted:x,onVolumeChange:H,onToggleMute:G}),jsxRuntime.jsx(q.TimeDisplay,{videoRef:t,isLive:R}),jsxRuntime.jsx("div",{style:{flex:1}}),R&&jsxRuntime.jsx(Je,{onClick:h}),jsxRuntime.jsx(q.SettingsMenu,{currentRate:d,playbackRates:s,onRateChange:Z,qualityLevels:V,currentQualityLevel:O,onQualityChange:ee}),M?.map(m=>jsxRuntime.jsx("button",{className:"controlButton","aria-label":m.label,title:m.title??m.label,onClick:m.onClick,children:m.icon},m.key)),p&&jsxRuntime.jsx(Ye,{onClick:l,isAudioMode:T}),jsxRuntime.jsx(q.PiPButton,{onClick:ne,isPiP:w}),jsxRuntime.jsx(q.TheaterButton,{onClick:r,isTheater:B}),jsxRuntime.jsx(q.FullscreenButton,{onClick:f,isFullscreen:k})]})]})})},Ye=St.memo(({onClick:t,isAudioMode:e})=>jsxRuntime.jsx("button",{onClick:t,className:"controlButton","aria-label":e?"Exit audio mode":"Audio only mode",title:e?"Exit audio mode":"Audio only mode","aria-pressed":e,children:e?jsxRuntime.jsx("svg",{width:"20",height:"20",viewBox:"0 0 24 24",fill:"currentColor",children:jsxRuntime.jsx("path",{d:"M17 10.5V7c0-.55-.45-1-1-1H4c-.55 0-1 .45-1 1v10c0 .55.45 1 1 1h12c.55 0 1-.45 1-1v-3.5l4 4v-11l-4 4z"})}):jsxRuntime.jsx("svg",{width:"20",height:"20",viewBox:"0 0 24 24",fill:"currentColor",children:jsxRuntime.jsx("path",{d:"M12 3a9 9 0 0 0-9 9v7c0 1.1.9 2 2 2h1a1 1 0 0 0 1-1v-5a1 1 0 0 0-1-1H4v-1a8 8 0 0 1 16 0v1h-2a1 1 0 0 0-1 1v5a1 1 0 0 0 1 1h1a3 3 0 0 0 3-3v-4c0-4.97-4.03-9-9-9z"})})}));Ye.displayName="AudioModeButton";var Je=St.memo(({onClick:t})=>jsxRuntime.jsx("button",{onClick:t,style:{background:"none",border:"1px solid rgba(255,255,255,0.6)",color:"#fff",borderRadius:3,padding:"2px 8px",fontSize:11,fontWeight:700,cursor:"pointer",letterSpacing:"0.06em"},title:"Go to live (L)",children:"GO LIVE"}));Je.displayName="GoLiveButton";var Be=St.memo(({x:t,y:e,isPlaying:c,src:s,videoRef:o,playerRef:g,onClose:u,contextMenuItems:a})=>{let x=St.useRef(null),[d,k]=St.useState(()=>o.current?.loop??false),w=Math.min(t,window.innerWidth-220),B=Math.min(e,window.innerHeight-290);St.useEffect(()=>{let M=C=>{x.current&&!x.current.contains(C.target)&&u();},L=C=>{C.key==="Escape"&&u();},I=()=>u();return document.addEventListener("mousedown",M),document.addEventListener("keydown",L),window.addEventListener("scroll",I,true),()=>{document.removeEventListener("mousedown",M),document.removeEventListener("keydown",L),window.removeEventListener("scroll",I,true);}},[u]);let T=St.useCallback(()=>{c?g.pause():g.play(),u();},[c,g,u]),p=St.useCallback(()=>{let M=o.current;if(!M)return;let L=!d;M.loop=L,k(L);},[o,d]),R=St.useCallback(async()=>{try{await navigator.clipboard.writeText(s);}catch{}u();},[s,u]),V=St.useCallback(async()=>{let M=Math.floor(o.current?.currentTime??0);try{await navigator.clipboard.writeText(`${s}?t=${M}`);}catch{}u();},[s,o,u]),O=St.useCallback(()=>{g.togglePictureInPicture(),u();},[g,u]);return jsxRuntime.jsxs("div",{ref:x,className:"contextMenu",style:{left:w,top:B},children:[jsxRuntime.jsx("button",{className:"contextMenuItem",onClick:T,children:c?"Pause":"Play"}),jsxRuntime.jsxs("button",{className:"contextMenuItem",onClick:p,children:[jsxRuntime.jsx("span",{children:"Loop"}),d&&jsxRuntime.jsx("span",{className:"contextMenuCheck",children:"\u2713"})]}),jsxRuntime.jsx("div",{className:"contextMenuDivider"}),jsxRuntime.jsx("button",{className:"contextMenuItem",onClick:R,children:"Copy video URL"}),jsxRuntime.jsx("button",{className:"contextMenuItem",onClick:V,children:"Copy video URL at current time"}),jsxRuntime.jsx("div",{className:"contextMenuDivider"}),jsxRuntime.jsx("button",{className:"contextMenuItem",onClick:O,children:"Picture-in-Picture"}),a&&a.length>0&&jsxRuntime.jsxs(jsxRuntime.Fragment,{children:[jsxRuntime.jsx("div",{className:"contextMenuDivider"}),a.map((M,L)=>jsxRuntime.jsx("button",{className:"contextMenuItem",onClick:()=>{M.onClick(),u();},children:M.label},L))]})]})});Be.displayName="ContextMenu";var Rt=Array.from({length:20},(t,e)=>e),De=({poster:t,logo:e,isPlaying:c})=>{let s=t?jsxRuntime.jsx("img",{src:t,alt:"Video artwork",className:"rvp-audio-artwork",draggable:false}):e?typeof e=="string"?jsxRuntime.jsx("img",{src:e,alt:"Logo",className:"rvp-audio-logo",draggable:false}):jsxRuntime.jsx("div",{className:"rvp-audio-logo-node",children:e}):null;return jsxRuntime.jsx("div",{className:"rvp-audio-overlay","data-test":"audio-mode-overlay",children:jsxRuntime.jsxs("div",{className:"rvp-audio-content",children:[s&&jsxRuntime.jsx("div",{className:"rvp-audio-artwork-wrapper",children:s}),jsxRuntime.jsxs("div",{className:"rvp-audio-badge","aria-label":"Audio only mode",children:[jsxRuntime.jsx("svg",{width:"12",height:"12",viewBox:"0 0 24 24",fill:"currentColor","aria-hidden":"true",children:jsxRuntime.jsx("path",{d:"M12 3a9 9 0 0 0-9 9v7c0 1.1.9 2 2 2h1a1 1 0 0 0 1-1v-5a1 1 0 0 0-1-1H4v-1a8 8 0 0 1 16 0v1h-2a1 1 0 0 0-1 1v5a1 1 0 0 0 1 1h1a3 3 0 0 0 3-3v-4c0-4.97-4.03-9-9-9z"})}),"Audio Only"]}),jsxRuntime.jsx("div",{className:`rvp-audio-equalizer${c?" rvp-audio-equalizer--playing":""}`,"aria-hidden":"true",children:Rt.map(o=>jsxRuntime.jsx("div",{className:"rvp-audio-bar",style:{"--bar-index":o}},o))})]})})};De.displayName="AudioModeOverlay";var tt=St.forwardRef(({src:t,poster:e,autoplay:c=false,muted:s=false,loop:o=false,controls:g=true,preload:u="metadata",playbackRates:a=[.25,.5,.75,1,1.25,1.5,1.75,2],className:x,enableHLS:d=true,enablePreview:k=true,thumbnailVtt:w,hlsConfig:B,subtitles:T,crossOrigin:p,logo:R,showAudioButton:V=true,defaultAudioMode:O,audioBandwidthThreshold:M,onPlay:L,onPause:I,onEnded:C,onError:W,onTimeUpdate:X,onDurationChange:j,onBuffering:H,onTheaterModeChange:G,onAudioModeChange:Z,contextMenuItems:ee,controlBarItems:ne},r)=>{let l=St.useRef(null),f=St.useRef(null),{state:h,ref:m,fullscreenContainerRef:v}=Ie(l,t,{autoplay:c,muted:s,loop:o,playbackRates:a,enableHLS:d,hlsConfig:B,defaultAudioMode:O,audioBandwidthThreshold:M,onPlay:L,onPause:I,onEnded:C,onError:W,onTimeUpdate:X,onDurationChange:j,onBuffering:H,onTheaterModeChange:G,onAudioModeChange:Z}),[E,D]=St.useState(null);St.useEffect(()=>{v.current=f.current;},[v]),St__default.default.useImperativeHandle(r,()=>m,[m]);let n=St.useCallback(()=>{f.current?.focus(),h.isPlaying?m.pause():m.play();},[h.isPlaying,m]),i=St.useCallback(()=>{m.toggleFullscreen();},[m]),b=St.useCallback(y=>{y.preventDefault(),D({x:y.clientX,y:y.clientY});},[]);return jsxRuntime.jsxs("div",{ref:f,tabIndex:0,style:{position:"relative",width:"100%",backgroundColor:"#000",aspectRatio:"16 / 9",userSelect:"none",outline:"none"},className:x,"data-test":"video-player-container","data-theater":h.isTheaterMode?"true":void 0,onContextMenu:b,children:[jsxRuntime.jsx("video",{ref:l,poster:e,preload:u,crossOrigin:p,onClick:n,onDoubleClick:i,playsInline:true,style:{width:"100%",height:"100%",display:"block",cursor:"pointer",visibility:h.isAudioMode?"hidden":"visible"},"data-test":"video-element",children:T?.map(y=>jsxRuntime.jsx("track",{kind:"subtitles",src:y.src,label:y.label,srcLang:y.srclang,default:y.default},y.id))}),h.isAudioMode&&jsxRuntime.jsx(De,{poster:e,logo:R,isPlaying:h.isPlaying}),g&&jsxRuntime.jsx(Re,{videoRef:l,playerRef:m,playerContainerRef:f,playbackRates:a,enablePreview:k,thumbnailVtt:w,isPlaying:h.isPlaying,volume:h.volume,isMuted:h.isMuted,playbackRate:h.playbackRate,isFullscreen:h.isFullscreen,isPictureInPicture:h.isPictureInPicture,isTheaterMode:h.isTheaterMode,isAudioMode:h.isAudioMode,showAudioButton:V,isLive:h.isLive,qualityLevels:h.qualityLevels,currentQualityLevel:h.currentQualityLevel,controlBarItems:ne}),E&&jsxRuntime.jsx(Be,{x:E.x,y:E.y,isPlaying:h.isPlaying,src:t,videoRef:l,playerRef:m,onClose:()=>D(null),contextMenuItems:ee}),h.isLive&&jsxRuntime.jsx("div",{style:{position:"absolute",top:12,left:12,backgroundColor:"#e53935",color:"#fff",fontSize:11,fontWeight:700,letterSpacing:"0.08em",padding:"2px 8px",borderRadius:3,pointerEvents:"none"},children:"LIVE"}),h.isBuffering&&!h.error&&jsxRuntime.jsxs("div",{style:{position:"absolute",inset:0,display:"flex",flexDirection:"column",alignItems:"center",justifyContent:"center",gap:12,color:"#fff",pointerEvents:"none"},"data-test":"buffering-indicator",children:[jsxRuntime.jsx("div",{style:{width:48,height:48,border:"4px solid rgba(255,255,255,0.25)",borderTop:"4px solid #fff",borderRadius:"50%",animation:"rvp-spin 0.8s linear infinite"}}),jsxRuntime.jsx("style",{children:"@keyframes rvp-spin { to { transform: rotate(360deg); } }"})]}),h.error&&jsxRuntime.jsx("div",{style:{position:"absolute",inset:0,display:"flex",alignItems:"center",justifyContent:"center",backgroundColor:"rgba(0,0,0,0.85)",color:"#fff",padding:24},"data-test":"error-overlay",children:jsxRuntime.jsxs("div",{style:{textAlign:"center",maxWidth:400},children:[jsxRuntime.jsx("div",{style:{fontSize:36,marginBottom:12},children:"\u26A0"}),jsxRuntime.jsx("h3",{style:{margin:"0 0 8px",fontSize:18},children:h.error.code==="MEDIA_ERR_SRC_NOT_SUPPORTED"?"Unsupported Format":h.error.code.startsWith("HLS")?"Stream Error":"Playback Error"}),jsxRuntime.jsx("p",{style:{margin:0,fontSize:13,opacity:.75},children:h.error.message})]})})]})});tt.displayName="VideoPlayer";var Ht=tt;var At={EXTREME:100,POOR:300,FAIR:700,GOOD:1500};exports.AUDIO_BANDWIDTH_THRESHOLDS=At;exports.ControlElements=Ke;exports.Controls=Re;exports.VideoPlayer=Ht;exports.findThumbnailCue=we;exports.formatTime=oe;exports.getMimeType=it;exports.isHLSUrl=be;exports.parseThumbnailVtt=ke;//# sourceMappingURL=index.js.map
|
|
3
|
+
`),a=0;for(;a<s.length;){let p=s[a].trim();if(p.includes("-->")){let u=p.indexOf("-->"),l=$e(p.slice(0,u)),L=$e(p.slice(u+3));for(a++;a<s.length&&!s[a].trim();)a++;if(a<s.length){let c=s[a].trim(),C=c.lastIndexOf("#xywh="),k=c,R=0,T=0,m=160,B=90;if(C!==-1){k=c.slice(0,C);let I=c.slice(C+6).split(",").map(Number);R=I[0]??0,T=I[1]??0,m=I[2]??160,B=I[3]??90;}r.push({start:l,end:L,url:pt(t,k),x:R,y:T,w:m,h:B});}}a++;}return r}function Se(n,t){if(!n.length)return null;let r=0,s=n.length-1;for(;r<=s;){let a=r+s>>1;if(n[a].end<=t)r=a+1;else if(n[a].start>t)s=a-1;else return n[a]}return null}var Ue=Dt.memo(({videoRef:n,playerRef:t,enablePreview:r=true,thumbnailVtt:s})=>{let a=Dt.useRef(null),p=Dt.useRef(null),u=Dt.useRef(null),l=Dt.useRef(null),L=Dt.useRef(null),c=Dt.useRef(null),C=Dt.useRef(null),[k,R]=Dt.useState([]),T=Dt.useRef(false),m=Dt.useRef(0),B=Dt.useRef(0),I=Dt.useRef(null),_=Dt.useRef([]),P=Dt.useRef(null);Dt.useEffect(()=>{let o=()=>{P.current=null;};return window.addEventListener("resize",o,{passive:true}),()=>window.removeEventListener("resize",o)},[]);let x=Dt.useCallback(()=>(!P.current&&a.current&&(P.current=a.current.getBoundingClientRect()),P.current),[]);Dt.useEffect(()=>{if(!s){_.current=[];return}let o=false;return fetch(s).then(i=>i.text()).then(i=>{o||(_.current=Re(i,s));}).catch(()=>{o||(_.current=[]);}),()=>{o=true;}},[s]),Dt.useEffect(()=>{let o=n.current;if(!o)return;let i=()=>{let f=isFinite(o.duration)?o.duration:0,y=o.currentTime,S=f>0?y/f*100:0;p.current&&(p.current.style.width=`${S}%`),u.current&&(u.current.style.left=`${S}%`),a.current&&(a.current.setAttribute("aria-valuenow",String(Math.round(y))),a.current.setAttribute("aria-valuemax",String(Math.round(f))),a.current.setAttribute("aria-valuetext",se(y)));};return o.addEventListener("timeupdate",i),o.addEventListener("durationchange",i),o.addEventListener("seeked",i),i(),()=>{o.removeEventListener("timeupdate",i),o.removeEventListener("durationchange",i),o.removeEventListener("seeked",i);}},[n]),Dt.useEffect(()=>{let o=n.current;if(!o)return;let i=()=>{let f=[];for(let y=0;y<o.buffered.length;y++)f.push({start:o.buffered.start(y),end:o.buffered.end(y)});R(f);};return o.addEventListener("progress",i),()=>o.removeEventListener("progress",i)},[n]);let D=Dt.useCallback(()=>{T.current=true,u.current?.classList.add("dragging");},[]),N=Dt.useCallback(()=>{T.current=false,u.current?.classList.remove("dragging");},[]),ne=Dt.useCallback(()=>{r&&(P.current=null,l.current&&(l.current.style.display="block"),c.current&&(c.current.style.display="block"));},[r]),Z=Dt.useCallback(()=>{l.current&&(l.current.style.display="none"),c.current&&(c.current.style.display="none");},[]),X=Dt.useCallback(o=>{if(!C.current||!_.current.length)return;let i=Se(_.current,o);if(I.current=i,!i)return;let f=C.current;f.style.backgroundImage=`url(${i.url})`,f.style.backgroundPosition=`-${i.x}px -${i.y}px`,f.style.width=`${i.w}px`,f.style.height=`${i.h}px`;},[]),M=Dt.useCallback(o=>{let i=x(),f=n.current?.duration;return !i||i.width===0||!f||!isFinite(f)?0:Math.max(0,Math.min(o-i.left,i.width))/i.width*f},[x,n]),G=Dt.useCallback(o=>{let i=x();return i?Math.max(0,Math.min(o-i.left,i.width)):0},[x]),U=Dt.useCallback(o=>{let i=n.current;if(!i)return;let f=i.currentTime,y=isFinite(i.duration)?i.duration:0;switch(o.key){case "ArrowLeft":case "ArrowRight":{o.preventDefault(),o.nativeEvent.stopImmediatePropagation();let S=o.shiftKey?10:5;t.seek(o.key==="ArrowLeft"?Math.max(0,f-S):Math.min(y,f+S));break}case "Home":o.preventDefault(),o.nativeEvent.stopImmediatePropagation(),t.seek(0);break;case "End":y>0&&(o.preventDefault(),o.nativeEvent.stopImmediatePropagation(),t.seek(y));break}},[n,t]),ee=Dt.useCallback(o=>{let i=M(o.clientX),f=G(o.clientX);if(m.current=f,B.current=i,c.current&&(c.current.style.left=`${f}px`),L.current&&(L.current.textContent=se(i)),X(i),l.current){let y=l.current.offsetWidth,S=x()?.width??0,h=y/2,E=Math.max(h,Math.min(f,S-h));l.current.style.left=`${E}px`;}T.current&&t.seek(i);},[t,X,M,G,x]),ie=Dt.useCallback(()=>{Z(),N();},[Z,N]),e=Dt.useCallback(o=>{o.preventDefault(),D(),t.seek(M(o.clientX));},[D,M,t]),d=Dt.useCallback(o=>{T.current||t.seek(M(o.clientX));},[M,t]);Dt.useEffect(()=>{let o=a.current;if(!o)return;let i=f=>{T.current&&f.preventDefault();};return o.addEventListener("touchmove",i,{passive:false}),()=>o.removeEventListener("touchmove",i)},[]);let v=Dt.useCallback(o=>{P.current=null,D(),t.seek(M(o.touches[0].clientX));},[D,M,t]),V=Dt.useCallback(o=>{T.current&&t.seek(M(o.touches[0].clientX));},[M,t]);Dt.useEffect(()=>{let o=()=>N();return window.addEventListener("mouseup",o),()=>window.removeEventListener("mouseup",o)},[N]);let O=Dt.useMemo(()=>{let o=n.current,i=o&&isFinite(o.duration)?o.duration:0;return i<=0||!k.length?null:k.map((f,y)=>{let S=f.start/i*100,h=(f.end-f.start)/i*100;return jsxRuntime.jsx("div",{className:"bufferedSegment",style:{left:`${S}%`,width:`${h}%`}},y)})},[k,n]);return jsxRuntime.jsxs("div",{ref:a,className:"progressContainer",onMouseMove:ee,onMouseEnter:ne,onMouseLeave:ie,onMouseDown:e,onMouseUp:N,onClick:d,onTouchStart:v,onTouchMove:V,onTouchEnd:N,onKeyDown:U,role:"slider","aria-label":"Video progress","aria-valuemin":0,"aria-valuemax":0,"aria-valuenow":0,"aria-valuetext":"0:00",tabIndex:0,children:[r&&jsxRuntime.jsxs("div",{ref:l,className:"previewTooltip",style:{left:0,display:"none"},"aria-hidden":"true",children:[s&&jsxRuntime.jsx("div",{ref:C,className:"previewThumbnail"}),jsxRuntime.jsx("div",{ref:L,className:"previewTime"})]}),jsxRuntime.jsxs("div",{className:"progressBackground",children:[O,jsxRuntime.jsx("div",{ref:p,className:"progressFilled",style:{width:"0%"}}),r&&jsxRuntime.jsx("div",{ref:c,className:"hoverIndicator",style:{left:0,display:"none"},"aria-hidden":"true"})]}),jsxRuntime.jsx("div",{ref:u,className:"scrubHandle",style:{left:"0%"},"aria-hidden":"true"})]})});Ue.displayName="ProgressBar";var Pe=Ue;var Qe=Dt.memo(({currentRate:n,playbackRates:t,onRateChange:r,qualityLevels:s=[],currentQualityLevel:a=-1,onQualityChange:p})=>{let[u,l]=Dt.useState(false),[L,c]=Dt.useState("speed"),C=Dt.useRef(null),k=s.length>0&&!!p;Dt.useEffect(()=>{let m=B=>{C.current&&!C.current.contains(B.target)&&l(false);};return u&&document.addEventListener("mousedown",m),()=>document.removeEventListener("mousedown",m)},[u]);let R=Dt.useMemo(()=>[...s].sort((m,B)=>B.bitrate-m.bitrate),[s]),T=Dt.useMemo(()=>a===-1?"Auto":s.find(m=>m.id===a)?.name??"Auto",[s,a]);return jsxRuntime.jsxs("div",{ref:C,className:"settingsContainer",children:[jsxRuntime.jsx("button",{onClick:()=>l(m=>!m),className:"controlButton","aria-label":"Settings",title:"Settings","aria-expanded":u,children:jsxRuntime.jsx("svg",{width:"20",height:"20",viewBox:"0 0 24 24",fill:"currentColor",children:jsxRuntime.jsx("path",{d:"M19.14 12.94c.04-.3.06-.61.06-.94s-.02-.64-.07-.94l2.03-1.58a.49.49 0 0 0 .12-.61l-1.92-3.32a.49.49 0 0 0-.59-.22l-2.39.96a7.02 7.02 0 0 0-1.62-.94l-.36-2.54a.484.484 0 0 0-.48-.41h-3.84c-.24 0-.43.17-.47.41l-.36 2.54a6.88 6.88 0 0 0-1.61.94l-2.39-.96a.488.488 0 0 0-.59.22L2.74 8.87a.48.48 0 0 0 .12.61l2.03 1.58c-.05.3-.09.63-.09.94s.02.64.07.94l-2.03 1.58a.49.49 0 0 0-.12.61l1.92 3.32c.12.22.37.29.59.22l2.39-.96c.5.38 1.03.7 1.62.94l.36 2.54c.05.24.24.41.48.41h3.84c.24 0 .44-.17.47-.41l.36-2.54a6.88 6.88 0 0 0 1.61-.94l2.39.96c.22.08.47 0 .59-.22l1.92-3.32a.47.47 0 0 0-.12-.61l-2.01-1.58zM12 15.6A3.6 3.6 0 0 1 8.4 12 3.6 3.6 0 0 1 12 8.4a3.6 3.6 0 0 1 3.6 3.6 3.6 3.6 0 0 1-3.6 3.6z"})})}),u&&jsxRuntime.jsxs("div",{className:"settingsDropdown",role:"menu",children:[k&&jsxRuntime.jsxs("div",{className:"settingsTabs",children:[jsxRuntime.jsx("button",{className:`settingsTab${L==="speed"?" active":""}`,onClick:()=>c("speed"),children:"Speed"}),jsxRuntime.jsx("button",{className:`settingsTab${L==="quality"?" active":""}`,onClick:()=>c("quality"),children:"Quality"})]}),(!k||L==="speed")&&jsxRuntime.jsxs("div",{children:[!k&&jsxRuntime.jsx("div",{className:"settingsPanelLabel",children:"Playback Speed"}),t.map(m=>jsxRuntime.jsx("button",{onClick:()=>{r(m),l(false);},className:`settingsOption${n===m?" active":""}`,role:"menuitemradio","aria-checked":n===m,children:m===1?"Normal":`${m}\xD7`},m))]}),k&&L==="quality"&&jsxRuntime.jsxs("div",{children:[jsxRuntime.jsxs("button",{onClick:()=>{p(-1),l(false);},className:`settingsOption${a===-1?" active":""}`,role:"menuitemradio","aria-checked":a===-1,children:["Auto ",a===-1&&T!=="Auto"?`(${T})`:""]}),R.map(m=>jsxRuntime.jsxs("button",{onClick:()=>{p(m.id),l(false);},className:`settingsOption${a===m.id?" active":""}`,role:"menuitemradio","aria-checked":a===m.id,children:[m.name,m.bitrate>0&&jsxRuntime.jsxs("span",{className:"settingsOptionBadge",children:[Math.round(m.bitrate/1e3)," kbps"]})]},m.id))]})]})]})});Qe.displayName="SettingsMenu";var Te=Qe;var Xe=Dt.memo(({videoRef:n,isLive:t=false})=>{let r=Dt.useRef(null),s=Dt.useRef(null);return Dt.useEffect(()=>{let a=n.current;if(!a)return;let p=()=>{r.current&&(r.current.textContent=se(a.currentTime));},u=()=>{if(s.current){let l=isFinite(a.duration)?a.duration:0;s.current.textContent=` / ${se(l)}`;}};return a.addEventListener("timeupdate",p),a.addEventListener("durationchange",u),a.addEventListener("seeked",p),p(),u(),()=>{a.removeEventListener("timeupdate",p),a.removeEventListener("durationchange",u),a.removeEventListener("seeked",p);}},[n,t]),t?jsxRuntime.jsx("span",{className:"timeDisplay",style:{opacity:.7},children:jsxRuntime.jsx("span",{ref:r,children:"0:00"})}):jsxRuntime.jsxs("span",{className:"timeDisplay",children:[jsxRuntime.jsx("span",{ref:r,children:"0:00"}),jsxRuntime.jsx("span",{ref:s,style:{opacity:.6},children:" / 0:00"})]})});Xe.displayName="TimeDisplay";var ke=Xe;var Q={PlayButton:fe,PauseButton:pe,FullscreenButton:ve,PiPButton:he,TheaterButton:ge,VolumeControl:Le,ProgressBar:Pe,SettingsMenu:Te,TimeDisplay:ke};var xe=Dt.memo(function({videoRef:t,playerRef:r,playerContainerRef:s,playbackRates:a,enablePreview:p,thumbnailVtt:u,isPlaying:l,volume:L,isMuted:c,playbackRate:C,isFullscreen:k,isPictureInPicture:R,isTheaterMode:T,isAudioMode:m,showAudioButton:B,audioModeIcon:I,videoModeIcon:_,audioModeLabel:P,videoModeLabel:x,isLive:D,qualityLevels:N,currentQualityLevel:ne,controlBarItems:Z,autoHideControls:X}){let M=Dt.useRef(null),[G,U]=Dt.useState(true),ee=Dt.useRef({isPlaying:l,volume:L,isMuted:c,isLive:D});ee.current={isPlaying:l,volume:L,isMuted:c,isLive:D},Dt.useEffect(()=>{if(m||!X){U(true),M.current&&clearTimeout(M.current);return}if(!l){U(true),M.current&&clearTimeout(M.current);return}let h=s.current;if(!h)return;let E=()=>{U(true),M.current&&clearTimeout(M.current),M.current=setTimeout(()=>U(false),3e3);},g=()=>{M.current&&clearTimeout(M.current),U(false);};return h.addEventListener("mousemove",E),h.addEventListener("mouseenter",E),h.addEventListener("mouseleave",g),h.addEventListener("touchstart",E,{passive:true}),U(false),()=>{h.removeEventListener("mousemove",E),h.removeEventListener("mouseenter",E),h.removeEventListener("mouseleave",g),h.removeEventListener("touchstart",E),M.current&&clearTimeout(M.current);}},[l,m,X,s]),Dt.useEffect(()=>{let h=E=>{if(!s.current?.contains(document.activeElement))return;let g=E.target;if(g.tagName==="INPUT"||g.tagName==="TEXTAREA"||g.isContentEditable)return;let{isPlaying:A,volume:b,isLive:z}=ee.current,j=t.current?.currentTime??0,ae=t.current?.duration??0;switch(E.code){case "Space":case "KeyK":E.preventDefault(),A?r.pause():r.play();break;case "ArrowLeft":E.preventDefault(),r.seek(Math.max(0,j-5));break;case "ArrowRight":E.preventDefault(),r.seek(Math.min(ae||1/0,j+5));break;case "ArrowUp":E.preventDefault(),r.setVolume(Math.min(1,b+.1));break;case "ArrowDown":E.preventDefault(),r.setVolume(Math.max(0,b-.1));break;case "KeyM":E.preventDefault(),r.toggleMute();break;case "KeyF":E.preventDefault(),r.toggleFullscreen();break;case "KeyP":E.preventDefault(),r.togglePictureInPicture();break;case "KeyT":E.preventDefault(),r.toggleTheaterMode();break;case "KeyL":E.preventDefault(),z&&r.seekToLive();break;case "Digit0":case "Digit1":case "Digit2":case "Digit3":case "Digit4":case "Digit5":case "Digit6":case "Digit7":case "Digit8":case "Digit9":{E.preventDefault();let we=Number(E.code.replace("Digit",""))*10;r.seek(ae/100*we);break}}};return window.addEventListener("keydown",h),()=>window.removeEventListener("keydown",h)},[r,s,t]);let ie=Dt.useCallback(()=>r.play(),[r]),e=Dt.useCallback(()=>r.pause(),[r]),d=Dt.useCallback(h=>r.setVolume(h),[r]),v=Dt.useCallback(()=>r.toggleMute(),[r]),V=Dt.useCallback(h=>r.setPlaybackRate(h),[r]),O=Dt.useCallback(h=>r.setQualityLevel(h),[r]),o=Dt.useCallback(()=>r.togglePictureInPicture(),[r]),i=Dt.useCallback(()=>r.toggleTheaterMode(),[r]),f=Dt.useCallback(()=>r.toggleAudioMode(),[r]),y=Dt.useCallback(()=>r.toggleFullscreen(),[r]),S=Dt.useCallback(()=>r.seekToLive(),[r]);return jsxRuntime.jsx("div",{style:{position:"absolute",inset:0,display:"flex",flexDirection:"column",justifyContent:"flex-end",opacity:G?1:0,transition:"opacity 0.3s",pointerEvents:"none",zIndex:2},children:jsxRuntime.jsxs("div",{style:{background:"linear-gradient(to top, rgba(0,0,0,0.75) 0%, rgba(0,0,0,0.2) 60%, transparent 100%)",padding:"48px 12px 12px",pointerEvents:G?"auto":"none"},role:"region","aria-label":"Video player controls",children:[jsxRuntime.jsx(Q.ProgressBar,{videoRef:t,playerRef:r,enablePreview:p,thumbnailVtt:u}),jsxRuntime.jsxs("div",{style:{display:"flex",alignItems:"center",gap:4,marginTop:4},children:[l?jsxRuntime.jsx(Q.PauseButton,{onClick:e}):jsxRuntime.jsx(Q.PlayButton,{onClick:ie}),jsxRuntime.jsx(Q.VolumeControl,{volume:L,isMuted:c,onVolumeChange:d,onToggleMute:v}),jsxRuntime.jsx(Q.TimeDisplay,{videoRef:t,isLive:D}),jsxRuntime.jsx("div",{style:{flex:1}}),D&&jsxRuntime.jsx(Ze,{onClick:S}),B&&jsxRuntime.jsx(Je,{onClick:f,isAudioMode:m,audioModeIcon:I,videoModeIcon:_,audioModeLabel:P,videoModeLabel:x}),jsxRuntime.jsx(Q.SettingsMenu,{currentRate:C,playbackRates:a,onRateChange:V,qualityLevels:N,currentQualityLevel:ne,onQualityChange:O}),Z?.map(h=>jsxRuntime.jsx("button",{className:"controlButton","aria-label":h.label,title:h.title??h.label,onClick:h.onClick,children:h.icon},h.key)),jsxRuntime.jsx(Q.PiPButton,{onClick:o,isPiP:R}),jsxRuntime.jsx(Q.TheaterButton,{onClick:i,isTheater:T}),jsxRuntime.jsx(Q.FullscreenButton,{onClick:y,isFullscreen:k})]})]})})});xe.displayName="Controls";var Je=Dt.memo(({onClick:n,isAudioMode:t,audioModeIcon:r,videoModeIcon:s,audioModeLabel:a,videoModeLabel:p})=>{let u=t?p??"Video":a??"Audio";return jsxRuntime.jsxs("button",{onClick:n,className:"rvp-audio-toggle-btn","aria-label":u,title:u,"aria-pressed":t,children:[t?s??jsxRuntime.jsx("svg",{width:"16",height:"16",viewBox:"0 0 24 24",fill:"currentColor",children:jsxRuntime.jsx("path",{d:"M17 10.5V7c0-.55-.45-1-1-1H4c-.55 0-1 .45-1 1v10c0 .55.45 1 1 1h12c.55 0 1-.45 1-1v-3.5l4 4v-11l-4 4z"})}):r??jsxRuntime.jsx("svg",{width:"16",height:"16",viewBox:"0 0 24 24",fill:"currentColor",children:jsxRuntime.jsx("path",{d:"M12 3a9 9 0 0 0-9 9v7c0 1.1.9 2 2 2h1a1 1 0 0 0 1-1v-5a1 1 0 0 0-1-1H4v-1a8 8 0 0 1 16 0v1h-2a1 1 0 0 0-1 1v5a1 1 0 0 0 1 1h1a3 3 0 0 0 3-3v-4c0-4.97-4.03-9-9-9z"})}),u]})});Je.displayName="AudioModeButton";var Ze=Dt.memo(({onClick:n})=>jsxRuntime.jsx("button",{onClick:n,style:{background:"none",border:"1px solid rgba(255,255,255,0.6)",color:"#fff",borderRadius:3,padding:"2px 8px",fontSize:11,fontWeight:700,cursor:"pointer",letterSpacing:"0.06em"},title:"Go to live (L)",children:"GO LIVE"}));Ze.displayName="GoLiveButton";var Ve=Dt.memo(({x:n,y:t,isPlaying:r,src:s,videoRef:a,playerRef:p,onClose:u,contextMenuItems:l})=>{let L=Dt.useRef(null),[c,C]=Dt.useState(()=>a.current?.loop??false),k=Math.min(n,window.innerWidth-220),R=Math.min(t,window.innerHeight-290);Dt.useEffect(()=>{let P=N=>{L.current&&!L.current.contains(N.target)&&u();},x=N=>{N.key==="Escape"&&u();},D=()=>u();return document.addEventListener("mousedown",P),document.addEventListener("keydown",x),window.addEventListener("scroll",D,true),()=>{document.removeEventListener("mousedown",P),document.removeEventListener("keydown",x),window.removeEventListener("scroll",D,true);}},[u]);let T=Dt.useCallback(()=>{r?p.pause():p.play(),u();},[r,p,u]),m=Dt.useCallback(()=>{let P=a.current;if(!P)return;let x=!c;P.loop=x,C(x);},[a,c]),B=Dt.useCallback(async()=>{try{await navigator.clipboard.writeText(s);}catch{}u();},[s,u]),I=Dt.useCallback(async()=>{let P=Math.floor(a.current?.currentTime??0);try{await navigator.clipboard.writeText(`${s}?t=${P}`);}catch{}u();},[s,a,u]),_=Dt.useCallback(()=>{p.togglePictureInPicture(),u();},[p,u]);return jsxRuntime.jsxs("div",{ref:L,className:"contextMenu",style:{left:k,top:R},children:[jsxRuntime.jsx("button",{className:"contextMenuItem",onClick:T,children:r?"Pause":"Play"}),jsxRuntime.jsxs("button",{className:"contextMenuItem",onClick:m,children:[jsxRuntime.jsx("span",{children:"Loop"}),c&&jsxRuntime.jsx("span",{className:"contextMenuCheck",children:"\u2713"})]}),jsxRuntime.jsx("div",{className:"contextMenuDivider"}),jsxRuntime.jsx("button",{className:"contextMenuItem",onClick:B,children:"Copy video URL"}),jsxRuntime.jsx("button",{className:"contextMenuItem",onClick:I,children:"Copy video URL at current time"}),jsxRuntime.jsx("div",{className:"contextMenuDivider"}),jsxRuntime.jsx("button",{className:"contextMenuItem",onClick:_,children:"Picture-in-Picture"}),l&&l.length>0&&jsxRuntime.jsxs(jsxRuntime.Fragment,{children:[jsxRuntime.jsx("div",{className:"contextMenuDivider"}),l.map((P,x)=>jsxRuntime.jsx("button",{className:"contextMenuItem",onClick:()=>{P.onClick(),u();},children:P.label},x))]})]})});Ve.displayName="ContextMenu";var Ae=Dt.memo(function({poster:t,logo:r,audioModeFallback:s,isBuffering:a=false,onOverlayClick:p}){return jsxRuntime.jsxs("div",{className:"rvp-audio-overlay",onClick:p,"data-test":"audio-mode-overlay",children:[t?jsxRuntime.jsx("div",{className:"rvp-audio-artwork-container",children:jsxRuntime.jsx("img",{src:t,alt:"Artwork",className:"rvp-audio-artwork",draggable:false})}):s?jsxRuntime.jsx("div",{style:{display:"flex",alignItems:"center",justifyContent:"center"},children:s}):r?typeof r=="string"?jsxRuntime.jsx("img",{src:r,alt:"Logo",className:"rvp-audio-logo",draggable:false}):jsxRuntime.jsx("div",{className:"rvp-audio-logo-node",children:r}):null,jsxRuntime.jsx("span",{className:"rvp-audio-label",children:"Audio Mode"}),a?jsxRuntime.jsx("div",{className:"rvp-audio-buffering-overlay","aria-label":"Buffering",children:jsxRuntime.jsx("div",{className:"rvp-audio-spinner"})}):null]})});Ae.displayName="AudioModeOverlay";var nt=Dt.forwardRef((n,t)=>{let{src:r,poster:s,className:a,controls:p=true,options:u={}}=n,{autoplay:l=false,muted:L=false,loop:c=false,preload:C="metadata",playbackRates:k=[.25,.5,.75,1,1.25,1.5,1.75,2],enableHLS:R=true,enablePreview:T=true,thumbnailVtt:m,hlsConfig:B,autoHideControls:I=true,subtitles:_,crossOrigin:P,logo:x,audioModeFallback:D,audioSrc:N,showAudioButton:ne,audioModeIcon:Z,videoModeIcon:X,audioModeLabel:M,videoModeLabel:G,defaultAudioMode:U,audioBandwidthThreshold:ee,onPlay:ie,onPause:e,onEnded:d,onError:v,onTimeUpdate:V,onDurationChange:O,onBuffering:o,onTheaterModeChange:i,onAudioModeChange:f,contextMenuItems:y,controlBarItems:S}=u,h=Dt.useRef(null),E=Dt.useRef(null),{state:g,ref:A,fullscreenContainerRef:b}=_e(h,r,{autoplay:l,muted:L,loop:c,playbackRates:k,enableHLS:R,hlsConfig:B,defaultAudioMode:U,audioBandwidthThreshold:ee,onPlay:ie,onPause:e,onEnded:d,onError:v,onTimeUpdate:V,onDurationChange:O,onBuffering:o,onTheaterModeChange:i,onAudioModeChange:f}),[z,j]=Dt.useState(null);Dt.useEffect(()=>{b.current=E.current;},[b]),Dt__default.default.useImperativeHandle(t,()=>A,[A]);let ae=Dt.useCallback(()=>{E.current?.focus(),g.isPlaying?A.pause():A.play();},[g.isPlaying,A]),we=Dt.useCallback(()=>{A.toggleFullscreen();},[A]),rt=Dt.useCallback(te=>{te.preventDefault(),j({x:te.clientX,y:te.clientY});},[]);return jsxRuntime.jsxs("div",{ref:E,tabIndex:0,style:{position:"relative",width:"100%",backgroundColor:"#000",aspectRatio:"16 / 9",userSelect:"none",outline:"none"},className:a,"data-test":"video-player-container","data-theater":g.isTheaterMode?"true":void 0,onContextMenu:rt,children:[jsxRuntime.jsx("video",{ref:h,poster:s,preload:C,crossOrigin:P,onClick:ae,onDoubleClick:we,playsInline:true,style:{width:"100%",height:"100%",display:"block",cursor:"pointer",visibility:g.isAudioMode?"hidden":"visible"},"data-test":"video-element",children:_?.map(te=>jsxRuntime.jsx("track",{kind:"subtitles",src:te.src,label:te.label,srcLang:te.srclang,default:te.default},te.id))}),g.isAudioMode&&jsxRuntime.jsx(Ae,{poster:s,logo:x,audioModeFallback:D,isBuffering:g.isBuffering,onOverlayClick:ae}),p&&jsxRuntime.jsx(xe,{videoRef:h,playerRef:A,playerContainerRef:E,playbackRates:k,enablePreview:T,thumbnailVtt:g.isAudioMode?void 0:m,isPlaying:g.isPlaying,volume:g.volume,isMuted:g.isMuted,playbackRate:g.playbackRate,isFullscreen:g.isFullscreen,isPictureInPicture:g.isPictureInPicture,isTheaterMode:g.isTheaterMode,isAudioMode:g.isAudioMode,showAudioButton:ne??!!N,audioModeIcon:Z,videoModeIcon:X,audioModeLabel:M,videoModeLabel:G,isLive:g.isLive,qualityLevels:g.qualityLevels,currentQualityLevel:g.currentQualityLevel,controlBarItems:S,autoHideControls:I}),z&&jsxRuntime.jsx(Ve,{x:z.x,y:z.y,isPlaying:g.isPlaying,src:r,videoRef:h,playerRef:A,onClose:()=>j(null),contextMenuItems:y}),g.isLive&&jsxRuntime.jsx("div",{style:{position:"absolute",top:12,left:12,backgroundColor:"#e53935",color:"#fff",fontSize:11,fontWeight:700,letterSpacing:"0.08em",padding:"2px 8px",borderRadius:3,pointerEvents:"none"},children:"LIVE"}),g.isBuffering&&!g.error&&jsxRuntime.jsx("div",{style:{position:"absolute",inset:0,display:"flex",flexDirection:"column",alignItems:"center",justifyContent:"center",gap:12,color:"#fff",pointerEvents:"none"},"data-test":"buffering-indicator",children:jsxRuntime.jsx("div",{style:{width:48,height:48,border:"4px solid rgba(255,255,255,0.25)",borderTop:"4px solid #fff",borderRadius:"50%",animation:"rvp-spin 0.8s linear infinite"}})}),g.error&&jsxRuntime.jsx("div",{style:{position:"absolute",inset:0,display:"flex",alignItems:"center",justifyContent:"center",backgroundColor:"rgba(0,0,0,0.85)",color:"#fff",padding:24},"data-test":"error-overlay",children:jsxRuntime.jsxs("div",{style:{textAlign:"center",maxWidth:400},children:[jsxRuntime.jsx("div",{style:{fontSize:36,marginBottom:12},children:"\u26A0"}),jsxRuntime.jsx("h3",{style:{margin:"0 0 8px",fontSize:18},children:g.error.code==="MEDIA_ERR_SRC_NOT_SUPPORTED"?"Unsupported Format":g.error.code.startsWith("HLS")?"Stream Error":"Playback Error"}),jsxRuntime.jsx("p",{style:{margin:0,fontSize:13,opacity:.75},children:g.error.message})]})})]})});nt.displayName="VideoPlayer";var At=nt;var It={EXTREME:100,POOR:300,FAIR:700,GOOD:1500};exports.AUDIO_BANDWIDTH_THRESHOLDS=It;exports.ControlElements=Ge;exports.Controls=xe;exports.VideoPlayer=At;exports.findThumbnailCue=Se;exports.formatTime=se;exports.getMimeType=at;exports.isHLSUrl=ye;exports.parseThumbnailVtt=Re;//# sourceMappingURL=index.js.map
|
|
4
4
|
//# sourceMappingURL=index.js.map
|