// src/hooks/useDebounce.ts 'use client'; import { useState, useEffect } from 'react'; export function useDebounce(value: T, delay: number): T { const [debouncedValue, setDebouncedValue] = useState(value); useEffect(() => { // Actualiza el valor "debounced" después del retraso especificado const handler = setTimeout(() => { setDebouncedValue(value); }, delay); // Limpia el temporizador si el valor cambia (por ejemplo, el usuario sigue escribiendo) // o si el componente se desmonta. return () => { clearTimeout(handler); }; }, [value, delay]); // Solo se vuelve a ejecutar si el valor o el retraso cambian return debouncedValue; }