react-magma-dom 4.10.0-next.26 → 4.10.0-next.27

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.
package/dist/index.d.ts CHANGED
@@ -43,7 +43,7 @@ export { Input, InputProps } from './components/Input';
43
43
  export { InputBase, InputBaseProps, InputIconPosition, InputSize, InputType, } from './components/InputBase';
44
44
  export { InputMessage } from './components/Input/InputMessage';
45
45
  export { Label, LabelPosition } from './components/Label';
46
- export { LoadingIndicator, LoadingIndicatorProps, } from './components/LoadingIndicator';
46
+ export { LoadingIndicator, LoadingIndicatorProps, LoadingIndicatorType, } from './components/LoadingIndicator';
47
47
  export { NativeSelect, NativeSelectProps } from './components/NativeSelect';
48
48
  export { NavTabs } from './components/NavTabs';
49
49
  export { NavTab } from './components/NavTabs/NavTab';
@@ -12143,12 +12143,12 @@
12143
12143
  "typeArguments": [
12144
12144
  {
12145
12145
  "type": "reference",
12146
- "id": 31645,
12146
+ "id": 31648,
12147
12147
  "name": "IconOnlyPopoverTriggerProps"
12148
12148
  },
12149
12149
  {
12150
12150
  "type": "reference",
12151
- "id": 31650,
12151
+ "id": 31653,
12152
12152
  "name": "IconTextPopoverTriggerProps"
12153
12153
  }
12154
12154
  ],
@@ -18168,12 +18168,12 @@
18168
18168
  "typeArguments": [
18169
18169
  {
18170
18170
  "type": "reference",
18171
- "id": 36050,
18171
+ "id": 36054,
18172
18172
  "name": "ToggleButtonTextProps"
18173
18173
  },
18174
18174
  {
18175
18175
  "type": "reference",
18176
- "id": 36334,
18176
+ "id": 36338,
18177
18177
  "name": "ToggleButtonIconProps"
18178
18178
  }
18179
18179
  ],
@@ -19713,7 +19713,7 @@
19713
19713
  "type": "query",
19714
19714
  "queryType": {
19715
19715
  "type": "reference",
19716
- "id": 34785,
19716
+ "id": 34789,
19717
19717
  "name": "useTreeView"
19718
19718
  }
19719
19719
  }
@@ -10311,11 +10311,10 @@ var ProgressBar = /*#__PURE__*/React.forwardRef(function (props, ref) {
10311
10311
 
10312
10312
  var _excluded$15 = ["color", "testId", "type"];
10313
10313
  function _EMOTION_STRINGIFIED_CSS_ERROR__$s() { return "You have tried to stringify object returned from `css` function. It isn't supposed to be used directly (e.g. as value of the `className` prop), but rather handed to emotion so it can handle it (e.g. as value of `css` prop)."; }
10314
- var LoadingIndicatorType;
10315
10314
  (function (LoadingIndicatorType) {
10316
10315
  LoadingIndicatorType["progressbar"] = "progressbar";
10317
10316
  LoadingIndicatorType["spinner"] = "spinner";
10318
- })(LoadingIndicatorType || (LoadingIndicatorType = {}));
10317
+ })(exports.LoadingIndicatorType || (exports.LoadingIndicatorType = {}));
10319
10318
  var StyledLoadingIndicator = /*#__PURE__*/_styled("div", {
10320
10319
  target: "et6g0oe2",
10321
10320
  label: "StyledLoadingIndicator"
@@ -10352,10 +10351,10 @@ var LoadingIndicator = /*#__PURE__*/React.forwardRef(function (props, ref) {
10352
10351
  var loadingIndicatorType = props.type;
10353
10352
  var messageLevel2Timeout = setTimeout(function () {
10354
10353
  setMessageLevel(2);
10355
- }, loadingIndicatorType === LoadingIndicatorType.progressbar ? 10000 : 5000);
10354
+ }, loadingIndicatorType === exports.LoadingIndicatorType.progressbar ? 10000 : 5000);
10356
10355
  var messageLevel3Timeout = setTimeout(function () {
10357
10356
  setMessageLevel(3);
10358
- }, loadingIndicatorType === LoadingIndicatorType.progressbar ? 30000 : 15000);
10357
+ }, loadingIndicatorType === exports.LoadingIndicatorType.progressbar ? 30000 : 15000);
10359
10358
  return function () {
10360
10359
  clearTimeout(messageLevel2Timeout);
10361
10360
  clearTimeout(messageLevel3Timeout);
@@ -10368,14 +10367,14 @@ var LoadingIndicator = /*#__PURE__*/React.forwardRef(function (props, ref) {
10368
10367
  var message1 = props.message1,
10369
10368
  message2 = props.message2,
10370
10369
  message3 = props.message3;
10371
- message1 = message1 ? message1 : type === LoadingIndicatorType.progressbar ? i18n.loadingIndicator.progressBar.messages.first : i18n.loadingIndicator.spinner.messages.first;
10372
- message2 = message2 ? message2 : type === LoadingIndicatorType.progressbar ? i18n.loadingIndicator.progressBar.messages.second : i18n.loadingIndicator.spinner.messages.second;
10373
- message3 = message3 ? message3 : type === LoadingIndicatorType.progressbar ? i18n.loadingIndicator.progressBar.messages.third : i18n.loadingIndicator.spinner.messages.third;
10370
+ message1 = message1 ? message1 : type === exports.LoadingIndicatorType.progressbar ? i18n.loadingIndicator.progressBar.messages.first : i18n.loadingIndicator.spinner.messages.first;
10371
+ message2 = message2 ? message2 : type === exports.LoadingIndicatorType.progressbar ? i18n.loadingIndicator.progressBar.messages.second : i18n.loadingIndicator.spinner.messages.second;
10372
+ message3 = message3 ? message3 : type === exports.LoadingIndicatorType.progressbar ? i18n.loadingIndicator.progressBar.messages.third : i18n.loadingIndicator.spinner.messages.third;
10374
10373
  return React.createElement(StyledLoadingIndicator, {
10375
10374
  "aria-busy": "true",
10376
10375
  "data-testid": testId,
10377
10376
  ref: ref
10378
- }, type === LoadingIndicatorType.progressbar ? React.createElement(ProgressBar, Object.assign({}, other, {
10377
+ }, type === exports.LoadingIndicatorType.progressbar ? React.createElement(ProgressBar, Object.assign({}, other, {
10379
10378
  color: color,
10380
10379
  height: theme.spaceScale.spacing03,
10381
10380
  isAnimated: true,
@@ -15743,7 +15742,7 @@ var StyledContainer$5 = /*#__PURE__*/_styled("div", {
15743
15742
  label: "StyledContainer"
15744
15743
  })( {
15745
15744
  name: "1r5gb7q",
15746
- styles: "display:inline-block/*# sourceMappingURL=data:application/json;charset=utf-8;base64,{"version":3,"sources":["Popover.tsx"],"names":[],"mappings":"AAiBmC","file":"Popover.tsx","sourcesContent":["import React from 'react';\r\nimport styled from '@emotion/styled';\r\nimport { offset, flip, autoUpdate, arrow, shift, useFloating, } from '@floating-ui/react';\r\nimport { useIsInverse } from '../../inverse';\r\nimport { resolveProps, useForkedRef, useGenerateId } from '../../utils';\r\nimport { ButtonGroupContext } from '../ButtonGroup';\r\nexport var PopoverPosition;\r\n(function (PopoverPosition) {\r\n    PopoverPosition[\"bottom\"] = \"bottom\";\r\n    PopoverPosition[\"top\"] = \"top\";\r\n})(PopoverPosition || (PopoverPosition = {}));\r\nexport var PopoverAlignment;\r\n(function (PopoverAlignment) {\r\n    PopoverAlignment[\"center\"] = \"center\";\r\n    PopoverAlignment[\"start\"] = \"start\";\r\n    PopoverAlignment[\"end\"] = \"end\";\r\n})(PopoverAlignment || (PopoverAlignment = {}));\r\nconst StyledContainer = styled.div `\n  display: inline-block;\n`;\r\nexport const PopoverContext = React.createContext({\r\n    isOpen: false,\r\n    setIsOpen: () => false,\r\n});\r\nexport function hasActiveElementsChecker(ref) {\r\n    return (Array.from(ref.current?.querySelectorAll('button, [href], input, select, textarea, [tabindex]:not([tabindex=\"-1\"]), video') || []).filter((element) => {\r\n        const style = window.getComputedStyle(element);\r\n        return (element instanceof HTMLElement &&\r\n            style.display !== 'none' &&\r\n            style.visibility !== 'hidden' &&\r\n            !element.hasAttribute('disabled'));\r\n    }).length > 0);\r\n}\r\nexport const Popover = React.forwardRef((props, forwardedRef) => {\r\n    const [isOpen, setIsOpen] = React.useState(false);\r\n    const contextProps = React.useContext(ButtonGroupContext);\r\n    const resolvedProps = resolveProps(contextProps, props);\r\n    const ownRef = React.useRef();\r\n    const toggleRef = React.useRef();\r\n    const contentRef = React.useRef(null);\r\n    const popoverContentId = React.useRef('');\r\n    const popoverTriggerId = React.useRef('');\r\n    const arrowRef = React.useRef(null);\r\n    const hasActiveElements = React.useMemo(() => hasActiveElementsChecker(contentRef), [contentRef, contentRef.current]);\r\n    const { onClose, onOpen, position = PopoverPosition.bottom, children, testId, maxHeight, width, hoverable, isDisabled, hasPointer = true, openByDefault, id: defaultId, apiRef, focusTrap, alignment = PopoverAlignment.center, ...other } = props;\r\n    React.useEffect(() => {\r\n        if (apiRef) {\r\n            apiRef.current = {\r\n                closePopoverManually(event) {\r\n                    closePopover(event);\r\n                },\r\n                openPopoverManually(event) {\r\n                    openPopover();\r\n                },\r\n            };\r\n        }\r\n        if (openByDefault) {\r\n            openPopover();\r\n        }\r\n    }, []);\r\n    React.useEffect(() => {\r\n        const handleEsc = event => {\r\n            if (event.key === 'Escape' && isOpen) {\r\n                closePopover(event);\r\n            }\r\n        };\r\n        window.addEventListener('keydown', handleEsc);\r\n        return () => {\r\n            window.removeEventListener('keydown', handleEsc);\r\n        };\r\n    }, [isOpen]);\r\n    const popoverId = useGenerateId(defaultId);\r\n    popoverTriggerId.current = `${popoverId}_trigger`;\r\n    popoverContentId.current = `${popoverId}_content`;\r\n    const ref = useForkedRef(forwardedRef, ownRef);\r\n    const isInverse = useIsInverse(resolvedProps.isInverse);\r\n    const handleMouseOver = () => {\r\n        if (hoverable && !isDisabled && !hasActiveElements) {\r\n            setIsOpen(true);\r\n        }\r\n    };\r\n    const handleMouseLeave = () => {\r\n        if (hoverable && !isDisabled && !hasActiveElements) {\r\n            setIsOpen(false);\r\n        }\r\n    };\r\n    function openPopover() {\r\n        setIsOpen(true);\r\n        if (!hoverable) {\r\n            toggleRef.current.focus();\r\n        }\r\n        onOpen && typeof onOpen === 'function' && onOpen();\r\n    }\r\n    function closePopover(event) {\r\n        setIsOpen(false);\r\n        if (toggleRef.current !== event.target && !hoverable) {\r\n            toggleRef.current.focus();\r\n        }\r\n        onClose && typeof onClose === 'function' && onClose(event);\r\n    }\r\n    function handleKeyDown(event) {\r\n        if (event.key === 'Escape') {\r\n            if (isOpen) {\r\n                event.stopPropagation();\r\n            }\r\n            closePopover(event);\r\n        }\r\n    }\r\n    function handlePopoverBlur(event) {\r\n        const { currentTarget, relatedTarget } = event;\r\n        const isInMenu = relatedTarget && currentTarget.contains(relatedTarget);\r\n        if (!isInMenu && isOpen) {\r\n            closePopover(event);\r\n        }\r\n    }\r\n    const placement = React.useMemo(() => {\r\n        return alignment === PopoverAlignment.center\r\n            ? position\r\n            : `${position}-${alignment}`;\r\n    }, [position, alignment]);\r\n    const { refs, floatingStyles, context, elements, update } = useFloating({\r\n        //flip() - Changes the placement of the floating element to keep it in view.\r\n        //offset() - Translates the floating element along the specified axes. (Space between the Trigger and the Content).\r\n        //shift() - Shifts the floating element along the specified axes to keep it in view within the clipping context or viewport.\r\n        //arrow() - Positions an arrow element pointing at the reference element, ensuring proper alignment.\r\n        middleware: [\r\n            flip(),\r\n            shift({ padding: 12 }),\r\n            offset(hasPointer ? 12 : 4),\r\n            arrow({ element: arrowRef }),\r\n        ],\r\n        placement: placement,\r\n        whileElementsMounted: autoUpdate,\r\n    });\r\n    React.useEffect(() => {\r\n        const referenceElement = elements.reference;\r\n        const floatingElement = elements.floating;\r\n        if (isOpen && referenceElement && floatingElement) {\r\n            return autoUpdate(referenceElement, floatingElement, update);\r\n        }\r\n    }, [isOpen, elements, update]);\r\n    const maxHeightString = typeof maxHeight === 'number' ? `${maxHeight}px` : maxHeight;\r\n    const widthString = width === 'target'\r\n        ? `${refs.reference.current?.getBoundingClientRect().width}px`\r\n        : typeof width === 'number'\r\n            ? `${width}px`\r\n            : width;\r\n    const onFocus = () => {\r\n        if (hoverable && !isDisabled && !hasActiveElements) {\r\n            openPopover();\r\n        }\r\n    };\r\n    return (React.createElement(PopoverContext.Provider, { value: {\r\n            floatingStyles,\r\n            position: placement,\r\n            closePopover,\r\n            popoverTriggerId,\r\n            popoverContentId,\r\n            openPopover,\r\n            isInverse,\r\n            isOpen,\r\n            maxHeight: maxHeightString,\r\n            width: widthString,\r\n            contentRef,\r\n            setIsOpen,\r\n            setFloating: refs.setFloating,\r\n            setReference: refs.setReference,\r\n            arrowRef,\r\n            arrowContext: context,\r\n            toggleRef,\r\n            isDisabled,\r\n            hoverable,\r\n            hasPointer,\r\n            focusTrap,\r\n            hasActiveElements,\r\n        } },\r\n        React.createElement(StyledContainer, Object.assign({}, other, { onKeyDown: handleKeyDown, onBlur: handlePopoverBlur, ref: ref, \"data-testid\": testId, onMouseOver: handleMouseOver, onMouseLeave: handleMouseLeave, id: popoverId, onFocus: onFocus }), children)));\r\n});\r\n//# sourceMappingURL=Popover.js.map"]} */",
15745
+ styles: "display:inline-block/*# sourceMappingURL=data:application/json;charset=utf-8;base64,{"version":3,"sources":["Popover.tsx"],"names":[],"mappings":"AAiBmC","file":"Popover.tsx","sourcesContent":["import React from 'react';\r\nimport styled from '@emotion/styled';\r\nimport { offset, flip, autoUpdate, arrow, shift, useFloating, } from '@floating-ui/react';\r\nimport { useIsInverse } from '../../inverse';\r\nimport { resolveProps, useForkedRef, useGenerateId } from '../../utils';\r\nimport { ButtonGroupContext } from '../ButtonGroup';\r\nexport var PopoverPosition;\r\n(function (PopoverPosition) {\r\n    PopoverPosition[\"bottom\"] = \"bottom\";\r\n    PopoverPosition[\"top\"] = \"top\";\r\n})(PopoverPosition || (PopoverPosition = {}));\r\nexport var PopoverAlignment;\r\n(function (PopoverAlignment) {\r\n    PopoverAlignment[\"center\"] = \"center\";\r\n    PopoverAlignment[\"start\"] = \"start\";\r\n    PopoverAlignment[\"end\"] = \"end\";\r\n})(PopoverAlignment || (PopoverAlignment = {}));\r\nconst StyledContainer = styled.div `\n  display: inline-block;\n`;\r\nexport const PopoverContext = React.createContext({\r\n    isOpen: false,\r\n    setIsOpen: () => false,\r\n});\r\nexport function hasActiveElementsChecker(ref) {\r\n    return (Array.from(ref.current?.querySelectorAll('button, [href], input, select, textarea, [tabindex]:not([tabindex=\"-1\"]), video') || []).filter((element) => {\r\n        const style = window.getComputedStyle(element);\r\n        return (element instanceof HTMLElement &&\r\n            style.display !== 'none' &&\r\n            style.visibility !== 'hidden' &&\r\n            !element.hasAttribute('disabled'));\r\n    }).length > 0);\r\n}\r\nexport function isElementInteractive(element) {\r\n    if (!element || !(element instanceof HTMLElement))\r\n        return false;\r\n    const tag = element.tagName.toLowerCase();\r\n    if (['button', 'input', 'select', 'textarea', 'a'].includes(tag) ||\r\n        element.hasAttribute('tabindex')) {\r\n        if (tag === 'a' && !element.href)\r\n            return false;\r\n        return !element.hasAttribute('disabled');\r\n    }\r\n    return false;\r\n}\r\nexport const Popover = React.forwardRef((props, forwardedRef) => {\r\n    const [isOpen, setIsOpen] = React.useState(false);\r\n    const contextProps = React.useContext(ButtonGroupContext);\r\n    const resolvedProps = resolveProps(contextProps, props);\r\n    const ownRef = React.useRef();\r\n    const toggleRef = React.useRef();\r\n    const contentRef = React.useRef(null);\r\n    const popoverContentId = React.useRef('');\r\n    const popoverTriggerId = React.useRef('');\r\n    const arrowRef = React.useRef(null);\r\n    const hasActiveElements = React.useMemo(() => hasActiveElementsChecker(contentRef), [contentRef, contentRef.current]);\r\n    const { onClose, onOpen, position = PopoverPosition.bottom, children, testId, maxHeight, width, hoverable, isDisabled, hasPointer = true, openByDefault, id: defaultId, apiRef, focusTrap, alignment = PopoverAlignment.center, ...other } = props;\r\n    React.useEffect(() => {\r\n        if (apiRef) {\r\n            apiRef.current = {\r\n                closePopoverManually(event) {\r\n                    closePopover(event);\r\n                },\r\n                openPopoverManually(event) {\r\n                    openPopover();\r\n                },\r\n            };\r\n        }\r\n        if (openByDefault) {\r\n            openPopover();\r\n        }\r\n    }, []);\r\n    React.useEffect(() => {\r\n        const handleEsc = event => {\r\n            if (event.key === 'Escape' && isOpen) {\r\n                closePopover(event);\r\n            }\r\n        };\r\n        window.addEventListener('keydown', handleEsc);\r\n        return () => {\r\n            window.removeEventListener('keydown', handleEsc);\r\n        };\r\n    }, [isOpen]);\r\n    const popoverId = useGenerateId(defaultId);\r\n    popoverTriggerId.current = `${popoverId}_trigger`;\r\n    popoverContentId.current = `${popoverId}_content`;\r\n    const ref = useForkedRef(forwardedRef, ownRef);\r\n    const isInverse = useIsInverse(resolvedProps.isInverse);\r\n    const handleMouseOver = () => {\r\n        if (hoverable && !isDisabled && !hasActiveElements) {\r\n            setIsOpen(true);\r\n        }\r\n    };\r\n    const handleMouseLeave = () => {\r\n        if (hoverable && !isDisabled && !hasActiveElements) {\r\n            setIsOpen(false);\r\n        }\r\n    };\r\n    function openPopover() {\r\n        setIsOpen(true);\r\n        if (!hoverable) {\r\n            toggleRef.current.focus();\r\n        }\r\n        onOpen && typeof onOpen === 'function' && onOpen();\r\n    }\r\n    function closePopover(event) {\r\n        setIsOpen(false);\r\n        if (event && event.type === 'blur') {\r\n            const relatedTarget = event.relatedTarget;\r\n            if (!isElementInteractive(relatedTarget) && !hoverable) {\r\n                toggleRef.current?.focus();\r\n            }\r\n        }\r\n        onClose && typeof onClose === 'function' && onClose(event);\r\n    }\r\n    function handleKeyDown(event) {\r\n        if (event.key === 'Escape') {\r\n            if (isOpen) {\r\n                event.stopPropagation();\r\n            }\r\n            closePopover(event);\r\n            toggleRef.current?.focus();\r\n        }\r\n    }\r\n    function handlePopoverBlur(event) {\r\n        const { currentTarget, relatedTarget } = event;\r\n        const isInMenu = relatedTarget && currentTarget.contains(relatedTarget);\r\n        if (!isInMenu && isOpen) {\r\n            closePopover(event);\r\n        }\r\n    }\r\n    const placement = React.useMemo(() => {\r\n        return alignment === PopoverAlignment.center\r\n            ? position\r\n            : `${position}-${alignment}`;\r\n    }, [position, alignment]);\r\n    const { refs, floatingStyles, context, elements, update } = useFloating({\r\n        //flip() - Changes the placement of the floating element to keep it in view.\r\n        //offset() - Translates the floating element along the specified axes. (Space between the Trigger and the Content).\r\n        //shift() - Shifts the floating element along the specified axes to keep it in view within the clipping context or viewport.\r\n        //arrow() - Positions an arrow element pointing at the reference element, ensuring proper alignment.\r\n        middleware: [\r\n            flip(),\r\n            shift({ padding: 12 }),\r\n            offset(hasPointer ? 12 : 4),\r\n            arrow({ element: arrowRef }),\r\n        ],\r\n        placement: placement,\r\n        whileElementsMounted: autoUpdate,\r\n    });\r\n    React.useEffect(() => {\r\n        const referenceElement = elements.reference;\r\n        const floatingElement = elements.floating;\r\n        if (isOpen && referenceElement && floatingElement) {\r\n            return autoUpdate(referenceElement, floatingElement, update);\r\n        }\r\n    }, [isOpen, elements, update]);\r\n    const maxHeightString = typeof maxHeight === 'number' ? `${maxHeight}px` : maxHeight;\r\n    const widthString = width === 'target'\r\n        ? `${refs.reference.current?.getBoundingClientRect().width}px`\r\n        : typeof width === 'number'\r\n            ? `${width}px`\r\n            : width;\r\n    const onFocus = () => {\r\n        if (hoverable && !isDisabled && !hasActiveElements) {\r\n            openPopover();\r\n        }\r\n    };\r\n    return (React.createElement(PopoverContext.Provider, { value: {\r\n            floatingStyles,\r\n            position: placement,\r\n            closePopover,\r\n            popoverTriggerId,\r\n            popoverContentId,\r\n            openPopover,\r\n            isInverse,\r\n            isOpen,\r\n            maxHeight: maxHeightString,\r\n            width: widthString,\r\n            contentRef,\r\n            setIsOpen,\r\n            setFloating: refs.setFloating,\r\n            setReference: refs.setReference,\r\n            arrowRef,\r\n            arrowContext: context,\r\n            toggleRef,\r\n            isDisabled,\r\n            hoverable,\r\n            hasPointer,\r\n            focusTrap,\r\n            hasActiveElements,\r\n        } },\r\n        React.createElement(StyledContainer, Object.assign({}, other, { onKeyDown: handleKeyDown, onBlur: handlePopoverBlur, ref: ref, \"data-testid\": testId, onMouseOver: handleMouseOver, onMouseLeave: handleMouseLeave, id: popoverId, onFocus: onFocus }), children)));\r\n});\r\n//# sourceMappingURL=Popover.js.map"]} */",
15747
15746
  toString: _EMOTION_STRINGIFIED_CSS_ERROR__$C
15748
15747
  });
15749
15748
  var PopoverContext = /*#__PURE__*/React__default.createContext({
@@ -15759,6 +15758,15 @@ function hasActiveElementsChecker(ref) {
15759
15758
  return element instanceof HTMLElement && style.display !== 'none' && style.visibility !== 'hidden' && !element.hasAttribute('disabled');
15760
15759
  }).length > 0;
15761
15760
  }
15761
+ function isElementInteractive(element) {
15762
+ if (!element || !(element instanceof HTMLElement)) return false;
15763
+ var tag = element.tagName.toLowerCase();
15764
+ if (['button', 'input', 'select', 'textarea', 'a'].includes(tag) || element.hasAttribute('tabindex')) {
15765
+ if (tag === 'a' && !element.href) return false;
15766
+ return !element.hasAttribute('disabled');
15767
+ }
15768
+ return false;
15769
+ }
15762
15770
  var Popover = /*#__PURE__*/React__default.forwardRef(function (props, forwardedRef) {
15763
15771
  var _refs$reference$curre;
15764
15772
  var _React$useState = React__default.useState(false),
@@ -15844,17 +15852,23 @@ var Popover = /*#__PURE__*/React__default.forwardRef(function (props, forwardedR
15844
15852
  }
15845
15853
  function closePopover(event) {
15846
15854
  setIsOpen(false);
15847
- if (toggleRef.current !== event.target && !hoverable) {
15848
- toggleRef.current.focus();
15855
+ if (event && event.type === 'blur') {
15856
+ var relatedTarget = event.relatedTarget;
15857
+ if (!isElementInteractive(relatedTarget) && !hoverable) {
15858
+ var _toggleRef$current;
15859
+ (_toggleRef$current = toggleRef.current) == null || _toggleRef$current.focus();
15860
+ }
15849
15861
  }
15850
15862
  onClose && typeof onClose === 'function' && onClose(event);
15851
15863
  }
15852
15864
  function handleKeyDown(event) {
15853
15865
  if (event.key === 'Escape') {
15866
+ var _toggleRef$current2;
15854
15867
  if (isOpen) {
15855
15868
  event.stopPropagation();
15856
15869
  }
15857
15870
  closePopover(event);
15871
+ (_toggleRef$current2 = toggleRef.current) == null || _toggleRef$current2.focus();
15858
15872
  }
15859
15873
  }
15860
15874
  function handlePopoverBlur(event) {