import { useEffect, useState } from "react"; // react-hook-form import { Controller, useForm } from "react-hook-form"; // types import { Props } from "./types"; export const CustomTextAttribute: React.FC = ({ attributeDetails, onChange, value, }) => { const [isEditing, setIsEditing] = useState(false); const { control, handleSubmit, reset, setFocus } = useForm({ defaultValues: { text: "" } }); const handleFormSubmit = (data: { text: string }) => { setIsEditing(false); onChange(data.text); }; useEffect(() => { if (isEditing) { setFocus("text"); } }, [isEditing, setFocus]); useEffect(() => { reset({ text: value ?? "" }); }, [reset, value]); useEffect(() => { const handleEscKeyPress = (e: KeyboardEvent) => { if (e.key === "Escape") setIsEditing(false); }; document.addEventListener("keydown", handleEscKeyPress); return () => { document.removeEventListener("keydown", handleEscKeyPress); }; }, []); return (
{!isEditing && (
setIsEditing(true)}> {value ?? "Empty"}
)} {isEditing && (
( )} /> )}
); };