45 lines
1.4 KiB
JavaScript
45 lines
1.4 KiB
JavaScript
|
import _slicedToArray from "@babel/runtime/helpers/esm/slicedToArray";
|
||
|
import _objectSpread from "@babel/runtime/helpers/esm/objectSpread2";
|
||
|
import * as React from 'react';
|
||
|
function getUseId() {
|
||
|
// We need fully clone React function here to avoid webpack warning React 17 do not export `useId`
|
||
|
var fullClone = _objectSpread({}, React);
|
||
|
return fullClone.useId;
|
||
|
}
|
||
|
var uuid = 0;
|
||
|
|
||
|
/** @private Note only worked in develop env. Not work in production. */
|
||
|
export function resetUuid() {
|
||
|
if (process.env.NODE_ENV !== 'production') {
|
||
|
uuid = 0;
|
||
|
}
|
||
|
}
|
||
|
export default function useId(id) {
|
||
|
// Inner id for accessibility usage. Only work in client side
|
||
|
var _React$useState = React.useState('ssr-id'),
|
||
|
_React$useState2 = _slicedToArray(_React$useState, 2),
|
||
|
innerId = _React$useState2[0],
|
||
|
setInnerId = _React$useState2[1];
|
||
|
var useOriginId = getUseId();
|
||
|
var reactNativeId = useOriginId === null || useOriginId === void 0 ? void 0 : useOriginId();
|
||
|
React.useEffect(function () {
|
||
|
if (!useOriginId) {
|
||
|
var nextId = uuid;
|
||
|
uuid += 1;
|
||
|
setInnerId("rc_unique_".concat(nextId));
|
||
|
}
|
||
|
}, []);
|
||
|
|
||
|
// Developer passed id is single source of truth
|
||
|
if (id) {
|
||
|
return id;
|
||
|
}
|
||
|
|
||
|
// Test env always return mock id
|
||
|
if (process.env.NODE_ENV === 'test') {
|
||
|
return 'test-id';
|
||
|
}
|
||
|
|
||
|
// Return react native id or inner id
|
||
|
return reactNativeId || innerId;
|
||
|
}
|