UNPKG

recharts

Version:
37 lines (33 loc) 1.25 kB
"use strict"; Object.defineProperty(exports, "__esModule", { value: true }); exports.useUniqueId = useUniqueId; var _useId = require("./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. */ 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 = (0, _useId.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. */