fix(qc): move accessibleCaptionCues memos after state declarations
Resolves TS2448/TS2454 — useMemo blocks referenced captionsVtt and retimedCaptionsVtt before their useState declarations. Co-Authored-By: Claude Sonnet 4.6 <noreply@anthropic.com>
This commit is contained in:
parent
90867e9824
commit
e52abca74b
1 changed files with 12 additions and 12 deletions
|
|
@ -66,18 +66,6 @@ export function QCDetail() {
|
|||
const [currentVideoTimeMs, setCurrentVideoTimeMs] = useState(0);
|
||||
const videoRef = useRef<HTMLVideoElement | null>(null);
|
||||
|
||||
// Accessible video captions: parse retimed (or fallback to original) cues
|
||||
const accessibleCaptionCues = useMemo(() => {
|
||||
const src = retimedCaptionsVtt || captionsVtt;
|
||||
if (!src) return [];
|
||||
try { return VTTParser.parse(src); } catch { return []; }
|
||||
}, [retimedCaptionsVtt, captionsVtt]);
|
||||
|
||||
const currentAccessibleCaption = useMemo(() => {
|
||||
const timeSec = currentVideoTimeMs / 1000;
|
||||
return accessibleCaptionCues.find(c => timeSec >= c.startTime && timeSec <= c.endTime) || null;
|
||||
}, [accessibleCaptionCues, currentVideoTimeMs]);
|
||||
|
||||
// Local state for pending regenerations (cleared on successful re-render)
|
||||
const [pendingRegenerations, setPendingRegenerations] = useState<number[]>([]);
|
||||
const [pausePointsModified, setPausePointsModified] = useState(false);
|
||||
|
|
@ -313,6 +301,18 @@ export function QCDetail() {
|
|||
const [captionsVtt, setCaptionsVtt] = useState('');
|
||||
const [retimedCaptionsVtt, setRetimedCaptionsVtt] = useState('');
|
||||
const [adVtt, setAdVtt] = useState('');
|
||||
|
||||
// Accessible video captions: parse retimed (or fallback to original) cues
|
||||
const accessibleCaptionCues = useMemo(() => {
|
||||
const src = retimedCaptionsVtt || captionsVtt;
|
||||
if (!src) return [];
|
||||
try { return VTTParser.parse(src); } catch { return []; }
|
||||
}, [retimedCaptionsVtt, captionsVtt]);
|
||||
|
||||
const currentAccessibleCaption = useMemo(() => {
|
||||
const timeSec = currentVideoTimeMs / 1000;
|
||||
return accessibleCaptionCues.find(c => timeSec >= c.startTime && timeSec <= c.endTime) || null;
|
||||
}, [accessibleCaptionCues, currentVideoTimeMs]);
|
||||
const [viewMode, setViewMode] = useState<'side-by-side' | 'video-only' | 'editor-only'>('side-by-side');
|
||||
const [showTimingAdjustment, setShowTimingAdjustment] = useState(false);
|
||||
const [timingOffset, setTimingOffset] = useState(0);
|
||||
|
|
|
|||
Loading…
Add table
Reference in a new issue