Files
player/examples/App.tsx
T
hibna c5efcb95d5 Add SRT subtitle support and improve subtitle handling
This update enables SRT subtitle files by converting them to VTT blob URLs, sets the default subtitle track automatically, and improves subtitle track switching. Subtitle styling is enhanced in CSS, and tests are updated to use the correct subtitle prop format.
2025-10-29 14:15:43 +03:00

139 lines
4.4 KiB
TypeScript
Raw Blame History

This file contains invisible Unicode characters
This file contains invisible Unicode characters that are indistinguishable to humans but may be processed differently by a computer. If you think that this is intentional, you can safely ignore this warning. Use the Escape button to reveal them.
import React, { useState } from 'react'
import { VideoPlayer } from '../src/components/VideoPlayer'
import type { SubtitleTrack } from '../src/types'
import './App.css'
function App() {
const [videoUrl, setVideoUrl] = useState('')
const [useDemo, setUseDemo] = useState(true)
// Demo video URLs (you can replace with your own)
const demoVideoUrl = '/s6ebilmemkac.mp4'
const demoPoster = '/s6ebilmemkac.webp'
const demoSubtitles: SubtitleTrack[] = [
{
src: '/ses.srt',
lang: 'tr',
label: 'Türkçe',
default: true,
},
]
const currentVideoUrl = useDemo ? demoVideoUrl : videoUrl
return (
<div className="app">
<header className="app-header">
<h1>🎬 Modern Video Player</h1>
<p>A feature-rich, modern video player built with React</p>
</header>
<main className="app-main">
<div className="video-section">
<div className="player-wrapper">
{currentVideoUrl ? (
<VideoPlayer
src={currentVideoUrl}
poster={useDemo ? demoPoster : undefined}
subtitles={demoSubtitles}
keyboardShortcuts={true}
pictureInPicture={true}
theme={{
primaryColor: '#ef4444',
accentColor: '#dc2626',
}}
onPlay={() => console.log('Playing')}
onPause={() => console.log('Paused')}
onTimeUpdate={(time) => console.log('Time:', time)}
/>
) : (
<div className="no-video">
<p>Enter a video URL or use the demo video</p>
</div>
)}
</div>
<div className="controls-section">
<div className="url-input">
<input
type="text"
placeholder="Enter video URL (MP4, HLS)"
value={videoUrl}
onChange={(e) => setVideoUrl(e.target.value)}
disabled={useDemo}
/>
<button
onClick={() => setUseDemo(!useDemo)}
className={useDemo ? 'active' : ''}
>
{useDemo ? 'Using Demo' : 'Use Demo'}
</button>
</div>
</div>
</div>
<div className="features-section">
<h2>Features</h2>
<div className="features-grid">
<div className="feature">
<h3> Keyboard Shortcuts</h3>
<ul>
<li><kbd>Space</kbd> or <kbd>K</kbd> - Play/Pause</li>
<li><kbd></kbd> / <kbd></kbd> - Seek 5s</li>
<li><kbd>J</kbd> / <kbd>L</kbd> - Seek 10s</li>
<li><kbd></kbd> / <kbd></kbd> - Volume</li>
<li><kbd>M</kbd> - Mute/Unmute</li>
<li><kbd>F</kbd> - Fullscreen</li>
<li><kbd>P</kbd> - Picture-in-Picture</li>
<li><kbd>0-9</kbd> - Jump to %</li>
</ul>
</div>
<div className="feature">
<h3>📱 Touch Gestures</h3>
<ul>
<li>Tap - Play/Pause</li>
<li>Double tap left - Rewind 10s</li>
<li>Double tap right - Forward 10s</li>
<li>Swipe left/right - Seek</li>
<li>Swipe up/down - Volume</li>
</ul>
</div>
<div className="feature">
<h3>🎨 Modern UI</h3>
<ul>
<li>Clean, minimalist design</li>
<li>Smooth animations</li>
<li>Custom red theme</li>
<li>Auto-hiding controls</li>
<li>Responsive layout</li>
</ul>
</div>
<div className="feature">
<h3>🚀 Advanced Features</h3>
<ul>
<li>HLS streaming support</li>
<li>HTTP Range Request (MP4)</li>
<li>Subtitles (VTT, SRT)</li>
<li>Multiple audio tracks</li>
<li>Playback speed control</li>
<li>Quality selector</li>
</ul>
</div>
</div>
</div>
</main>
<footer className="app-footer">
<p>Built with React, TypeScript, and Vite</p>
<p>Zero runtime dependencies ~8KB gzipped</p>
</footer>
</div>
)
}
export default App