import React, { useState } from 'react'; import { X, Dumbbell, User, Flame, Timer as TimerIcon, ArrowUp, ArrowRight, Footprints, Ruler, Percent } from 'lucide-react'; import { ExerciseDef, ExerciseType, Language } from '../types'; import { t } from '../services/i18n'; import FilledInput from './FilledInput'; interface ExerciseModalProps { isOpen: boolean; onClose: () => void; onSave: (exercise: ExerciseDef) => Promise | void; lang: Language; } const ExerciseModal: React.FC = ({ isOpen, onClose, onSave, lang }) => { const [newName, setNewName] = useState(''); const [newType, setNewType] = useState(ExerciseType.STRENGTH); const [newBwPercentage, setNewBwPercentage] = useState('100'); const exerciseTypeLabels: Record = { [ExerciseType.STRENGTH]: t('type_strength', lang), [ExerciseType.BODYWEIGHT]: t('type_bodyweight', lang), [ExerciseType.CARDIO]: t('type_cardio', lang), [ExerciseType.STATIC]: t('type_static', lang), [ExerciseType.HIGH_JUMP]: t('type_height', lang), [ExerciseType.LONG_JUMP]: t('type_dist', lang), [ExerciseType.PLYOMETRIC]: t('type_jump', lang), }; const handleCreateExercise = async () => { if (!newName.trim()) return; const newEx: ExerciseDef = { id: crypto.randomUUID(), name: newName.trim(), type: newType, ...(newType === ExerciseType.BODYWEIGHT && { bodyWeightPercentage: parseFloat(newBwPercentage) || 100 }) }; await onSave(newEx); setNewName(''); setNewType(ExerciseType.STRENGTH); setNewBwPercentage('100'); onClose(); }; if (!isOpen) return null; return (

{t('create_exercise', lang)}

setNewName(e.target.value)} type="text" autoFocus />
{[ { id: ExerciseType.STRENGTH, label: exerciseTypeLabels[ExerciseType.STRENGTH], icon: Dumbbell }, { id: ExerciseType.BODYWEIGHT, label: exerciseTypeLabels[ExerciseType.BODYWEIGHT], icon: User }, { id: ExerciseType.CARDIO, label: exerciseTypeLabels[ExerciseType.CARDIO], icon: Flame }, { id: ExerciseType.STATIC, label: exerciseTypeLabels[ExerciseType.STATIC], icon: TimerIcon }, { id: ExerciseType.HIGH_JUMP, label: exerciseTypeLabels[ExerciseType.HIGH_JUMP], icon: ArrowUp }, { id: ExerciseType.LONG_JUMP, label: exerciseTypeLabels[ExerciseType.LONG_JUMP], icon: Ruler }, { id: ExerciseType.PLYOMETRIC, label: exerciseTypeLabels[ExerciseType.PLYOMETRIC], icon: Footprints }, ].map((type) => ( ))}
{newType === ExerciseType.BODYWEIGHT && ( setNewBwPercentage(e.target.value)} icon={} /> )}
); }; export default ExerciseModal;