Check Availability
How It Works
Best Practice: Debouncing
import { useIsSubnameAvailable } from '@justaname.id/react';
import { useState } from 'react';
import { useDebounce } from '@uidotdev/usehooks';
export const CheckAvailability = () => {
const [username, setUsername] = useState('');
// Wait 500ms after user stops typing before checking
const debouncedUsername = useDebounce(username, 500);
const { isSubnameAvailable, isLoading } = useIsSubnameAvailable({
username: debouncedUsername
});
return (
<div>
<input
value={username}
onChange={(e) => setUsername(e.target.value)}
placeholder="Enter username"
/>
{isLoading && <span>Checking...</span>}
{!isLoading && debouncedUsername && (
<span>{isSubnameAvailable ? '✅ Available' : '❌ Taken'}</span>
)}
</div>
);
};Last updated