- Source unique : supprime app/data/librodrome.config.yml, renomme site/ en bookplayer.config.yml - Morceaux : renommés avec slugs lisibles, fichiers audio renommés, inversion ch2↔ch3 corrigée - Chapitres : 11 fichiers .md réécrits avec le vrai contenu du livre (synthèse fidèle du PDF) - Routes : /lire → /modele-eco, /ecouter → /en-musique, redirections 301 - Admin chapitres : champs structurés (titre, description, temps lecture), compteur mots - Éditeur markdown : mode split, plein écran, support Tab, meilleur rendu aperçu - Admin morceaux : drag & drop, ajout/suppression, gestion playlist - Light mode : palettes printemps/été plus saturées et contrastées, teintes primary - Raccourcis clavier player : espace, flèches gauche/droite - Paroles : toggle supprimé, toujours visibles et scrollables - Nouvelles pages : autonomie, evenement Co-Authored-By: Claude Opus 4.6 <noreply@anthropic.com>
42 lines
1003 B
TypeScript
42 lines
1003 B
TypeScript
export function useKeyboardShortcuts() {
|
|
const store = usePlayerStore()
|
|
const { togglePlayPause, playNext, playPrev } = useAudioPlayer()
|
|
|
|
function isInputFocused(): boolean {
|
|
const el = document.activeElement
|
|
if (!el) return false
|
|
const tag = el.tagName.toLowerCase()
|
|
if (tag === 'input' || tag === 'textarea' || tag === 'select') return true
|
|
if ((el as HTMLElement).isContentEditable) return true
|
|
return false
|
|
}
|
|
|
|
function onKeyDown(e: KeyboardEvent) {
|
|
if (isInputFocused()) return
|
|
if (!store.currentSong) return
|
|
|
|
switch (e.code) {
|
|
case 'Space':
|
|
e.preventDefault()
|
|
togglePlayPause()
|
|
break
|
|
case 'ArrowRight':
|
|
e.preventDefault()
|
|
playNext()
|
|
break
|
|
case 'ArrowLeft':
|
|
e.preventDefault()
|
|
playPrev()
|
|
break
|
|
}
|
|
}
|
|
|
|
onMounted(() => {
|
|
window.addEventListener('keydown', onKeyDown)
|
|
})
|
|
|
|
onUnmounted(() => {
|
|
window.removeEventListener('keydown', onKeyDown)
|
|
})
|
|
}
|