{"version":3,"file":"react-tooltip.min.cjs","sources":["../src/utils/handle-style.ts","../src/utils/compute-tooltip-position.ts","../src/utils/css-supports.ts","../src/utils/debounce.ts","../src/utils/deep-equal.ts","../src/utils/get-scroll-parent.ts","../src/utils/use-isomorphic-layout-effect.ts","../src/utils/clear-timeout-ref.ts","../src/components/TooltipProvider/TooltipProvider.tsx","../src/components/Tooltip/Tooltip.tsx","../src/utils/css-time-to-ms.ts","../src/components/TooltipContent/TooltipContent.tsx","../src/components/TooltipController/TooltipController.tsx","../src/index.tsx","../src/components/TooltipProvider/TooltipWrapper.tsx"],"sourcesContent":["// This is the ID for the core styles of ReactTooltip\nconst REACT_TOOLTIP_CORE_STYLES_ID = 'react-tooltip-core-styles'\n// This is the ID for the visual styles of ReactTooltip\nconst REACT_TOOLTIP_BASE_STYLES_ID = 'react-tooltip-base-styles'\n\nconst injected = {\n  core: false,\n  base: false,\n}\n\nfunction injectStyle({\n  css,\n  id = REACT_TOOLTIP_BASE_STYLES_ID,\n  type = 'base',\n  ref,\n}: {\n  css: string\n  id?: string\n  type?: 'core' | 'base'\n  // eslint-disable-next-line @typescript-eslint/no-explicit-any\n  ref?: any\n}) {\n  if (!css || typeof document === 'undefined' || injected[type]) {\n    return\n  }\n\n  if (\n    type === 'core' &&\n    typeof process !== 'undefined' && // this validation prevents docs from breaking even with `process?`\n    process?.env?.REACT_TOOLTIP_DISABLE_CORE_STYLES\n  ) {\n    return\n  }\n\n  if (\n    type !== 'base' &&\n    typeof process !== 'undefined' && // this validation prevents docs from breaking even with `process?`\n    process?.env?.REACT_TOOLTIP_DISABLE_BASE_STYLES\n  ) {\n    return\n  }\n\n  if (type === 'core') {\n    // eslint-disable-next-line no-param-reassign\n    id = REACT_TOOLTIP_CORE_STYLES_ID\n  }\n\n  if (!ref) {\n    // eslint-disable-next-line no-param-reassign\n    ref = {}\n  }\n  const { insertAt } = ref\n\n  if (document.getElementById(id)) {\n    // this could happen in cases the tooltip is imported by multiple js modules\n    return\n  }\n\n  const head = document.head || document.getElementsByTagName('head')[0]\n  // eslint-disable-next-line @typescript-eslint/no-explicit-any\n  const style: any = document.createElement('style')\n  style.id = id\n  style.type = 'text/css'\n\n  if (insertAt === 'top') {\n    if (head.firstChild) {\n      head.insertBefore(style, head.firstChild)\n    } else {\n      head.appendChild(style)\n    }\n  } else {\n    head.appendChild(style)\n  }\n\n  if (style.styleSheet) {\n    style.styleSheet.cssText = css\n  } else {\n    style.appendChild(document.createTextNode(css))\n  }\n\n  injected[type] = true\n}\n\n/**\n * @deprecated Use the `disableStyleInjection` tooltip prop instead.\n * See https://react-tooltip.com/docs/examples/styling#disabling-reacttooltip-css\n */\nfunction removeStyle({\n  type = 'base',\n  id = REACT_TOOLTIP_BASE_STYLES_ID,\n}: {\n  type?: 'core' | 'base'\n  id?: string\n} = {}) {\n  if (!injected[type]) {\n    return\n  }\n\n  if (type === 'core') {\n    // eslint-disable-next-line no-param-reassign\n    id = REACT_TOOLTIP_CORE_STYLES_ID\n  }\n\n  const style = document.getElementById(id)\n  if (style?.tagName === 'style') {\n    style?.remove()\n  } else if (process.env.NODE_ENV !== 'production') {\n    // eslint-disable-next-line no-console\n    console.warn(\n      `[react-tooltip] Failed to remove 'style' element with id '${id}'. Call \\`injectStyle()\\` first`,\n    )\n  }\n\n  injected[type] = false\n}\n\nexport { injectStyle, removeStyle }\n","import { computePosition, offset, shift, arrow, flip } from '@floating-ui/dom'\nimport type { IComputePositionArgs } from './compute-tooltip-position-types'\n\nconst computeTooltipPosition = async ({\n  elementReference = null,\n  tooltipReference = null,\n  tooltipArrowReference = null,\n  place = 'top',\n  offset: offsetValue = 10,\n  strategy = 'absolute',\n  middlewares = [\n    offset(Number(offsetValue)),\n    flip({\n      fallbackAxisSideDirection: 'start',\n    }),\n    shift({ padding: 5 }),\n  ],\n  border,\n  arrowSize = 8,\n}: IComputePositionArgs) => {\n  if (!elementReference) {\n    // elementReference can be null or undefined and we will not compute the position\n    // eslint-disable-next-line no-console\n    // console.error('The reference element for tooltip was not defined: ', elementReference)\n    return { tooltipStyles: {}, tooltipArrowStyles: {}, place }\n  }\n\n  if (tooltipReference === null) {\n    return { tooltipStyles: {}, tooltipArrowStyles: {}, place }\n  }\n\n  const middleware = middlewares\n\n  if (tooltipArrowReference) {\n    middleware.push(arrow({ element: tooltipArrowReference as HTMLElement, padding: 5 }))\n\n    return computePosition(elementReference as HTMLElement, tooltipReference as HTMLElement, {\n      placement: place,\n      strategy,\n      middleware,\n    }).then(({ x, y, placement, middlewareData }) => {\n      const styles = { left: `${x}px`, top: `${y}px`, border }\n\n      /* c8 ignore start */\n      const { x: arrowX, y: arrowY } = middlewareData.arrow ?? { x: 0, y: 0 }\n\n      const staticSide =\n        {\n          top: 'bottom',\n          right: 'left',\n          bottom: 'top',\n          left: 'right',\n        }[placement.split('-')[0]] ?? 'bottom'\n      /* c8 ignore end */\n\n      const borderSide = border && {\n        borderBottom: border,\n        borderRight: border,\n      }\n\n      let borderWidth = 0\n      if (border) {\n        const match = `${border}`.match(/(\\d+)px/)\n        if (match?.[1]) {\n          borderWidth = Number(match[1])\n        } else {\n          /**\n           * this means `border` was set without `width`,\n           * or non-px value (such as `medium`, `thick`, ...)\n           */\n          borderWidth = 1\n        }\n      }\n\n      /* c8 ignore start */\n      const arrowStyle = {\n        left: arrowX != null ? `${arrowX}px` : '',\n        top: arrowY != null ? `${arrowY}px` : '',\n        right: '',\n        bottom: '',\n        ...borderSide,\n        [staticSide]: `-${arrowSize / 2 + borderWidth}px`,\n      }\n      /* c8 ignore end */\n\n      return { tooltipStyles: styles, tooltipArrowStyles: arrowStyle, place: placement }\n    })\n  }\n\n  return computePosition(elementReference as HTMLElement, tooltipReference as HTMLElement, {\n    placement: 'bottom',\n    strategy,\n    middleware,\n  }).then(({ x, y, placement }) => {\n    const styles = { left: `${x}px`, top: `${y}px` }\n\n    return { tooltipStyles: styles, tooltipArrowStyles: {}, place: placement }\n  })\n}\n\nexport default computeTooltipPosition\n","const cssSupports = (property: string, value: string): boolean => {\n  const hasCssSupports = 'CSS' in window && 'supports' in window.CSS\n  return hasCssSupports ? window.CSS.supports(property, value) : true\n}\n\nexport default cssSupports\n","/* eslint-disable @typescript-eslint/no-explicit-any */\n/**\n * This function debounce the received function\n * @param { function } \tfunc\t\t\t\tFunction to be debounced\n * @param { number } \t\twait\t\t\t\tTime to wait before execut the function\n * @param { boolean } \timmediate\t\tParam to define if the function will be executed immediately\n */\nconst debounce = <T, A extends any[]>(\n  func: (...args: A) => void,\n  wait?: number,\n  immediate?: boolean,\n) => {\n  let timeout: NodeJS.Timeout | null = null\n\n  const debounced = function debounced(this: T, ...args: A): void {\n    const later = () => {\n      timeout = null\n      if (!immediate) {\n        func.apply(this, args)\n      }\n    }\n\n    if (immediate && !timeout) {\n      /**\n       * there's no need to clear the timeout\n       * since we expect it to resolve and set `timeout = null`\n       */\n      func.apply(this, args)\n      timeout = setTimeout(later, wait)\n    }\n\n    if (!immediate) {\n      if (timeout) {\n        clearTimeout(timeout)\n      }\n      timeout = setTimeout(later, wait)\n    }\n  }\n\n  debounced.cancel = () => {\n    /* c8 ignore start */\n    if (!timeout) {\n      return\n    }\n    /* c8 ignore end */\n    clearTimeout(timeout)\n    timeout = null\n  }\n\n  return debounced\n}\n\nexport default debounce\n","const isObject = (object: unknown): object is Record<string, unknown> => {\n  return object !== null && !Array.isArray(object) && typeof object === 'object'\n}\n\nconst deepEqual = (object1: unknown, object2: unknown): boolean => {\n  if (object1 === object2) {\n    return true\n  }\n\n  if (Array.isArray(object1) && Array.isArray(object2)) {\n    if (object1.length !== object2.length) {\n      return false\n    }\n    return object1.every((val, index) => deepEqual(val, object2[index]))\n  }\n\n  if (Array.isArray(object1) !== Array.isArray(object2)) {\n    return false\n  }\n\n  if (!isObject(object1) || !isObject(object2)) {\n    return object1 === object2\n  }\n\n  const keys1 = Object.keys(object1)\n  const keys2 = Object.keys(object2)\n  if (keys1.length !== keys2.length) {\n    return false\n  }\n\n  return keys1.every((key) => deepEqual(object1[key], object2[key]))\n}\n\nexport default deepEqual\n","const isScrollable = (node: Element) => {\n  if (!(node instanceof HTMLElement || node instanceof SVGElement)) {\n    return false\n  }\n  const style = getComputedStyle(node)\n  return ['overflow', 'overflow-x', 'overflow-y'].some((propertyName) => {\n    const value = style.getPropertyValue(propertyName)\n    return value === 'auto' || value === 'scroll'\n  })\n}\n\nconst getScrollParent = (node: Element | null) => {\n  if (!node) {\n    return null\n  }\n  let currentParent = node.parentElement\n  while (currentParent) {\n    if (isScrollable(currentParent)) {\n      return currentParent\n    }\n    currentParent = currentParent.parentElement\n  }\n  return document.scrollingElement || document.documentElement\n}\n\nexport default getScrollParent\n","import { useLayoutEffect, useEffect } from 'react'\n\nconst useIsomorphicLayoutEffect = typeof window !== 'undefined' ? useLayoutEffect : useEffect\n\nexport default useIsomorphicLayoutEffect\n","const clearTimeoutRef = (ref: React.MutableRefObject<NodeJS.Timeout | null>) => {\n  if (ref.current) {\n    clearTimeout(ref.current)\n    // eslint-disable-next-line no-param-reassign\n    ref.current = null\n  }\n}\n\nexport default clearTimeoutRef\n","import React, {\n  createContext,\n  PropsWithChildren,\n  useCallback,\n  useContext,\n  useMemo,\n  useState,\n} from 'react'\n\nimport type {\n  AnchorRef,\n  TooltipContextData,\n  TooltipContextDataWrapper,\n} from './TooltipProviderTypes'\n\nconst DEFAULT_TOOLTIP_ID = 'DEFAULT_TOOLTIP_ID'\nconst DEFAULT_CONTEXT_DATA: TooltipContextData = {\n  anchorRefs: new Set(),\n  activeAnchor: { current: null },\n  attach: () => {\n    /* attach anchor element */\n  },\n  detach: () => {\n    /* detach anchor element */\n  },\n  setActiveAnchor: () => {\n    /* set active anchor */\n  },\n}\n\nconst DEFAULT_CONTEXT_DATA_WRAPPER: TooltipContextDataWrapper = {\n  getTooltipData: () => DEFAULT_CONTEXT_DATA,\n}\n\nconst TooltipContext = createContext<TooltipContextDataWrapper>(DEFAULT_CONTEXT_DATA_WRAPPER)\n\n/**\n * @deprecated Use the `data-tooltip-id` attribute, or the `anchorSelect` prop instead.\n * See https://react-tooltip.com/docs/getting-started\n */\nconst TooltipProvider: React.FC<PropsWithChildren<void>> = ({ children }) => {\n  const [anchorRefMap, setAnchorRefMap] = useState<Record<string, Set<AnchorRef>>>({\n    [DEFAULT_TOOLTIP_ID]: new Set(),\n  })\n  const [activeAnchorMap, setActiveAnchorMap] = useState<Record<string, AnchorRef>>({\n    [DEFAULT_TOOLTIP_ID]: { current: null },\n  })\n\n  const attach = (tooltipId: string, ...refs: AnchorRef[]) => {\n    setAnchorRefMap((oldMap) => {\n      const tooltipRefs = oldMap[tooltipId] ?? new Set()\n      refs.forEach((ref) => tooltipRefs.add(ref))\n      // create new object to trigger re-render\n      return { ...oldMap, [tooltipId]: new Set(tooltipRefs) }\n    })\n  }\n\n  const detach = (tooltipId: string, ...refs: AnchorRef[]) => {\n    setAnchorRefMap((oldMap) => {\n      const tooltipRefs = oldMap[tooltipId]\n      if (!tooltipRefs) {\n        // tooltip not found\n        // maybe thow error?\n        return oldMap\n      }\n      refs.forEach((ref) => tooltipRefs.delete(ref))\n      // create new object to trigger re-render\n      return { ...oldMap }\n    })\n  }\n\n  const setActiveAnchor = (tooltipId: string, ref: React.RefObject<HTMLElement>) => {\n    setActiveAnchorMap((oldMap) => {\n      if (oldMap[tooltipId]?.current === ref.current) {\n        return oldMap\n      }\n      // create new object to trigger re-render\n      return { ...oldMap, [tooltipId]: ref }\n    })\n  }\n\n  const getTooltipData = useCallback(\n    (tooltipId = DEFAULT_TOOLTIP_ID) => ({\n      anchorRefs: anchorRefMap[tooltipId] ?? new Set(),\n      activeAnchor: activeAnchorMap[tooltipId] ?? { current: null },\n      attach: (...refs: AnchorRef[]) => attach(tooltipId, ...refs),\n      detach: (...refs: AnchorRef[]) => detach(tooltipId, ...refs),\n      setActiveAnchor: (ref: AnchorRef) => setActiveAnchor(tooltipId, ref),\n    }),\n    [anchorRefMap, activeAnchorMap, attach, detach],\n  )\n\n  const context = useMemo(() => {\n    return {\n      getTooltipData,\n    }\n  }, [getTooltipData])\n\n  return <TooltipContext.Provider value={context}>{children}</TooltipContext.Provider>\n}\n\nexport function useTooltip(tooltipId = DEFAULT_TOOLTIP_ID) {\n  return useContext(TooltipContext).getTooltipData(tooltipId)\n}\n\nexport default TooltipProvider\n","import React, { useEffect, useState, useRef, useCallback, useImperativeHandle } from 'react'\nimport { autoUpdate } from '@floating-ui/dom'\nimport classNames from 'classnames'\nimport {\n  debounce,\n  deepEqual,\n  useIsomorphicLayoutEffect,\n  getScrollParent,\n  computeTooltipPosition,\n  cssTimeToMs,\n  clearTimeoutRef,\n} from 'utils'\nimport type { IComputedPosition } from 'utils'\nimport { useTooltip } from 'components/TooltipProvider'\nimport coreStyles from './core-styles.module.css'\nimport styles from './styles.module.css'\nimport type {\n  AnchorCloseEvents,\n  AnchorOpenEvents,\n  GlobalCloseEvents,\n  IPosition,\n  ITooltip,\n  TooltipImperativeOpenOptions,\n} from './TooltipTypes'\n\nconst Tooltip = ({\n  // props\n  forwardRef,\n  id,\n  className,\n  classNameArrow,\n  variant = 'dark',\n  anchorId,\n  anchorSelect,\n  place = 'top',\n  offset = 10,\n  events = ['hover'],\n  openOnClick = false,\n  positionStrategy = 'absolute',\n  middlewares,\n  wrapper: WrapperElement,\n  delayShow = 0,\n  delayHide = 0,\n  float = false,\n  hidden = false,\n  noArrow = false,\n  clickable = false,\n  closeOnEsc = false,\n  closeOnScroll = false,\n  closeOnResize = false,\n  openEvents,\n  closeEvents,\n  globalCloseEvents,\n  imperativeModeOnly,\n  style: externalStyles,\n  position,\n  afterShow,\n  afterHide,\n  disableTooltip,\n  // props handled by controller\n  content,\n  contentWrapperRef,\n  isOpen,\n  defaultIsOpen = false,\n  setIsOpen,\n  activeAnchor,\n  setActiveAnchor,\n  border,\n  opacity,\n  arrowColor,\n  arrowSize = 8,\n  role = 'tooltip',\n}: ITooltip) => {\n  const tooltipRef = useRef<HTMLElement>(null)\n  const tooltipArrowRef = useRef<HTMLElement>(null)\n  const tooltipShowDelayTimerRef = useRef<NodeJS.Timeout | null>(null)\n  const tooltipHideDelayTimerRef = useRef<NodeJS.Timeout | null>(null)\n  const missedTransitionTimerRef = useRef<NodeJS.Timeout | null>(null)\n  const [computedPosition, setComputedPosition] = useState<IComputedPosition>({\n    tooltipStyles: {},\n    tooltipArrowStyles: {},\n    place,\n  })\n  const [show, setShow] = useState(false)\n  const [rendered, setRendered] = useState(false)\n  const [imperativeOptions, setImperativeOptions] = useState<TooltipImperativeOpenOptions | null>(\n    null,\n  )\n  const wasShowing = useRef(false)\n  const lastFloatPosition = useRef<IPosition | null>(null)\n  /**\n   * @todo Remove this in a future version (provider/wrapper method is deprecated)\n   */\n  const { anchorRefs, setActiveAnchor: setProviderActiveAnchor } = useTooltip(id)\n  const hoveringTooltip = useRef(false)\n  const [anchorsBySelect, setAnchorsBySelect] = useState<HTMLElement[]>([])\n  const mounted = useRef(false)\n\n  /**\n   * @todo Update when deprecated stuff gets removed.\n   */\n  const shouldOpenOnClick = openOnClick || events.includes('click')\n  const hasClickEvent =\n    shouldOpenOnClick || openEvents?.click || openEvents?.dblclick || openEvents?.mousedown\n  const actualOpenEvents: AnchorOpenEvents = openEvents\n    ? { ...openEvents }\n    : {\n        mouseover: true,\n        focus: true,\n        mouseenter: false,\n        click: false,\n        dblclick: false,\n        mousedown: false,\n      }\n  if (!openEvents && shouldOpenOnClick) {\n    Object.assign(actualOpenEvents, {\n      mouseenter: false,\n      focus: false,\n      mouseover: false,\n      click: true,\n    })\n  }\n  const actualCloseEvents: AnchorCloseEvents = closeEvents\n    ? { ...closeEvents }\n    : {\n        mouseout: true,\n        blur: true,\n        mouseleave: false,\n        click: false,\n        dblclick: false,\n        mouseup: false,\n      }\n  if (!closeEvents && shouldOpenOnClick) {\n    Object.assign(actualCloseEvents, {\n      mouseleave: false,\n      blur: false,\n      mouseout: false,\n    })\n  }\n  const actualGlobalCloseEvents: GlobalCloseEvents = globalCloseEvents\n    ? { ...globalCloseEvents }\n    : {\n        escape: closeOnEsc || false,\n        scroll: closeOnScroll || false,\n        resize: closeOnResize || false,\n        clickOutsideAnchor: hasClickEvent || false,\n      }\n\n  if (imperativeModeOnly) {\n    Object.assign(actualOpenEvents, {\n      mouseover: false,\n      focus: false,\n      mouseenter: false,\n      click: false,\n      dblclick: false,\n      mousedown: false,\n    })\n    Object.assign(actualCloseEvents, {\n      mouseout: false,\n      blur: false,\n      mouseleave: false,\n      click: false,\n      dblclick: false,\n      mouseup: false,\n    })\n    Object.assign(actualGlobalCloseEvents, {\n      escape: false,\n      scroll: false,\n      resize: false,\n      clickOutsideAnchor: false,\n    })\n  }\n\n  /**\n   * useLayoutEffect runs before useEffect,\n   * but should be used carefully because of caveats\n   * https://beta.reactjs.org/reference/react/useLayoutEffect#caveats\n   */\n  useIsomorphicLayoutEffect(() => {\n    mounted.current = true\n    return () => {\n      mounted.current = false\n    }\n  }, [])\n\n  const handleShow = (value: boolean) => {\n    if (!mounted.current) {\n      return\n    }\n    if (value) {\n      setRendered(true)\n    }\n    /**\n     * wait for the component to render and calculate position\n     * before actually showing\n     */\n    setTimeout(() => {\n      if (!mounted.current) {\n        return\n      }\n      setIsOpen?.(value)\n      if (isOpen === undefined) {\n        setShow(value)\n      }\n    }, 10)\n  }\n\n  /**\n   * this replicates the effect from `handleShow()`\n   * when `isOpen` is changed from outside\n   */\n  useEffect(() => {\n    if (isOpen === undefined) {\n      return () => null\n    }\n    if (isOpen) {\n      setRendered(true)\n    }\n    const timeout = setTimeout(() => {\n      setShow(isOpen)\n    }, 10)\n    return () => {\n      clearTimeout(timeout)\n    }\n  }, [isOpen])\n\n  useEffect(() => {\n    if (show === wasShowing.current) {\n      return\n    }\n    clearTimeoutRef(missedTransitionTimerRef)\n    wasShowing.current = show\n    if (show) {\n      afterShow?.()\n    } else {\n      /**\n       * see `onTransitionEnd` on tooltip wrapper\n       */\n      const style = getComputedStyle(document.body)\n      const transitionShowDelay = cssTimeToMs(style.getPropertyValue('--rt-transition-show-delay'))\n      missedTransitionTimerRef.current = setTimeout(() => {\n        /**\n         * if the tooltip switches from `show === true` to `show === false` too fast\n         * the transition never runs, so `onTransitionEnd` callback never gets fired\n         */\n        setRendered(false)\n        setImperativeOptions(null)\n        afterHide?.()\n        // +25ms just to make sure `onTransitionEnd` (if it gets fired) has time to run\n      }, transitionShowDelay + 25)\n    }\n  }, [show])\n\n  const handleComputedPosition = (newComputedPosition: IComputedPosition) => {\n    setComputedPosition((oldComputedPosition) =>\n      deepEqual(oldComputedPosition, newComputedPosition)\n        ? oldComputedPosition\n        : newComputedPosition,\n    )\n  }\n\n  const handleShowTooltipDelayed = (delay = delayShow) => {\n    clearTimeoutRef(tooltipShowDelayTimerRef)\n\n    if (rendered) {\n      // if the tooltip is already rendered, ignore delay\n      handleShow(true)\n      return\n    }\n\n    tooltipShowDelayTimerRef.current = setTimeout(() => {\n      handleShow(true)\n    }, delay)\n  }\n\n  const handleHideTooltipDelayed = (delay = delayHide) => {\n    clearTimeoutRef(tooltipHideDelayTimerRef)\n\n    tooltipHideDelayTimerRef.current = setTimeout(() => {\n      if (hoveringTooltip.current) {\n        return\n      }\n      handleShow(false)\n    }, delay)\n  }\n\n  const handleShowTooltip = (event?: Event) => {\n    if (!event) {\n      return\n    }\n    const target = (event.currentTarget ?? event.target) as HTMLElement | null\n    if (!target?.isConnected) {\n      /**\n       * this happens when the target is removed from the DOM\n       * at the same time the tooltip gets triggered\n       */\n      setActiveAnchor(null)\n      setProviderActiveAnchor({ current: null })\n      return\n    }\n    if (delayShow) {\n      handleShowTooltipDelayed()\n    } else {\n      handleShow(true)\n    }\n    setActiveAnchor(target)\n    setProviderActiveAnchor({ current: target })\n\n    clearTimeoutRef(tooltipHideDelayTimerRef)\n  }\n\n  const handleHideTooltip = () => {\n    if (clickable) {\n      // allow time for the mouse to reach the tooltip, in case there's a gap\n      handleHideTooltipDelayed(delayHide || 100)\n    } else if (delayHide) {\n      handleHideTooltipDelayed()\n    } else {\n      handleShow(false)\n    }\n\n    clearTimeoutRef(tooltipShowDelayTimerRef)\n  }\n\n  const handleTooltipPosition = ({ x, y }: IPosition) => {\n    const virtualElement = {\n      getBoundingClientRect() {\n        return {\n          x,\n          y,\n          width: 0,\n          height: 0,\n          top: y,\n          left: x,\n          right: x,\n          bottom: y,\n        }\n      },\n    } as Element\n    computeTooltipPosition({\n      place: imperativeOptions?.place ?? place,\n      offset,\n      elementReference: virtualElement,\n      tooltipReference: tooltipRef.current,\n      tooltipArrowReference: tooltipArrowRef.current,\n      strategy: positionStrategy,\n      middlewares,\n      border,\n      arrowSize,\n    }).then((computedStylesData) => {\n      handleComputedPosition(computedStylesData)\n    })\n  }\n\n  const handlePointerMove = (event?: Event) => {\n    if (!event) {\n      return\n    }\n    const mouseEvent = event as MouseEvent\n    const mousePosition = {\n      x: mouseEvent.clientX,\n      y: mouseEvent.clientY,\n    }\n    handleTooltipPosition(mousePosition)\n    lastFloatPosition.current = mousePosition\n  }\n\n  const handleClickOutsideAnchors = (event: MouseEvent) => {\n    if (!show) {\n      return\n    }\n    const target = event.target as HTMLElement\n    if (!target.isConnected) {\n      return\n    }\n    if (tooltipRef.current?.contains(target)) {\n      return\n    }\n    const anchorById = document.querySelector<HTMLElement>(`[id='${anchorId}']`)\n    const anchors = [anchorById, ...anchorsBySelect]\n    if (anchors.some((anchor) => anchor?.contains(target))) {\n      return\n    }\n    handleShow(false)\n    clearTimeoutRef(tooltipShowDelayTimerRef)\n  }\n\n  // debounce handler to prevent call twice when\n  // mouse enter and focus events being triggered toggether\n  const internalDebouncedHandleShowTooltip = debounce(handleShowTooltip, 50, true)\n  const internalDebouncedHandleHideTooltip = debounce(handleHideTooltip, 50, true)\n  // If either of the functions is called while the other is still debounced,\n  // reset the timeout. Otherwise if there is a sub-50ms (leave A, enter B, leave B)\n  // sequence of events, the tooltip will stay open because the hide debounce\n  // from leave A prevented the leave B event from calling it, leaving the\n  // tooltip visible.\n  const debouncedHandleShowTooltip = (e?: Event) => {\n    internalDebouncedHandleHideTooltip.cancel()\n    internalDebouncedHandleShowTooltip(e)\n  }\n  const debouncedHandleHideTooltip = () => {\n    internalDebouncedHandleShowTooltip.cancel()\n    internalDebouncedHandleHideTooltip()\n  }\n\n  const updateTooltipPosition = useCallback(() => {\n    const actualPosition = imperativeOptions?.position ?? position\n    if (actualPosition) {\n      // if `position` is set, override regular and `float` positioning\n      handleTooltipPosition(actualPosition)\n      return\n    }\n\n    if (float) {\n      if (lastFloatPosition.current) {\n        /*\n          Without this, changes to `content`, `place`, `offset`, ..., will only\n          trigger a position calculation after a `mousemove` event.\n\n          To see why this matters, comment this line, run `yarn dev` and click the\n          \"Hover me!\" anchor.\n        */\n        handleTooltipPosition(lastFloatPosition.current)\n      }\n      // if `float` is set, override regular positioning\n      return\n    }\n\n    if (!activeAnchor?.isConnected) {\n      return\n    }\n\n    computeTooltipPosition({\n      place: imperativeOptions?.place ?? place,\n      offset,\n      elementReference: activeAnchor,\n      tooltipReference: tooltipRef.current,\n      tooltipArrowReference: tooltipArrowRef.current,\n      strategy: positionStrategy,\n      middlewares,\n      border,\n      arrowSize,\n    }).then((computedStylesData) => {\n      if (!mounted.current) {\n        // invalidate computed positions after remount\n        return\n      }\n      handleComputedPosition(computedStylesData)\n    })\n  }, [\n    show,\n    activeAnchor,\n    content,\n    externalStyles,\n    place,\n    imperativeOptions?.place,\n    offset,\n    positionStrategy,\n    position,\n    imperativeOptions?.position,\n    float,\n    arrowSize,\n  ])\n\n  useEffect(() => {\n    const elementRefs = new Set(anchorRefs)\n\n    anchorsBySelect.forEach((anchor) => {\n      if (disableTooltip?.(anchor)) {\n        return\n      }\n      elementRefs.add({ current: anchor })\n    })\n\n    const anchorById = document.querySelector<HTMLElement>(`[id='${anchorId}']`)\n    if (anchorById && !disableTooltip?.(anchorById)) {\n      elementRefs.add({ current: anchorById })\n    }\n\n    const handleScrollResize = () => {\n      handleShow(false)\n    }\n\n    const anchorScrollParent = getScrollParent(activeAnchor)\n    const tooltipScrollParent = getScrollParent(tooltipRef.current)\n\n    if (actualGlobalCloseEvents.scroll) {\n      window.addEventListener('scroll', handleScrollResize)\n      anchorScrollParent?.addEventListener('scroll', handleScrollResize)\n      tooltipScrollParent?.addEventListener('scroll', handleScrollResize)\n    }\n    let updateTooltipCleanup: null | (() => void) = null\n    if (actualGlobalCloseEvents.resize) {\n      window.addEventListener('resize', handleScrollResize)\n    } else if (activeAnchor && tooltipRef.current) {\n      updateTooltipCleanup = autoUpdate(\n        activeAnchor as HTMLElement,\n        tooltipRef.current as HTMLElement,\n        updateTooltipPosition,\n        {\n          ancestorResize: true,\n          elementResize: true,\n          layoutShift: true,\n        },\n      )\n    }\n\n    const handleEsc = (event: KeyboardEvent) => {\n      if (event.key !== 'Escape') {\n        return\n      }\n      handleShow(false)\n    }\n    if (actualGlobalCloseEvents.escape) {\n      window.addEventListener('keydown', handleEsc)\n    }\n\n    if (actualGlobalCloseEvents.clickOutsideAnchor) {\n      window.addEventListener('click', handleClickOutsideAnchors)\n    }\n\n    const enabledEvents: { event: string; listener: (event?: Event) => void }[] = []\n\n    const activeAnchorContainsTarget = (event?: Event): boolean =>\n      Boolean(event?.target && activeAnchor?.contains(event.target as HTMLElement))\n    const handleClickOpenTooltipAnchor = (event?: Event) => {\n      if (show && activeAnchorContainsTarget(event)) {\n        /**\n         * ignore clicking the anchor that was used to open the tooltip.\n         * this avoids conflict with the click close event.\n         */\n        return\n      }\n      handleShowTooltip(event)\n    }\n    const handleClickCloseTooltipAnchor = (event?: Event) => {\n      if (!show || !activeAnchorContainsTarget(event)) {\n        /**\n         * ignore clicking the anchor that was NOT used to open the tooltip.\n         * this avoids closing the tooltip when clicking on a\n         * new anchor with the tooltip already open.\n         */\n        return\n      }\n      handleHideTooltip()\n    }\n\n    const regularEvents = ['mouseover', 'mouseout', 'mouseenter', 'mouseleave', 'focus', 'blur']\n    const clickEvents = ['click', 'dblclick', 'mousedown', 'mouseup']\n\n    Object.entries(actualOpenEvents).forEach(([event, enabled]) => {\n      if (!enabled) {\n        return\n      }\n      if (regularEvents.includes(event)) {\n        enabledEvents.push({ event, listener: debouncedHandleShowTooltip })\n      } else if (clickEvents.includes(event)) {\n        enabledEvents.push({ event, listener: handleClickOpenTooltipAnchor })\n      } else {\n        // never happens\n      }\n    })\n\n    Object.entries(actualCloseEvents).forEach(([event, enabled]) => {\n      if (!enabled) {\n        return\n      }\n      if (regularEvents.includes(event)) {\n        enabledEvents.push({ event, listener: debouncedHandleHideTooltip })\n      } else if (clickEvents.includes(event)) {\n        enabledEvents.push({ event, listener: handleClickCloseTooltipAnchor })\n      } else {\n        // never happens\n      }\n    })\n\n    if (float) {\n      enabledEvents.push({\n        event: 'pointermove',\n        listener: handlePointerMove,\n      })\n    }\n\n    const handleMouseOverTooltip = () => {\n      hoveringTooltip.current = true\n    }\n    const handleMouseOutTooltip = () => {\n      hoveringTooltip.current = false\n      handleHideTooltip()\n    }\n\n    const addHoveringTooltipListeners =\n      clickable && (actualCloseEvents.mouseout || actualCloseEvents.mouseleave)\n    if (addHoveringTooltipListeners) {\n      // used to keep the tooltip open when hovering from anchor to tooltip.\n      // only relevant if either `mouseout`/`mouseleave` is in use\n      tooltipRef.current?.addEventListener('mouseover', handleMouseOverTooltip)\n      tooltipRef.current?.addEventListener('mouseout', handleMouseOutTooltip)\n    }\n\n    enabledEvents.forEach(({ event, listener }) => {\n      elementRefs.forEach((ref) => {\n        ref.current?.addEventListener(event, listener)\n      })\n    })\n\n    return () => {\n      if (actualGlobalCloseEvents.scroll) {\n        window.removeEventListener('scroll', handleScrollResize)\n        anchorScrollParent?.removeEventListener('scroll', handleScrollResize)\n        tooltipScrollParent?.removeEventListener('scroll', handleScrollResize)\n      }\n      if (actualGlobalCloseEvents.resize) {\n        window.removeEventListener('resize', handleScrollResize)\n      } else {\n        updateTooltipCleanup?.()\n      }\n      if (actualGlobalCloseEvents.clickOutsideAnchor) {\n        window.removeEventListener('click', handleClickOutsideAnchors)\n      }\n      if (actualGlobalCloseEvents.escape) {\n        window.removeEventListener('keydown', handleEsc)\n      }\n      if (addHoveringTooltipListeners) {\n        tooltipRef.current?.removeEventListener('mouseover', handleMouseOverTooltip)\n        tooltipRef.current?.removeEventListener('mouseout', handleMouseOutTooltip)\n      }\n      enabledEvents.forEach(({ event, listener }) => {\n        elementRefs.forEach((ref) => {\n          ref.current?.removeEventListener(event, listener)\n        })\n      })\n    }\n    /**\n     * rendered is also a dependency to ensure anchor observers are re-registered\n     * since `tooltipRef` becomes stale after removing/adding the tooltip to the DOM\n     */\n  }, [\n    activeAnchor,\n    updateTooltipPosition,\n    rendered,\n    anchorRefs,\n    anchorsBySelect,\n    // the effect uses the `actual*Events` objects, but this should work\n    openEvents,\n    closeEvents,\n    globalCloseEvents,\n    shouldOpenOnClick,\n    delayShow,\n    delayHide,\n  ])\n\n  useEffect(() => {\n    let selector = imperativeOptions?.anchorSelect ?? anchorSelect ?? ''\n    if (!selector && id) {\n      selector = `[data-tooltip-id='${id.replace(/'/g, \"\\\\'\")}']`\n    }\n    const documentObserverCallback: MutationCallback = (mutationList) => {\n      const newAnchors: HTMLElement[] = []\n      const removedAnchors: HTMLElement[] = []\n      mutationList.forEach((mutation) => {\n        if (mutation.type === 'attributes' && mutation.attributeName === 'data-tooltip-id') {\n          const newId = (mutation.target as HTMLElement).getAttribute('data-tooltip-id')\n          if (newId === id) {\n            newAnchors.push(mutation.target as HTMLElement)\n          } else if (mutation.oldValue === id) {\n            // data-tooltip-id has now been changed, so we need to remove this anchor\n            removedAnchors.push(mutation.target as HTMLElement)\n          }\n        }\n        if (mutation.type !== 'childList') {\n          return\n        }\n        if (activeAnchor) {\n          const elements = [...mutation.removedNodes].filter((node) => node.nodeType === 1)\n          if (selector) {\n            try {\n              removedAnchors.push(\n                // the element itself is an anchor\n                ...(elements.filter((element) =>\n                  (element as HTMLElement).matches(selector),\n                ) as HTMLElement[]),\n              )\n              removedAnchors.push(\n                // the element has children which are anchors\n                ...elements.flatMap(\n                  (element) =>\n                    [...(element as HTMLElement).querySelectorAll(selector)] as HTMLElement[],\n                ),\n              )\n            } catch {\n              /**\n               * invalid CSS selector.\n               * already warned on tooltip controller\n               */\n            }\n          }\n          elements.some((node) => {\n            if (node?.contains?.(activeAnchor)) {\n              setRendered(false)\n              handleShow(false)\n              setActiveAnchor(null)\n              clearTimeoutRef(tooltipShowDelayTimerRef)\n              clearTimeoutRef(tooltipHideDelayTimerRef)\n              return true\n            }\n            return false\n          })\n        }\n        if (!selector) {\n          return\n        }\n        try {\n          const elements = [...mutation.addedNodes].filter((node) => node.nodeType === 1)\n          newAnchors.push(\n            // the element itself is an anchor\n            ...(elements.filter((element) =>\n              (element as HTMLElement).matches(selector),\n            ) as HTMLElement[]),\n          )\n          newAnchors.push(\n            // the element has children which are anchors\n            ...elements.flatMap(\n              (element) =>\n                [...(element as HTMLElement).querySelectorAll(selector)] as HTMLElement[],\n            ),\n          )\n        } catch {\n          /**\n           * invalid CSS selector.\n           * already warned on tooltip controller\n           */\n        }\n      })\n      if (newAnchors.length || removedAnchors.length) {\n        setAnchorsBySelect((anchors) => [\n          ...anchors.filter((anchor) => !removedAnchors.includes(anchor)),\n          ...newAnchors,\n        ])\n      }\n    }\n    const documentObserver = new MutationObserver(documentObserverCallback)\n    // watch for anchor being removed from the DOM\n    documentObserver.observe(document.body, {\n      childList: true,\n      subtree: true,\n      attributes: true,\n      attributeFilter: ['data-tooltip-id'],\n      // to track the prev value if we need to remove anchor when data-tooltip-id gets changed\n      attributeOldValue: true,\n    })\n    return () => {\n      documentObserver.disconnect()\n    }\n  }, [id, anchorSelect, imperativeOptions?.anchorSelect, activeAnchor])\n\n  useEffect(() => {\n    updateTooltipPosition()\n  }, [updateTooltipPosition])\n\n  useEffect(() => {\n    if (!contentWrapperRef?.current) {\n      return () => null\n    }\n    const contentObserver = new ResizeObserver(() => {\n      setTimeout(() => updateTooltipPosition())\n    })\n    contentObserver.observe(contentWrapperRef.current)\n    return () => {\n      contentObserver.disconnect()\n    }\n  }, [content, contentWrapperRef?.current])\n\n  useEffect(() => {\n    const anchorById = document.querySelector<HTMLElement>(`[id='${anchorId}']`)\n    const anchors = [...anchorsBySelect, anchorById]\n    if (!activeAnchor || !anchors.includes(activeAnchor)) {\n      /**\n       * if there is no active anchor,\n       * or if the current active anchor is not amongst the allowed ones,\n       * reset it\n       */\n      setActiveAnchor(anchorsBySelect[0] ?? anchorById)\n    }\n  }, [anchorId, anchorsBySelect, activeAnchor])\n\n  useEffect(() => {\n    if (defaultIsOpen) {\n      handleShow(true)\n    }\n    return () => {\n      clearTimeoutRef(tooltipShowDelayTimerRef)\n      clearTimeoutRef(tooltipHideDelayTimerRef)\n    }\n  }, [])\n\n  useEffect(() => {\n    let selector = imperativeOptions?.anchorSelect ?? anchorSelect\n    if (!selector && id) {\n      selector = `[data-tooltip-id='${id.replace(/'/g, \"\\\\'\")}']`\n    }\n    if (!selector) {\n      return\n    }\n    try {\n      const anchors = Array.from(document.querySelectorAll<HTMLElement>(selector))\n      setAnchorsBySelect(anchors)\n    } catch {\n      // warning was already issued in the controller\n      setAnchorsBySelect([])\n    }\n  }, [id, anchorSelect, imperativeOptions?.anchorSelect])\n\n  useEffect(() => {\n    if (tooltipShowDelayTimerRef.current) {\n      /**\n       * if the delay changes while the tooltip is waiting to show,\n       * reset the timer with the new delay\n       */\n      clearTimeoutRef(tooltipShowDelayTimerRef)\n      handleShowTooltipDelayed(delayShow)\n    }\n  }, [delayShow])\n\n  const actualContent = imperativeOptions?.content ?? content\n  const canShow = show && Object.keys(computedPosition.tooltipStyles).length > 0\n\n  useImperativeHandle(forwardRef, () => ({\n    open: (options) => {\n      if (options?.anchorSelect) {\n        try {\n          document.querySelector(options.anchorSelect)\n        } catch {\n          if (!process.env.NODE_ENV || process.env.NODE_ENV !== 'production') {\n            // eslint-disable-next-line no-console\n            console.warn(`[react-tooltip] \"${options.anchorSelect}\" is not a valid CSS selector`)\n          }\n          return\n        }\n      }\n      setImperativeOptions(options ?? null)\n      if (options?.delay) {\n        handleShowTooltipDelayed(options.delay)\n      } else {\n        handleShow(true)\n      }\n    },\n    close: (options) => {\n      if (options?.delay) {\n        handleHideTooltipDelayed(options.delay)\n      } else {\n        handleShow(false)\n      }\n    },\n    activeAnchor,\n    place: computedPosition.place,\n    isOpen: Boolean(rendered && !hidden && actualContent && canShow),\n  }))\n\n  return rendered && !hidden && actualContent ? (\n    <WrapperElement\n      id={id}\n      role={role}\n      className={classNames(\n        'react-tooltip',\n        coreStyles['tooltip'],\n        styles['tooltip'],\n        styles[variant],\n        className,\n        `react-tooltip__place-${computedPosition.place}`,\n        coreStyles[canShow ? 'show' : 'closing'],\n        canShow ? 'react-tooltip__show' : 'react-tooltip__closing',\n        positionStrategy === 'fixed' && coreStyles['fixed'],\n        clickable && coreStyles['clickable'],\n      )}\n      onTransitionEnd={(event: TransitionEvent) => {\n        clearTimeoutRef(missedTransitionTimerRef)\n        if (show || event.propertyName !== 'opacity') {\n          return\n        }\n        setRendered(false)\n        setImperativeOptions(null)\n        afterHide?.()\n      }}\n      style={{\n        ...externalStyles,\n        ...computedPosition.tooltipStyles,\n        opacity: opacity !== undefined && canShow ? opacity : undefined,\n      }}\n      ref={tooltipRef}\n    >\n      {actualContent}\n      <WrapperElement\n        className={classNames(\n          'react-tooltip-arrow',\n          coreStyles['arrow'],\n          styles['arrow'],\n          classNameArrow,\n          noArrow && coreStyles['noArrow'],\n        )}\n        style={{\n          ...computedPosition.tooltipArrowStyles,\n          background: arrowColor\n            ? `linear-gradient(to right bottom, transparent 50%, ${arrowColor} 50%)`\n            : undefined,\n          '--rt-arrow-size': `${arrowSize}px`,\n        }}\n        ref={tooltipArrowRef}\n      />\n    </WrapperElement>\n  ) : null\n}\n\nexport default Tooltip\n","const cssTimeToMs = (time: string): number => {\n  const match = time.match(/^([\\d.]+)(ms|s)$/)\n  if (!match) {\n    return 0\n  }\n  const [, amount, unit] = match\n  return Number(amount) * (unit === 'ms' ? 1 : 1000)\n}\n\nexport default cssTimeToMs\n","/* eslint-disable react/no-danger */\nimport React from 'react'\nimport type { ITooltipContent } from './TooltipContentTypes'\n\nconst TooltipContent = ({ content }: ITooltipContent) => {\n  return <span dangerouslySetInnerHTML={{ __html: content }} />\n}\n\nexport default TooltipContent\n","import React, { useEffect, useRef, useState } from 'react'\nimport { Tooltip } from 'components/Tooltip'\nimport type {\n  EventsType,\n  PositionStrategy,\n  PlacesType,\n  VariantType,\n  WrapperType,\n  DataAttribute,\n  ITooltip,\n  ChildrenType,\n  TooltipRefProps,\n} from 'components/Tooltip/TooltipTypes'\nimport { useTooltip } from 'components/TooltipProvider'\nimport { TooltipContent } from 'components/TooltipContent'\nimport { cssSupports } from 'utils'\nimport classNames from 'classnames'\nimport type { ITooltipController } from './TooltipControllerTypes'\n\nconst TooltipController = React.forwardRef<TooltipRefProps, ITooltipController>(\n  (\n    {\n      id,\n      anchorId,\n      anchorSelect,\n      content,\n      html,\n      render,\n      className,\n      classNameArrow,\n      variant = 'dark',\n      place = 'top',\n      offset = 10,\n      wrapper = 'div',\n      children = null,\n      events = ['hover'],\n      openOnClick = false,\n      positionStrategy = 'absolute',\n      middlewares,\n      delayShow = 0,\n      delayHide = 0,\n      float = false,\n      hidden = false,\n      noArrow = false,\n      clickable = false,\n      closeOnEsc = false,\n      closeOnScroll = false,\n      closeOnResize = false,\n      openEvents,\n      closeEvents,\n      globalCloseEvents,\n      imperativeModeOnly = false,\n      style,\n      position,\n      isOpen,\n      defaultIsOpen = false,\n      disableStyleInjection = false,\n      border,\n      opacity,\n      arrowColor,\n      arrowSize,\n      setIsOpen,\n      afterShow,\n      afterHide,\n      disableTooltip,\n      role = 'tooltip',\n    }: ITooltipController,\n    ref,\n  ) => {\n    const [tooltipContent, setTooltipContent] = useState(content)\n    const [tooltipHtml, setTooltipHtml] = useState(html)\n    const [tooltipPlace, setTooltipPlace] = useState(place)\n    const [tooltipVariant, setTooltipVariant] = useState(variant)\n    const [tooltipOffset, setTooltipOffset] = useState(offset)\n    const [tooltipDelayShow, setTooltipDelayShow] = useState(delayShow)\n    const [tooltipDelayHide, setTooltipDelayHide] = useState(delayHide)\n    const [tooltipFloat, setTooltipFloat] = useState(float)\n    const [tooltipHidden, setTooltipHidden] = useState(hidden)\n    const [tooltipWrapper, setTooltipWrapper] = useState<WrapperType>(wrapper)\n    const [tooltipEvents, setTooltipEvents] = useState(events)\n    const [tooltipPositionStrategy, setTooltipPositionStrategy] = useState(positionStrategy)\n    const [tooltipClassName, setTooltipClassName] = useState<string | null>(null)\n    const [activeAnchor, setActiveAnchor] = useState<HTMLElement | null>(null)\n    const styleInjectionRef = useRef(disableStyleInjection)\n    /**\n     * @todo Remove this in a future version (provider/wrapper method is deprecated)\n     */\n    const { anchorRefs, activeAnchor: providerActiveAnchor } = useTooltip(id)\n\n    const getDataAttributesFromAnchorElement = (elementReference: HTMLElement) => {\n      const dataAttributes = elementReference?.getAttributeNames().reduce((acc, name) => {\n        if (name.startsWith('data-tooltip-')) {\n          const parsedAttribute = name.replace(/^data-tooltip-/, '') as DataAttribute\n          acc[parsedAttribute] = elementReference?.getAttribute(name) ?? null\n        }\n        return acc\n      }, {} as Record<DataAttribute, string | null>)\n\n      return dataAttributes\n    }\n\n    const applyAllDataAttributesFromAnchorElement = (\n      dataAttributes: Record<string, string | null>,\n    ) => {\n      const handleDataAttributes: Record<DataAttribute, (value: string | null) => void> = {\n        place: (value) => {\n          setTooltipPlace((value as PlacesType) ?? place)\n        },\n        content: (value) => {\n          setTooltipContent(value ?? content)\n        },\n        html: (value) => {\n          setTooltipHtml(value ?? html)\n        },\n        variant: (value) => {\n          setTooltipVariant((value as VariantType) ?? variant)\n        },\n        offset: (value) => {\n          setTooltipOffset(value === null ? offset : Number(value))\n        },\n        wrapper: (value) => {\n          setTooltipWrapper((value as WrapperType) ?? wrapper)\n        },\n        events: (value) => {\n          const parsed = value?.split(' ') as EventsType[]\n          setTooltipEvents(parsed ?? events)\n        },\n        'position-strategy': (value) => {\n          setTooltipPositionStrategy((value as PositionStrategy) ?? positionStrategy)\n        },\n        'delay-show': (value) => {\n          setTooltipDelayShow(value === null ? delayShow : Number(value))\n        },\n        'delay-hide': (value) => {\n          setTooltipDelayHide(value === null ? delayHide : Number(value))\n        },\n        float: (value) => {\n          setTooltipFloat(value === null ? float : value === 'true')\n        },\n        hidden: (value) => {\n          setTooltipHidden(value === null ? hidden : value === 'true')\n        },\n        'class-name': (value) => {\n          setTooltipClassName(value)\n        },\n      }\n      // reset unset data attributes to default values\n      // without this, data attributes from the last active anchor will still be used\n      Object.values(handleDataAttributes).forEach((handler) => handler(null))\n      Object.entries(dataAttributes).forEach(([key, value]) => {\n        handleDataAttributes[key as DataAttribute]?.(value)\n      })\n    }\n\n    useEffect(() => {\n      setTooltipContent(content)\n    }, [content])\n\n    useEffect(() => {\n      setTooltipHtml(html)\n    }, [html])\n\n    useEffect(() => {\n      setTooltipPlace(place)\n    }, [place])\n\n    useEffect(() => {\n      setTooltipVariant(variant)\n    }, [variant])\n\n    useEffect(() => {\n      setTooltipOffset(offset)\n    }, [offset])\n\n    useEffect(() => {\n      setTooltipDelayShow(delayShow)\n    }, [delayShow])\n\n    useEffect(() => {\n      setTooltipDelayHide(delayHide)\n    }, [delayHide])\n\n    useEffect(() => {\n      setTooltipFloat(float)\n    }, [float])\n\n    useEffect(() => {\n      setTooltipHidden(hidden)\n    }, [hidden])\n\n    useEffect(() => {\n      setTooltipPositionStrategy(positionStrategy)\n    }, [positionStrategy])\n\n    useEffect(() => {\n      if (styleInjectionRef.current === disableStyleInjection) {\n        return\n      }\n      /* c8 ignore start */\n      if (process.env.NODE_ENV !== 'production') {\n        // eslint-disable-next-line no-console\n        console.warn('[react-tooltip] Do not change `disableStyleInjection` dynamically.')\n      }\n      /* c8 ignore end */\n    }, [disableStyleInjection])\n\n    useEffect(() => {\n      if (typeof window !== 'undefined') {\n        window.dispatchEvent(\n          new CustomEvent('react-tooltip-inject-styles', {\n            detail: {\n              disableCore: disableStyleInjection === 'core',\n              disableBase: disableStyleInjection,\n            },\n          }),\n        )\n      }\n    }, [])\n\n    useEffect(() => {\n      const elementRefs = new Set(anchorRefs)\n\n      let selector = anchorSelect\n      if (!selector && id) {\n        selector = `[data-tooltip-id='${id.replace(/'/g, \"\\\\'\")}']`\n      }\n      if (selector) {\n        try {\n          const anchorsBySelect = document.querySelectorAll<HTMLElement>(selector)\n          anchorsBySelect.forEach((anchor) => {\n            elementRefs.add({ current: anchor })\n          })\n        } catch {\n          /* c8 ignore start */\n          if (!process.env.NODE_ENV || process.env.NODE_ENV !== 'production') {\n            // eslint-disable-next-line no-console\n            console.warn(`[react-tooltip] \"${selector}\" is not a valid CSS selector`)\n          }\n          /* c8 ignore end */\n        }\n      }\n\n      const anchorById = document.querySelector<HTMLElement>(`[id='${anchorId}']`)\n      if (anchorById) {\n        elementRefs.add({ current: anchorById })\n      }\n\n      if (!elementRefs.size) {\n        return () => null\n      }\n\n      const anchorElement = activeAnchor ?? anchorById ?? providerActiveAnchor.current\n\n      const observerCallback: MutationCallback = (mutationList) => {\n        mutationList.forEach((mutation) => {\n          if (\n            !anchorElement ||\n            mutation.type !== 'attributes' ||\n            !mutation.attributeName?.startsWith('data-tooltip-')\n          ) {\n            return\n          }\n          // make sure to get all set attributes, since all unset attributes are reset\n          const dataAttributes = getDataAttributesFromAnchorElement(anchorElement)\n          applyAllDataAttributesFromAnchorElement(dataAttributes)\n        })\n      }\n\n      // Create an observer instance linked to the callback function\n      const observer = new MutationObserver(observerCallback)\n\n      // do not check for subtree and childrens, we only want to know attribute changes\n      // to stay watching `data-attributes-*` from anchor element\n      const observerConfig = { attributes: true, childList: false, subtree: false }\n\n      if (anchorElement) {\n        const dataAttributes = getDataAttributesFromAnchorElement(anchorElement)\n        applyAllDataAttributesFromAnchorElement(dataAttributes)\n        // Start observing the target node for configured mutations\n        observer.observe(anchorElement, observerConfig)\n      }\n\n      return () => {\n        // Remove the observer when the tooltip is destroyed\n        observer.disconnect()\n      }\n    }, [anchorRefs, providerActiveAnchor, activeAnchor, anchorId, anchorSelect])\n\n    useEffect(() => {\n      /* c8 ignore start */\n      if (process.env.NODE_ENV === 'production') {\n        return\n      }\n      /* c8 ignore end */\n      if (style?.border) {\n        // eslint-disable-next-line no-console\n        console.warn('[react-tooltip] Do not set `style.border`. Use `border` prop instead.')\n      }\n      if (border && !cssSupports('border', `${border}`)) {\n        // eslint-disable-next-line no-console\n        console.warn(`[react-tooltip] \"${border}\" is not a valid \\`border\\`.`)\n      }\n      if (style?.opacity) {\n        // eslint-disable-next-line no-console\n        console.warn('[react-tooltip] Do not set `style.opacity`. Use `opacity` prop instead.')\n      }\n      if (opacity && !cssSupports('opacity', `${opacity}`)) {\n        // eslint-disable-next-line no-console\n        console.warn(`[react-tooltip] \"${opacity}\" is not a valid \\`opacity\\`.`)\n      }\n    }, [])\n\n    /**\n     * content priority: children < render or content < html\n     * children should be lower priority so that it can be used as the \"default\" content\n     */\n    let renderedContent: ChildrenType = children\n    const contentWrapperRef = useRef<HTMLDivElement>(null)\n    if (render) {\n      const actualContent =\n        activeAnchor?.getAttribute('data-tooltip-content') || tooltipContent || null\n      const rendered = render({ content: actualContent, activeAnchor }) as React.ReactNode\n      renderedContent = rendered ? (\n        <div ref={contentWrapperRef} className=\"react-tooltip-content-wrapper\">\n          {rendered}\n        </div>\n      ) : null\n    } else if (tooltipContent) {\n      renderedContent = tooltipContent\n    }\n    if (tooltipHtml) {\n      renderedContent = <TooltipContent content={tooltipHtml} />\n    }\n\n    const props: ITooltip = {\n      forwardRef: ref,\n      id,\n      anchorId,\n      anchorSelect,\n      className: classNames(className, tooltipClassName),\n      classNameArrow,\n      content: renderedContent,\n      contentWrapperRef,\n      place: tooltipPlace,\n      variant: tooltipVariant,\n      offset: tooltipOffset,\n      wrapper: tooltipWrapper,\n      events: tooltipEvents,\n      openOnClick,\n      positionStrategy: tooltipPositionStrategy,\n      middlewares,\n      delayShow: tooltipDelayShow,\n      delayHide: tooltipDelayHide,\n      float: tooltipFloat,\n      hidden: tooltipHidden,\n      noArrow,\n      clickable,\n      closeOnEsc,\n      closeOnScroll,\n      closeOnResize,\n      openEvents,\n      closeEvents,\n      globalCloseEvents,\n      imperativeModeOnly,\n      style,\n      position,\n      isOpen,\n      defaultIsOpen,\n      border,\n      opacity,\n      arrowColor,\n      arrowSize,\n      setIsOpen,\n      afterShow,\n      afterHide,\n      disableTooltip,\n      activeAnchor,\n      setActiveAnchor: (anchor: HTMLElement | null) => setActiveAnchor(anchor),\n      role,\n    }\n\n    return <Tooltip {...props} />\n  },\n)\n\nexport default TooltipController\n","import './tokens.css'\n\nimport { injectStyle } from 'utils/handle-style'\n\nimport type {\n  ChildrenType,\n  DataAttribute,\n  EventsType,\n  PlacesType,\n  PositionStrategy,\n  VariantType,\n  WrapperType,\n  IPosition,\n  Middleware,\n  TooltipRefProps,\n} from './components/Tooltip/TooltipTypes'\nimport type { ITooltipController } from './components/TooltipController/TooltipControllerTypes'\nimport type { ITooltipWrapper } from './components/TooltipProvider/TooltipProviderTypes'\n\n// those content will be replaced in build time with the `react-tooltip.css` builded content\nconst TooltipCoreStyles = 'react-tooltip-core-css-placeholder'\nconst TooltipStyles = 'react-tooltip-css-placeholder'\n\nif (typeof window !== 'undefined') {\n  window.addEventListener('react-tooltip-inject-styles', ((\n    event: CustomEvent<{ disableCore: boolean; disableBase: boolean }>,\n  ) => {\n    if (!event.detail.disableCore) {\n      injectStyle({ css: TooltipCoreStyles, type: 'core' })\n    }\n    if (!event.detail.disableBase) {\n      injectStyle({ css: TooltipStyles, type: 'base' })\n    }\n  }) as EventListener)\n}\n\nexport { TooltipController as Tooltip } from './components/TooltipController'\nexport { TooltipProvider, TooltipWrapper } from './components/TooltipProvider'\nexport type {\n  ChildrenType,\n  DataAttribute,\n  EventsType,\n  PlacesType,\n  PositionStrategy,\n  VariantType,\n  WrapperType,\n  ITooltipController as ITooltip,\n  ITooltipWrapper,\n  IPosition,\n  Middleware,\n  TooltipRefProps,\n}\n\nexport { removeStyle } from './utils/handle-style'\n","import React, { useEffect, useRef } from 'react'\nimport classNames from 'classnames'\nimport { useTooltip } from './TooltipProvider'\nimport type { ITooltipWrapper } from './TooltipProviderTypes'\n\n/**\n * @deprecated Use the `data-tooltip-id` attribute, or the `anchorSelect` prop instead.\n * See https://react-tooltip.com/docs/getting-started\n */\nconst TooltipWrapper = ({\n  tooltipId,\n  children,\n  className,\n  place,\n  content,\n  html,\n  variant,\n  offset,\n  wrapper,\n  events,\n  positionStrategy,\n  delayShow,\n  delayHide,\n}: ITooltipWrapper) => {\n  const { attach, detach } = useTooltip(tooltipId)\n  const anchorRef = useRef<HTMLElement | null>(null)\n\n  useEffect(() => {\n    attach(anchorRef)\n    return () => {\n      detach(anchorRef)\n    }\n  }, [])\n\n  return (\n    <span\n      ref={anchorRef}\n      className={classNames('react-tooltip-wrapper', className)}\n      data-tooltip-place={place}\n      data-tooltip-content={content}\n      data-tooltip-html={html}\n      data-tooltip-variant={variant}\n      data-tooltip-offset={offset}\n      data-tooltip-wrapper={wrapper}\n      data-tooltip-events={events}\n      data-tooltip-position-strategy={positionStrategy}\n      data-tooltip-delay-show={delayShow}\n      data-tooltip-delay-hide={delayHide}\n    >\n      {children}\n    </span>\n  )\n}\n\nexport default TooltipWrapper\n"],"names":["REACT_TOOLTIP_CORE_STYLES_ID","REACT_TOOLTIP_BASE_STYLES_ID","injected","core","base","injectStyle","css","id","type","ref","document","process","_a","env","REACT_TOOLTIP_DISABLE_CORE_STYLES","_b","REACT_TOOLTIP_DISABLE_BASE_STYLES","insertAt","getElementById","head","getElementsByTagName","style","createElement","firstChild","insertBefore","appendChild","styleSheet","cssText","createTextNode","computeTooltipPosition","async","elementReference","tooltipReference","tooltipArrowReference","place","offset","offsetValue","strategy","middlewares","Number","flip","fallbackAxisSideDirection","shift","padding","border","arrowSize","tooltipStyles","tooltipArrowStyles","middleware","push","arrow","element","computePosition","placement","then","x","y","middlewareData","styles","left","top","arrowX","arrowY","staticSide","right","bottom","split","borderSide","borderBottom","borderRight","borderWidth","match","cssSupports","property","value","window","CSS","supports","debounce","func","wait","immediate","timeout","debounced","args","later","apply","this","setTimeout","clearTimeout","cancel","isObject","object","Array","isArray","deepEqual","object1","object2","length","every","val","index","keys1","Object","keys","keys2","key","isScrollable","node","HTMLElement","SVGElement","getComputedStyle","some","propertyName","getPropertyValue","getScrollParent","currentParent","parentElement","scrollingElement","documentElement","useIsomorphicLayoutEffect","useLayoutEffect","useEffect","clearTimeoutRef","current","DEFAULT_TOOLTIP_ID","DEFAULT_CONTEXT_DATA","anchorRefs","Set","activeAnchor","attach","detach","setActiveAnchor","DEFAULT_CONTEXT_DATA_WRAPPER","getTooltipData","TooltipContext","createContext","useTooltip","tooltipId","useContext","Tooltip","forwardRef","className","classNameArrow","variant","anchorId","anchorSelect","events","openOnClick","positionStrategy","wrapper","WrapperElement","delayShow","delayHide","float","hidden","noArrow","clickable","closeOnEsc","closeOnScroll","closeOnResize","openEvents","closeEvents","globalCloseEvents","imperativeModeOnly","externalStyles","position","afterShow","afterHide","disableTooltip","content","contentWrapperRef","isOpen","defaultIsOpen","setIsOpen","opacity","arrowColor","role","tooltipRef","useRef","tooltipArrowRef","tooltipShowDelayTimerRef","tooltipHideDelayTimerRef","missedTransitionTimerRef","computedPosition","setComputedPosition","useState","show","setShow","rendered","setRendered","imperativeOptions","setImperativeOptions","wasShowing","lastFloatPosition","setProviderActiveAnchor","hoveringTooltip","anchorsBySelect","setAnchorsBySelect","mounted","shouldOpenOnClick","includes","hasClickEvent","click","dblclick","mousedown","actualOpenEvents","mouseover","focus","mouseenter","assign","actualCloseEvents","mouseout","blur","mouseleave","mouseup","actualGlobalCloseEvents","escape","scroll","resize","clickOutsideAnchor","handleShow","undefined","transitionShowDelay","time","amount","unit","cssTimeToMs","body","handleComputedPosition","newComputedPosition","oldComputedPosition","handleShowTooltipDelayed","delay","handleHideTooltipDelayed","handleShowTooltip","event","target","currentTarget","isConnected","handleHideTooltip","handleTooltipPosition","virtualElement","getBoundingClientRect","width","height","computedStylesData","handlePointerMove","mouseEvent","mousePosition","clientX","clientY","handleClickOutsideAnchors","contains","querySelector","anchor","internalDebouncedHandleShowTooltip","internalDebouncedHandleHideTooltip","debouncedHandleShowTooltip","e","debouncedHandleHideTooltip","updateTooltipPosition","useCallback","actualPosition","elementRefs","forEach","add","anchorById","handleScrollResize","anchorScrollParent","tooltipScrollParent","addEventListener","updateTooltipCleanup","autoUpdate","ancestorResize","elementResize","layoutShift","handleEsc","enabledEvents","activeAnchorContainsTarget","Boolean","handleClickOpenTooltipAnchor","handleClickCloseTooltipAnchor","regularEvents","clickEvents","entries","enabled","listener","handleMouseOverTooltip","handleMouseOutTooltip","addHoveringTooltipListeners","removeEventListener","selector","replace","documentObserver","MutationObserver","mutationList","newAnchors","removedAnchors","mutation","attributeName","getAttribute","oldValue","elements","removedNodes","filter","nodeType","matches","flatMap","querySelectorAll","call","addedNodes","anchors","observe","childList","subtree","attributes","attributeFilter","attributeOldValue","disconnect","contentObserver","ResizeObserver","from","actualContent","canShow","useImperativeHandle","open","options","console","warn","close","React","classNames","coreStyles","onTransitionEnd","background","TooltipContent","dangerouslySetInnerHTML","__html","TooltipController","html","render","children","disableStyleInjection","tooltipContent","setTooltipContent","tooltipHtml","setTooltipHtml","tooltipPlace","setTooltipPlace","tooltipVariant","setTooltipVariant","tooltipOffset","setTooltipOffset","tooltipDelayShow","setTooltipDelayShow","tooltipDelayHide","setTooltipDelayHide","tooltipFloat","setTooltipFloat","tooltipHidden","setTooltipHidden","tooltipWrapper","setTooltipWrapper","tooltipEvents","setTooltipEvents","tooltipPositionStrategy","setTooltipPositionStrategy","tooltipClassName","setTooltipClassName","styleInjectionRef","providerActiveAnchor","getDataAttributesFromAnchorElement","getAttributeNames","reduce","acc","name","startsWith","applyAllDataAttributesFromAnchorElement","dataAttributes","handleDataAttributes","parsed","values","handler","dispatchEvent","CustomEvent","detail","disableCore","disableBase","size","anchorElement","observer","observerConfig","renderedContent","props","anchorRefMap","setAnchorRefMap","activeAnchorMap","setActiveAnchorMap","refs","oldMap","tooltipRefs","delete","context","useMemo","Provider","anchorRef","tagName","remove"],"mappings":"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"}