import { ChangeEvent } from 'react'; import { Trash2 } from 'lucide-react'; import { FormError } from '@@/form-components/FormError'; import { Button } from '@@/buttons'; import { isArrayErrorType } from '@@/form-components/formikUtils'; import { Annotation, AnnotationErrors } from './types'; interface Props { annotations: Annotation[]; handleAnnotationChange: ( index: number, key: 'Key' | 'Value', val: string ) => void; removeAnnotation: (index: number) => void; errors: AnnotationErrors; placeholder: string[]; } export function AnnotationsForm({ annotations, handleAnnotationChange, removeAnnotation, errors, placeholder, }: Props) { const annotationErrors = isArrayErrorType(errors) ? errors : undefined; return ( <> {annotations.map((annotation, i) => (
Key ) => handleAnnotationChange(i, 'Key', e.target.value) } />
{annotationErrors?.[i]?.Key && ( {annotationErrors[i]?.Key} )}
Value ) => handleAnnotationChange(i, 'Value', e.target.value) } />
{annotationErrors?.[i]?.Value && ( {annotationErrors[i]?.Value} )}
))} ); }