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/components/Popover/Popover.d.ts +1 -0
- package/dist/esm/index.js +19 -4
- package/dist/esm/index.js.map +1 -1
- package/dist/index.d.ts +1 -1
- package/dist/properties.json +5 -5
- package/dist/react-magma-dom.cjs.development.js +25 -11
- package/dist/react-magma-dom.cjs.development.js.map +1 -1
- package/dist/react-magma-dom.cjs.production.min.js +1 -1
- package/dist/react-magma-dom.cjs.production.min.js.map +1 -1
- package/package.json +1 -1
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';
|
package/dist/properties.json
CHANGED
|
@@ -12143,12 +12143,12 @@
|
|
|
12143
12143
|
"typeArguments": [
|
|
12144
12144
|
{
|
|
12145
12145
|
"type": "reference",
|
|
12146
|
-
"id":
|
|
12146
|
+
"id": 31648,
|
|
12147
12147
|
"name": "IconOnlyPopoverTriggerProps"
|
|
12148
12148
|
},
|
|
12149
12149
|
{
|
|
12150
12150
|
"type": "reference",
|
|
12151
|
-
"id":
|
|
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":
|
|
18171
|
+
"id": 36054,
|
|
18172
18172
|
"name": "ToggleButtonTextProps"
|
|
18173
18173
|
},
|
|
18174
18174
|
{
|
|
18175
18175
|
"type": "reference",
|
|
18176
|
-
"id":
|
|
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":
|
|
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 (
|
|
15848
|
-
|
|
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) {
|