import React from 'react'; import { TypeSelector } from './TypeSelector'; import { NumberSelector } from './NumberSelector'; import { VideoProgressStore } from '../lib/storage/VideoProgress' import { SelectBox } from '../components/SelectBox'; import './EpisodeSelector.css' import { useWindowSize } from '../hooks/useWindowSize'; export function EpisodeSelector({ setSelectedSeason, selectedSeason, setEpisode, seasons, episodes, currentSeason, currentEpisode, streamData }) { const choices = episodes ? episodes.map(v => { const progressData = VideoProgressStore.get(); let currentlyAt = 0; let totalDuration = 0; const progress = progressData?.[streamData.source]?.[streamData.type]?.[streamData.slug]?.[`${selectedSeason}-${v}`] if (progress) { currentlyAt = progress.currentlyAt totalDuration = progress.totalDuration } const percentage = Math.round((currentlyAt / totalDuration) * 100) return { value: v.toString(), label: v, percentage } }) : []; const windowSize = useWindowSize() return (