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; } } var useOriginId = getUseId(); export default useOriginId ? // Use React `useId` function useId(id) { var reactId = useOriginId(); // 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 reactId; } : // Use compatible of `useId` function useCompatId(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]; React.useEffect(function () { 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 innerId; };