recharts
Version:
React charts
37 lines (33 loc) • 1.25 kB
JavaScript
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.
*/
;