UNPKG

recharts

Version:
32 lines (28 loc) 1.13 kB
import { useId } from './useId'; /** * A hook that generates a unique ID. It uses React.useId() in React 18+ for SSR safety * and falls back to a client-side-only unique ID generator for older versions. * * The ID will stay the same across renders, and you can optionally provide a prefix. * * @param [prefix] - An optional prefix for the generated ID. * @param [customId] - An optional custom ID to override the generated one. * @returns The unique ID. */ export function useUniqueId(prefix, customId) { /* * We have to call this hook here even if we don't use the result because * rules of hooks demand that hooks are never called conditionally. */ var generatedId = useId(); // If a custom ID is provided, it always takes precedence. if (customId) { return customId; } // Apply the prefix if one was provided. return prefix ? "".concat(prefix, "-").concat(generatedId) : generatedId; } /** * The useUniqueId hook returns a unique ID that is either reused from external props or generated internally. * Either way the ID is now guaranteed to be present so no more nulls or undefined. */