import { state } from './state'; import { displayTimeFromAbsolute, absoluteTimeFromDisplay, absoluteTimeFromRatio, getBounds, } from './timeline'; import { showControls, toggleMute, togglePlayPause, toggleFullscreen, seekBy, setVolume, formatTime, } from './controls'; export const setupKeyboard = (): void => { document.addEventListener('keydown', e => { const target = e.target as HTMLElement; if (target.tagName === 'INPUT' || target.tagName === 'TEXTAREA' || target.isContentEditable) return; switch (e.code) { case 'Space': case 'KeyK': e.preventDefault(); togglePlayPause(); showControls(); break; case 'ArrowLeft': case 'KeyJ': e.preventDefault(); seekBy(-10); break; case 'ArrowRight': case 'KeyL': e.preventDefault(); seekBy(10); break; case 'ArrowUp': e.preventDefault(); setVolume(state.video.volume + 0.05); showControls(); break; case 'ArrowDown': e.preventDefault(); setVolume(state.video.volume - 0.05); showControls(); break; case 'KeyM': e.preventDefault(); toggleMute(); showControls(); break; case 'KeyF': e.preventDefault(); toggleFullscreen(); showControls(); break; default: if (/^\d$/.test(e.key)) { const b = getBounds(); if (b.duration > 0) { e.preventDefault(); state.video.currentTime = absoluteTimeFromRatio(parseInt(e.key, 10) / 10); showControls(); } } } }); };