@commercetools-uikit/tooltip 19.25.1 → 20.0.0

This diff represents the content of publicly available package versions that have been released to one of the supported registries. The information contained in this diff is provided for informational purposes only and reflects changes between package versions as they appear in their respective public registries.
@@ -5,7 +5,6 @@ Object.defineProperty(exports, '__esModule', { value: true });
5
5
  var _defineProperty = require('@babel/runtime-corejs3/helpers/defineProperty');
6
6
  var _slicedToArray = require('@babel/runtime-corejs3/helpers/slicedToArray');
7
7
  var _objectWithoutProperties = require('@babel/runtime-corejs3/helpers/objectWithoutProperties');
8
- var _pt = require('prop-types');
9
8
  var _setTimeout = require('@babel/runtime-corejs3/core-js-stable/set-timeout');
10
9
  var _Object$keys = require('@babel/runtime-corejs3/core-js-stable/object/keys');
11
10
  var _Object$getOwnPropertySymbols = require('@babel/runtime-corejs3/core-js-stable/object/get-own-property-symbols');
@@ -28,7 +27,6 @@ var jsxRuntime = require('@emotion/react/jsx-runtime');
28
27
 
29
28
  function _interopDefault (e) { return e && e.__esModule ? e : { 'default': e }; }
30
29
 
31
- var _pt__default = /*#__PURE__*/_interopDefault(_pt);
32
30
  var _setTimeout__default = /*#__PURE__*/_interopDefault(_setTimeout);
33
31
  var _Object$keys__default = /*#__PURE__*/_interopDefault(_Object$keys);
34
32
  var _Object$getOwnPropertySymbols__default = /*#__PURE__*/_interopDefault(_Object$getOwnPropertySymbols);
@@ -151,8 +149,8 @@ const Tooltip = _ref => {
151
149
  _ref$placement = _ref.placement,
152
150
  placement = _ref$placement === void 0 ? 'top' : _ref$placement,
153
151
  props = _objectWithoutProperties(_ref, _excluded);
154
- const enterTimer = react$1.useRef();
155
- const leaveTimer = react$1.useRef();
152
+ const enterTimer = react$1.useRef(null);
153
+ const leaveTimer = react$1.useRef(null);
156
154
  if (props.components?.BodyComponent) {
157
155
  process.env.NODE_ENV !== "production" ? utils.warning(reactIs.isValidElementType(props.components.BodyComponent), `ui-kit/Tooltip: the prop 'components.BodyComponent' is not a valid React element.`) : void 0;
158
156
  }
@@ -295,10 +293,10 @@ const Tooltip = _ref => {
295
293
  constraint: horizontalConstraint,
296
294
  placement: popper.placement,
297
295
  customStyles: props.styles?.body
298
- })), process.env.NODE_ENV === "production" ? "" : ";label:Tooltip;", process.env.NODE_ENV === "production" ? "" : "/*# sourceMappingURL=data:application/json;charset=utf-8;base64,{"version":3,"sources":["tooltip.tsx"],"names":[],"mappings":"AAmViB","file":"tooltip.tsx","sourcesContent":["// inspired from https://github.com/mui-org/material-ui/blob/9ecc8db8abbfb829111d3b5c0678267827984024/packages/material-ui/src/Tooltip/Tooltip.js\nimport { Modifiers } from 'popper.js';\nimport {\n  ComponentType,\n  FocusEvent,\n  ChangeEvent,\n  LegacyRef,\n  CSSProperties,\n  ReactElement,\n  useRef,\n  useEffect,\n  useCallback,\n  cloneElement,\n  useState,\n} from 'react';\nimport { isValidElementType } from 'react-is';\nimport isNil from 'lodash/isNil';\nimport usePopper from 'use-popper';\nimport { css } from '@emotion/react';\nimport { useFieldId } from '@commercetools-uikit/hooks';\nimport { createSequentialId, warning } from '@commercetools-uikit/utils';\nimport {\n  Wrapper,\n  Body,\n  getBodyStyles,\n  getTooltipStyles,\n} from './tooltip.styles';\n\nconst sequentialId = createSequentialId('tooltip-');\n\nexport type TComponents = {\n  /**\n   * The component rendered as the tooltip body.\n   */\n  BodyComponent?: ComponentType;\n  /**\n   * Where the tooltip should be rendered. This can be useful to render the tooltip into another part of the document, using React portal.\n   */\n  TooltipWrapperComponent?: ComponentType;\n  /**\n   * A custom component wrapper for the tooltip.\n   */\n  WrapperComponent?: ComponentType;\n};\n\nexport type TTooltipProps = {\n  children: ReactElement;\n\n  /**\n   * Delay (in milliseconds) between the start of the user interaction, and showing the tooltip.\n   */\n  showAfter?: number;\n  /**\n   * Delay (in milliseconds) between the end of the user interaction, and the closing of the tooltip.\n   */\n  closeAfter?: number;\n  /**\n   * Custom css-in-js object styles for the tooltip body.\n   */\n  styles?: Record<string, CSSProperties>;\n  /**\n   * Determines if the tooltip should not appear.\n   */\n  off?: boolean;\n  /**\n   * An identifier for the tooltip, used for `aria-describedby`.\n   */\n  id?: string;\n  /**\n   * A callback function, called when the tooltip is closing.\n   */\n  onClose?: (e?: ChangeEvent | FocusEvent) => void;\n  /**\n   * A callback function, called when the tooltip is opening.\n   */\n  onOpen?: (e?: ChangeEvent | FocusEvent) => void;\n  isOpen?: boolean;\n  /**\n   * How the tooltip is positioned relative to the child element.\n   */\n  placement?:\n    | 'top'\n    | 'top-start'\n    | 'top-end'\n    | 'right'\n    | 'right-start'\n    | 'right-end'\n    | 'bottom'\n    | 'bottom-start'\n    | 'bottom-end'\n    | 'left'\n    | 'left-start'\n    | 'left-end';\n  /**\n   * The message to show in the tooltip.\n   */\n  title: string;\n  /**\n   * Provides a way to fine-tune an appearance of underlying Popper tooltip element. For more information, please check [Popper.js documentation](https://popper.js.org/popper-documentation.html#modifiers).\n   */\n  modifiers?: Modifiers;\n  /**\n   * Customize the appearance of certain elements of the tooltip.\n   */\n  components?: TComponents;\n  /**\n   * Horizontal size limit of the tooltip.\n   */\n  horizontalConstraint?:\n    | 1\n    | 2\n    | 3\n    | 4\n    | 5\n    | 6\n    | 7\n    | 8\n    | 9\n    | 10\n    | 11\n    | 12\n    | 13\n    | 14\n    | 15\n    | 16\n    | 'scale'\n    | 'auto';\n};\n\nexport type TTooltipState = 'closed' | 'entering' | 'opened' | 'exiting';\n\nconst TooltipWrapper = (props: Pick<TTooltipProps, 'children'>) => (\n  <>{props.children}</>\n);\nTooltipWrapper.displayName = 'TooltipWrapperComponent';\n\nconst Tooltip = ({\n  showAfter = 300,\n  closeAfter = 200,\n  horizontalConstraint = 'scale',\n  off = false,\n  placement = 'top',\n  ...props\n}: TTooltipProps) => {\n  const enterTimer = useRef<ReturnType<typeof setTimeout>>();\n  const leaveTimer = useRef<ReturnType<typeof setTimeout>>();\n\n  if (props.components?.BodyComponent) {\n    warning(\n      isValidElementType(props.components.BodyComponent),\n      `ui-kit/Tooltip: the prop 'components.BodyComponent' is not a valid React element.`\n    );\n  }\n  if (props.components?.TooltipWrapperComponent) {\n    warning(\n      isValidElementType(props.components.TooltipWrapperComponent),\n      `ui-kit/Tooltip: the prop 'components.TooltipWrapperComponent' is not a valid React element.`\n    );\n  }\n  if (props.components?.WrapperComponent) {\n    warning(\n      isValidElementType(props.components.WrapperComponent),\n      `ui-kit/Tooltip: the prop 'components.WrapperComponent' is not a valid React element.`\n    );\n  }\n\n  useEffect(() => {\n    return () => {\n      if (enterTimer.current) {\n        clearTimeout(enterTimer.current);\n      }\n      if (leaveTimer.current) {\n        clearTimeout(leaveTimer.current);\n      }\n    };\n  }, []);\n\n  const { reference, popper, popperInstance } = usePopper({\n    placement: placement,\n    modifiers: props.modifiers,\n  });\n  const [state, setState] = useState<TTooltipState>('closed');\n\n  const isControlled = !isNil(props.isOpen);\n  const tooltipIsOpen = isControlled\n    ? props.isOpen\n    : state === 'opened' || state === 'exiting';\n  const id = useFieldId(props.id, sequentialId);\n\n  const { onClose } = props;\n  const handleClose = useCallback(\n    (event?: ChangeEvent | FocusEvent) => {\n      if (!isControlled) {\n        setState('closed');\n      }\n      if (onClose) {\n        onClose(event);\n      }\n    },\n    [isControlled, onClose]\n  );\n\n  const { onFocus, onMouseOver } = props.children.props;\n  const { onOpen } = props;\n  const handleEnter = useCallback(\n    (event?: ChangeEvent | FocusEvent) => {\n      if (event) {\n        if (event.type === 'mouseover' && onMouseOver) {\n          onMouseOver(event);\n        }\n\n        if (event.type === 'focus' && onFocus) {\n          onFocus(event);\n        }\n\n        if (state !== 'opened' && !isControlled) {\n          setState('entering');\n          enterTimer.current = setTimeout(() => {\n            setState('opened');\n\n            if (onOpen) {\n              onOpen(event);\n            }\n          }, showAfter);\n        }\n\n        event.preventDefault();\n        event.stopPropagation();\n      }\n    },\n    [onFocus, onOpen, onMouseOver, isControlled, state, showAfter]\n  );\n\n  const { onBlur, onMouseLeave } = props.children.props;\n\n  const handleLeave = useCallback(\n    (event) => {\n      clearTimeout(enterTimer.current);\n      clearTimeout(leaveTimer.current);\n\n      if (event.type === 'mouseleave' && onMouseLeave) {\n        onMouseLeave(event);\n      }\n\n      if (event.type === 'blur' && onBlur) {\n        onBlur(event);\n      }\n\n      if (closeAfter && state === 'opened') {\n        leaveTimer.current = setTimeout(() => {\n          const tooltipElement = popperInstance?.popper.querySelector(\n            '[data-testid=\"tooltip-message-wrapper\"]'\n          ) as HTMLElement;\n\n          if (tooltipElement) {\n            tooltipElement.addEventListener('animationend', () =>\n              handleClose()\n            );\n          } else {\n            handleClose();\n          }\n\n          setState('exiting');\n        }, closeAfter);\n      } else {\n        handleClose(event);\n      }\n    },\n    [closeAfter, onBlur, onMouseLeave, handleClose, state, popperInstance]\n  );\n\n  useEffect(() => {\n    // if tooltip was open, and then component\n    // updated to be off, we should close the tooltip\n    if (state === 'opened' && off) {\n      if (closeAfter) {\n        leaveTimer.current = setTimeout(() => {\n          handleClose();\n        }, closeAfter);\n      } else {\n        handleClose();\n      }\n    }\n  }, [off, closeAfter, handleClose, state]);\n\n  const childrenProps = {\n    // don't pass event listeners to children\n    onFocus: null,\n    onMouseOver: null,\n    onMouseLeave: null,\n    onBlur: null,\n  };\n\n  const tooltipProps = !off\n    ? {\n        'aria-describedby': tooltipIsOpen ? id : null,\n        // for seo and accessibility, we add the tooltip's title\n        // as a native title when the title is hidden\n        title:\n          !tooltipIsOpen &&\n          state !== 'entering' &&\n          typeof props.title === 'string'\n            ? props.title\n            : null,\n      }\n    : {};\n\n  const eventListeners = !off\n    ? {\n        onMouseEnter: handleEnter,\n        onMouseLeave: handleLeave,\n        onFocus: handleEnter,\n        onBlur: handleLeave,\n      }\n    : {};\n\n  const WrapperComponent = props.components?.WrapperComponent || Wrapper;\n  const BodyComponent = props.components?.BodyComponent || Body;\n  const TooltipWrapperComponent =\n    props.components?.TooltipWrapperComponent || TooltipWrapper;\n\n  return (\n    <>\n      <WrapperComponent\n        {...eventListeners}\n        // @ts-expect-error: yes, ref can be undefined\n        ref={reference.ref}\n      >\n        {cloneElement(props.children, {\n          ...childrenProps,\n          ...tooltipProps,\n        })}\n      </WrapperComponent>\n      {tooltipIsOpen && (\n        <TooltipWrapperComponent>\n          <div\n            // ref accepts `LegacyRef`, which is a union of `RefObject` and `string`\n            // propper.ref returns `RefObject`\n            ref={popper.ref as LegacyRef<HTMLDivElement>}\n            css={css({\n              ...popper.styles,\n              ...getBodyStyles({\n                constraint: horizontalConstraint,\n                placement: popper.placement,\n                customStyles: props.styles?.body,\n              }),\n            })}\n            data-placement={popper.placement}\n          >\n            <div\n              css={css({\n                ...getTooltipStyles(state),\n              })}\n              data-testid=\"tooltip-message-wrapper\"\n            >\n              <BodyComponent>{props.title}</BodyComponent>\n            </div>\n          </div>\n        </TooltipWrapperComponent>\n      )}\n    </>\n  );\n};\n\nTooltip.displayName = 'ToolTip';\n\nexport default Tooltip;\n"]} */"),
296
+ })), process.env.NODE_ENV === "production" ? "" : ";label:Tooltip;", process.env.NODE_ENV === "production" ? "" : "/*# sourceMappingURL=data:application/json;charset=utf-8;base64,{"version":3,"sources":["tooltip.tsx"],"names":[],"mappings":"AA0ViB","file":"tooltip.tsx","sourcesContent":["// inspired from https://github.com/mui-org/material-ui/blob/9ecc8db8abbfb829111d3b5c0678267827984024/packages/material-ui/src/Tooltip/Tooltip.js\nimport { Modifiers } from 'popper.js';\nimport {\n  type ComponentType,\n  type FocusEvent,\n  type ChangeEvent,\n  type Ref,\n  type CSSProperties,\n  type ReactElement,\n  useRef,\n  useEffect,\n  useCallback,\n  cloneElement,\n  useState,\n} from 'react';\nimport { isValidElementType } from 'react-is';\nimport isNil from 'lodash/isNil';\nimport usePopper from 'use-popper';\nimport { css } from '@emotion/react';\nimport { useFieldId } from '@commercetools-uikit/hooks';\nimport { createSequentialId, warning } from '@commercetools-uikit/utils';\nimport {\n  Wrapper,\n  Body,\n  getBodyStyles,\n  getTooltipStyles,\n} from './tooltip.styles';\n\nconst sequentialId = createSequentialId('tooltip-');\n\nexport type TComponents = {\n  /**\n   * The component rendered as the tooltip body.\n   */\n  BodyComponent?: ComponentType;\n  /**\n   * Where the tooltip should be rendered. This can be useful to render the tooltip into another part of the document, using React portal.\n   */\n  TooltipWrapperComponent?: ComponentType;\n  /**\n   * A custom component wrapper for the tooltip.\n   */\n  WrapperComponent?: ComponentType;\n};\n\nexport type TTooltipChildProps = {\n  onFocus?: Function | null;\n  onMouseOver?: Function | null;\n  onBlur?: Function | null;\n  onMouseLeave?: Function | null;\n} & Record<string, unknown>;\n\nexport type TTooltipProps = {\n  children: ReactElement<TTooltipChildProps>;\n\n  /**\n   * Delay (in milliseconds) between the start of the user interaction, and showing the tooltip.\n   */\n  showAfter?: number;\n  /**\n   * Delay (in milliseconds) between the end of the user interaction, and the closing of the tooltip.\n   */\n  closeAfter?: number;\n  /**\n   * Custom css-in-js object styles for the tooltip body.\n   */\n  styles?: Record<string, CSSProperties>;\n  /**\n   * Determines if the tooltip should not appear.\n   */\n  off?: boolean;\n  /**\n   * An identifier for the tooltip, used for `aria-describedby`.\n   */\n  id?: string;\n  /**\n   * A callback function, called when the tooltip is closing.\n   */\n  onClose?: (e?: ChangeEvent | FocusEvent) => void;\n  /**\n   * A callback function, called when the tooltip is opening.\n   */\n  onOpen?: (e?: ChangeEvent | FocusEvent) => void;\n  isOpen?: boolean;\n  /**\n   * How the tooltip is positioned relative to the child element.\n   */\n  placement?:\n    | 'top'\n    | 'top-start'\n    | 'top-end'\n    | 'right'\n    | 'right-start'\n    | 'right-end'\n    | 'bottom'\n    | 'bottom-start'\n    | 'bottom-end'\n    | 'left'\n    | 'left-start'\n    | 'left-end';\n  /**\n   * The message to show in the tooltip.\n   */\n  title: string;\n  /**\n   * Provides a way to fine-tune an appearance of underlying Popper tooltip element. For more information, please check [Popper.js documentation](https://popper.js.org/popper-documentation.html#modifiers).\n   */\n  modifiers?: Modifiers;\n  /**\n   * Customize the appearance of certain elements of the tooltip.\n   */\n  components?: TComponents;\n  /**\n   * Horizontal size limit of the tooltip.\n   */\n  horizontalConstraint?:\n    | 1\n    | 2\n    | 3\n    | 4\n    | 5\n    | 6\n    | 7\n    | 8\n    | 9\n    | 10\n    | 11\n    | 12\n    | 13\n    | 14\n    | 15\n    | 16\n    | 'scale'\n    | 'auto';\n};\n\nexport type TTooltipState = 'closed' | 'entering' | 'opened' | 'exiting';\n\nconst TooltipWrapper = (props: Pick<TTooltipProps, 'children'>) => (\n  <>{props.children}</>\n);\nTooltipWrapper.displayName = 'TooltipWrapperComponent';\n\nconst Tooltip = ({\n  showAfter = 300,\n  closeAfter = 200,\n  horizontalConstraint = 'scale',\n  off = false,\n  placement = 'top',\n  ...props\n}: TTooltipProps) => {\n  const enterTimer = useRef<ReturnType<typeof setTimeout>>(null);\n  const leaveTimer = useRef<ReturnType<typeof setTimeout>>(null);\n\n  if (props.components?.BodyComponent) {\n    warning(\n      isValidElementType(props.components.BodyComponent),\n      `ui-kit/Tooltip: the prop 'components.BodyComponent' is not a valid React element.`\n    );\n  }\n  if (props.components?.TooltipWrapperComponent) {\n    warning(\n      isValidElementType(props.components.TooltipWrapperComponent),\n      `ui-kit/Tooltip: the prop 'components.TooltipWrapperComponent' is not a valid React element.`\n    );\n  }\n  if (props.components?.WrapperComponent) {\n    warning(\n      isValidElementType(props.components.WrapperComponent),\n      `ui-kit/Tooltip: the prop 'components.WrapperComponent' is not a valid React element.`\n    );\n  }\n\n  useEffect(() => {\n    return () => {\n      if (enterTimer.current) {\n        clearTimeout(enterTimer.current);\n      }\n      if (leaveTimer.current) {\n        clearTimeout(leaveTimer.current);\n      }\n    };\n  }, []);\n\n  const { reference, popper, popperInstance } = usePopper({\n    placement: placement,\n    modifiers: props.modifiers,\n  });\n  const [state, setState] = useState<TTooltipState>('closed');\n\n  const isControlled = !isNil(props.isOpen);\n  const tooltipIsOpen = isControlled\n    ? props.isOpen\n    : state === 'opened' || state === 'exiting';\n  const id = useFieldId(props.id, sequentialId);\n\n  const { onClose } = props;\n  const handleClose = useCallback(\n    (event?: ChangeEvent | FocusEvent) => {\n      if (!isControlled) {\n        setState('closed');\n      }\n      if (onClose) {\n        onClose(event);\n      }\n    },\n    [isControlled, onClose]\n  );\n\n  const { onFocus, onMouseOver } = props.children.props;\n  const { onOpen } = props;\n  const handleEnter = useCallback(\n    (event?: ChangeEvent | FocusEvent) => {\n      if (event) {\n        if (event.type === 'mouseover' && onMouseOver) {\n          onMouseOver(event);\n        }\n\n        if (event.type === 'focus' && onFocus) {\n          onFocus(event);\n        }\n\n        if (state !== 'opened' && !isControlled) {\n          setState('entering');\n          enterTimer.current = setTimeout(() => {\n            setState('opened');\n\n            if (onOpen) {\n              onOpen(event);\n            }\n          }, showAfter);\n        }\n\n        event.preventDefault();\n        event.stopPropagation();\n      }\n    },\n    [onFocus, onOpen, onMouseOver, isControlled, state, showAfter]\n  );\n\n  const { onBlur, onMouseLeave } = props.children.props;\n\n  const handleLeave = useCallback(\n    (event: ChangeEvent | FocusEvent) => {\n      clearTimeout(enterTimer.current!);\n      clearTimeout(leaveTimer.current!);\n\n      if (event.type === 'mouseleave' && onMouseLeave) {\n        onMouseLeave(event);\n      }\n\n      if (event.type === 'blur' && onBlur) {\n        onBlur(event);\n      }\n\n      if (closeAfter && state === 'opened') {\n        leaveTimer.current = setTimeout(() => {\n          const tooltipElement = popperInstance?.popper.querySelector(\n            '[data-testid=\"tooltip-message-wrapper\"]'\n          ) as HTMLElement;\n\n          if (tooltipElement) {\n            tooltipElement.addEventListener('animationend', () =>\n              handleClose()\n            );\n          } else {\n            handleClose();\n          }\n\n          setState('exiting');\n        }, closeAfter);\n      } else {\n        handleClose(event);\n      }\n    },\n    [closeAfter, onBlur, onMouseLeave, handleClose, state, popperInstance]\n  );\n\n  useEffect(() => {\n    // if tooltip was open, and then component\n    // updated to be off, we should close the tooltip\n    if (state === 'opened' && off) {\n      if (closeAfter) {\n        leaveTimer.current = setTimeout(() => {\n          handleClose();\n        }, closeAfter);\n      } else {\n        handleClose();\n      }\n    }\n  }, [off, closeAfter, handleClose, state]);\n\n  const childrenProps = {\n    // don't pass event listeners to children\n    onFocus: null,\n    onMouseOver: null,\n    onMouseLeave: null,\n    onBlur: null,\n  };\n\n  const tooltipProps = !off\n    ? {\n        'aria-describedby': tooltipIsOpen ? id : null,\n        // for seo and accessibility, we add the tooltip's title\n        // as a native title when the title is hidden\n        title:\n          !tooltipIsOpen &&\n          state !== 'entering' &&\n          typeof props.title === 'string'\n            ? props.title\n            : null,\n      }\n    : {};\n\n  const eventListeners = !off\n    ? {\n        onMouseEnter: handleEnter,\n        onMouseLeave: handleLeave,\n        onFocus: handleEnter,\n        onBlur: handleLeave,\n      }\n    : {};\n\n  const WrapperComponent = props.components?.WrapperComponent || Wrapper;\n  const BodyComponent = props.components?.BodyComponent || Body;\n  const TooltipWrapperComponent =\n    props.components?.TooltipWrapperComponent || TooltipWrapper;\n\n  return (\n    <>\n      <WrapperComponent\n        {...eventListeners}\n        // @ts-expect-error: yes, ref can be undefined\n        ref={reference.ref}\n      >\n        {cloneElement(props.children, {\n          ...childrenProps,\n          ...tooltipProps,\n        })}\n      </WrapperComponent>\n      {tooltipIsOpen && (\n        <TooltipWrapperComponent>\n          <div\n            // ref accepts `LegacyRef`, which is a union of `RefObject` and `string`\n            // propper.ref returns `RefObject`\n            ref={popper.ref as Ref<HTMLDivElement>}\n            css={css({\n              ...popper.styles,\n              ...getBodyStyles({\n                constraint: horizontalConstraint,\n                placement: popper.placement,\n                customStyles: props.styles?.body,\n              }),\n            })}\n            data-placement={popper.placement}\n          >\n            <div\n              css={css({\n                ...getTooltipStyles(state),\n              })}\n              data-testid=\"tooltip-message-wrapper\"\n            >\n              <BodyComponent>{props.title}</BodyComponent>\n            </div>\n          </div>\n        </TooltipWrapperComponent>\n      )}\n    </>\n  );\n};\n\nTooltip.displayName = 'ToolTip';\n\nexport default Tooltip;\n"]} */"),
299
297
  "data-placement": popper.placement,
300
298
  children: jsxRuntime.jsx("div", {
301
- css: /*#__PURE__*/react.css(_objectSpread({}, getTooltipStyles(state)), process.env.NODE_ENV === "production" ? "" : ";label:Tooltip;", process.env.NODE_ENV === "production" ? "" : "/*# sourceMappingURL=data:application/json;charset=utf-8;base64,{"version":3,"sources":["tooltip.tsx"],"names":[],"mappings":"AA8VmB","file":"tooltip.tsx","sourcesContent":["// inspired from https://github.com/mui-org/material-ui/blob/9ecc8db8abbfb829111d3b5c0678267827984024/packages/material-ui/src/Tooltip/Tooltip.js\nimport { Modifiers } from 'popper.js';\nimport {\n  ComponentType,\n  FocusEvent,\n  ChangeEvent,\n  LegacyRef,\n  CSSProperties,\n  ReactElement,\n  useRef,\n  useEffect,\n  useCallback,\n  cloneElement,\n  useState,\n} from 'react';\nimport { isValidElementType } from 'react-is';\nimport isNil from 'lodash/isNil';\nimport usePopper from 'use-popper';\nimport { css } from '@emotion/react';\nimport { useFieldId } from '@commercetools-uikit/hooks';\nimport { createSequentialId, warning } from '@commercetools-uikit/utils';\nimport {\n  Wrapper,\n  Body,\n  getBodyStyles,\n  getTooltipStyles,\n} from './tooltip.styles';\n\nconst sequentialId = createSequentialId('tooltip-');\n\nexport type TComponents = {\n  /**\n   * The component rendered as the tooltip body.\n   */\n  BodyComponent?: ComponentType;\n  /**\n   * Where the tooltip should be rendered. This can be useful to render the tooltip into another part of the document, using React portal.\n   */\n  TooltipWrapperComponent?: ComponentType;\n  /**\n   * A custom component wrapper for the tooltip.\n   */\n  WrapperComponent?: ComponentType;\n};\n\nexport type TTooltipProps = {\n  children: ReactElement;\n\n  /**\n   * Delay (in milliseconds) between the start of the user interaction, and showing the tooltip.\n   */\n  showAfter?: number;\n  /**\n   * Delay (in milliseconds) between the end of the user interaction, and the closing of the tooltip.\n   */\n  closeAfter?: number;\n  /**\n   * Custom css-in-js object styles for the tooltip body.\n   */\n  styles?: Record<string, CSSProperties>;\n  /**\n   * Determines if the tooltip should not appear.\n   */\n  off?: boolean;\n  /**\n   * An identifier for the tooltip, used for `aria-describedby`.\n   */\n  id?: string;\n  /**\n   * A callback function, called when the tooltip is closing.\n   */\n  onClose?: (e?: ChangeEvent | FocusEvent) => void;\n  /**\n   * A callback function, called when the tooltip is opening.\n   */\n  onOpen?: (e?: ChangeEvent | FocusEvent) => void;\n  isOpen?: boolean;\n  /**\n   * How the tooltip is positioned relative to the child element.\n   */\n  placement?:\n    | 'top'\n    | 'top-start'\n    | 'top-end'\n    | 'right'\n    | 'right-start'\n    | 'right-end'\n    | 'bottom'\n    | 'bottom-start'\n    | 'bottom-end'\n    | 'left'\n    | 'left-start'\n    | 'left-end';\n  /**\n   * The message to show in the tooltip.\n   */\n  title: string;\n  /**\n   * Provides a way to fine-tune an appearance of underlying Popper tooltip element. For more information, please check [Popper.js documentation](https://popper.js.org/popper-documentation.html#modifiers).\n   */\n  modifiers?: Modifiers;\n  /**\n   * Customize the appearance of certain elements of the tooltip.\n   */\n  components?: TComponents;\n  /**\n   * Horizontal size limit of the tooltip.\n   */\n  horizontalConstraint?:\n    | 1\n    | 2\n    | 3\n    | 4\n    | 5\n    | 6\n    | 7\n    | 8\n    | 9\n    | 10\n    | 11\n    | 12\n    | 13\n    | 14\n    | 15\n    | 16\n    | 'scale'\n    | 'auto';\n};\n\nexport type TTooltipState = 'closed' | 'entering' | 'opened' | 'exiting';\n\nconst TooltipWrapper = (props: Pick<TTooltipProps, 'children'>) => (\n  <>{props.children}</>\n);\nTooltipWrapper.displayName = 'TooltipWrapperComponent';\n\nconst Tooltip = ({\n  showAfter = 300,\n  closeAfter = 200,\n  horizontalConstraint = 'scale',\n  off = false,\n  placement = 'top',\n  ...props\n}: TTooltipProps) => {\n  const enterTimer = useRef<ReturnType<typeof setTimeout>>();\n  const leaveTimer = useRef<ReturnType<typeof setTimeout>>();\n\n  if (props.components?.BodyComponent) {\n    warning(\n      isValidElementType(props.components.BodyComponent),\n      `ui-kit/Tooltip: the prop 'components.BodyComponent' is not a valid React element.`\n    );\n  }\n  if (props.components?.TooltipWrapperComponent) {\n    warning(\n      isValidElementType(props.components.TooltipWrapperComponent),\n      `ui-kit/Tooltip: the prop 'components.TooltipWrapperComponent' is not a valid React element.`\n    );\n  }\n  if (props.components?.WrapperComponent) {\n    warning(\n      isValidElementType(props.components.WrapperComponent),\n      `ui-kit/Tooltip: the prop 'components.WrapperComponent' is not a valid React element.`\n    );\n  }\n\n  useEffect(() => {\n    return () => {\n      if (enterTimer.current) {\n        clearTimeout(enterTimer.current);\n      }\n      if (leaveTimer.current) {\n        clearTimeout(leaveTimer.current);\n      }\n    };\n  }, []);\n\n  const { reference, popper, popperInstance } = usePopper({\n    placement: placement,\n    modifiers: props.modifiers,\n  });\n  const [state, setState] = useState<TTooltipState>('closed');\n\n  const isControlled = !isNil(props.isOpen);\n  const tooltipIsOpen = isControlled\n    ? props.isOpen\n    : state === 'opened' || state === 'exiting';\n  const id = useFieldId(props.id, sequentialId);\n\n  const { onClose } = props;\n  const handleClose = useCallback(\n    (event?: ChangeEvent | FocusEvent) => {\n      if (!isControlled) {\n        setState('closed');\n      }\n      if (onClose) {\n        onClose(event);\n      }\n    },\n    [isControlled, onClose]\n  );\n\n  const { onFocus, onMouseOver } = props.children.props;\n  const { onOpen } = props;\n  const handleEnter = useCallback(\n    (event?: ChangeEvent | FocusEvent) => {\n      if (event) {\n        if (event.type === 'mouseover' && onMouseOver) {\n          onMouseOver(event);\n        }\n\n        if (event.type === 'focus' && onFocus) {\n          onFocus(event);\n        }\n\n        if (state !== 'opened' && !isControlled) {\n          setState('entering');\n          enterTimer.current = setTimeout(() => {\n            setState('opened');\n\n            if (onOpen) {\n              onOpen(event);\n            }\n          }, showAfter);\n        }\n\n        event.preventDefault();\n        event.stopPropagation();\n      }\n    },\n    [onFocus, onOpen, onMouseOver, isControlled, state, showAfter]\n  );\n\n  const { onBlur, onMouseLeave } = props.children.props;\n\n  const handleLeave = useCallback(\n    (event) => {\n      clearTimeout(enterTimer.current);\n      clearTimeout(leaveTimer.current);\n\n      if (event.type === 'mouseleave' && onMouseLeave) {\n        onMouseLeave(event);\n      }\n\n      if (event.type === 'blur' && onBlur) {\n        onBlur(event);\n      }\n\n      if (closeAfter && state === 'opened') {\n        leaveTimer.current = setTimeout(() => {\n          const tooltipElement = popperInstance?.popper.querySelector(\n            '[data-testid=\"tooltip-message-wrapper\"]'\n          ) as HTMLElement;\n\n          if (tooltipElement) {\n            tooltipElement.addEventListener('animationend', () =>\n              handleClose()\n            );\n          } else {\n            handleClose();\n          }\n\n          setState('exiting');\n        }, closeAfter);\n      } else {\n        handleClose(event);\n      }\n    },\n    [closeAfter, onBlur, onMouseLeave, handleClose, state, popperInstance]\n  );\n\n  useEffect(() => {\n    // if tooltip was open, and then component\n    // updated to be off, we should close the tooltip\n    if (state === 'opened' && off) {\n      if (closeAfter) {\n        leaveTimer.current = setTimeout(() => {\n          handleClose();\n        }, closeAfter);\n      } else {\n        handleClose();\n      }\n    }\n  }, [off, closeAfter, handleClose, state]);\n\n  const childrenProps = {\n    // don't pass event listeners to children\n    onFocus: null,\n    onMouseOver: null,\n    onMouseLeave: null,\n    onBlur: null,\n  };\n\n  const tooltipProps = !off\n    ? {\n        'aria-describedby': tooltipIsOpen ? id : null,\n        // for seo and accessibility, we add the tooltip's title\n        // as a native title when the title is hidden\n        title:\n          !tooltipIsOpen &&\n          state !== 'entering' &&\n          typeof props.title === 'string'\n            ? props.title\n            : null,\n      }\n    : {};\n\n  const eventListeners = !off\n    ? {\n        onMouseEnter: handleEnter,\n        onMouseLeave: handleLeave,\n        onFocus: handleEnter,\n        onBlur: handleLeave,\n      }\n    : {};\n\n  const WrapperComponent = props.components?.WrapperComponent || Wrapper;\n  const BodyComponent = props.components?.BodyComponent || Body;\n  const TooltipWrapperComponent =\n    props.components?.TooltipWrapperComponent || TooltipWrapper;\n\n  return (\n    <>\n      <WrapperComponent\n        {...eventListeners}\n        // @ts-expect-error: yes, ref can be undefined\n        ref={reference.ref}\n      >\n        {cloneElement(props.children, {\n          ...childrenProps,\n          ...tooltipProps,\n        })}\n      </WrapperComponent>\n      {tooltipIsOpen && (\n        <TooltipWrapperComponent>\n          <div\n            // ref accepts `LegacyRef`, which is a union of `RefObject` and `string`\n            // propper.ref returns `RefObject`\n            ref={popper.ref as LegacyRef<HTMLDivElement>}\n            css={css({\n              ...popper.styles,\n              ...getBodyStyles({\n                constraint: horizontalConstraint,\n                placement: popper.placement,\n                customStyles: props.styles?.body,\n              }),\n            })}\n            data-placement={popper.placement}\n          >\n            <div\n              css={css({\n                ...getTooltipStyles(state),\n              })}\n              data-testid=\"tooltip-message-wrapper\"\n            >\n              <BodyComponent>{props.title}</BodyComponent>\n            </div>\n          </div>\n        </TooltipWrapperComponent>\n      )}\n    </>\n  );\n};\n\nTooltip.displayName = 'ToolTip';\n\nexport default Tooltip;\n"]} */"),
299
+ css: /*#__PURE__*/react.css(_objectSpread({}, getTooltipStyles(state)), process.env.NODE_ENV === "production" ? "" : ";label:Tooltip;", process.env.NODE_ENV === "production" ? "" : "/*# sourceMappingURL=data:application/json;charset=utf-8;base64,{"version":3,"sources":["tooltip.tsx"],"names":[],"mappings":"AAqWmB","file":"tooltip.tsx","sourcesContent":["// inspired from https://github.com/mui-org/material-ui/blob/9ecc8db8abbfb829111d3b5c0678267827984024/packages/material-ui/src/Tooltip/Tooltip.js\nimport { Modifiers } from 'popper.js';\nimport {\n  type ComponentType,\n  type FocusEvent,\n  type ChangeEvent,\n  type Ref,\n  type CSSProperties,\n  type ReactElement,\n  useRef,\n  useEffect,\n  useCallback,\n  cloneElement,\n  useState,\n} from 'react';\nimport { isValidElementType } from 'react-is';\nimport isNil from 'lodash/isNil';\nimport usePopper from 'use-popper';\nimport { css } from '@emotion/react';\nimport { useFieldId } from '@commercetools-uikit/hooks';\nimport { createSequentialId, warning } from '@commercetools-uikit/utils';\nimport {\n  Wrapper,\n  Body,\n  getBodyStyles,\n  getTooltipStyles,\n} from './tooltip.styles';\n\nconst sequentialId = createSequentialId('tooltip-');\n\nexport type TComponents = {\n  /**\n   * The component rendered as the tooltip body.\n   */\n  BodyComponent?: ComponentType;\n  /**\n   * Where the tooltip should be rendered. This can be useful to render the tooltip into another part of the document, using React portal.\n   */\n  TooltipWrapperComponent?: ComponentType;\n  /**\n   * A custom component wrapper for the tooltip.\n   */\n  WrapperComponent?: ComponentType;\n};\n\nexport type TTooltipChildProps = {\n  onFocus?: Function | null;\n  onMouseOver?: Function | null;\n  onBlur?: Function | null;\n  onMouseLeave?: Function | null;\n} & Record<string, unknown>;\n\nexport type TTooltipProps = {\n  children: ReactElement<TTooltipChildProps>;\n\n  /**\n   * Delay (in milliseconds) between the start of the user interaction, and showing the tooltip.\n   */\n  showAfter?: number;\n  /**\n   * Delay (in milliseconds) between the end of the user interaction, and the closing of the tooltip.\n   */\n  closeAfter?: number;\n  /**\n   * Custom css-in-js object styles for the tooltip body.\n   */\n  styles?: Record<string, CSSProperties>;\n  /**\n   * Determines if the tooltip should not appear.\n   */\n  off?: boolean;\n  /**\n   * An identifier for the tooltip, used for `aria-describedby`.\n   */\n  id?: string;\n  /**\n   * A callback function, called when the tooltip is closing.\n   */\n  onClose?: (e?: ChangeEvent | FocusEvent) => void;\n  /**\n   * A callback function, called when the tooltip is opening.\n   */\n  onOpen?: (e?: ChangeEvent | FocusEvent) => void;\n  isOpen?: boolean;\n  /**\n   * How the tooltip is positioned relative to the child element.\n   */\n  placement?:\n    | 'top'\n    | 'top-start'\n    | 'top-end'\n    | 'right'\n    | 'right-start'\n    | 'right-end'\n    | 'bottom'\n    | 'bottom-start'\n    | 'bottom-end'\n    | 'left'\n    | 'left-start'\n    | 'left-end';\n  /**\n   * The message to show in the tooltip.\n   */\n  title: string;\n  /**\n   * Provides a way to fine-tune an appearance of underlying Popper tooltip element. For more information, please check [Popper.js documentation](https://popper.js.org/popper-documentation.html#modifiers).\n   */\n  modifiers?: Modifiers;\n  /**\n   * Customize the appearance of certain elements of the tooltip.\n   */\n  components?: TComponents;\n  /**\n   * Horizontal size limit of the tooltip.\n   */\n  horizontalConstraint?:\n    | 1\n    | 2\n    | 3\n    | 4\n    | 5\n    | 6\n    | 7\n    | 8\n    | 9\n    | 10\n    | 11\n    | 12\n    | 13\n    | 14\n    | 15\n    | 16\n    | 'scale'\n    | 'auto';\n};\n\nexport type TTooltipState = 'closed' | 'entering' | 'opened' | 'exiting';\n\nconst TooltipWrapper = (props: Pick<TTooltipProps, 'children'>) => (\n  <>{props.children}</>\n);\nTooltipWrapper.displayName = 'TooltipWrapperComponent';\n\nconst Tooltip = ({\n  showAfter = 300,\n  closeAfter = 200,\n  horizontalConstraint = 'scale',\n  off = false,\n  placement = 'top',\n  ...props\n}: TTooltipProps) => {\n  const enterTimer = useRef<ReturnType<typeof setTimeout>>(null);\n  const leaveTimer = useRef<ReturnType<typeof setTimeout>>(null);\n\n  if (props.components?.BodyComponent) {\n    warning(\n      isValidElementType(props.components.BodyComponent),\n      `ui-kit/Tooltip: the prop 'components.BodyComponent' is not a valid React element.`\n    );\n  }\n  if (props.components?.TooltipWrapperComponent) {\n    warning(\n      isValidElementType(props.components.TooltipWrapperComponent),\n      `ui-kit/Tooltip: the prop 'components.TooltipWrapperComponent' is not a valid React element.`\n    );\n  }\n  if (props.components?.WrapperComponent) {\n    warning(\n      isValidElementType(props.components.WrapperComponent),\n      `ui-kit/Tooltip: the prop 'components.WrapperComponent' is not a valid React element.`\n    );\n  }\n\n  useEffect(() => {\n    return () => {\n      if (enterTimer.current) {\n        clearTimeout(enterTimer.current);\n      }\n      if (leaveTimer.current) {\n        clearTimeout(leaveTimer.current);\n      }\n    };\n  }, []);\n\n  const { reference, popper, popperInstance } = usePopper({\n    placement: placement,\n    modifiers: props.modifiers,\n  });\n  const [state, setState] = useState<TTooltipState>('closed');\n\n  const isControlled = !isNil(props.isOpen);\n  const tooltipIsOpen = isControlled\n    ? props.isOpen\n    : state === 'opened' || state === 'exiting';\n  const id = useFieldId(props.id, sequentialId);\n\n  const { onClose } = props;\n  const handleClose = useCallback(\n    (event?: ChangeEvent | FocusEvent) => {\n      if (!isControlled) {\n        setState('closed');\n      }\n      if (onClose) {\n        onClose(event);\n      }\n    },\n    [isControlled, onClose]\n  );\n\n  const { onFocus, onMouseOver } = props.children.props;\n  const { onOpen } = props;\n  const handleEnter = useCallback(\n    (event?: ChangeEvent | FocusEvent) => {\n      if (event) {\n        if (event.type === 'mouseover' && onMouseOver) {\n          onMouseOver(event);\n        }\n\n        if (event.type === 'focus' && onFocus) {\n          onFocus(event);\n        }\n\n        if (state !== 'opened' && !isControlled) {\n          setState('entering');\n          enterTimer.current = setTimeout(() => {\n            setState('opened');\n\n            if (onOpen) {\n              onOpen(event);\n            }\n          }, showAfter);\n        }\n\n        event.preventDefault();\n        event.stopPropagation();\n      }\n    },\n    [onFocus, onOpen, onMouseOver, isControlled, state, showAfter]\n  );\n\n  const { onBlur, onMouseLeave } = props.children.props;\n\n  const handleLeave = useCallback(\n    (event: ChangeEvent | FocusEvent) => {\n      clearTimeout(enterTimer.current!);\n      clearTimeout(leaveTimer.current!);\n\n      if (event.type === 'mouseleave' && onMouseLeave) {\n        onMouseLeave(event);\n      }\n\n      if (event.type === 'blur' && onBlur) {\n        onBlur(event);\n      }\n\n      if (closeAfter && state === 'opened') {\n        leaveTimer.current = setTimeout(() => {\n          const tooltipElement = popperInstance?.popper.querySelector(\n            '[data-testid=\"tooltip-message-wrapper\"]'\n          ) as HTMLElement;\n\n          if (tooltipElement) {\n            tooltipElement.addEventListener('animationend', () =>\n              handleClose()\n            );\n          } else {\n            handleClose();\n          }\n\n          setState('exiting');\n        }, closeAfter);\n      } else {\n        handleClose(event);\n      }\n    },\n    [closeAfter, onBlur, onMouseLeave, handleClose, state, popperInstance]\n  );\n\n  useEffect(() => {\n    // if tooltip was open, and then component\n    // updated to be off, we should close the tooltip\n    if (state === 'opened' && off) {\n      if (closeAfter) {\n        leaveTimer.current = setTimeout(() => {\n          handleClose();\n        }, closeAfter);\n      } else {\n        handleClose();\n      }\n    }\n  }, [off, closeAfter, handleClose, state]);\n\n  const childrenProps = {\n    // don't pass event listeners to children\n    onFocus: null,\n    onMouseOver: null,\n    onMouseLeave: null,\n    onBlur: null,\n  };\n\n  const tooltipProps = !off\n    ? {\n        'aria-describedby': tooltipIsOpen ? id : null,\n        // for seo and accessibility, we add the tooltip's title\n        // as a native title when the title is hidden\n        title:\n          !tooltipIsOpen &&\n          state !== 'entering' &&\n          typeof props.title === 'string'\n            ? props.title\n            : null,\n      }\n    : {};\n\n  const eventListeners = !off\n    ? {\n        onMouseEnter: handleEnter,\n        onMouseLeave: handleLeave,\n        onFocus: handleEnter,\n        onBlur: handleLeave,\n      }\n    : {};\n\n  const WrapperComponent = props.components?.WrapperComponent || Wrapper;\n  const BodyComponent = props.components?.BodyComponent || Body;\n  const TooltipWrapperComponent =\n    props.components?.TooltipWrapperComponent || TooltipWrapper;\n\n  return (\n    <>\n      <WrapperComponent\n        {...eventListeners}\n        // @ts-expect-error: yes, ref can be undefined\n        ref={reference.ref}\n      >\n        {cloneElement(props.children, {\n          ...childrenProps,\n          ...tooltipProps,\n        })}\n      </WrapperComponent>\n      {tooltipIsOpen && (\n        <TooltipWrapperComponent>\n          <div\n            // ref accepts `LegacyRef`, which is a union of `RefObject` and `string`\n            // propper.ref returns `RefObject`\n            ref={popper.ref as Ref<HTMLDivElement>}\n            css={css({\n              ...popper.styles,\n              ...getBodyStyles({\n                constraint: horizontalConstraint,\n                placement: popper.placement,\n                customStyles: props.styles?.body,\n              }),\n            })}\n            data-placement={popper.placement}\n          >\n            <div\n              css={css({\n                ...getTooltipStyles(state),\n              })}\n              data-testid=\"tooltip-message-wrapper\"\n            >\n              <BodyComponent>{props.title}</BodyComponent>\n            </div>\n          </div>\n        </TooltipWrapperComponent>\n      )}\n    </>\n  );\n};\n\nTooltip.displayName = 'ToolTip';\n\nexport default Tooltip;\n"]} */"),
302
300
  "data-testid": "tooltip-message-wrapper",
303
301
  children: jsxRuntime.jsx(BodyComponent, {
304
302
  children: props.title
@@ -308,31 +306,11 @@ const Tooltip = _ref => {
308
306
  })]
309
307
  });
310
308
  };
311
- Tooltip.propTypes = process.env.NODE_ENV !== "production" ? {
312
- children: _pt__default["default"].element.isRequired,
313
- showAfter: _pt__default["default"].number,
314
- closeAfter: _pt__default["default"].number,
315
- styles: _pt__default["default"].objectOf(_pt__default["default"].any),
316
- off: _pt__default["default"].bool,
317
- id: _pt__default["default"].string,
318
- onClose: _pt__default["default"].func,
319
- onOpen: _pt__default["default"].func,
320
- isOpen: _pt__default["default"].bool,
321
- placement: _pt__default["default"].oneOf(['top', 'top-start', 'top-end', 'right', 'right-start', 'right-end', 'bottom', 'bottom-start', 'bottom-end', 'left', 'left-start', 'left-end']),
322
- title: _pt__default["default"].string.isRequired,
323
- modifiers: _pt__default["default"].any,
324
- components: _pt__default["default"].shape({
325
- BodyComponent: _pt__default["default"].elementType,
326
- TooltipWrapperComponent: _pt__default["default"].elementType,
327
- WrapperComponent: _pt__default["default"].elementType
328
- }),
329
- horizontalConstraint: _pt__default["default"].oneOf([1, 2, 3, 4, 5, 6, 7, 8, 9, 10, 11, 12, 13, 14, 15, 16, 'scale', 'auto'])
330
- } : {};
331
309
  Tooltip.displayName = 'ToolTip';
332
310
  var Tooltip$1 = Tooltip;
333
311
 
334
312
  // NOTE: This string will be replaced on build time with the package version.
335
- var version = "19.25.1";
313
+ var version = "20.0.0";
336
314
 
337
315
  exports["default"] = Tooltip$1;
338
316
  exports.version = version;
@@ -5,7 +5,6 @@ Object.defineProperty(exports, '__esModule', { value: true });
5
5
  var _defineProperty = require('@babel/runtime-corejs3/helpers/defineProperty');
6
6
  var _slicedToArray = require('@babel/runtime-corejs3/helpers/slicedToArray');
7
7
  var _objectWithoutProperties = require('@babel/runtime-corejs3/helpers/objectWithoutProperties');
8
- require('prop-types');
9
8
  var _setTimeout = require('@babel/runtime-corejs3/core-js-stable/set-timeout');
10
9
  var _Object$keys = require('@babel/runtime-corejs3/core-js-stable/object/keys');
11
10
  var _Object$getOwnPropertySymbols = require('@babel/runtime-corejs3/core-js-stable/object/get-own-property-symbols');
@@ -139,8 +138,8 @@ const Tooltip = _ref => {
139
138
  _ref$placement = _ref.placement,
140
139
  placement = _ref$placement === void 0 ? 'top' : _ref$placement,
141
140
  props = _objectWithoutProperties(_ref, _excluded);
142
- const enterTimer = react$1.useRef();
143
- const leaveTimer = react$1.useRef();
141
+ const enterTimer = react$1.useRef(null);
142
+ const leaveTimer = react$1.useRef(null);
144
143
  if (props.components?.BodyComponent) ;
145
144
  if (props.components?.TooltipWrapperComponent) ;
146
145
  if (props.components?.WrapperComponent) ;
@@ -290,12 +289,11 @@ const Tooltip = _ref => {
290
289
  })]
291
290
  });
292
291
  };
293
- Tooltip.propTypes = {};
294
292
  Tooltip.displayName = 'ToolTip';
295
293
  var Tooltip$1 = Tooltip;
296
294
 
297
295
  // NOTE: This string will be replaced on build time with the package version.
298
- var version = "19.25.1";
296
+ var version = "20.0.0";
299
297
 
300
298
  exports["default"] = Tooltip$1;
301
299
  exports.version = version;
@@ -1,7 +1,6 @@
1
1
  import _defineProperty from '@babel/runtime-corejs3/helpers/esm/defineProperty';
2
2
  import _slicedToArray from '@babel/runtime-corejs3/helpers/esm/slicedToArray';
3
3
  import _objectWithoutProperties from '@babel/runtime-corejs3/helpers/esm/objectWithoutProperties';
4
- import _pt from 'prop-types';
5
4
  import _setTimeout from '@babel/runtime-corejs3/core-js-stable/set-timeout';
6
5
  import _Object$keys from '@babel/runtime-corejs3/core-js-stable/object/keys';
7
6
  import _Object$getOwnPropertySymbols from '@babel/runtime-corejs3/core-js-stable/object/get-own-property-symbols';
@@ -131,8 +130,8 @@ const Tooltip = _ref => {
131
130
  _ref$placement = _ref.placement,
132
131
  placement = _ref$placement === void 0 ? 'top' : _ref$placement,
133
132
  props = _objectWithoutProperties(_ref, _excluded);
134
- const enterTimer = useRef();
135
- const leaveTimer = useRef();
133
+ const enterTimer = useRef(null);
134
+ const leaveTimer = useRef(null);
136
135
  if (props.components?.BodyComponent) {
137
136
  process.env.NODE_ENV !== "production" ? warning(isValidElementType(props.components.BodyComponent), `ui-kit/Tooltip: the prop 'components.BodyComponent' is not a valid React element.`) : void 0;
138
137
  }
@@ -275,10 +274,10 @@ const Tooltip = _ref => {
275
274
  constraint: horizontalConstraint,
276
275
  placement: popper.placement,
277
276
  customStyles: props.styles?.body
278
- })), process.env.NODE_ENV === "production" ? "" : ";label:Tooltip;", process.env.NODE_ENV === "production" ? "" : "/*# sourceMappingURL=data:application/json;charset=utf-8;base64,{"version":3,"sources":["tooltip.tsx"],"names":[],"mappings":"AAmViB","file":"tooltip.tsx","sourcesContent":["// inspired from https://github.com/mui-org/material-ui/blob/9ecc8db8abbfb829111d3b5c0678267827984024/packages/material-ui/src/Tooltip/Tooltip.js\nimport { Modifiers } from 'popper.js';\nimport {\n  ComponentType,\n  FocusEvent,\n  ChangeEvent,\n  LegacyRef,\n  CSSProperties,\n  ReactElement,\n  useRef,\n  useEffect,\n  useCallback,\n  cloneElement,\n  useState,\n} from 'react';\nimport { isValidElementType } from 'react-is';\nimport isNil from 'lodash/isNil';\nimport usePopper from 'use-popper';\nimport { css } from '@emotion/react';\nimport { useFieldId } from '@commercetools-uikit/hooks';\nimport { createSequentialId, warning } from '@commercetools-uikit/utils';\nimport {\n  Wrapper,\n  Body,\n  getBodyStyles,\n  getTooltipStyles,\n} from './tooltip.styles';\n\nconst sequentialId = createSequentialId('tooltip-');\n\nexport type TComponents = {\n  /**\n   * The component rendered as the tooltip body.\n   */\n  BodyComponent?: ComponentType;\n  /**\n   * Where the tooltip should be rendered. This can be useful to render the tooltip into another part of the document, using React portal.\n   */\n  TooltipWrapperComponent?: ComponentType;\n  /**\n   * A custom component wrapper for the tooltip.\n   */\n  WrapperComponent?: ComponentType;\n};\n\nexport type TTooltipProps = {\n  children: ReactElement;\n\n  /**\n   * Delay (in milliseconds) between the start of the user interaction, and showing the tooltip.\n   */\n  showAfter?: number;\n  /**\n   * Delay (in milliseconds) between the end of the user interaction, and the closing of the tooltip.\n   */\n  closeAfter?: number;\n  /**\n   * Custom css-in-js object styles for the tooltip body.\n   */\n  styles?: Record<string, CSSProperties>;\n  /**\n   * Determines if the tooltip should not appear.\n   */\n  off?: boolean;\n  /**\n   * An identifier for the tooltip, used for `aria-describedby`.\n   */\n  id?: string;\n  /**\n   * A callback function, called when the tooltip is closing.\n   */\n  onClose?: (e?: ChangeEvent | FocusEvent) => void;\n  /**\n   * A callback function, called when the tooltip is opening.\n   */\n  onOpen?: (e?: ChangeEvent | FocusEvent) => void;\n  isOpen?: boolean;\n  /**\n   * How the tooltip is positioned relative to the child element.\n   */\n  placement?:\n    | 'top'\n    | 'top-start'\n    | 'top-end'\n    | 'right'\n    | 'right-start'\n    | 'right-end'\n    | 'bottom'\n    | 'bottom-start'\n    | 'bottom-end'\n    | 'left'\n    | 'left-start'\n    | 'left-end';\n  /**\n   * The message to show in the tooltip.\n   */\n  title: string;\n  /**\n   * Provides a way to fine-tune an appearance of underlying Popper tooltip element. For more information, please check [Popper.js documentation](https://popper.js.org/popper-documentation.html#modifiers).\n   */\n  modifiers?: Modifiers;\n  /**\n   * Customize the appearance of certain elements of the tooltip.\n   */\n  components?: TComponents;\n  /**\n   * Horizontal size limit of the tooltip.\n   */\n  horizontalConstraint?:\n    | 1\n    | 2\n    | 3\n    | 4\n    | 5\n    | 6\n    | 7\n    | 8\n    | 9\n    | 10\n    | 11\n    | 12\n    | 13\n    | 14\n    | 15\n    | 16\n    | 'scale'\n    | 'auto';\n};\n\nexport type TTooltipState = 'closed' | 'entering' | 'opened' | 'exiting';\n\nconst TooltipWrapper = (props: Pick<TTooltipProps, 'children'>) => (\n  <>{props.children}</>\n);\nTooltipWrapper.displayName = 'TooltipWrapperComponent';\n\nconst Tooltip = ({\n  showAfter = 300,\n  closeAfter = 200,\n  horizontalConstraint = 'scale',\n  off = false,\n  placement = 'top',\n  ...props\n}: TTooltipProps) => {\n  const enterTimer = useRef<ReturnType<typeof setTimeout>>();\n  const leaveTimer = useRef<ReturnType<typeof setTimeout>>();\n\n  if (props.components?.BodyComponent) {\n    warning(\n      isValidElementType(props.components.BodyComponent),\n      `ui-kit/Tooltip: the prop 'components.BodyComponent' is not a valid React element.`\n    );\n  }\n  if (props.components?.TooltipWrapperComponent) {\n    warning(\n      isValidElementType(props.components.TooltipWrapperComponent),\n      `ui-kit/Tooltip: the prop 'components.TooltipWrapperComponent' is not a valid React element.`\n    );\n  }\n  if (props.components?.WrapperComponent) {\n    warning(\n      isValidElementType(props.components.WrapperComponent),\n      `ui-kit/Tooltip: the prop 'components.WrapperComponent' is not a valid React element.`\n    );\n  }\n\n  useEffect(() => {\n    return () => {\n      if (enterTimer.current) {\n        clearTimeout(enterTimer.current);\n      }\n      if (leaveTimer.current) {\n        clearTimeout(leaveTimer.current);\n      }\n    };\n  }, []);\n\n  const { reference, popper, popperInstance } = usePopper({\n    placement: placement,\n    modifiers: props.modifiers,\n  });\n  const [state, setState] = useState<TTooltipState>('closed');\n\n  const isControlled = !isNil(props.isOpen);\n  const tooltipIsOpen = isControlled\n    ? props.isOpen\n    : state === 'opened' || state === 'exiting';\n  const id = useFieldId(props.id, sequentialId);\n\n  const { onClose } = props;\n  const handleClose = useCallback(\n    (event?: ChangeEvent | FocusEvent) => {\n      if (!isControlled) {\n        setState('closed');\n      }\n      if (onClose) {\n        onClose(event);\n      }\n    },\n    [isControlled, onClose]\n  );\n\n  const { onFocus, onMouseOver } = props.children.props;\n  const { onOpen } = props;\n  const handleEnter = useCallback(\n    (event?: ChangeEvent | FocusEvent) => {\n      if (event) {\n        if (event.type === 'mouseover' && onMouseOver) {\n          onMouseOver(event);\n        }\n\n        if (event.type === 'focus' && onFocus) {\n          onFocus(event);\n        }\n\n        if (state !== 'opened' && !isControlled) {\n          setState('entering');\n          enterTimer.current = setTimeout(() => {\n            setState('opened');\n\n            if (onOpen) {\n              onOpen(event);\n            }\n          }, showAfter);\n        }\n\n        event.preventDefault();\n        event.stopPropagation();\n      }\n    },\n    [onFocus, onOpen, onMouseOver, isControlled, state, showAfter]\n  );\n\n  const { onBlur, onMouseLeave } = props.children.props;\n\n  const handleLeave = useCallback(\n    (event) => {\n      clearTimeout(enterTimer.current);\n      clearTimeout(leaveTimer.current);\n\n      if (event.type === 'mouseleave' && onMouseLeave) {\n        onMouseLeave(event);\n      }\n\n      if (event.type === 'blur' && onBlur) {\n        onBlur(event);\n      }\n\n      if (closeAfter && state === 'opened') {\n        leaveTimer.current = setTimeout(() => {\n          const tooltipElement = popperInstance?.popper.querySelector(\n            '[data-testid=\"tooltip-message-wrapper\"]'\n          ) as HTMLElement;\n\n          if (tooltipElement) {\n            tooltipElement.addEventListener('animationend', () =>\n              handleClose()\n            );\n          } else {\n            handleClose();\n          }\n\n          setState('exiting');\n        }, closeAfter);\n      } else {\n        handleClose(event);\n      }\n    },\n    [closeAfter, onBlur, onMouseLeave, handleClose, state, popperInstance]\n  );\n\n  useEffect(() => {\n    // if tooltip was open, and then component\n    // updated to be off, we should close the tooltip\n    if (state === 'opened' && off) {\n      if (closeAfter) {\n        leaveTimer.current = setTimeout(() => {\n          handleClose();\n        }, closeAfter);\n      } else {\n        handleClose();\n      }\n    }\n  }, [off, closeAfter, handleClose, state]);\n\n  const childrenProps = {\n    // don't pass event listeners to children\n    onFocus: null,\n    onMouseOver: null,\n    onMouseLeave: null,\n    onBlur: null,\n  };\n\n  const tooltipProps = !off\n    ? {\n        'aria-describedby': tooltipIsOpen ? id : null,\n        // for seo and accessibility, we add the tooltip's title\n        // as a native title when the title is hidden\n        title:\n          !tooltipIsOpen &&\n          state !== 'entering' &&\n          typeof props.title === 'string'\n            ? props.title\n            : null,\n      }\n    : {};\n\n  const eventListeners = !off\n    ? {\n        onMouseEnter: handleEnter,\n        onMouseLeave: handleLeave,\n        onFocus: handleEnter,\n        onBlur: handleLeave,\n      }\n    : {};\n\n  const WrapperComponent = props.components?.WrapperComponent || Wrapper;\n  const BodyComponent = props.components?.BodyComponent || Body;\n  const TooltipWrapperComponent =\n    props.components?.TooltipWrapperComponent || TooltipWrapper;\n\n  return (\n    <>\n      <WrapperComponent\n        {...eventListeners}\n        // @ts-expect-error: yes, ref can be undefined\n        ref={reference.ref}\n      >\n        {cloneElement(props.children, {\n          ...childrenProps,\n          ...tooltipProps,\n        })}\n      </WrapperComponent>\n      {tooltipIsOpen && (\n        <TooltipWrapperComponent>\n          <div\n            // ref accepts `LegacyRef`, which is a union of `RefObject` and `string`\n            // propper.ref returns `RefObject`\n            ref={popper.ref as LegacyRef<HTMLDivElement>}\n            css={css({\n              ...popper.styles,\n              ...getBodyStyles({\n                constraint: horizontalConstraint,\n                placement: popper.placement,\n                customStyles: props.styles?.body,\n              }),\n            })}\n            data-placement={popper.placement}\n          >\n            <div\n              css={css({\n                ...getTooltipStyles(state),\n              })}\n              data-testid=\"tooltip-message-wrapper\"\n            >\n              <BodyComponent>{props.title}</BodyComponent>\n            </div>\n          </div>\n        </TooltipWrapperComponent>\n      )}\n    </>\n  );\n};\n\nTooltip.displayName = 'ToolTip';\n\nexport default Tooltip;\n"]} */"),
277
+ })), process.env.NODE_ENV === "production" ? "" : ";label:Tooltip;", process.env.NODE_ENV === "production" ? "" : "/*# sourceMappingURL=data:application/json;charset=utf-8;base64,{"version":3,"sources":["tooltip.tsx"],"names":[],"mappings":"AA0ViB","file":"tooltip.tsx","sourcesContent":["// inspired from https://github.com/mui-org/material-ui/blob/9ecc8db8abbfb829111d3b5c0678267827984024/packages/material-ui/src/Tooltip/Tooltip.js\nimport { Modifiers } from 'popper.js';\nimport {\n  type ComponentType,\n  type FocusEvent,\n  type ChangeEvent,\n  type Ref,\n  type CSSProperties,\n  type ReactElement,\n  useRef,\n  useEffect,\n  useCallback,\n  cloneElement,\n  useState,\n} from 'react';\nimport { isValidElementType } from 'react-is';\nimport isNil from 'lodash/isNil';\nimport usePopper from 'use-popper';\nimport { css } from '@emotion/react';\nimport { useFieldId } from '@commercetools-uikit/hooks';\nimport { createSequentialId, warning } from '@commercetools-uikit/utils';\nimport {\n  Wrapper,\n  Body,\n  getBodyStyles,\n  getTooltipStyles,\n} from './tooltip.styles';\n\nconst sequentialId = createSequentialId('tooltip-');\n\nexport type TComponents = {\n  /**\n   * The component rendered as the tooltip body.\n   */\n  BodyComponent?: ComponentType;\n  /**\n   * Where the tooltip should be rendered. This can be useful to render the tooltip into another part of the document, using React portal.\n   */\n  TooltipWrapperComponent?: ComponentType;\n  /**\n   * A custom component wrapper for the tooltip.\n   */\n  WrapperComponent?: ComponentType;\n};\n\nexport type TTooltipChildProps = {\n  onFocus?: Function | null;\n  onMouseOver?: Function | null;\n  onBlur?: Function | null;\n  onMouseLeave?: Function | null;\n} & Record<string, unknown>;\n\nexport type TTooltipProps = {\n  children: ReactElement<TTooltipChildProps>;\n\n  /**\n   * Delay (in milliseconds) between the start of the user interaction, and showing the tooltip.\n   */\n  showAfter?: number;\n  /**\n   * Delay (in milliseconds) between the end of the user interaction, and the closing of the tooltip.\n   */\n  closeAfter?: number;\n  /**\n   * Custom css-in-js object styles for the tooltip body.\n   */\n  styles?: Record<string, CSSProperties>;\n  /**\n   * Determines if the tooltip should not appear.\n   */\n  off?: boolean;\n  /**\n   * An identifier for the tooltip, used for `aria-describedby`.\n   */\n  id?: string;\n  /**\n   * A callback function, called when the tooltip is closing.\n   */\n  onClose?: (e?: ChangeEvent | FocusEvent) => void;\n  /**\n   * A callback function, called when the tooltip is opening.\n   */\n  onOpen?: (e?: ChangeEvent | FocusEvent) => void;\n  isOpen?: boolean;\n  /**\n   * How the tooltip is positioned relative to the child element.\n   */\n  placement?:\n    | 'top'\n    | 'top-start'\n    | 'top-end'\n    | 'right'\n    | 'right-start'\n    | 'right-end'\n    | 'bottom'\n    | 'bottom-start'\n    | 'bottom-end'\n    | 'left'\n    | 'left-start'\n    | 'left-end';\n  /**\n   * The message to show in the tooltip.\n   */\n  title: string;\n  /**\n   * Provides a way to fine-tune an appearance of underlying Popper tooltip element. For more information, please check [Popper.js documentation](https://popper.js.org/popper-documentation.html#modifiers).\n   */\n  modifiers?: Modifiers;\n  /**\n   * Customize the appearance of certain elements of the tooltip.\n   */\n  components?: TComponents;\n  /**\n   * Horizontal size limit of the tooltip.\n   */\n  horizontalConstraint?:\n    | 1\n    | 2\n    | 3\n    | 4\n    | 5\n    | 6\n    | 7\n    | 8\n    | 9\n    | 10\n    | 11\n    | 12\n    | 13\n    | 14\n    | 15\n    | 16\n    | 'scale'\n    | 'auto';\n};\n\nexport type TTooltipState = 'closed' | 'entering' | 'opened' | 'exiting';\n\nconst TooltipWrapper = (props: Pick<TTooltipProps, 'children'>) => (\n  <>{props.children}</>\n);\nTooltipWrapper.displayName = 'TooltipWrapperComponent';\n\nconst Tooltip = ({\n  showAfter = 300,\n  closeAfter = 200,\n  horizontalConstraint = 'scale',\n  off = false,\n  placement = 'top',\n  ...props\n}: TTooltipProps) => {\n  const enterTimer = useRef<ReturnType<typeof setTimeout>>(null);\n  const leaveTimer = useRef<ReturnType<typeof setTimeout>>(null);\n\n  if (props.components?.BodyComponent) {\n    warning(\n      isValidElementType(props.components.BodyComponent),\n      `ui-kit/Tooltip: the prop 'components.BodyComponent' is not a valid React element.`\n    );\n  }\n  if (props.components?.TooltipWrapperComponent) {\n    warning(\n      isValidElementType(props.components.TooltipWrapperComponent),\n      `ui-kit/Tooltip: the prop 'components.TooltipWrapperComponent' is not a valid React element.`\n    );\n  }\n  if (props.components?.WrapperComponent) {\n    warning(\n      isValidElementType(props.components.WrapperComponent),\n      `ui-kit/Tooltip: the prop 'components.WrapperComponent' is not a valid React element.`\n    );\n  }\n\n  useEffect(() => {\n    return () => {\n      if (enterTimer.current) {\n        clearTimeout(enterTimer.current);\n      }\n      if (leaveTimer.current) {\n        clearTimeout(leaveTimer.current);\n      }\n    };\n  }, []);\n\n  const { reference, popper, popperInstance } = usePopper({\n    placement: placement,\n    modifiers: props.modifiers,\n  });\n  const [state, setState] = useState<TTooltipState>('closed');\n\n  const isControlled = !isNil(props.isOpen);\n  const tooltipIsOpen = isControlled\n    ? props.isOpen\n    : state === 'opened' || state === 'exiting';\n  const id = useFieldId(props.id, sequentialId);\n\n  const { onClose } = props;\n  const handleClose = useCallback(\n    (event?: ChangeEvent | FocusEvent) => {\n      if (!isControlled) {\n        setState('closed');\n      }\n      if (onClose) {\n        onClose(event);\n      }\n    },\n    [isControlled, onClose]\n  );\n\n  const { onFocus, onMouseOver } = props.children.props;\n  const { onOpen } = props;\n  const handleEnter = useCallback(\n    (event?: ChangeEvent | FocusEvent) => {\n      if (event) {\n        if (event.type === 'mouseover' && onMouseOver) {\n          onMouseOver(event);\n        }\n\n        if (event.type === 'focus' && onFocus) {\n          onFocus(event);\n        }\n\n        if (state !== 'opened' && !isControlled) {\n          setState('entering');\n          enterTimer.current = setTimeout(() => {\n            setState('opened');\n\n            if (onOpen) {\n              onOpen(event);\n            }\n          }, showAfter);\n        }\n\n        event.preventDefault();\n        event.stopPropagation();\n      }\n    },\n    [onFocus, onOpen, onMouseOver, isControlled, state, showAfter]\n  );\n\n  const { onBlur, onMouseLeave } = props.children.props;\n\n  const handleLeave = useCallback(\n    (event: ChangeEvent | FocusEvent) => {\n      clearTimeout(enterTimer.current!);\n      clearTimeout(leaveTimer.current!);\n\n      if (event.type === 'mouseleave' && onMouseLeave) {\n        onMouseLeave(event);\n      }\n\n      if (event.type === 'blur' && onBlur) {\n        onBlur(event);\n      }\n\n      if (closeAfter && state === 'opened') {\n        leaveTimer.current = setTimeout(() => {\n          const tooltipElement = popperInstance?.popper.querySelector(\n            '[data-testid=\"tooltip-message-wrapper\"]'\n          ) as HTMLElement;\n\n          if (tooltipElement) {\n            tooltipElement.addEventListener('animationend', () =>\n              handleClose()\n            );\n          } else {\n            handleClose();\n          }\n\n          setState('exiting');\n        }, closeAfter);\n      } else {\n        handleClose(event);\n      }\n    },\n    [closeAfter, onBlur, onMouseLeave, handleClose, state, popperInstance]\n  );\n\n  useEffect(() => {\n    // if tooltip was open, and then component\n    // updated to be off, we should close the tooltip\n    if (state === 'opened' && off) {\n      if (closeAfter) {\n        leaveTimer.current = setTimeout(() => {\n          handleClose();\n        }, closeAfter);\n      } else {\n        handleClose();\n      }\n    }\n  }, [off, closeAfter, handleClose, state]);\n\n  const childrenProps = {\n    // don't pass event listeners to children\n    onFocus: null,\n    onMouseOver: null,\n    onMouseLeave: null,\n    onBlur: null,\n  };\n\n  const tooltipProps = !off\n    ? {\n        'aria-describedby': tooltipIsOpen ? id : null,\n        // for seo and accessibility, we add the tooltip's title\n        // as a native title when the title is hidden\n        title:\n          !tooltipIsOpen &&\n          state !== 'entering' &&\n          typeof props.title === 'string'\n            ? props.title\n            : null,\n      }\n    : {};\n\n  const eventListeners = !off\n    ? {\n        onMouseEnter: handleEnter,\n        onMouseLeave: handleLeave,\n        onFocus: handleEnter,\n        onBlur: handleLeave,\n      }\n    : {};\n\n  const WrapperComponent = props.components?.WrapperComponent || Wrapper;\n  const BodyComponent = props.components?.BodyComponent || Body;\n  const TooltipWrapperComponent =\n    props.components?.TooltipWrapperComponent || TooltipWrapper;\n\n  return (\n    <>\n      <WrapperComponent\n        {...eventListeners}\n        // @ts-expect-error: yes, ref can be undefined\n        ref={reference.ref}\n      >\n        {cloneElement(props.children, {\n          ...childrenProps,\n          ...tooltipProps,\n        })}\n      </WrapperComponent>\n      {tooltipIsOpen && (\n        <TooltipWrapperComponent>\n          <div\n            // ref accepts `LegacyRef`, which is a union of `RefObject` and `string`\n            // propper.ref returns `RefObject`\n            ref={popper.ref as Ref<HTMLDivElement>}\n            css={css({\n              ...popper.styles,\n              ...getBodyStyles({\n                constraint: horizontalConstraint,\n                placement: popper.placement,\n                customStyles: props.styles?.body,\n              }),\n            })}\n            data-placement={popper.placement}\n          >\n            <div\n              css={css({\n                ...getTooltipStyles(state),\n              })}\n              data-testid=\"tooltip-message-wrapper\"\n            >\n              <BodyComponent>{props.title}</BodyComponent>\n            </div>\n          </div>\n        </TooltipWrapperComponent>\n      )}\n    </>\n  );\n};\n\nTooltip.displayName = 'ToolTip';\n\nexport default Tooltip;\n"]} */"),
279
278
  "data-placement": popper.placement,
280
279
  children: jsx("div", {
281
- css: /*#__PURE__*/css(_objectSpread({}, getTooltipStyles(state)), process.env.NODE_ENV === "production" ? "" : ";label:Tooltip;", process.env.NODE_ENV === "production" ? "" : "/*# sourceMappingURL=data:application/json;charset=utf-8;base64,{"version":3,"sources":["tooltip.tsx"],"names":[],"mappings":"AA8VmB","file":"tooltip.tsx","sourcesContent":["// inspired from https://github.com/mui-org/material-ui/blob/9ecc8db8abbfb829111d3b5c0678267827984024/packages/material-ui/src/Tooltip/Tooltip.js\nimport { Modifiers } from 'popper.js';\nimport {\n  ComponentType,\n  FocusEvent,\n  ChangeEvent,\n  LegacyRef,\n  CSSProperties,\n  ReactElement,\n  useRef,\n  useEffect,\n  useCallback,\n  cloneElement,\n  useState,\n} from 'react';\nimport { isValidElementType } from 'react-is';\nimport isNil from 'lodash/isNil';\nimport usePopper from 'use-popper';\nimport { css } from '@emotion/react';\nimport { useFieldId } from '@commercetools-uikit/hooks';\nimport { createSequentialId, warning } from '@commercetools-uikit/utils';\nimport {\n  Wrapper,\n  Body,\n  getBodyStyles,\n  getTooltipStyles,\n} from './tooltip.styles';\n\nconst sequentialId = createSequentialId('tooltip-');\n\nexport type TComponents = {\n  /**\n   * The component rendered as the tooltip body.\n   */\n  BodyComponent?: ComponentType;\n  /**\n   * Where the tooltip should be rendered. This can be useful to render the tooltip into another part of the document, using React portal.\n   */\n  TooltipWrapperComponent?: ComponentType;\n  /**\n   * A custom component wrapper for the tooltip.\n   */\n  WrapperComponent?: ComponentType;\n};\n\nexport type TTooltipProps = {\n  children: ReactElement;\n\n  /**\n   * Delay (in milliseconds) between the start of the user interaction, and showing the tooltip.\n   */\n  showAfter?: number;\n  /**\n   * Delay (in milliseconds) between the end of the user interaction, and the closing of the tooltip.\n   */\n  closeAfter?: number;\n  /**\n   * Custom css-in-js object styles for the tooltip body.\n   */\n  styles?: Record<string, CSSProperties>;\n  /**\n   * Determines if the tooltip should not appear.\n   */\n  off?: boolean;\n  /**\n   * An identifier for the tooltip, used for `aria-describedby`.\n   */\n  id?: string;\n  /**\n   * A callback function, called when the tooltip is closing.\n   */\n  onClose?: (e?: ChangeEvent | FocusEvent) => void;\n  /**\n   * A callback function, called when the tooltip is opening.\n   */\n  onOpen?: (e?: ChangeEvent | FocusEvent) => void;\n  isOpen?: boolean;\n  /**\n   * How the tooltip is positioned relative to the child element.\n   */\n  placement?:\n    | 'top'\n    | 'top-start'\n    | 'top-end'\n    | 'right'\n    | 'right-start'\n    | 'right-end'\n    | 'bottom'\n    | 'bottom-start'\n    | 'bottom-end'\n    | 'left'\n    | 'left-start'\n    | 'left-end';\n  /**\n   * The message to show in the tooltip.\n   */\n  title: string;\n  /**\n   * Provides a way to fine-tune an appearance of underlying Popper tooltip element. For more information, please check [Popper.js documentation](https://popper.js.org/popper-documentation.html#modifiers).\n   */\n  modifiers?: Modifiers;\n  /**\n   * Customize the appearance of certain elements of the tooltip.\n   */\n  components?: TComponents;\n  /**\n   * Horizontal size limit of the tooltip.\n   */\n  horizontalConstraint?:\n    | 1\n    | 2\n    | 3\n    | 4\n    | 5\n    | 6\n    | 7\n    | 8\n    | 9\n    | 10\n    | 11\n    | 12\n    | 13\n    | 14\n    | 15\n    | 16\n    | 'scale'\n    | 'auto';\n};\n\nexport type TTooltipState = 'closed' | 'entering' | 'opened' | 'exiting';\n\nconst TooltipWrapper = (props: Pick<TTooltipProps, 'children'>) => (\n  <>{props.children}</>\n);\nTooltipWrapper.displayName = 'TooltipWrapperComponent';\n\nconst Tooltip = ({\n  showAfter = 300,\n  closeAfter = 200,\n  horizontalConstraint = 'scale',\n  off = false,\n  placement = 'top',\n  ...props\n}: TTooltipProps) => {\n  const enterTimer = useRef<ReturnType<typeof setTimeout>>();\n  const leaveTimer = useRef<ReturnType<typeof setTimeout>>();\n\n  if (props.components?.BodyComponent) {\n    warning(\n      isValidElementType(props.components.BodyComponent),\n      `ui-kit/Tooltip: the prop 'components.BodyComponent' is not a valid React element.`\n    );\n  }\n  if (props.components?.TooltipWrapperComponent) {\n    warning(\n      isValidElementType(props.components.TooltipWrapperComponent),\n      `ui-kit/Tooltip: the prop 'components.TooltipWrapperComponent' is not a valid React element.`\n    );\n  }\n  if (props.components?.WrapperComponent) {\n    warning(\n      isValidElementType(props.components.WrapperComponent),\n      `ui-kit/Tooltip: the prop 'components.WrapperComponent' is not a valid React element.`\n    );\n  }\n\n  useEffect(() => {\n    return () => {\n      if (enterTimer.current) {\n        clearTimeout(enterTimer.current);\n      }\n      if (leaveTimer.current) {\n        clearTimeout(leaveTimer.current);\n      }\n    };\n  }, []);\n\n  const { reference, popper, popperInstance } = usePopper({\n    placement: placement,\n    modifiers: props.modifiers,\n  });\n  const [state, setState] = useState<TTooltipState>('closed');\n\n  const isControlled = !isNil(props.isOpen);\n  const tooltipIsOpen = isControlled\n    ? props.isOpen\n    : state === 'opened' || state === 'exiting';\n  const id = useFieldId(props.id, sequentialId);\n\n  const { onClose } = props;\n  const handleClose = useCallback(\n    (event?: ChangeEvent | FocusEvent) => {\n      if (!isControlled) {\n        setState('closed');\n      }\n      if (onClose) {\n        onClose(event);\n      }\n    },\n    [isControlled, onClose]\n  );\n\n  const { onFocus, onMouseOver } = props.children.props;\n  const { onOpen } = props;\n  const handleEnter = useCallback(\n    (event?: ChangeEvent | FocusEvent) => {\n      if (event) {\n        if (event.type === 'mouseover' && onMouseOver) {\n          onMouseOver(event);\n        }\n\n        if (event.type === 'focus' && onFocus) {\n          onFocus(event);\n        }\n\n        if (state !== 'opened' && !isControlled) {\n          setState('entering');\n          enterTimer.current = setTimeout(() => {\n            setState('opened');\n\n            if (onOpen) {\n              onOpen(event);\n            }\n          }, showAfter);\n        }\n\n        event.preventDefault();\n        event.stopPropagation();\n      }\n    },\n    [onFocus, onOpen, onMouseOver, isControlled, state, showAfter]\n  );\n\n  const { onBlur, onMouseLeave } = props.children.props;\n\n  const handleLeave = useCallback(\n    (event) => {\n      clearTimeout(enterTimer.current);\n      clearTimeout(leaveTimer.current);\n\n      if (event.type === 'mouseleave' && onMouseLeave) {\n        onMouseLeave(event);\n      }\n\n      if (event.type === 'blur' && onBlur) {\n        onBlur(event);\n      }\n\n      if (closeAfter && state === 'opened') {\n        leaveTimer.current = setTimeout(() => {\n          const tooltipElement = popperInstance?.popper.querySelector(\n            '[data-testid=\"tooltip-message-wrapper\"]'\n          ) as HTMLElement;\n\n          if (tooltipElement) {\n            tooltipElement.addEventListener('animationend', () =>\n              handleClose()\n            );\n          } else {\n            handleClose();\n          }\n\n          setState('exiting');\n        }, closeAfter);\n      } else {\n        handleClose(event);\n      }\n    },\n    [closeAfter, onBlur, onMouseLeave, handleClose, state, popperInstance]\n  );\n\n  useEffect(() => {\n    // if tooltip was open, and then component\n    // updated to be off, we should close the tooltip\n    if (state === 'opened' && off) {\n      if (closeAfter) {\n        leaveTimer.current = setTimeout(() => {\n          handleClose();\n        }, closeAfter);\n      } else {\n        handleClose();\n      }\n    }\n  }, [off, closeAfter, handleClose, state]);\n\n  const childrenProps = {\n    // don't pass event listeners to children\n    onFocus: null,\n    onMouseOver: null,\n    onMouseLeave: null,\n    onBlur: null,\n  };\n\n  const tooltipProps = !off\n    ? {\n        'aria-describedby': tooltipIsOpen ? id : null,\n        // for seo and accessibility, we add the tooltip's title\n        // as a native title when the title is hidden\n        title:\n          !tooltipIsOpen &&\n          state !== 'entering' &&\n          typeof props.title === 'string'\n            ? props.title\n            : null,\n      }\n    : {};\n\n  const eventListeners = !off\n    ? {\n        onMouseEnter: handleEnter,\n        onMouseLeave: handleLeave,\n        onFocus: handleEnter,\n        onBlur: handleLeave,\n      }\n    : {};\n\n  const WrapperComponent = props.components?.WrapperComponent || Wrapper;\n  const BodyComponent = props.components?.BodyComponent || Body;\n  const TooltipWrapperComponent =\n    props.components?.TooltipWrapperComponent || TooltipWrapper;\n\n  return (\n    <>\n      <WrapperComponent\n        {...eventListeners}\n        // @ts-expect-error: yes, ref can be undefined\n        ref={reference.ref}\n      >\n        {cloneElement(props.children, {\n          ...childrenProps,\n          ...tooltipProps,\n        })}\n      </WrapperComponent>\n      {tooltipIsOpen && (\n        <TooltipWrapperComponent>\n          <div\n            // ref accepts `LegacyRef`, which is a union of `RefObject` and `string`\n            // propper.ref returns `RefObject`\n            ref={popper.ref as LegacyRef<HTMLDivElement>}\n            css={css({\n              ...popper.styles,\n              ...getBodyStyles({\n                constraint: horizontalConstraint,\n                placement: popper.placement,\n                customStyles: props.styles?.body,\n              }),\n            })}\n            data-placement={popper.placement}\n          >\n            <div\n              css={css({\n                ...getTooltipStyles(state),\n              })}\n              data-testid=\"tooltip-message-wrapper\"\n            >\n              <BodyComponent>{props.title}</BodyComponent>\n            </div>\n          </div>\n        </TooltipWrapperComponent>\n      )}\n    </>\n  );\n};\n\nTooltip.displayName = 'ToolTip';\n\nexport default Tooltip;\n"]} */"),
280
+ css: /*#__PURE__*/css(_objectSpread({}, getTooltipStyles(state)), process.env.NODE_ENV === "production" ? "" : ";label:Tooltip;", process.env.NODE_ENV === "production" ? "" : "/*# sourceMappingURL=data:application/json;charset=utf-8;base64,{"version":3,"sources":["tooltip.tsx"],"names":[],"mappings":"AAqWmB","file":"tooltip.tsx","sourcesContent":["// inspired from https://github.com/mui-org/material-ui/blob/9ecc8db8abbfb829111d3b5c0678267827984024/packages/material-ui/src/Tooltip/Tooltip.js\nimport { Modifiers } from 'popper.js';\nimport {\n  type ComponentType,\n  type FocusEvent,\n  type ChangeEvent,\n  type Ref,\n  type CSSProperties,\n  type ReactElement,\n  useRef,\n  useEffect,\n  useCallback,\n  cloneElement,\n  useState,\n} from 'react';\nimport { isValidElementType } from 'react-is';\nimport isNil from 'lodash/isNil';\nimport usePopper from 'use-popper';\nimport { css } from '@emotion/react';\nimport { useFieldId } from '@commercetools-uikit/hooks';\nimport { createSequentialId, warning } from '@commercetools-uikit/utils';\nimport {\n  Wrapper,\n  Body,\n  getBodyStyles,\n  getTooltipStyles,\n} from './tooltip.styles';\n\nconst sequentialId = createSequentialId('tooltip-');\n\nexport type TComponents = {\n  /**\n   * The component rendered as the tooltip body.\n   */\n  BodyComponent?: ComponentType;\n  /**\n   * Where the tooltip should be rendered. This can be useful to render the tooltip into another part of the document, using React portal.\n   */\n  TooltipWrapperComponent?: ComponentType;\n  /**\n   * A custom component wrapper for the tooltip.\n   */\n  WrapperComponent?: ComponentType;\n};\n\nexport type TTooltipChildProps = {\n  onFocus?: Function | null;\n  onMouseOver?: Function | null;\n  onBlur?: Function | null;\n  onMouseLeave?: Function | null;\n} & Record<string, unknown>;\n\nexport type TTooltipProps = {\n  children: ReactElement<TTooltipChildProps>;\n\n  /**\n   * Delay (in milliseconds) between the start of the user interaction, and showing the tooltip.\n   */\n  showAfter?: number;\n  /**\n   * Delay (in milliseconds) between the end of the user interaction, and the closing of the tooltip.\n   */\n  closeAfter?: number;\n  /**\n   * Custom css-in-js object styles for the tooltip body.\n   */\n  styles?: Record<string, CSSProperties>;\n  /**\n   * Determines if the tooltip should not appear.\n   */\n  off?: boolean;\n  /**\n   * An identifier for the tooltip, used for `aria-describedby`.\n   */\n  id?: string;\n  /**\n   * A callback function, called when the tooltip is closing.\n   */\n  onClose?: (e?: ChangeEvent | FocusEvent) => void;\n  /**\n   * A callback function, called when the tooltip is opening.\n   */\n  onOpen?: (e?: ChangeEvent | FocusEvent) => void;\n  isOpen?: boolean;\n  /**\n   * How the tooltip is positioned relative to the child element.\n   */\n  placement?:\n    | 'top'\n    | 'top-start'\n    | 'top-end'\n    | 'right'\n    | 'right-start'\n    | 'right-end'\n    | 'bottom'\n    | 'bottom-start'\n    | 'bottom-end'\n    | 'left'\n    | 'left-start'\n    | 'left-end';\n  /**\n   * The message to show in the tooltip.\n   */\n  title: string;\n  /**\n   * Provides a way to fine-tune an appearance of underlying Popper tooltip element. For more information, please check [Popper.js documentation](https://popper.js.org/popper-documentation.html#modifiers).\n   */\n  modifiers?: Modifiers;\n  /**\n   * Customize the appearance of certain elements of the tooltip.\n   */\n  components?: TComponents;\n  /**\n   * Horizontal size limit of the tooltip.\n   */\n  horizontalConstraint?:\n    | 1\n    | 2\n    | 3\n    | 4\n    | 5\n    | 6\n    | 7\n    | 8\n    | 9\n    | 10\n    | 11\n    | 12\n    | 13\n    | 14\n    | 15\n    | 16\n    | 'scale'\n    | 'auto';\n};\n\nexport type TTooltipState = 'closed' | 'entering' | 'opened' | 'exiting';\n\nconst TooltipWrapper = (props: Pick<TTooltipProps, 'children'>) => (\n  <>{props.children}</>\n);\nTooltipWrapper.displayName = 'TooltipWrapperComponent';\n\nconst Tooltip = ({\n  showAfter = 300,\n  closeAfter = 200,\n  horizontalConstraint = 'scale',\n  off = false,\n  placement = 'top',\n  ...props\n}: TTooltipProps) => {\n  const enterTimer = useRef<ReturnType<typeof setTimeout>>(null);\n  const leaveTimer = useRef<ReturnType<typeof setTimeout>>(null);\n\n  if (props.components?.BodyComponent) {\n    warning(\n      isValidElementType(props.components.BodyComponent),\n      `ui-kit/Tooltip: the prop 'components.BodyComponent' is not a valid React element.`\n    );\n  }\n  if (props.components?.TooltipWrapperComponent) {\n    warning(\n      isValidElementType(props.components.TooltipWrapperComponent),\n      `ui-kit/Tooltip: the prop 'components.TooltipWrapperComponent' is not a valid React element.`\n    );\n  }\n  if (props.components?.WrapperComponent) {\n    warning(\n      isValidElementType(props.components.WrapperComponent),\n      `ui-kit/Tooltip: the prop 'components.WrapperComponent' is not a valid React element.`\n    );\n  }\n\n  useEffect(() => {\n    return () => {\n      if (enterTimer.current) {\n        clearTimeout(enterTimer.current);\n      }\n      if (leaveTimer.current) {\n        clearTimeout(leaveTimer.current);\n      }\n    };\n  }, []);\n\n  const { reference, popper, popperInstance } = usePopper({\n    placement: placement,\n    modifiers: props.modifiers,\n  });\n  const [state, setState] = useState<TTooltipState>('closed');\n\n  const isControlled = !isNil(props.isOpen);\n  const tooltipIsOpen = isControlled\n    ? props.isOpen\n    : state === 'opened' || state === 'exiting';\n  const id = useFieldId(props.id, sequentialId);\n\n  const { onClose } = props;\n  const handleClose = useCallback(\n    (event?: ChangeEvent | FocusEvent) => {\n      if (!isControlled) {\n        setState('closed');\n      }\n      if (onClose) {\n        onClose(event);\n      }\n    },\n    [isControlled, onClose]\n  );\n\n  const { onFocus, onMouseOver } = props.children.props;\n  const { onOpen } = props;\n  const handleEnter = useCallback(\n    (event?: ChangeEvent | FocusEvent) => {\n      if (event) {\n        if (event.type === 'mouseover' && onMouseOver) {\n          onMouseOver(event);\n        }\n\n        if (event.type === 'focus' && onFocus) {\n          onFocus(event);\n        }\n\n        if (state !== 'opened' && !isControlled) {\n          setState('entering');\n          enterTimer.current = setTimeout(() => {\n            setState('opened');\n\n            if (onOpen) {\n              onOpen(event);\n            }\n          }, showAfter);\n        }\n\n        event.preventDefault();\n        event.stopPropagation();\n      }\n    },\n    [onFocus, onOpen, onMouseOver, isControlled, state, showAfter]\n  );\n\n  const { onBlur, onMouseLeave } = props.children.props;\n\n  const handleLeave = useCallback(\n    (event: ChangeEvent | FocusEvent) => {\n      clearTimeout(enterTimer.current!);\n      clearTimeout(leaveTimer.current!);\n\n      if (event.type === 'mouseleave' && onMouseLeave) {\n        onMouseLeave(event);\n      }\n\n      if (event.type === 'blur' && onBlur) {\n        onBlur(event);\n      }\n\n      if (closeAfter && state === 'opened') {\n        leaveTimer.current = setTimeout(() => {\n          const tooltipElement = popperInstance?.popper.querySelector(\n            '[data-testid=\"tooltip-message-wrapper\"]'\n          ) as HTMLElement;\n\n          if (tooltipElement) {\n            tooltipElement.addEventListener('animationend', () =>\n              handleClose()\n            );\n          } else {\n            handleClose();\n          }\n\n          setState('exiting');\n        }, closeAfter);\n      } else {\n        handleClose(event);\n      }\n    },\n    [closeAfter, onBlur, onMouseLeave, handleClose, state, popperInstance]\n  );\n\n  useEffect(() => {\n    // if tooltip was open, and then component\n    // updated to be off, we should close the tooltip\n    if (state === 'opened' && off) {\n      if (closeAfter) {\n        leaveTimer.current = setTimeout(() => {\n          handleClose();\n        }, closeAfter);\n      } else {\n        handleClose();\n      }\n    }\n  }, [off, closeAfter, handleClose, state]);\n\n  const childrenProps = {\n    // don't pass event listeners to children\n    onFocus: null,\n    onMouseOver: null,\n    onMouseLeave: null,\n    onBlur: null,\n  };\n\n  const tooltipProps = !off\n    ? {\n        'aria-describedby': tooltipIsOpen ? id : null,\n        // for seo and accessibility, we add the tooltip's title\n        // as a native title when the title is hidden\n        title:\n          !tooltipIsOpen &&\n          state !== 'entering' &&\n          typeof props.title === 'string'\n            ? props.title\n            : null,\n      }\n    : {};\n\n  const eventListeners = !off\n    ? {\n        onMouseEnter: handleEnter,\n        onMouseLeave: handleLeave,\n        onFocus: handleEnter,\n        onBlur: handleLeave,\n      }\n    : {};\n\n  const WrapperComponent = props.components?.WrapperComponent || Wrapper;\n  const BodyComponent = props.components?.BodyComponent || Body;\n  const TooltipWrapperComponent =\n    props.components?.TooltipWrapperComponent || TooltipWrapper;\n\n  return (\n    <>\n      <WrapperComponent\n        {...eventListeners}\n        // @ts-expect-error: yes, ref can be undefined\n        ref={reference.ref}\n      >\n        {cloneElement(props.children, {\n          ...childrenProps,\n          ...tooltipProps,\n        })}\n      </WrapperComponent>\n      {tooltipIsOpen && (\n        <TooltipWrapperComponent>\n          <div\n            // ref accepts `LegacyRef`, which is a union of `RefObject` and `string`\n            // propper.ref returns `RefObject`\n            ref={popper.ref as Ref<HTMLDivElement>}\n            css={css({\n              ...popper.styles,\n              ...getBodyStyles({\n                constraint: horizontalConstraint,\n                placement: popper.placement,\n                customStyles: props.styles?.body,\n              }),\n            })}\n            data-placement={popper.placement}\n          >\n            <div\n              css={css({\n                ...getTooltipStyles(state),\n              })}\n              data-testid=\"tooltip-message-wrapper\"\n            >\n              <BodyComponent>{props.title}</BodyComponent>\n            </div>\n          </div>\n        </TooltipWrapperComponent>\n      )}\n    </>\n  );\n};\n\nTooltip.displayName = 'ToolTip';\n\nexport default Tooltip;\n"]} */"),
282
281
  "data-testid": "tooltip-message-wrapper",
283
282
  children: jsx(BodyComponent, {
284
283
  children: props.title
@@ -288,30 +287,10 @@ const Tooltip = _ref => {
288
287
  })]
289
288
  });
290
289
  };
291
- Tooltip.propTypes = process.env.NODE_ENV !== "production" ? {
292
- children: _pt.element.isRequired,
293
- showAfter: _pt.number,
294
- closeAfter: _pt.number,
295
- styles: _pt.objectOf(_pt.any),
296
- off: _pt.bool,
297
- id: _pt.string,
298
- onClose: _pt.func,
299
- onOpen: _pt.func,
300
- isOpen: _pt.bool,
301
- placement: _pt.oneOf(['top', 'top-start', 'top-end', 'right', 'right-start', 'right-end', 'bottom', 'bottom-start', 'bottom-end', 'left', 'left-start', 'left-end']),
302
- title: _pt.string.isRequired,
303
- modifiers: _pt.any,
304
- components: _pt.shape({
305
- BodyComponent: _pt.elementType,
306
- TooltipWrapperComponent: _pt.elementType,
307
- WrapperComponent: _pt.elementType
308
- }),
309
- horizontalConstraint: _pt.oneOf([1, 2, 3, 4, 5, 6, 7, 8, 9, 10, 11, 12, 13, 14, 15, 16, 'scale', 'auto'])
310
- } : {};
311
290
  Tooltip.displayName = 'ToolTip';
312
291
  var Tooltip$1 = Tooltip;
313
292
 
314
293
  // NOTE: This string will be replaced on build time with the package version.
315
- var version = "19.25.1";
294
+ var version = "20.0.0";
316
295
 
317
296
  export { Tooltip$1 as default, version };
@@ -1 +1 @@
1
- export type { TTooltipProps, TComponents } from "./tooltip.js";
1
+ export type { TTooltipProps, TComponents, TTooltipChildProps } from "./tooltip.js";
@@ -1,5 +1,5 @@
1
1
  import { Modifiers } from 'popper.js';
2
- import { ComponentType, FocusEvent, ChangeEvent, CSSProperties, ReactElement } from 'react';
2
+ import { type ComponentType, type FocusEvent, type ChangeEvent, type CSSProperties, type ReactElement } from 'react';
3
3
  export type TComponents = {
4
4
  /**
5
5
  * The component rendered as the tooltip body.
@@ -14,8 +14,14 @@ export type TComponents = {
14
14
  */
15
15
  WrapperComponent?: ComponentType;
16
16
  };
17
+ export type TTooltipChildProps = {
18
+ onFocus?: Function | null;
19
+ onMouseOver?: Function | null;
20
+ onBlur?: Function | null;
21
+ onMouseLeave?: Function | null;
22
+ } & Record<string, unknown>;
17
23
  export type TTooltipProps = {
18
- children: ReactElement;
24
+ children: ReactElement<TTooltipChildProps>;
19
25
  /**
20
26
  * Delay (in milliseconds) between the start of the user interaction, and showing the tooltip.
21
27
  */
package/package.json CHANGED
@@ -1,7 +1,7 @@
1
1
  {
2
2
  "name": "@commercetools-uikit/tooltip",
3
3
  "description": "Tooltips display informative text when users hover over or focus on an element.",
4
- "version": "19.25.1",
4
+ "version": "20.0.0",
5
5
  "bugs": "https://github.com/commercetools/ui-kit/issues",
6
6
  "repository": {
7
7
  "type": "git",
@@ -21,21 +21,20 @@
21
21
  "dependencies": {
22
22
  "@babel/runtime": "^7.20.13",
23
23
  "@babel/runtime-corejs3": "^7.20.13",
24
- "@commercetools-uikit/constraints": "19.25.1",
25
- "@commercetools-uikit/design-system": "19.25.1",
26
- "@commercetools-uikit/hooks": "19.25.1",
27
- "@commercetools-uikit/utils": "19.25.1",
24
+ "@commercetools-uikit/constraints": "20.0.0",
25
+ "@commercetools-uikit/design-system": "20.0.0",
26
+ "@commercetools-uikit/hooks": "20.0.0",
27
+ "@commercetools-uikit/utils": "20.0.0",
28
28
  "@emotion/react": "^11.10.5",
29
29
  "@emotion/styled": "^11.10.5",
30
30
  "lodash": "4.17.21",
31
- "prop-types": "15.8.1",
32
- "react-is": "17.0.2",
31
+ "react-is": "19.0.0",
33
32
  "use-popper": "1.1.6"
34
33
  },
35
34
  "devDependencies": {
36
- "react": "17.0.2"
35
+ "react": "19.0.0"
37
36
  },
38
37
  "peerDependencies": {
39
- "react": "17.x"
38
+ "react": "19.x"
40
39
  }
41
40
  }