react-magma-dom 4.6.0-next.7 → 4.6.0-next.9

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.
@@ -10443,13 +10443,15 @@ var ModalContainer = /*#__PURE__*/_styled(Transition, {
10443
10443
  label: "ModalContainer"
10444
10444
  })("bottom:0;left:0;overflow-y:auto;padding:", function (props) {
10445
10445
  return props.theme.spaceScale.spacing03;
10446
- }, ";right:0;top:0;z-index:998;" + ( "/*# sourceMappingURL=data:application/json;charset=utf-8;base64,{"version":3,"sources":["Modal.tsx"],"names":[],"mappings":"AAuB0C","file":"Modal.tsx","sourcesContent":["import * as React from 'react';\r\nimport ReactDOM from 'react-dom';\r\nimport styled from '@emotion/styled';\r\nimport { Global, css } from '@emotion/react';\r\nimport { ThemeContext } from '../../theme/ThemeContext';\r\nimport { magma } from '../../theme/magma';\r\nimport { I18nContext } from '../../i18n';\r\nimport { ButtonColor, ButtonVariant } from '../Button';\r\nimport { IconButton } from '../IconButton';\r\nimport { CloseIcon } from 'react-magma-icons';\r\nimport { Heading } from '../Heading';\r\nimport { TypographyVisualStyle } from '../Typography';\r\nimport { Transition } from '../Transition';\r\nimport { omit, useGenerateId, usePrevious } from '../../utils';\r\nimport { useFocusLock } from '../../hooks/useFocusLock';\r\nimport { transparentize } from 'polished';\r\nimport { useIsInverse } from '../../inverse';\r\nexport var ModalSize;\r\n(function (ModalSize) {\r\n    ModalSize[\"large\"] = \"large\";\r\n    ModalSize[\"medium\"] = \"medium\";\r\n    ModalSize[\"small\"] = \"small\";\r\n})(ModalSize || (ModalSize = {}));\r\nconst ModalContainer = styled(Transition) `\n  bottom: 0;\n  left: 0;\n  overflow-y: auto;\n  padding: ${props => props.theme.spaceScale.spacing03};\n  right: 0;\n  top: 0;\n  z-index: 998;\n`;\r\nconst ModalBackdrop = styled(Transition) `\n  backdrop-filter: blur(3px);\n  background: ${props => transparentize(0.4, props.theme.colors.neutral900)};\n  bottom: 0;\n  left: 0;\n  right: 0;\n  top: 0;\n  z-index: 997;\n  position: fixed;\n`;\r\nconst ModalContent = styled.div `\n  background: ${props => props.isInverse\r\n    ? props.theme.colors.primary600\r\n    : props.theme.colors.neutral100};\n  border: 1px solid;\n  border-color: ${props => props.isInverse\r\n    ? transparentize(0.5, props.theme.colors.tertiary)\r\n    : props.theme.colors.neutral};\n  border-radius: ${props => props.theme.borderRadius};\n  box-shadow: ${props => `0 2px 6px ${transparentize(0.85, props.theme.colors.neutral900)}`};\n  color: ${props => props.isInverse\r\n    ? props.theme.colors.neutral100\r\n    : props.theme.colors.neutral700};\n  margin: 0 auto;\n  position: relative;\n  z-index: 1000;\n\n  max-width: ${props => {\r\n    switch (props.size) {\r\n        case 'large':\r\n            return props.theme.modal.width.large;\r\n        case 'small':\r\n            return props.theme.modal.width.small;\r\n        default:\r\n            return props.theme.modal.width.medium;\r\n    }\r\n}};\n\n  @media (min-width: ${props => props.theme.breakpoints.small}px) {\n    margin: ${props => props.theme.spaceScale.spacing08} auto;\n  }\n`;\r\nconst ModalHeader = styled.div `\n  padding: ${props => props.theme.spaceScale.spacing05}\n    ${props => props.theme.spaceScale.spacing05} 0\n    ${props => props.theme.spaceScale.spacing05};\n  @media (min-width: ${props => props.theme.breakpoints.small}px) {\n    padding: ${props => props.theme.spaceScale.spacing06}\n      ${props => props.theme.spaceScale.spacing06} 0\n      ${props => props.theme.spaceScale.spacing06};\n  }\n`;\r\nconst ModalWrapper = styled.div `\n  padding: ${props => props.theme.spaceScale.spacing05};\n  @media (min-width: ${props => props.theme.breakpoints.small}px) {\n    padding: ${props => props.theme.spaceScale.spacing06};\n  }\n`;\r\nconst H1 = styled(Heading) `\n  font-size: ${props => props.theme.typographyVisualStyles.headingSmall.desktop.fontSize};\n  line-height: ${props => props.theme.typographyVisualStyles.headingSmall.desktop.lineHeight};\n  color: ${props => props.isInverse\r\n    ? props.theme.colors.neutral100\r\n    : props.theme.colors.neutral700};\n  margin: 0;\n  padding-right: ${props => props.theme.spaceScale.spacing10};\n  font-weight: 600;\n`;\r\nconst CloseBtn = styled.span `\n  position: absolute;\n  top: 0;\n  right: 0;\n  margin: ${props => props.theme.spaceScale.spacing02};\n`;\r\nexport const Modal = React.forwardRef((props, ref) => {\r\n    const lastFocus = React.useRef();\r\n    const headingRef = React.useRef();\r\n    const bodyRef = React.useRef();\r\n    const id = useGenerateId(props.id);\r\n    const headingId = `${id}_heading`;\r\n    const contentId = `${id}_content`;\r\n    const [isModalOpen, setIsModalOpen] = React.useState(props.isOpen);\r\n    const [isExiting, setIsExiting] = React.useState(false);\r\n    const [currentTarget, setCurrentTarget] = React.useState(null);\r\n    const [modalCount, setModalCount] = React.useState(0);\r\n    const focusTrapElement = useFocusLock(isModalOpen, headingRef, bodyRef);\r\n    const prevOpen = usePrevious(props.isOpen);\r\n    React.useEffect(() => {\r\n        if (props.isModalClosingControlledManually &&\r\n            prevOpen &&\r\n            !props.isOpen &&\r\n            isModalOpen) {\r\n            setIsModalOpen(false);\r\n        }\r\n        else if (!prevOpen && props.isOpen) {\r\n            setIsModalOpen(true);\r\n            if (props.headerRef && typeof props.headerRef === 'function') {\r\n                props.headerRef(headingRef);\r\n            }\r\n        }\r\n        else if (prevOpen && !props.isOpen && isModalOpen) {\r\n            handleClose();\r\n        }\r\n    }, [props.isOpen]);\r\n    React.useEffect(() => {\r\n        if (isModalOpen) {\r\n            lastFocus.current = document.activeElement;\r\n            const count = document.querySelectorAll('[aria-modal=\"true\"]').length;\r\n            setModalCount(count);\r\n            if (!props.isEscKeyDownDisabled) {\r\n                document.body.addEventListener('keydown', handleEscapeKeyDown, false);\r\n            }\r\n        }\r\n        return () => {\r\n            document.body.removeEventListener('keydown', handleEscapeKeyDown, false);\r\n        };\r\n    }, [isModalOpen]);\r\n    function handleModalClick(event) {\r\n        if (!document.getElementById(contentId).contains(event.target) &&\r\n            event.target === currentTarget) {\r\n            handleClose(event);\r\n        }\r\n    }\r\n    function handleModalOnMouseDown(event) {\r\n        setCurrentTarget(event.target);\r\n    }\r\n    function handleEscapeKeyDown(event) {\r\n        if (event.key === 'Escape') {\r\n            event.preventDefault();\r\n            event.stopPropagation();\r\n            props.onEscKeyDown &&\r\n                typeof props.onEscKeyDown === 'function' &&\r\n                props.onEscKeyDown(event);\r\n            //Supports nested modals\r\n            const modalsInDom = document.querySelectorAll('[aria-modal=\"true\"]').length;\r\n            if (modalCount <= 1 && modalsInDom !== 1) {\r\n                if (document.getElementById(id).contains(event.target)) {\r\n                    handleClose(event);\r\n                }\r\n                else {\r\n                    headingRef.current.focus();\r\n                }\r\n            }\r\n            else {\r\n                handleClose(event);\r\n            }\r\n        }\r\n    }\r\n    function handleClose(event) {\r\n        if (event) {\r\n            event.stopPropagation();\r\n        }\r\n        setIsExiting(true);\r\n        setTimeout(() => {\r\n            setIsExiting(false);\r\n            if (!props.isModalClosingControlledManually) {\r\n                setIsModalOpen(false);\r\n            }\r\n            if (lastFocus.current) {\r\n                lastFocus.current.focus();\r\n            }\r\n            props.onClose && typeof props.onClose === 'function' && props.onClose();\r\n        }, 300);\r\n    }\r\n    const { ariaLabel, children, closeAriaLabel, closeButtonSize, containerStyle, containerTransition = { slideTop: true }, isBackgroundClickDisabled, isEscKeyDownDisabled, header, isCloseButtonHidden, isOpen, unmountOnExit = true, testId, ...rest } = props;\r\n    const isInverse = useIsInverse(props.isInverse);\r\n    const other = omit(['onEscKeyDown'], rest);\r\n    const theme = React.useContext(ThemeContext);\r\n    const i18n = React.useContext(I18nContext);\r\n    const CloseIconButton = (React.createElement(CloseIcon, { size: magma.iconSizes[closeButtonSize]\r\n            ? magma.iconSizes[closeButtonSize]\r\n            : magma.iconSizes.medium }));\r\n    return isModalOpen\r\n        ? ReactDOM.createPortal(React.createElement(\"div\", { ref: focusTrapElement },\r\n            React.createElement(Global, { styles: css `\n                html {\n                  overflow: ${isOpen ? 'hidden' : 'auto'};\n                }\n              ` }),\r\n            React.createElement(ModalBackdrop, { \"data-testid\": \"modal-backdrop\", isExiting: isExiting, onMouseDown: isBackgroundClickDisabled\r\n                    ? event => event.preventDefault()\r\n                    : null, fade: true, isOpen: isModalOpen, unmountOnExit: true, theme: theme },\r\n                React.createElement(ModalContainer, Object.assign({ \"aria-labelledby\": header ? headingId : null, \"aria-label\": !header ? ariaLabel : null, \"aria-modal\": true, \"data-testid\": testId, id: id, onClick: isBackgroundClickDisabled ? null : handleModalClick, onMouseDown: isBackgroundClickDisabled ? null : handleModalOnMouseDown, role: \"dialog\", style: containerStyle, theme: theme, isOpen: isModalOpen }, containerTransition, { unmountOnExit: unmountOnExit }),\r\n                    React.createElement(ModalContent, Object.assign({}, other, { \"data-testid\": \"modal-content\", id: contentId, isExiting: isExiting, ref: ref, theme: theme }),\r\n                        header && (React.createElement(ModalHeader, { theme: theme }, header && (React.createElement(H1, { id: headingId, isInverse: isInverse, level: 1, ref: headingRef, visualStyle: TypographyVisualStyle.headingSmall, tabIndex: -1, theme: theme }, header)))),\r\n                        React.createElement(ModalWrapper, { ref: bodyRef, theme: theme }, children),\r\n                        !isCloseButtonHidden && (React.createElement(CloseBtn, { theme: theme },\r\n                            React.createElement(IconButton, { \"aria-label\": closeAriaLabel\r\n                                    ? closeAriaLabel\r\n                                    : i18n.modal.closeAriaLabel, color: ButtonColor.primary, icon: CloseIconButton, isInverse: isInverse, onClick: handleClose, testId: \"modal-closebtn\", variant: ButtonVariant.link }))))))), document.getElementsByTagName('body')[0])\r\n        : null;\r\n});\r\n//# sourceMappingURL=Modal.js.map"]} */"));
10446
+ }, ";right:0;top:0;z-index:", function (props) {
10447
+ return props.modalCount >= 2 ? '999' : '998';
10448
+ }, ";" + ( "/*# sourceMappingURL=data:application/json;charset=utf-8;base64,{"version":3,"sources":["Modal.tsx"],"names":[],"mappings":"AAuB0C","file":"Modal.tsx","sourcesContent":["import * as React from 'react';\r\nimport ReactDOM from 'react-dom';\r\nimport styled from '@emotion/styled';\r\nimport { Global, css } from '@emotion/react';\r\nimport { ThemeContext } from '../../theme/ThemeContext';\r\nimport { magma } from '../../theme/magma';\r\nimport { I18nContext } from '../../i18n';\r\nimport { ButtonColor, ButtonVariant } from '../Button';\r\nimport { IconButton } from '../IconButton';\r\nimport { CloseIcon } from 'react-magma-icons';\r\nimport { Heading } from '../Heading';\r\nimport { TypographyVisualStyle } from '../Typography';\r\nimport { Transition } from '../Transition';\r\nimport { omit, useGenerateId, usePrevious } from '../../utils';\r\nimport { useFocusLock } from '../../hooks/useFocusLock';\r\nimport { transparentize } from 'polished';\r\nimport { useIsInverse } from '../../inverse';\r\nexport var ModalSize;\r\n(function (ModalSize) {\r\n    ModalSize[\"large\"] = \"large\";\r\n    ModalSize[\"medium\"] = \"medium\";\r\n    ModalSize[\"small\"] = \"small\";\r\n})(ModalSize || (ModalSize = {}));\r\nconst ModalContainer = styled(Transition) `\n  bottom: 0;\n  left: 0;\n  overflow-y: auto;\n  padding: ${props => props.theme.spaceScale.spacing03};\n  right: 0;\n  top: 0;\n  z-index: ${props => (props.modalCount >= 2 ? '999' : '998')};\n`;\r\nconst ModalBackdrop = styled(Transition) `\n  backdrop-filter: blur(3px);\n  background: ${props => transparentize(0.4, props.theme.colors.neutral900)};\n  bottom: 0;\n  left: 0;\n  right: 0;\n  top: 0;\n  z-index: 997;\n  position: fixed;\n`;\r\nconst ModalContent = styled.div `\n  background: ${props => props.isInverse\r\n    ? props.theme.colors.primary600\r\n    : props.theme.colors.neutral100};\n  border: 1px solid;\n  border-color: ${props => props.isInverse\r\n    ? transparentize(0.5, props.theme.colors.tertiary)\r\n    : props.theme.colors.neutral};\n  border-radius: ${props => props.theme.borderRadius};\n  box-shadow: ${props => `0 2px 6px ${transparentize(0.85, props.theme.colors.neutral900)}`};\n  color: ${props => props.isInverse\r\n    ? props.theme.colors.neutral100\r\n    : props.theme.colors.neutral700};\n  margin: 0 auto;\n  position: relative;\n  z-index: 1000;\n\n  max-width: ${props => {\r\n    switch (props.size) {\r\n        case 'large':\r\n            return props.theme.modal.width.large;\r\n        case 'small':\r\n            return props.theme.modal.width.small;\r\n        default:\r\n            return props.theme.modal.width.medium;\r\n    }\r\n}};\n\n  @media (min-width: ${props => props.theme.breakpoints.small}px) {\n    margin: ${props => props.theme.spaceScale.spacing08} auto;\n  }\n`;\r\nconst ModalHeader = styled.div `\n  padding: ${props => props.theme.spaceScale.spacing05}\n    ${props => props.theme.spaceScale.spacing05} 0\n    ${props => props.theme.spaceScale.spacing05};\n  @media (min-width: ${props => props.theme.breakpoints.small}px) {\n    padding: ${props => props.theme.spaceScale.spacing06}\n      ${props => props.theme.spaceScale.spacing06} 0\n      ${props => props.theme.spaceScale.spacing06};\n  }\n`;\r\nconst ModalWrapper = styled.div `\n  padding: ${props => props.theme.spaceScale.spacing05};\n  @media (min-width: ${props => props.theme.breakpoints.small}px) {\n    padding: ${props => props.theme.spaceScale.spacing06};\n  }\n`;\r\nconst H1 = styled(Heading) `\n  font-size: ${props => props.theme.typographyVisualStyles.headingSmall.desktop.fontSize};\n  line-height: ${props => props.theme.typographyVisualStyles.headingSmall.desktop.lineHeight};\n  color: ${props => props.isInverse\r\n    ? props.theme.colors.neutral100\r\n    : props.theme.colors.neutral700};\n  margin: 0;\n  padding-right: ${props => props.theme.spaceScale.spacing10};\n  font-weight: 600;\n`;\r\nconst CloseBtn = styled.span `\n  position: absolute;\n  top: 0;\n  right: 0;\n  margin: ${props => props.theme.spaceScale.spacing02};\n`;\r\nexport const Modal = React.forwardRef((props, ref) => {\r\n    const lastFocus = React.useRef();\r\n    const headingRef = React.useRef();\r\n    const bodyRef = React.useRef();\r\n    const id = useGenerateId(props.id);\r\n    const headingId = `${id}_heading`;\r\n    const contentId = `${id}_content`;\r\n    const [isModalOpen, setIsModalOpen] = React.useState(props.isOpen);\r\n    const [isExiting, setIsExiting] = React.useState(false);\r\n    const [currentTarget, setCurrentTarget] = React.useState(null);\r\n    const [modalCount, setModalCount] = React.useState(0);\r\n    const focusTrapElement = useFocusLock(isModalOpen, headingRef, bodyRef);\r\n    const prevOpen = usePrevious(props.isOpen);\r\n    React.useEffect(() => {\r\n        if (props.isModalClosingControlledManually &&\r\n            prevOpen &&\r\n            !props.isOpen &&\r\n            isModalOpen) {\r\n            setIsModalOpen(false);\r\n        }\r\n        else if (!prevOpen && props.isOpen) {\r\n            setIsModalOpen(true);\r\n            if (props.headerRef && typeof props.headerRef === 'function') {\r\n                props.headerRef(headingRef);\r\n            }\r\n        }\r\n        else if (prevOpen && !props.isOpen && isModalOpen) {\r\n            handleClose();\r\n        }\r\n    }, [props.isOpen]);\r\n    React.useEffect(() => {\r\n        if (isModalOpen) {\r\n            lastFocus.current = document.activeElement;\r\n            const count = document.querySelectorAll('[aria-modal=\"true\"]').length;\r\n            setModalCount(count);\r\n            if (!props.isEscKeyDownDisabled) {\r\n                document.body.addEventListener('keydown', handleEscapeKeyDown, false);\r\n            }\r\n        }\r\n        return () => {\r\n            document.body.removeEventListener('keydown', handleEscapeKeyDown, false);\r\n        };\r\n    }, [isModalOpen]);\r\n    function handleModalClick(event) {\r\n        if (!document.getElementById(contentId).contains(event.target) &&\r\n            event.target === currentTarget) {\r\n            handleClose(event);\r\n        }\r\n    }\r\n    function handleModalOnMouseDown(event) {\r\n        setCurrentTarget(event.target);\r\n    }\r\n    function handleEscapeKeyDown(event) {\r\n        if (event.key === 'Escape') {\r\n            event.preventDefault();\r\n            event.stopPropagation();\r\n            props.onEscKeyDown &&\r\n                typeof props.onEscKeyDown === 'function' &&\r\n                props.onEscKeyDown(event);\r\n            //Supports nested modals\r\n            const modalsInDom = document.querySelectorAll('[aria-modal=\"true\"]').length;\r\n            if (modalCount <= 1 && modalsInDom !== 1) {\r\n                if (document.getElementById(id).contains(event.target)) {\r\n                    handleClose(event);\r\n                }\r\n                else {\r\n                    headingRef.current.focus();\r\n                }\r\n            }\r\n            else {\r\n                handleClose(event);\r\n            }\r\n        }\r\n    }\r\n    function handleClose(event) {\r\n        if (event) {\r\n            event.stopPropagation();\r\n        }\r\n        setIsExiting(true);\r\n        setTimeout(() => {\r\n            setIsExiting(false);\r\n            if (!props.isModalClosingControlledManually) {\r\n                setIsModalOpen(false);\r\n            }\r\n            if (lastFocus.current) {\r\n                lastFocus.current.focus();\r\n            }\r\n            props.onClose && typeof props.onClose === 'function' && props.onClose();\r\n        }, 300);\r\n    }\r\n    const { ariaLabel, children, closeAriaLabel, closeButtonSize, containerStyle, containerTransition = { slideTop: true }, isBackgroundClickDisabled, isEscKeyDownDisabled, header, isCloseButtonHidden, isOpen, unmountOnExit = true, testId, ...rest } = props;\r\n    const isInverse = useIsInverse(props.isInverse);\r\n    const other = omit(['onEscKeyDown'], rest);\r\n    const theme = React.useContext(ThemeContext);\r\n    const i18n = React.useContext(I18nContext);\r\n    const CloseIconButton = (React.createElement(CloseIcon, { size: magma.iconSizes[closeButtonSize]\r\n            ? magma.iconSizes[closeButtonSize]\r\n            : magma.iconSizes.medium }));\r\n    return isModalOpen\r\n        ? ReactDOM.createPortal(React.createElement(\"div\", { ref: focusTrapElement },\r\n            React.createElement(Global, { styles: css `\n                html {\n                  overflow: ${isOpen ? 'hidden' : 'auto'};\n                }\n              ` }),\r\n            React.createElement(ModalContainer, Object.assign({ \"aria-labelledby\": header ? headingId : null, \"aria-label\": !header ? ariaLabel : null, \"aria-modal\": true, \"data-testid\": testId, id: id, modalCount: modalCount, onClick: isBackgroundClickDisabled ? null : handleModalClick, onMouseDown: isBackgroundClickDisabled ? null : handleModalOnMouseDown, role: \"dialog\", style: containerStyle, theme: theme, isOpen: isModalOpen }, containerTransition, { unmountOnExit: unmountOnExit }),\r\n                React.createElement(ModalContent, Object.assign({}, other, { \"data-testid\": \"modal-content\", id: contentId, isExiting: isExiting, ref: ref, theme: theme }),\r\n                    header && (React.createElement(ModalHeader, { theme: theme }, header && (React.createElement(H1, { id: headingId, isInverse: isInverse, level: 1, ref: headingRef, visualStyle: TypographyVisualStyle.headingSmall, tabIndex: -1, theme: theme }, header)))),\r\n                    React.createElement(ModalWrapper, { ref: bodyRef, theme: theme }, children),\r\n                    !isCloseButtonHidden && (React.createElement(CloseBtn, { theme: theme },\r\n                        React.createElement(IconButton, { \"aria-label\": closeAriaLabel\r\n                                ? closeAriaLabel\r\n                                : i18n.modal.closeAriaLabel, color: ButtonColor.primary, icon: CloseIconButton, isInverse: isInverse, onClick: handleClose, testId: \"modal-closebtn\", variant: ButtonVariant.link }))))),\r\n            React.createElement(ModalBackdrop, { \"data-testid\": \"modal-backdrop\", isExiting: isExiting, onMouseDown: isBackgroundClickDisabled\r\n                    ? event => event.preventDefault()\r\n                    : null, fade: true, isOpen: isModalOpen, style: modalCount >= 2 && { zIndex: '998' }, unmountOnExit: true, theme: theme })), document.getElementsByTagName('body')[0])\r\n        : null;\r\n});\r\n//# sourceMappingURL=Modal.js.map"]} */"));
10447
10449
  var ModalBackdrop = /*#__PURE__*/_styled(Transition, {
10448
10450
  target: "e1pxemtw5",
10449
10451
  label: "ModalBackdrop"
10450
10452
  })("backdrop-filter:blur(3px);background:", function (props) {
10451
10453
  return polished.transparentize(0.4, props.theme.colors.neutral900);
10452
- }, ";bottom:0;left:0;right:0;top:0;z-index:997;position:fixed;" + ( "/*# sourceMappingURL=data:application/json;charset=utf-8;base64,{"version":3,"sources":["Modal.tsx"],"names":[],"mappings":"AAgCyC","file":"Modal.tsx","sourcesContent":["import * as React from 'react';\r\nimport ReactDOM from 'react-dom';\r\nimport styled from '@emotion/styled';\r\nimport { Global, css } from '@emotion/react';\r\nimport { ThemeContext } from '../../theme/ThemeContext';\r\nimport { magma } from '../../theme/magma';\r\nimport { I18nContext } from '../../i18n';\r\nimport { ButtonColor, ButtonVariant } from '../Button';\r\nimport { IconButton } from '../IconButton';\r\nimport { CloseIcon } from 'react-magma-icons';\r\nimport { Heading } from '../Heading';\r\nimport { TypographyVisualStyle } from '../Typography';\r\nimport { Transition } from '../Transition';\r\nimport { omit, useGenerateId, usePrevious } from '../../utils';\r\nimport { useFocusLock } from '../../hooks/useFocusLock';\r\nimport { transparentize } from 'polished';\r\nimport { useIsInverse } from '../../inverse';\r\nexport var ModalSize;\r\n(function (ModalSize) {\r\n    ModalSize[\"large\"] = \"large\";\r\n    ModalSize[\"medium\"] = \"medium\";\r\n    ModalSize[\"small\"] = \"small\";\r\n})(ModalSize || (ModalSize = {}));\r\nconst ModalContainer = styled(Transition) `\n  bottom: 0;\n  left: 0;\n  overflow-y: auto;\n  padding: ${props => props.theme.spaceScale.spacing03};\n  right: 0;\n  top: 0;\n  z-index: 998;\n`;\r\nconst ModalBackdrop = styled(Transition) `\n  backdrop-filter: blur(3px);\n  background: ${props => transparentize(0.4, props.theme.colors.neutral900)};\n  bottom: 0;\n  left: 0;\n  right: 0;\n  top: 0;\n  z-index: 997;\n  position: fixed;\n`;\r\nconst ModalContent = styled.div `\n  background: ${props => props.isInverse\r\n    ? props.theme.colors.primary600\r\n    : props.theme.colors.neutral100};\n  border: 1px solid;\n  border-color: ${props => props.isInverse\r\n    ? transparentize(0.5, props.theme.colors.tertiary)\r\n    : props.theme.colors.neutral};\n  border-radius: ${props => props.theme.borderRadius};\n  box-shadow: ${props => `0 2px 6px ${transparentize(0.85, props.theme.colors.neutral900)}`};\n  color: ${props => props.isInverse\r\n    ? props.theme.colors.neutral100\r\n    : props.theme.colors.neutral700};\n  margin: 0 auto;\n  position: relative;\n  z-index: 1000;\n\n  max-width: ${props => {\r\n    switch (props.size) {\r\n        case 'large':\r\n            return props.theme.modal.width.large;\r\n        case 'small':\r\n            return props.theme.modal.width.small;\r\n        default:\r\n            return props.theme.modal.width.medium;\r\n    }\r\n}};\n\n  @media (min-width: ${props => props.theme.breakpoints.small}px) {\n    margin: ${props => props.theme.spaceScale.spacing08} auto;\n  }\n`;\r\nconst ModalHeader = styled.div `\n  padding: ${props => props.theme.spaceScale.spacing05}\n    ${props => props.theme.spaceScale.spacing05} 0\n    ${props => props.theme.spaceScale.spacing05};\n  @media (min-width: ${props => props.theme.breakpoints.small}px) {\n    padding: ${props => props.theme.spaceScale.spacing06}\n      ${props => props.theme.spaceScale.spacing06} 0\n      ${props => props.theme.spaceScale.spacing06};\n  }\n`;\r\nconst ModalWrapper = styled.div `\n  padding: ${props => props.theme.spaceScale.spacing05};\n  @media (min-width: ${props => props.theme.breakpoints.small}px) {\n    padding: ${props => props.theme.spaceScale.spacing06};\n  }\n`;\r\nconst H1 = styled(Heading) `\n  font-size: ${props => props.theme.typographyVisualStyles.headingSmall.desktop.fontSize};\n  line-height: ${props => props.theme.typographyVisualStyles.headingSmall.desktop.lineHeight};\n  color: ${props => props.isInverse\r\n    ? props.theme.colors.neutral100\r\n    : props.theme.colors.neutral700};\n  margin: 0;\n  padding-right: ${props => props.theme.spaceScale.spacing10};\n  font-weight: 600;\n`;\r\nconst CloseBtn = styled.span `\n  position: absolute;\n  top: 0;\n  right: 0;\n  margin: ${props => props.theme.spaceScale.spacing02};\n`;\r\nexport const Modal = React.forwardRef((props, ref) => {\r\n    const lastFocus = React.useRef();\r\n    const headingRef = React.useRef();\r\n    const bodyRef = React.useRef();\r\n    const id = useGenerateId(props.id);\r\n    const headingId = `${id}_heading`;\r\n    const contentId = `${id}_content`;\r\n    const [isModalOpen, setIsModalOpen] = React.useState(props.isOpen);\r\n    const [isExiting, setIsExiting] = React.useState(false);\r\n    const [currentTarget, setCurrentTarget] = React.useState(null);\r\n    const [modalCount, setModalCount] = React.useState(0);\r\n    const focusTrapElement = useFocusLock(isModalOpen, headingRef, bodyRef);\r\n    const prevOpen = usePrevious(props.isOpen);\r\n    React.useEffect(() => {\r\n        if (props.isModalClosingControlledManually &&\r\n            prevOpen &&\r\n            !props.isOpen &&\r\n            isModalOpen) {\r\n            setIsModalOpen(false);\r\n        }\r\n        else if (!prevOpen && props.isOpen) {\r\n            setIsModalOpen(true);\r\n            if (props.headerRef && typeof props.headerRef === 'function') {\r\n                props.headerRef(headingRef);\r\n            }\r\n        }\r\n        else if (prevOpen && !props.isOpen && isModalOpen) {\r\n            handleClose();\r\n        }\r\n    }, [props.isOpen]);\r\n    React.useEffect(() => {\r\n        if (isModalOpen) {\r\n            lastFocus.current = document.activeElement;\r\n            const count = document.querySelectorAll('[aria-modal=\"true\"]').length;\r\n            setModalCount(count);\r\n            if (!props.isEscKeyDownDisabled) {\r\n                document.body.addEventListener('keydown', handleEscapeKeyDown, false);\r\n            }\r\n        }\r\n        return () => {\r\n            document.body.removeEventListener('keydown', handleEscapeKeyDown, false);\r\n        };\r\n    }, [isModalOpen]);\r\n    function handleModalClick(event) {\r\n        if (!document.getElementById(contentId).contains(event.target) &&\r\n            event.target === currentTarget) {\r\n            handleClose(event);\r\n        }\r\n    }\r\n    function handleModalOnMouseDown(event) {\r\n        setCurrentTarget(event.target);\r\n    }\r\n    function handleEscapeKeyDown(event) {\r\n        if (event.key === 'Escape') {\r\n            event.preventDefault();\r\n            event.stopPropagation();\r\n            props.onEscKeyDown &&\r\n                typeof props.onEscKeyDown === 'function' &&\r\n                props.onEscKeyDown(event);\r\n            //Supports nested modals\r\n            const modalsInDom = document.querySelectorAll('[aria-modal=\"true\"]').length;\r\n            if (modalCount <= 1 && modalsInDom !== 1) {\r\n                if (document.getElementById(id).contains(event.target)) {\r\n                    handleClose(event);\r\n                }\r\n                else {\r\n                    headingRef.current.focus();\r\n                }\r\n            }\r\n            else {\r\n                handleClose(event);\r\n            }\r\n        }\r\n    }\r\n    function handleClose(event) {\r\n        if (event) {\r\n            event.stopPropagation();\r\n        }\r\n        setIsExiting(true);\r\n        setTimeout(() => {\r\n            setIsExiting(false);\r\n            if (!props.isModalClosingControlledManually) {\r\n                setIsModalOpen(false);\r\n            }\r\n            if (lastFocus.current) {\r\n                lastFocus.current.focus();\r\n            }\r\n            props.onClose && typeof props.onClose === 'function' && props.onClose();\r\n        }, 300);\r\n    }\r\n    const { ariaLabel, children, closeAriaLabel, closeButtonSize, containerStyle, containerTransition = { slideTop: true }, isBackgroundClickDisabled, isEscKeyDownDisabled, header, isCloseButtonHidden, isOpen, unmountOnExit = true, testId, ...rest } = props;\r\n    const isInverse = useIsInverse(props.isInverse);\r\n    const other = omit(['onEscKeyDown'], rest);\r\n    const theme = React.useContext(ThemeContext);\r\n    const i18n = React.useContext(I18nContext);\r\n    const CloseIconButton = (React.createElement(CloseIcon, { size: magma.iconSizes[closeButtonSize]\r\n            ? magma.iconSizes[closeButtonSize]\r\n            : magma.iconSizes.medium }));\r\n    return isModalOpen\r\n        ? ReactDOM.createPortal(React.createElement(\"div\", { ref: focusTrapElement },\r\n            React.createElement(Global, { styles: css `\n                html {\n                  overflow: ${isOpen ? 'hidden' : 'auto'};\n                }\n              ` }),\r\n            React.createElement(ModalBackdrop, { \"data-testid\": \"modal-backdrop\", isExiting: isExiting, onMouseDown: isBackgroundClickDisabled\r\n                    ? event => event.preventDefault()\r\n                    : null, fade: true, isOpen: isModalOpen, unmountOnExit: true, theme: theme },\r\n                React.createElement(ModalContainer, Object.assign({ \"aria-labelledby\": header ? headingId : null, \"aria-label\": !header ? ariaLabel : null, \"aria-modal\": true, \"data-testid\": testId, id: id, onClick: isBackgroundClickDisabled ? null : handleModalClick, onMouseDown: isBackgroundClickDisabled ? null : handleModalOnMouseDown, role: \"dialog\", style: containerStyle, theme: theme, isOpen: isModalOpen }, containerTransition, { unmountOnExit: unmountOnExit }),\r\n                    React.createElement(ModalContent, Object.assign({}, other, { \"data-testid\": \"modal-content\", id: contentId, isExiting: isExiting, ref: ref, theme: theme }),\r\n                        header && (React.createElement(ModalHeader, { theme: theme }, header && (React.createElement(H1, { id: headingId, isInverse: isInverse, level: 1, ref: headingRef, visualStyle: TypographyVisualStyle.headingSmall, tabIndex: -1, theme: theme }, header)))),\r\n                        React.createElement(ModalWrapper, { ref: bodyRef, theme: theme }, children),\r\n                        !isCloseButtonHidden && (React.createElement(CloseBtn, { theme: theme },\r\n                            React.createElement(IconButton, { \"aria-label\": closeAriaLabel\r\n                                    ? closeAriaLabel\r\n                                    : i18n.modal.closeAriaLabel, color: ButtonColor.primary, icon: CloseIconButton, isInverse: isInverse, onClick: handleClose, testId: \"modal-closebtn\", variant: ButtonVariant.link }))))))), document.getElementsByTagName('body')[0])\r\n        : null;\r\n});\r\n//# sourceMappingURL=Modal.js.map"]} */"));
10454
+ }, ";bottom:0;left:0;right:0;top:0;z-index:997;position:fixed;" + ( "/*# sourceMappingURL=data:application/json;charset=utf-8;base64,{"version":3,"sources":["Modal.tsx"],"names":[],"mappings":"AAgCyC","file":"Modal.tsx","sourcesContent":["import * as React from 'react';\r\nimport ReactDOM from 'react-dom';\r\nimport styled from '@emotion/styled';\r\nimport { Global, css } from '@emotion/react';\r\nimport { ThemeContext } from '../../theme/ThemeContext';\r\nimport { magma } from '../../theme/magma';\r\nimport { I18nContext } from '../../i18n';\r\nimport { ButtonColor, ButtonVariant } from '../Button';\r\nimport { IconButton } from '../IconButton';\r\nimport { CloseIcon } from 'react-magma-icons';\r\nimport { Heading } from '../Heading';\r\nimport { TypographyVisualStyle } from '../Typography';\r\nimport { Transition } from '../Transition';\r\nimport { omit, useGenerateId, usePrevious } from '../../utils';\r\nimport { useFocusLock } from '../../hooks/useFocusLock';\r\nimport { transparentize } from 'polished';\r\nimport { useIsInverse } from '../../inverse';\r\nexport var ModalSize;\r\n(function (ModalSize) {\r\n    ModalSize[\"large\"] = \"large\";\r\n    ModalSize[\"medium\"] = \"medium\";\r\n    ModalSize[\"small\"] = \"small\";\r\n})(ModalSize || (ModalSize = {}));\r\nconst ModalContainer = styled(Transition) `\n  bottom: 0;\n  left: 0;\n  overflow-y: auto;\n  padding: ${props => props.theme.spaceScale.spacing03};\n  right: 0;\n  top: 0;\n  z-index: ${props => (props.modalCount >= 2 ? '999' : '998')};\n`;\r\nconst ModalBackdrop = styled(Transition) `\n  backdrop-filter: blur(3px);\n  background: ${props => transparentize(0.4, props.theme.colors.neutral900)};\n  bottom: 0;\n  left: 0;\n  right: 0;\n  top: 0;\n  z-index: 997;\n  position: fixed;\n`;\r\nconst ModalContent = styled.div `\n  background: ${props => props.isInverse\r\n    ? props.theme.colors.primary600\r\n    : props.theme.colors.neutral100};\n  border: 1px solid;\n  border-color: ${props => props.isInverse\r\n    ? transparentize(0.5, props.theme.colors.tertiary)\r\n    : props.theme.colors.neutral};\n  border-radius: ${props => props.theme.borderRadius};\n  box-shadow: ${props => `0 2px 6px ${transparentize(0.85, props.theme.colors.neutral900)}`};\n  color: ${props => props.isInverse\r\n    ? props.theme.colors.neutral100\r\n    : props.theme.colors.neutral700};\n  margin: 0 auto;\n  position: relative;\n  z-index: 1000;\n\n  max-width: ${props => {\r\n    switch (props.size) {\r\n        case 'large':\r\n            return props.theme.modal.width.large;\r\n        case 'small':\r\n            return props.theme.modal.width.small;\r\n        default:\r\n            return props.theme.modal.width.medium;\r\n    }\r\n}};\n\n  @media (min-width: ${props => props.theme.breakpoints.small}px) {\n    margin: ${props => props.theme.spaceScale.spacing08} auto;\n  }\n`;\r\nconst ModalHeader = styled.div `\n  padding: ${props => props.theme.spaceScale.spacing05}\n    ${props => props.theme.spaceScale.spacing05} 0\n    ${props => props.theme.spaceScale.spacing05};\n  @media (min-width: ${props => props.theme.breakpoints.small}px) {\n    padding: ${props => props.theme.spaceScale.spacing06}\n      ${props => props.theme.spaceScale.spacing06} 0\n      ${props => props.theme.spaceScale.spacing06};\n  }\n`;\r\nconst ModalWrapper = styled.div `\n  padding: ${props => props.theme.spaceScale.spacing05};\n  @media (min-width: ${props => props.theme.breakpoints.small}px) {\n    padding: ${props => props.theme.spaceScale.spacing06};\n  }\n`;\r\nconst H1 = styled(Heading) `\n  font-size: ${props => props.theme.typographyVisualStyles.headingSmall.desktop.fontSize};\n  line-height: ${props => props.theme.typographyVisualStyles.headingSmall.desktop.lineHeight};\n  color: ${props => props.isInverse\r\n    ? props.theme.colors.neutral100\r\n    : props.theme.colors.neutral700};\n  margin: 0;\n  padding-right: ${props => props.theme.spaceScale.spacing10};\n  font-weight: 600;\n`;\r\nconst CloseBtn = styled.span `\n  position: absolute;\n  top: 0;\n  right: 0;\n  margin: ${props => props.theme.spaceScale.spacing02};\n`;\r\nexport const Modal = React.forwardRef((props, ref) => {\r\n    const lastFocus = React.useRef();\r\n    const headingRef = React.useRef();\r\n    const bodyRef = React.useRef();\r\n    const id = useGenerateId(props.id);\r\n    const headingId = `${id}_heading`;\r\n    const contentId = `${id}_content`;\r\n    const [isModalOpen, setIsModalOpen] = React.useState(props.isOpen);\r\n    const [isExiting, setIsExiting] = React.useState(false);\r\n    const [currentTarget, setCurrentTarget] = React.useState(null);\r\n    const [modalCount, setModalCount] = React.useState(0);\r\n    const focusTrapElement = useFocusLock(isModalOpen, headingRef, bodyRef);\r\n    const prevOpen = usePrevious(props.isOpen);\r\n    React.useEffect(() => {\r\n        if (props.isModalClosingControlledManually &&\r\n            prevOpen &&\r\n            !props.isOpen &&\r\n            isModalOpen) {\r\n            setIsModalOpen(false);\r\n        }\r\n        else if (!prevOpen && props.isOpen) {\r\n            setIsModalOpen(true);\r\n            if (props.headerRef && typeof props.headerRef === 'function') {\r\n                props.headerRef(headingRef);\r\n            }\r\n        }\r\n        else if (prevOpen && !props.isOpen && isModalOpen) {\r\n            handleClose();\r\n        }\r\n    }, [props.isOpen]);\r\n    React.useEffect(() => {\r\n        if (isModalOpen) {\r\n            lastFocus.current = document.activeElement;\r\n            const count = document.querySelectorAll('[aria-modal=\"true\"]').length;\r\n            setModalCount(count);\r\n            if (!props.isEscKeyDownDisabled) {\r\n                document.body.addEventListener('keydown', handleEscapeKeyDown, false);\r\n            }\r\n        }\r\n        return () => {\r\n            document.body.removeEventListener('keydown', handleEscapeKeyDown, false);\r\n        };\r\n    }, [isModalOpen]);\r\n    function handleModalClick(event) {\r\n        if (!document.getElementById(contentId).contains(event.target) &&\r\n            event.target === currentTarget) {\r\n            handleClose(event);\r\n        }\r\n    }\r\n    function handleModalOnMouseDown(event) {\r\n        setCurrentTarget(event.target);\r\n    }\r\n    function handleEscapeKeyDown(event) {\r\n        if (event.key === 'Escape') {\r\n            event.preventDefault();\r\n            event.stopPropagation();\r\n            props.onEscKeyDown &&\r\n                typeof props.onEscKeyDown === 'function' &&\r\n                props.onEscKeyDown(event);\r\n            //Supports nested modals\r\n            const modalsInDom = document.querySelectorAll('[aria-modal=\"true\"]').length;\r\n            if (modalCount <= 1 && modalsInDom !== 1) {\r\n                if (document.getElementById(id).contains(event.target)) {\r\n                    handleClose(event);\r\n                }\r\n                else {\r\n                    headingRef.current.focus();\r\n                }\r\n            }\r\n            else {\r\n                handleClose(event);\r\n            }\r\n        }\r\n    }\r\n    function handleClose(event) {\r\n        if (event) {\r\n            event.stopPropagation();\r\n        }\r\n        setIsExiting(true);\r\n        setTimeout(() => {\r\n            setIsExiting(false);\r\n            if (!props.isModalClosingControlledManually) {\r\n                setIsModalOpen(false);\r\n            }\r\n            if (lastFocus.current) {\r\n                lastFocus.current.focus();\r\n            }\r\n            props.onClose && typeof props.onClose === 'function' && props.onClose();\r\n        }, 300);\r\n    }\r\n    const { ariaLabel, children, closeAriaLabel, closeButtonSize, containerStyle, containerTransition = { slideTop: true }, isBackgroundClickDisabled, isEscKeyDownDisabled, header, isCloseButtonHidden, isOpen, unmountOnExit = true, testId, ...rest } = props;\r\n    const isInverse = useIsInverse(props.isInverse);\r\n    const other = omit(['onEscKeyDown'], rest);\r\n    const theme = React.useContext(ThemeContext);\r\n    const i18n = React.useContext(I18nContext);\r\n    const CloseIconButton = (React.createElement(CloseIcon, { size: magma.iconSizes[closeButtonSize]\r\n            ? magma.iconSizes[closeButtonSize]\r\n            : magma.iconSizes.medium }));\r\n    return isModalOpen\r\n        ? ReactDOM.createPortal(React.createElement(\"div\", { ref: focusTrapElement },\r\n            React.createElement(Global, { styles: css `\n                html {\n                  overflow: ${isOpen ? 'hidden' : 'auto'};\n                }\n              ` }),\r\n            React.createElement(ModalContainer, Object.assign({ \"aria-labelledby\": header ? headingId : null, \"aria-label\": !header ? ariaLabel : null, \"aria-modal\": true, \"data-testid\": testId, id: id, modalCount: modalCount, onClick: isBackgroundClickDisabled ? null : handleModalClick, onMouseDown: isBackgroundClickDisabled ? null : handleModalOnMouseDown, role: \"dialog\", style: containerStyle, theme: theme, isOpen: isModalOpen }, containerTransition, { unmountOnExit: unmountOnExit }),\r\n                React.createElement(ModalContent, Object.assign({}, other, { \"data-testid\": \"modal-content\", id: contentId, isExiting: isExiting, ref: ref, theme: theme }),\r\n                    header && (React.createElement(ModalHeader, { theme: theme }, header && (React.createElement(H1, { id: headingId, isInverse: isInverse, level: 1, ref: headingRef, visualStyle: TypographyVisualStyle.headingSmall, tabIndex: -1, theme: theme }, header)))),\r\n                    React.createElement(ModalWrapper, { ref: bodyRef, theme: theme }, children),\r\n                    !isCloseButtonHidden && (React.createElement(CloseBtn, { theme: theme },\r\n                        React.createElement(IconButton, { \"aria-label\": closeAriaLabel\r\n                                ? closeAriaLabel\r\n                                : i18n.modal.closeAriaLabel, color: ButtonColor.primary, icon: CloseIconButton, isInverse: isInverse, onClick: handleClose, testId: \"modal-closebtn\", variant: ButtonVariant.link }))))),\r\n            React.createElement(ModalBackdrop, { \"data-testid\": \"modal-backdrop\", isExiting: isExiting, onMouseDown: isBackgroundClickDisabled\r\n                    ? event => event.preventDefault()\r\n                    : null, fade: true, isOpen: isModalOpen, style: modalCount >= 2 && { zIndex: '998' }, unmountOnExit: true, theme: theme })), document.getElementsByTagName('body')[0])\r\n        : null;\r\n});\r\n//# sourceMappingURL=Modal.js.map"]} */"));
10453
10455
  var ModalContent = /*#__PURE__*/_styled("div", {
10454
10456
  target: "e1pxemtw4",
10455
10457
  label: "ModalContent"
@@ -10476,7 +10478,7 @@ var ModalContent = /*#__PURE__*/_styled("div", {
10476
10478
  return props.theme.breakpoints.small;
10477
10479
  }, "px){margin:", function (props) {
10478
10480
  return props.theme.spaceScale.spacing08;
10479
- }, " auto;}" + ( "/*# sourceMappingURL=data:application/json;charset=utf-8;base64,{"version":3,"sources":["Modal.tsx"],"names":[],"mappings":"AA0CgC","file":"Modal.tsx","sourcesContent":["import * as React from 'react';\r\nimport ReactDOM from 'react-dom';\r\nimport styled from '@emotion/styled';\r\nimport { Global, css } from '@emotion/react';\r\nimport { ThemeContext } from '../../theme/ThemeContext';\r\nimport { magma } from '../../theme/magma';\r\nimport { I18nContext } from '../../i18n';\r\nimport { ButtonColor, ButtonVariant } from '../Button';\r\nimport { IconButton } from '../IconButton';\r\nimport { CloseIcon } from 'react-magma-icons';\r\nimport { Heading } from '../Heading';\r\nimport { TypographyVisualStyle } from '../Typography';\r\nimport { Transition } from '../Transition';\r\nimport { omit, useGenerateId, usePrevious } from '../../utils';\r\nimport { useFocusLock } from '../../hooks/useFocusLock';\r\nimport { transparentize } from 'polished';\r\nimport { useIsInverse } from '../../inverse';\r\nexport var ModalSize;\r\n(function (ModalSize) {\r\n    ModalSize[\"large\"] = \"large\";\r\n    ModalSize[\"medium\"] = \"medium\";\r\n    ModalSize[\"small\"] = \"small\";\r\n})(ModalSize || (ModalSize = {}));\r\nconst ModalContainer = styled(Transition) `\n  bottom: 0;\n  left: 0;\n  overflow-y: auto;\n  padding: ${props => props.theme.spaceScale.spacing03};\n  right: 0;\n  top: 0;\n  z-index: 998;\n`;\r\nconst ModalBackdrop = styled(Transition) `\n  backdrop-filter: blur(3px);\n  background: ${props => transparentize(0.4, props.theme.colors.neutral900)};\n  bottom: 0;\n  left: 0;\n  right: 0;\n  top: 0;\n  z-index: 997;\n  position: fixed;\n`;\r\nconst ModalContent = styled.div `\n  background: ${props => props.isInverse\r\n    ? props.theme.colors.primary600\r\n    : props.theme.colors.neutral100};\n  border: 1px solid;\n  border-color: ${props => props.isInverse\r\n    ? transparentize(0.5, props.theme.colors.tertiary)\r\n    : props.theme.colors.neutral};\n  border-radius: ${props => props.theme.borderRadius};\n  box-shadow: ${props => `0 2px 6px ${transparentize(0.85, props.theme.colors.neutral900)}`};\n  color: ${props => props.isInverse\r\n    ? props.theme.colors.neutral100\r\n    : props.theme.colors.neutral700};\n  margin: 0 auto;\n  position: relative;\n  z-index: 1000;\n\n  max-width: ${props => {\r\n    switch (props.size) {\r\n        case 'large':\r\n            return props.theme.modal.width.large;\r\n        case 'small':\r\n            return props.theme.modal.width.small;\r\n        default:\r\n            return props.theme.modal.width.medium;\r\n    }\r\n}};\n\n  @media (min-width: ${props => props.theme.breakpoints.small}px) {\n    margin: ${props => props.theme.spaceScale.spacing08} auto;\n  }\n`;\r\nconst ModalHeader = styled.div `\n  padding: ${props => props.theme.spaceScale.spacing05}\n    ${props => props.theme.spaceScale.spacing05} 0\n    ${props => props.theme.spaceScale.spacing05};\n  @media (min-width: ${props => props.theme.breakpoints.small}px) {\n    padding: ${props => props.theme.spaceScale.spacing06}\n      ${props => props.theme.spaceScale.spacing06} 0\n      ${props => props.theme.spaceScale.spacing06};\n  }\n`;\r\nconst ModalWrapper = styled.div `\n  padding: ${props => props.theme.spaceScale.spacing05};\n  @media (min-width: ${props => props.theme.breakpoints.small}px) {\n    padding: ${props => props.theme.spaceScale.spacing06};\n  }\n`;\r\nconst H1 = styled(Heading) `\n  font-size: ${props => props.theme.typographyVisualStyles.headingSmall.desktop.fontSize};\n  line-height: ${props => props.theme.typographyVisualStyles.headingSmall.desktop.lineHeight};\n  color: ${props => props.isInverse\r\n    ? props.theme.colors.neutral100\r\n    : props.theme.colors.neutral700};\n  margin: 0;\n  padding-right: ${props => props.theme.spaceScale.spacing10};\n  font-weight: 600;\n`;\r\nconst CloseBtn = styled.span `\n  position: absolute;\n  top: 0;\n  right: 0;\n  margin: ${props => props.theme.spaceScale.spacing02};\n`;\r\nexport const Modal = React.forwardRef((props, ref) => {\r\n    const lastFocus = React.useRef();\r\n    const headingRef = React.useRef();\r\n    const bodyRef = React.useRef();\r\n    const id = useGenerateId(props.id);\r\n    const headingId = `${id}_heading`;\r\n    const contentId = `${id}_content`;\r\n    const [isModalOpen, setIsModalOpen] = React.useState(props.isOpen);\r\n    const [isExiting, setIsExiting] = React.useState(false);\r\n    const [currentTarget, setCurrentTarget] = React.useState(null);\r\n    const [modalCount, setModalCount] = React.useState(0);\r\n    const focusTrapElement = useFocusLock(isModalOpen, headingRef, bodyRef);\r\n    const prevOpen = usePrevious(props.isOpen);\r\n    React.useEffect(() => {\r\n        if (props.isModalClosingControlledManually &&\r\n            prevOpen &&\r\n            !props.isOpen &&\r\n            isModalOpen) {\r\n            setIsModalOpen(false);\r\n        }\r\n        else if (!prevOpen && props.isOpen) {\r\n            setIsModalOpen(true);\r\n            if (props.headerRef && typeof props.headerRef === 'function') {\r\n                props.headerRef(headingRef);\r\n            }\r\n        }\r\n        else if (prevOpen && !props.isOpen && isModalOpen) {\r\n            handleClose();\r\n        }\r\n    }, [props.isOpen]);\r\n    React.useEffect(() => {\r\n        if (isModalOpen) {\r\n            lastFocus.current = document.activeElement;\r\n            const count = document.querySelectorAll('[aria-modal=\"true\"]').length;\r\n            setModalCount(count);\r\n            if (!props.isEscKeyDownDisabled) {\r\n                document.body.addEventListener('keydown', handleEscapeKeyDown, false);\r\n            }\r\n        }\r\n        return () => {\r\n            document.body.removeEventListener('keydown', handleEscapeKeyDown, false);\r\n        };\r\n    }, [isModalOpen]);\r\n    function handleModalClick(event) {\r\n        if (!document.getElementById(contentId).contains(event.target) &&\r\n            event.target === currentTarget) {\r\n            handleClose(event);\r\n        }\r\n    }\r\n    function handleModalOnMouseDown(event) {\r\n        setCurrentTarget(event.target);\r\n    }\r\n    function handleEscapeKeyDown(event) {\r\n        if (event.key === 'Escape') {\r\n            event.preventDefault();\r\n            event.stopPropagation();\r\n            props.onEscKeyDown &&\r\n                typeof props.onEscKeyDown === 'function' &&\r\n                props.onEscKeyDown(event);\r\n            //Supports nested modals\r\n            const modalsInDom = document.querySelectorAll('[aria-modal=\"true\"]').length;\r\n            if (modalCount <= 1 && modalsInDom !== 1) {\r\n                if (document.getElementById(id).contains(event.target)) {\r\n                    handleClose(event);\r\n                }\r\n                else {\r\n                    headingRef.current.focus();\r\n                }\r\n            }\r\n            else {\r\n                handleClose(event);\r\n            }\r\n        }\r\n    }\r\n    function handleClose(event) {\r\n        if (event) {\r\n            event.stopPropagation();\r\n        }\r\n        setIsExiting(true);\r\n        setTimeout(() => {\r\n            setIsExiting(false);\r\n            if (!props.isModalClosingControlledManually) {\r\n                setIsModalOpen(false);\r\n            }\r\n            if (lastFocus.current) {\r\n                lastFocus.current.focus();\r\n            }\r\n            props.onClose && typeof props.onClose === 'function' && props.onClose();\r\n        }, 300);\r\n    }\r\n    const { ariaLabel, children, closeAriaLabel, closeButtonSize, containerStyle, containerTransition = { slideTop: true }, isBackgroundClickDisabled, isEscKeyDownDisabled, header, isCloseButtonHidden, isOpen, unmountOnExit = true, testId, ...rest } = props;\r\n    const isInverse = useIsInverse(props.isInverse);\r\n    const other = omit(['onEscKeyDown'], rest);\r\n    const theme = React.useContext(ThemeContext);\r\n    const i18n = React.useContext(I18nContext);\r\n    const CloseIconButton = (React.createElement(CloseIcon, { size: magma.iconSizes[closeButtonSize]\r\n            ? magma.iconSizes[closeButtonSize]\r\n            : magma.iconSizes.medium }));\r\n    return isModalOpen\r\n        ? ReactDOM.createPortal(React.createElement(\"div\", { ref: focusTrapElement },\r\n            React.createElement(Global, { styles: css `\n                html {\n                  overflow: ${isOpen ? 'hidden' : 'auto'};\n                }\n              ` }),\r\n            React.createElement(ModalBackdrop, { \"data-testid\": \"modal-backdrop\", isExiting: isExiting, onMouseDown: isBackgroundClickDisabled\r\n                    ? event => event.preventDefault()\r\n                    : null, fade: true, isOpen: isModalOpen, unmountOnExit: true, theme: theme },\r\n                React.createElement(ModalContainer, Object.assign({ \"aria-labelledby\": header ? headingId : null, \"aria-label\": !header ? ariaLabel : null, \"aria-modal\": true, \"data-testid\": testId, id: id, onClick: isBackgroundClickDisabled ? null : handleModalClick, onMouseDown: isBackgroundClickDisabled ? null : handleModalOnMouseDown, role: \"dialog\", style: containerStyle, theme: theme, isOpen: isModalOpen }, containerTransition, { unmountOnExit: unmountOnExit }),\r\n                    React.createElement(ModalContent, Object.assign({}, other, { \"data-testid\": \"modal-content\", id: contentId, isExiting: isExiting, ref: ref, theme: theme }),\r\n                        header && (React.createElement(ModalHeader, { theme: theme }, header && (React.createElement(H1, { id: headingId, isInverse: isInverse, level: 1, ref: headingRef, visualStyle: TypographyVisualStyle.headingSmall, tabIndex: -1, theme: theme }, header)))),\r\n                        React.createElement(ModalWrapper, { ref: bodyRef, theme: theme }, children),\r\n                        !isCloseButtonHidden && (React.createElement(CloseBtn, { theme: theme },\r\n                            React.createElement(IconButton, { \"aria-label\": closeAriaLabel\r\n                                    ? closeAriaLabel\r\n                                    : i18n.modal.closeAriaLabel, color: ButtonColor.primary, icon: CloseIconButton, isInverse: isInverse, onClick: handleClose, testId: \"modal-closebtn\", variant: ButtonVariant.link }))))))), document.getElementsByTagName('body')[0])\r\n        : null;\r\n});\r\n//# sourceMappingURL=Modal.js.map"]} */"));
10481
+ }, " auto;}" + ( "/*# sourceMappingURL=data:application/json;charset=utf-8;base64,{"version":3,"sources":["Modal.tsx"],"names":[],"mappings":"AA0CgC","file":"Modal.tsx","sourcesContent":["import * as React from 'react';\r\nimport ReactDOM from 'react-dom';\r\nimport styled from '@emotion/styled';\r\nimport { Global, css } from '@emotion/react';\r\nimport { ThemeContext } from '../../theme/ThemeContext';\r\nimport { magma } from '../../theme/magma';\r\nimport { I18nContext } from '../../i18n';\r\nimport { ButtonColor, ButtonVariant } from '../Button';\r\nimport { IconButton } from '../IconButton';\r\nimport { CloseIcon } from 'react-magma-icons';\r\nimport { Heading } from '../Heading';\r\nimport { TypographyVisualStyle } from '../Typography';\r\nimport { Transition } from '../Transition';\r\nimport { omit, useGenerateId, usePrevious } from '../../utils';\r\nimport { useFocusLock } from '../../hooks/useFocusLock';\r\nimport { transparentize } from 'polished';\r\nimport { useIsInverse } from '../../inverse';\r\nexport var ModalSize;\r\n(function (ModalSize) {\r\n    ModalSize[\"large\"] = \"large\";\r\n    ModalSize[\"medium\"] = \"medium\";\r\n    ModalSize[\"small\"] = \"small\";\r\n})(ModalSize || (ModalSize = {}));\r\nconst ModalContainer = styled(Transition) `\n  bottom: 0;\n  left: 0;\n  overflow-y: auto;\n  padding: ${props => props.theme.spaceScale.spacing03};\n  right: 0;\n  top: 0;\n  z-index: ${props => (props.modalCount >= 2 ? '999' : '998')};\n`;\r\nconst ModalBackdrop = styled(Transition) `\n  backdrop-filter: blur(3px);\n  background: ${props => transparentize(0.4, props.theme.colors.neutral900)};\n  bottom: 0;\n  left: 0;\n  right: 0;\n  top: 0;\n  z-index: 997;\n  position: fixed;\n`;\r\nconst ModalContent = styled.div `\n  background: ${props => props.isInverse\r\n    ? props.theme.colors.primary600\r\n    : props.theme.colors.neutral100};\n  border: 1px solid;\n  border-color: ${props => props.isInverse\r\n    ? transparentize(0.5, props.theme.colors.tertiary)\r\n    : props.theme.colors.neutral};\n  border-radius: ${props => props.theme.borderRadius};\n  box-shadow: ${props => `0 2px 6px ${transparentize(0.85, props.theme.colors.neutral900)}`};\n  color: ${props => props.isInverse\r\n    ? props.theme.colors.neutral100\r\n    : props.theme.colors.neutral700};\n  margin: 0 auto;\n  position: relative;\n  z-index: 1000;\n\n  max-width: ${props => {\r\n    switch (props.size) {\r\n        case 'large':\r\n            return props.theme.modal.width.large;\r\n        case 'small':\r\n            return props.theme.modal.width.small;\r\n        default:\r\n            return props.theme.modal.width.medium;\r\n    }\r\n}};\n\n  @media (min-width: ${props => props.theme.breakpoints.small}px) {\n    margin: ${props => props.theme.spaceScale.spacing08} auto;\n  }\n`;\r\nconst ModalHeader = styled.div `\n  padding: ${props => props.theme.spaceScale.spacing05}\n    ${props => props.theme.spaceScale.spacing05} 0\n    ${props => props.theme.spaceScale.spacing05};\n  @media (min-width: ${props => props.theme.breakpoints.small}px) {\n    padding: ${props => props.theme.spaceScale.spacing06}\n      ${props => props.theme.spaceScale.spacing06} 0\n      ${props => props.theme.spaceScale.spacing06};\n  }\n`;\r\nconst ModalWrapper = styled.div `\n  padding: ${props => props.theme.spaceScale.spacing05};\n  @media (min-width: ${props => props.theme.breakpoints.small}px) {\n    padding: ${props => props.theme.spaceScale.spacing06};\n  }\n`;\r\nconst H1 = styled(Heading) `\n  font-size: ${props => props.theme.typographyVisualStyles.headingSmall.desktop.fontSize};\n  line-height: ${props => props.theme.typographyVisualStyles.headingSmall.desktop.lineHeight};\n  color: ${props => props.isInverse\r\n    ? props.theme.colors.neutral100\r\n    : props.theme.colors.neutral700};\n  margin: 0;\n  padding-right: ${props => props.theme.spaceScale.spacing10};\n  font-weight: 600;\n`;\r\nconst CloseBtn = styled.span `\n  position: absolute;\n  top: 0;\n  right: 0;\n  margin: ${props => props.theme.spaceScale.spacing02};\n`;\r\nexport const Modal = React.forwardRef((props, ref) => {\r\n    const lastFocus = React.useRef();\r\n    const headingRef = React.useRef();\r\n    const bodyRef = React.useRef();\r\n    const id = useGenerateId(props.id);\r\n    const headingId = `${id}_heading`;\r\n    const contentId = `${id}_content`;\r\n    const [isModalOpen, setIsModalOpen] = React.useState(props.isOpen);\r\n    const [isExiting, setIsExiting] = React.useState(false);\r\n    const [currentTarget, setCurrentTarget] = React.useState(null);\r\n    const [modalCount, setModalCount] = React.useState(0);\r\n    const focusTrapElement = useFocusLock(isModalOpen, headingRef, bodyRef);\r\n    const prevOpen = usePrevious(props.isOpen);\r\n    React.useEffect(() => {\r\n        if (props.isModalClosingControlledManually &&\r\n            prevOpen &&\r\n            !props.isOpen &&\r\n            isModalOpen) {\r\n            setIsModalOpen(false);\r\n        }\r\n        else if (!prevOpen && props.isOpen) {\r\n            setIsModalOpen(true);\r\n            if (props.headerRef && typeof props.headerRef === 'function') {\r\n                props.headerRef(headingRef);\r\n            }\r\n        }\r\n        else if (prevOpen && !props.isOpen && isModalOpen) {\r\n            handleClose();\r\n        }\r\n    }, [props.isOpen]);\r\n    React.useEffect(() => {\r\n        if (isModalOpen) {\r\n            lastFocus.current = document.activeElement;\r\n            const count = document.querySelectorAll('[aria-modal=\"true\"]').length;\r\n            setModalCount(count);\r\n            if (!props.isEscKeyDownDisabled) {\r\n                document.body.addEventListener('keydown', handleEscapeKeyDown, false);\r\n            }\r\n        }\r\n        return () => {\r\n            document.body.removeEventListener('keydown', handleEscapeKeyDown, false);\r\n        };\r\n    }, [isModalOpen]);\r\n    function handleModalClick(event) {\r\n        if (!document.getElementById(contentId).contains(event.target) &&\r\n            event.target === currentTarget) {\r\n            handleClose(event);\r\n        }\r\n    }\r\n    function handleModalOnMouseDown(event) {\r\n        setCurrentTarget(event.target);\r\n    }\r\n    function handleEscapeKeyDown(event) {\r\n        if (event.key === 'Escape') {\r\n            event.preventDefault();\r\n            event.stopPropagation();\r\n            props.onEscKeyDown &&\r\n                typeof props.onEscKeyDown === 'function' &&\r\n                props.onEscKeyDown(event);\r\n            //Supports nested modals\r\n            const modalsInDom = document.querySelectorAll('[aria-modal=\"true\"]').length;\r\n            if (modalCount <= 1 && modalsInDom !== 1) {\r\n                if (document.getElementById(id).contains(event.target)) {\r\n                    handleClose(event);\r\n                }\r\n                else {\r\n                    headingRef.current.focus();\r\n                }\r\n            }\r\n            else {\r\n                handleClose(event);\r\n            }\r\n        }\r\n    }\r\n    function handleClose(event) {\r\n        if (event) {\r\n            event.stopPropagation();\r\n        }\r\n        setIsExiting(true);\r\n        setTimeout(() => {\r\n            setIsExiting(false);\r\n            if (!props.isModalClosingControlledManually) {\r\n                setIsModalOpen(false);\r\n            }\r\n            if (lastFocus.current) {\r\n                lastFocus.current.focus();\r\n            }\r\n            props.onClose && typeof props.onClose === 'function' && props.onClose();\r\n        }, 300);\r\n    }\r\n    const { ariaLabel, children, closeAriaLabel, closeButtonSize, containerStyle, containerTransition = { slideTop: true }, isBackgroundClickDisabled, isEscKeyDownDisabled, header, isCloseButtonHidden, isOpen, unmountOnExit = true, testId, ...rest } = props;\r\n    const isInverse = useIsInverse(props.isInverse);\r\n    const other = omit(['onEscKeyDown'], rest);\r\n    const theme = React.useContext(ThemeContext);\r\n    const i18n = React.useContext(I18nContext);\r\n    const CloseIconButton = (React.createElement(CloseIcon, { size: magma.iconSizes[closeButtonSize]\r\n            ? magma.iconSizes[closeButtonSize]\r\n            : magma.iconSizes.medium }));\r\n    return isModalOpen\r\n        ? ReactDOM.createPortal(React.createElement(\"div\", { ref: focusTrapElement },\r\n            React.createElement(Global, { styles: css `\n                html {\n                  overflow: ${isOpen ? 'hidden' : 'auto'};\n                }\n              ` }),\r\n            React.createElement(ModalContainer, Object.assign({ \"aria-labelledby\": header ? headingId : null, \"aria-label\": !header ? ariaLabel : null, \"aria-modal\": true, \"data-testid\": testId, id: id, modalCount: modalCount, onClick: isBackgroundClickDisabled ? null : handleModalClick, onMouseDown: isBackgroundClickDisabled ? null : handleModalOnMouseDown, role: \"dialog\", style: containerStyle, theme: theme, isOpen: isModalOpen }, containerTransition, { unmountOnExit: unmountOnExit }),\r\n                React.createElement(ModalContent, Object.assign({}, other, { \"data-testid\": \"modal-content\", id: contentId, isExiting: isExiting, ref: ref, theme: theme }),\r\n                    header && (React.createElement(ModalHeader, { theme: theme }, header && (React.createElement(H1, { id: headingId, isInverse: isInverse, level: 1, ref: headingRef, visualStyle: TypographyVisualStyle.headingSmall, tabIndex: -1, theme: theme }, header)))),\r\n                    React.createElement(ModalWrapper, { ref: bodyRef, theme: theme }, children),\r\n                    !isCloseButtonHidden && (React.createElement(CloseBtn, { theme: theme },\r\n                        React.createElement(IconButton, { \"aria-label\": closeAriaLabel\r\n                                ? closeAriaLabel\r\n                                : i18n.modal.closeAriaLabel, color: ButtonColor.primary, icon: CloseIconButton, isInverse: isInverse, onClick: handleClose, testId: \"modal-closebtn\", variant: ButtonVariant.link }))))),\r\n            React.createElement(ModalBackdrop, { \"data-testid\": \"modal-backdrop\", isExiting: isExiting, onMouseDown: isBackgroundClickDisabled\r\n                    ? event => event.preventDefault()\r\n                    : null, fade: true, isOpen: isModalOpen, style: modalCount >= 2 && { zIndex: '998' }, unmountOnExit: true, theme: theme })), document.getElementsByTagName('body')[0])\r\n        : null;\r\n});\r\n//# sourceMappingURL=Modal.js.map"]} */"));
10480
10482
  var ModalHeader = /*#__PURE__*/_styled("div", {
10481
10483
  target: "e1pxemtw3",
10482
10484
  label: "ModalHeader"
@@ -10494,7 +10496,7 @@ var ModalHeader = /*#__PURE__*/_styled("div", {
10494
10496
  return props.theme.spaceScale.spacing06;
10495
10497
  }, " 0 ", function (props) {
10496
10498
  return props.theme.spaceScale.spacing06;
10497
- }, ";}" + ( "/*# sourceMappingURL=data:application/json;charset=utf-8;base64,{"version":3,"sources":["Modal.tsx"],"names":[],"mappings":"AA0E+B","file":"Modal.tsx","sourcesContent":["import * as React from 'react';\r\nimport ReactDOM from 'react-dom';\r\nimport styled from '@emotion/styled';\r\nimport { Global, css } from '@emotion/react';\r\nimport { ThemeContext } from '../../theme/ThemeContext';\r\nimport { magma } from '../../theme/magma';\r\nimport { I18nContext } from '../../i18n';\r\nimport { ButtonColor, ButtonVariant } from '../Button';\r\nimport { IconButton } from '../IconButton';\r\nimport { CloseIcon } from 'react-magma-icons';\r\nimport { Heading } from '../Heading';\r\nimport { TypographyVisualStyle } from '../Typography';\r\nimport { Transition } from '../Transition';\r\nimport { omit, useGenerateId, usePrevious } from '../../utils';\r\nimport { useFocusLock } from '../../hooks/useFocusLock';\r\nimport { transparentize } from 'polished';\r\nimport { useIsInverse } from '../../inverse';\r\nexport var ModalSize;\r\n(function (ModalSize) {\r\n    ModalSize[\"large\"] = \"large\";\r\n    ModalSize[\"medium\"] = \"medium\";\r\n    ModalSize[\"small\"] = \"small\";\r\n})(ModalSize || (ModalSize = {}));\r\nconst ModalContainer = styled(Transition) `\n  bottom: 0;\n  left: 0;\n  overflow-y: auto;\n  padding: ${props => props.theme.spaceScale.spacing03};\n  right: 0;\n  top: 0;\n  z-index: 998;\n`;\r\nconst ModalBackdrop = styled(Transition) `\n  backdrop-filter: blur(3px);\n  background: ${props => transparentize(0.4, props.theme.colors.neutral900)};\n  bottom: 0;\n  left: 0;\n  right: 0;\n  top: 0;\n  z-index: 997;\n  position: fixed;\n`;\r\nconst ModalContent = styled.div `\n  background: ${props => props.isInverse\r\n    ? props.theme.colors.primary600\r\n    : props.theme.colors.neutral100};\n  border: 1px solid;\n  border-color: ${props => props.isInverse\r\n    ? transparentize(0.5, props.theme.colors.tertiary)\r\n    : props.theme.colors.neutral};\n  border-radius: ${props => props.theme.borderRadius};\n  box-shadow: ${props => `0 2px 6px ${transparentize(0.85, props.theme.colors.neutral900)}`};\n  color: ${props => props.isInverse\r\n    ? props.theme.colors.neutral100\r\n    : props.theme.colors.neutral700};\n  margin: 0 auto;\n  position: relative;\n  z-index: 1000;\n\n  max-width: ${props => {\r\n    switch (props.size) {\r\n        case 'large':\r\n            return props.theme.modal.width.large;\r\n        case 'small':\r\n            return props.theme.modal.width.small;\r\n        default:\r\n            return props.theme.modal.width.medium;\r\n    }\r\n}};\n\n  @media (min-width: ${props => props.theme.breakpoints.small}px) {\n    margin: ${props => props.theme.spaceScale.spacing08} auto;\n  }\n`;\r\nconst ModalHeader = styled.div `\n  padding: ${props => props.theme.spaceScale.spacing05}\n    ${props => props.theme.spaceScale.spacing05} 0\n    ${props => props.theme.spaceScale.spacing05};\n  @media (min-width: ${props => props.theme.breakpoints.small}px) {\n    padding: ${props => props.theme.spaceScale.spacing06}\n      ${props => props.theme.spaceScale.spacing06} 0\n      ${props => props.theme.spaceScale.spacing06};\n  }\n`;\r\nconst ModalWrapper = styled.div `\n  padding: ${props => props.theme.spaceScale.spacing05};\n  @media (min-width: ${props => props.theme.breakpoints.small}px) {\n    padding: ${props => props.theme.spaceScale.spacing06};\n  }\n`;\r\nconst H1 = styled(Heading) `\n  font-size: ${props => props.theme.typographyVisualStyles.headingSmall.desktop.fontSize};\n  line-height: ${props => props.theme.typographyVisualStyles.headingSmall.desktop.lineHeight};\n  color: ${props => props.isInverse\r\n    ? props.theme.colors.neutral100\r\n    : props.theme.colors.neutral700};\n  margin: 0;\n  padding-right: ${props => props.theme.spaceScale.spacing10};\n  font-weight: 600;\n`;\r\nconst CloseBtn = styled.span `\n  position: absolute;\n  top: 0;\n  right: 0;\n  margin: ${props => props.theme.spaceScale.spacing02};\n`;\r\nexport const Modal = React.forwardRef((props, ref) => {\r\n    const lastFocus = React.useRef();\r\n    const headingRef = React.useRef();\r\n    const bodyRef = React.useRef();\r\n    const id = useGenerateId(props.id);\r\n    const headingId = `${id}_heading`;\r\n    const contentId = `${id}_content`;\r\n    const [isModalOpen, setIsModalOpen] = React.useState(props.isOpen);\r\n    const [isExiting, setIsExiting] = React.useState(false);\r\n    const [currentTarget, setCurrentTarget] = React.useState(null);\r\n    const [modalCount, setModalCount] = React.useState(0);\r\n    const focusTrapElement = useFocusLock(isModalOpen, headingRef, bodyRef);\r\n    const prevOpen = usePrevious(props.isOpen);\r\n    React.useEffect(() => {\r\n        if (props.isModalClosingControlledManually &&\r\n            prevOpen &&\r\n            !props.isOpen &&\r\n            isModalOpen) {\r\n            setIsModalOpen(false);\r\n        }\r\n        else if (!prevOpen && props.isOpen) {\r\n            setIsModalOpen(true);\r\n            if (props.headerRef && typeof props.headerRef === 'function') {\r\n                props.headerRef(headingRef);\r\n            }\r\n        }\r\n        else if (prevOpen && !props.isOpen && isModalOpen) {\r\n            handleClose();\r\n        }\r\n    }, [props.isOpen]);\r\n    React.useEffect(() => {\r\n        if (isModalOpen) {\r\n            lastFocus.current = document.activeElement;\r\n            const count = document.querySelectorAll('[aria-modal=\"true\"]').length;\r\n            setModalCount(count);\r\n            if (!props.isEscKeyDownDisabled) {\r\n                document.body.addEventListener('keydown', handleEscapeKeyDown, false);\r\n            }\r\n        }\r\n        return () => {\r\n            document.body.removeEventListener('keydown', handleEscapeKeyDown, false);\r\n        };\r\n    }, [isModalOpen]);\r\n    function handleModalClick(event) {\r\n        if (!document.getElementById(contentId).contains(event.target) &&\r\n            event.target === currentTarget) {\r\n            handleClose(event);\r\n        }\r\n    }\r\n    function handleModalOnMouseDown(event) {\r\n        setCurrentTarget(event.target);\r\n    }\r\n    function handleEscapeKeyDown(event) {\r\n        if (event.key === 'Escape') {\r\n            event.preventDefault();\r\n            event.stopPropagation();\r\n            props.onEscKeyDown &&\r\n                typeof props.onEscKeyDown === 'function' &&\r\n                props.onEscKeyDown(event);\r\n            //Supports nested modals\r\n            const modalsInDom = document.querySelectorAll('[aria-modal=\"true\"]').length;\r\n            if (modalCount <= 1 && modalsInDom !== 1) {\r\n                if (document.getElementById(id).contains(event.target)) {\r\n                    handleClose(event);\r\n                }\r\n                else {\r\n                    headingRef.current.focus();\r\n                }\r\n            }\r\n            else {\r\n                handleClose(event);\r\n            }\r\n        }\r\n    }\r\n    function handleClose(event) {\r\n        if (event) {\r\n            event.stopPropagation();\r\n        }\r\n        setIsExiting(true);\r\n        setTimeout(() => {\r\n            setIsExiting(false);\r\n            if (!props.isModalClosingControlledManually) {\r\n                setIsModalOpen(false);\r\n            }\r\n            if (lastFocus.current) {\r\n                lastFocus.current.focus();\r\n            }\r\n            props.onClose && typeof props.onClose === 'function' && props.onClose();\r\n        }, 300);\r\n    }\r\n    const { ariaLabel, children, closeAriaLabel, closeButtonSize, containerStyle, containerTransition = { slideTop: true }, isBackgroundClickDisabled, isEscKeyDownDisabled, header, isCloseButtonHidden, isOpen, unmountOnExit = true, testId, ...rest } = props;\r\n    const isInverse = useIsInverse(props.isInverse);\r\n    const other = omit(['onEscKeyDown'], rest);\r\n    const theme = React.useContext(ThemeContext);\r\n    const i18n = React.useContext(I18nContext);\r\n    const CloseIconButton = (React.createElement(CloseIcon, { size: magma.iconSizes[closeButtonSize]\r\n            ? magma.iconSizes[closeButtonSize]\r\n            : magma.iconSizes.medium }));\r\n    return isModalOpen\r\n        ? ReactDOM.createPortal(React.createElement(\"div\", { ref: focusTrapElement },\r\n            React.createElement(Global, { styles: css `\n                html {\n                  overflow: ${isOpen ? 'hidden' : 'auto'};\n                }\n              ` }),\r\n            React.createElement(ModalBackdrop, { \"data-testid\": \"modal-backdrop\", isExiting: isExiting, onMouseDown: isBackgroundClickDisabled\r\n                    ? event => event.preventDefault()\r\n                    : null, fade: true, isOpen: isModalOpen, unmountOnExit: true, theme: theme },\r\n                React.createElement(ModalContainer, Object.assign({ \"aria-labelledby\": header ? headingId : null, \"aria-label\": !header ? ariaLabel : null, \"aria-modal\": true, \"data-testid\": testId, id: id, onClick: isBackgroundClickDisabled ? null : handleModalClick, onMouseDown: isBackgroundClickDisabled ? null : handleModalOnMouseDown, role: \"dialog\", style: containerStyle, theme: theme, isOpen: isModalOpen }, containerTransition, { unmountOnExit: unmountOnExit }),\r\n                    React.createElement(ModalContent, Object.assign({}, other, { \"data-testid\": \"modal-content\", id: contentId, isExiting: isExiting, ref: ref, theme: theme }),\r\n                        header && (React.createElement(ModalHeader, { theme: theme }, header && (React.createElement(H1, { id: headingId, isInverse: isInverse, level: 1, ref: headingRef, visualStyle: TypographyVisualStyle.headingSmall, tabIndex: -1, theme: theme }, header)))),\r\n                        React.createElement(ModalWrapper, { ref: bodyRef, theme: theme }, children),\r\n                        !isCloseButtonHidden && (React.createElement(CloseBtn, { theme: theme },\r\n                            React.createElement(IconButton, { \"aria-label\": closeAriaLabel\r\n                                    ? closeAriaLabel\r\n                                    : i18n.modal.closeAriaLabel, color: ButtonColor.primary, icon: CloseIconButton, isInverse: isInverse, onClick: handleClose, testId: \"modal-closebtn\", variant: ButtonVariant.link }))))))), document.getElementsByTagName('body')[0])\r\n        : null;\r\n});\r\n//# sourceMappingURL=Modal.js.map"]} */"));
10499
+ }, ";}" + ( "/*# sourceMappingURL=data:application/json;charset=utf-8;base64,{"version":3,"sources":["Modal.tsx"],"names":[],"mappings":"AA0E+B","file":"Modal.tsx","sourcesContent":["import * as React from 'react';\r\nimport ReactDOM from 'react-dom';\r\nimport styled from '@emotion/styled';\r\nimport { Global, css } from '@emotion/react';\r\nimport { ThemeContext } from '../../theme/ThemeContext';\r\nimport { magma } from '../../theme/magma';\r\nimport { I18nContext } from '../../i18n';\r\nimport { ButtonColor, ButtonVariant } from '../Button';\r\nimport { IconButton } from '../IconButton';\r\nimport { CloseIcon } from 'react-magma-icons';\r\nimport { Heading } from '../Heading';\r\nimport { TypographyVisualStyle } from '../Typography';\r\nimport { Transition } from '../Transition';\r\nimport { omit, useGenerateId, usePrevious } from '../../utils';\r\nimport { useFocusLock } from '../../hooks/useFocusLock';\r\nimport { transparentize } from 'polished';\r\nimport { useIsInverse } from '../../inverse';\r\nexport var ModalSize;\r\n(function (ModalSize) {\r\n    ModalSize[\"large\"] = \"large\";\r\n    ModalSize[\"medium\"] = \"medium\";\r\n    ModalSize[\"small\"] = \"small\";\r\n})(ModalSize || (ModalSize = {}));\r\nconst ModalContainer = styled(Transition) `\n  bottom: 0;\n  left: 0;\n  overflow-y: auto;\n  padding: ${props => props.theme.spaceScale.spacing03};\n  right: 0;\n  top: 0;\n  z-index: ${props => (props.modalCount >= 2 ? '999' : '998')};\n`;\r\nconst ModalBackdrop = styled(Transition) `\n  backdrop-filter: blur(3px);\n  background: ${props => transparentize(0.4, props.theme.colors.neutral900)};\n  bottom: 0;\n  left: 0;\n  right: 0;\n  top: 0;\n  z-index: 997;\n  position: fixed;\n`;\r\nconst ModalContent = styled.div `\n  background: ${props => props.isInverse\r\n    ? props.theme.colors.primary600\r\n    : props.theme.colors.neutral100};\n  border: 1px solid;\n  border-color: ${props => props.isInverse\r\n    ? transparentize(0.5, props.theme.colors.tertiary)\r\n    : props.theme.colors.neutral};\n  border-radius: ${props => props.theme.borderRadius};\n  box-shadow: ${props => `0 2px 6px ${transparentize(0.85, props.theme.colors.neutral900)}`};\n  color: ${props => props.isInverse\r\n    ? props.theme.colors.neutral100\r\n    : props.theme.colors.neutral700};\n  margin: 0 auto;\n  position: relative;\n  z-index: 1000;\n\n  max-width: ${props => {\r\n    switch (props.size) {\r\n        case 'large':\r\n            return props.theme.modal.width.large;\r\n        case 'small':\r\n            return props.theme.modal.width.small;\r\n        default:\r\n            return props.theme.modal.width.medium;\r\n    }\r\n}};\n\n  @media (min-width: ${props => props.theme.breakpoints.small}px) {\n    margin: ${props => props.theme.spaceScale.spacing08} auto;\n  }\n`;\r\nconst ModalHeader = styled.div `\n  padding: ${props => props.theme.spaceScale.spacing05}\n    ${props => props.theme.spaceScale.spacing05} 0\n    ${props => props.theme.spaceScale.spacing05};\n  @media (min-width: ${props => props.theme.breakpoints.small}px) {\n    padding: ${props => props.theme.spaceScale.spacing06}\n      ${props => props.theme.spaceScale.spacing06} 0\n      ${props => props.theme.spaceScale.spacing06};\n  }\n`;\r\nconst ModalWrapper = styled.div `\n  padding: ${props => props.theme.spaceScale.spacing05};\n  @media (min-width: ${props => props.theme.breakpoints.small}px) {\n    padding: ${props => props.theme.spaceScale.spacing06};\n  }\n`;\r\nconst H1 = styled(Heading) `\n  font-size: ${props => props.theme.typographyVisualStyles.headingSmall.desktop.fontSize};\n  line-height: ${props => props.theme.typographyVisualStyles.headingSmall.desktop.lineHeight};\n  color: ${props => props.isInverse\r\n    ? props.theme.colors.neutral100\r\n    : props.theme.colors.neutral700};\n  margin: 0;\n  padding-right: ${props => props.theme.spaceScale.spacing10};\n  font-weight: 600;\n`;\r\nconst CloseBtn = styled.span `\n  position: absolute;\n  top: 0;\n  right: 0;\n  margin: ${props => props.theme.spaceScale.spacing02};\n`;\r\nexport const Modal = React.forwardRef((props, ref) => {\r\n    const lastFocus = React.useRef();\r\n    const headingRef = React.useRef();\r\n    const bodyRef = React.useRef();\r\n    const id = useGenerateId(props.id);\r\n    const headingId = `${id}_heading`;\r\n    const contentId = `${id}_content`;\r\n    const [isModalOpen, setIsModalOpen] = React.useState(props.isOpen);\r\n    const [isExiting, setIsExiting] = React.useState(false);\r\n    const [currentTarget, setCurrentTarget] = React.useState(null);\r\n    const [modalCount, setModalCount] = React.useState(0);\r\n    const focusTrapElement = useFocusLock(isModalOpen, headingRef, bodyRef);\r\n    const prevOpen = usePrevious(props.isOpen);\r\n    React.useEffect(() => {\r\n        if (props.isModalClosingControlledManually &&\r\n            prevOpen &&\r\n            !props.isOpen &&\r\n            isModalOpen) {\r\n            setIsModalOpen(false);\r\n        }\r\n        else if (!prevOpen && props.isOpen) {\r\n            setIsModalOpen(true);\r\n            if (props.headerRef && typeof props.headerRef === 'function') {\r\n                props.headerRef(headingRef);\r\n            }\r\n        }\r\n        else if (prevOpen && !props.isOpen && isModalOpen) {\r\n            handleClose();\r\n        }\r\n    }, [props.isOpen]);\r\n    React.useEffect(() => {\r\n        if (isModalOpen) {\r\n            lastFocus.current = document.activeElement;\r\n            const count = document.querySelectorAll('[aria-modal=\"true\"]').length;\r\n            setModalCount(count);\r\n            if (!props.isEscKeyDownDisabled) {\r\n                document.body.addEventListener('keydown', handleEscapeKeyDown, false);\r\n            }\r\n        }\r\n        return () => {\r\n            document.body.removeEventListener('keydown', handleEscapeKeyDown, false);\r\n        };\r\n    }, [isModalOpen]);\r\n    function handleModalClick(event) {\r\n        if (!document.getElementById(contentId).contains(event.target) &&\r\n            event.target === currentTarget) {\r\n            handleClose(event);\r\n        }\r\n    }\r\n    function handleModalOnMouseDown(event) {\r\n        setCurrentTarget(event.target);\r\n    }\r\n    function handleEscapeKeyDown(event) {\r\n        if (event.key === 'Escape') {\r\n            event.preventDefault();\r\n            event.stopPropagation();\r\n            props.onEscKeyDown &&\r\n                typeof props.onEscKeyDown === 'function' &&\r\n                props.onEscKeyDown(event);\r\n            //Supports nested modals\r\n            const modalsInDom = document.querySelectorAll('[aria-modal=\"true\"]').length;\r\n            if (modalCount <= 1 && modalsInDom !== 1) {\r\n                if (document.getElementById(id).contains(event.target)) {\r\n                    handleClose(event);\r\n                }\r\n                else {\r\n                    headingRef.current.focus();\r\n                }\r\n            }\r\n            else {\r\n                handleClose(event);\r\n            }\r\n        }\r\n    }\r\n    function handleClose(event) {\r\n        if (event) {\r\n            event.stopPropagation();\r\n        }\r\n        setIsExiting(true);\r\n        setTimeout(() => {\r\n            setIsExiting(false);\r\n            if (!props.isModalClosingControlledManually) {\r\n                setIsModalOpen(false);\r\n            }\r\n            if (lastFocus.current) {\r\n                lastFocus.current.focus();\r\n            }\r\n            props.onClose && typeof props.onClose === 'function' && props.onClose();\r\n        }, 300);\r\n    }\r\n    const { ariaLabel, children, closeAriaLabel, closeButtonSize, containerStyle, containerTransition = { slideTop: true }, isBackgroundClickDisabled, isEscKeyDownDisabled, header, isCloseButtonHidden, isOpen, unmountOnExit = true, testId, ...rest } = props;\r\n    const isInverse = useIsInverse(props.isInverse);\r\n    const other = omit(['onEscKeyDown'], rest);\r\n    const theme = React.useContext(ThemeContext);\r\n    const i18n = React.useContext(I18nContext);\r\n    const CloseIconButton = (React.createElement(CloseIcon, { size: magma.iconSizes[closeButtonSize]\r\n            ? magma.iconSizes[closeButtonSize]\r\n            : magma.iconSizes.medium }));\r\n    return isModalOpen\r\n        ? ReactDOM.createPortal(React.createElement(\"div\", { ref: focusTrapElement },\r\n            React.createElement(Global, { styles: css `\n                html {\n                  overflow: ${isOpen ? 'hidden' : 'auto'};\n                }\n              ` }),\r\n            React.createElement(ModalContainer, Object.assign({ \"aria-labelledby\": header ? headingId : null, \"aria-label\": !header ? ariaLabel : null, \"aria-modal\": true, \"data-testid\": testId, id: id, modalCount: modalCount, onClick: isBackgroundClickDisabled ? null : handleModalClick, onMouseDown: isBackgroundClickDisabled ? null : handleModalOnMouseDown, role: \"dialog\", style: containerStyle, theme: theme, isOpen: isModalOpen }, containerTransition, { unmountOnExit: unmountOnExit }),\r\n                React.createElement(ModalContent, Object.assign({}, other, { \"data-testid\": \"modal-content\", id: contentId, isExiting: isExiting, ref: ref, theme: theme }),\r\n                    header && (React.createElement(ModalHeader, { theme: theme }, header && (React.createElement(H1, { id: headingId, isInverse: isInverse, level: 1, ref: headingRef, visualStyle: TypographyVisualStyle.headingSmall, tabIndex: -1, theme: theme }, header)))),\r\n                    React.createElement(ModalWrapper, { ref: bodyRef, theme: theme }, children),\r\n                    !isCloseButtonHidden && (React.createElement(CloseBtn, { theme: theme },\r\n                        React.createElement(IconButton, { \"aria-label\": closeAriaLabel\r\n                                ? closeAriaLabel\r\n                                : i18n.modal.closeAriaLabel, color: ButtonColor.primary, icon: CloseIconButton, isInverse: isInverse, onClick: handleClose, testId: \"modal-closebtn\", variant: ButtonVariant.link }))))),\r\n            React.createElement(ModalBackdrop, { \"data-testid\": \"modal-backdrop\", isExiting: isExiting, onMouseDown: isBackgroundClickDisabled\r\n                    ? event => event.preventDefault()\r\n                    : null, fade: true, isOpen: isModalOpen, style: modalCount >= 2 && { zIndex: '998' }, unmountOnExit: true, theme: theme })), document.getElementsByTagName('body')[0])\r\n        : null;\r\n});\r\n//# sourceMappingURL=Modal.js.map"]} */"));
10498
10500
  var ModalWrapper = /*#__PURE__*/_styled("div", {
10499
10501
  target: "e1pxemtw2",
10500
10502
  label: "ModalWrapper"
@@ -10504,7 +10506,7 @@ var ModalWrapper = /*#__PURE__*/_styled("div", {
10504
10506
  return props.theme.breakpoints.small;
10505
10507
  }, "px){padding:", function (props) {
10506
10508
  return props.theme.spaceScale.spacing06;
10507
- }, ";}" + ( "/*# sourceMappingURL=data:application/json;charset=utf-8;base64,{"version":3,"sources":["Modal.tsx"],"names":[],"mappings":"AAoFgC","file":"Modal.tsx","sourcesContent":["import * as React from 'react';\r\nimport ReactDOM from 'react-dom';\r\nimport styled from '@emotion/styled';\r\nimport { Global, css } from '@emotion/react';\r\nimport { ThemeContext } from '../../theme/ThemeContext';\r\nimport { magma } from '../../theme/magma';\r\nimport { I18nContext } from '../../i18n';\r\nimport { ButtonColor, ButtonVariant } from '../Button';\r\nimport { IconButton } from '../IconButton';\r\nimport { CloseIcon } from 'react-magma-icons';\r\nimport { Heading } from '../Heading';\r\nimport { TypographyVisualStyle } from '../Typography';\r\nimport { Transition } from '../Transition';\r\nimport { omit, useGenerateId, usePrevious } from '../../utils';\r\nimport { useFocusLock } from '../../hooks/useFocusLock';\r\nimport { transparentize } from 'polished';\r\nimport { useIsInverse } from '../../inverse';\r\nexport var ModalSize;\r\n(function (ModalSize) {\r\n    ModalSize[\"large\"] = \"large\";\r\n    ModalSize[\"medium\"] = \"medium\";\r\n    ModalSize[\"small\"] = \"small\";\r\n})(ModalSize || (ModalSize = {}));\r\nconst ModalContainer = styled(Transition) `\n  bottom: 0;\n  left: 0;\n  overflow-y: auto;\n  padding: ${props => props.theme.spaceScale.spacing03};\n  right: 0;\n  top: 0;\n  z-index: 998;\n`;\r\nconst ModalBackdrop = styled(Transition) `\n  backdrop-filter: blur(3px);\n  background: ${props => transparentize(0.4, props.theme.colors.neutral900)};\n  bottom: 0;\n  left: 0;\n  right: 0;\n  top: 0;\n  z-index: 997;\n  position: fixed;\n`;\r\nconst ModalContent = styled.div `\n  background: ${props => props.isInverse\r\n    ? props.theme.colors.primary600\r\n    : props.theme.colors.neutral100};\n  border: 1px solid;\n  border-color: ${props => props.isInverse\r\n    ? transparentize(0.5, props.theme.colors.tertiary)\r\n    : props.theme.colors.neutral};\n  border-radius: ${props => props.theme.borderRadius};\n  box-shadow: ${props => `0 2px 6px ${transparentize(0.85, props.theme.colors.neutral900)}`};\n  color: ${props => props.isInverse\r\n    ? props.theme.colors.neutral100\r\n    : props.theme.colors.neutral700};\n  margin: 0 auto;\n  position: relative;\n  z-index: 1000;\n\n  max-width: ${props => {\r\n    switch (props.size) {\r\n        case 'large':\r\n            return props.theme.modal.width.large;\r\n        case 'small':\r\n            return props.theme.modal.width.small;\r\n        default:\r\n            return props.theme.modal.width.medium;\r\n    }\r\n}};\n\n  @media (min-width: ${props => props.theme.breakpoints.small}px) {\n    margin: ${props => props.theme.spaceScale.spacing08} auto;\n  }\n`;\r\nconst ModalHeader = styled.div `\n  padding: ${props => props.theme.spaceScale.spacing05}\n    ${props => props.theme.spaceScale.spacing05} 0\n    ${props => props.theme.spaceScale.spacing05};\n  @media (min-width: ${props => props.theme.breakpoints.small}px) {\n    padding: ${props => props.theme.spaceScale.spacing06}\n      ${props => props.theme.spaceScale.spacing06} 0\n      ${props => props.theme.spaceScale.spacing06};\n  }\n`;\r\nconst ModalWrapper = styled.div `\n  padding: ${props => props.theme.spaceScale.spacing05};\n  @media (min-width: ${props => props.theme.breakpoints.small}px) {\n    padding: ${props => props.theme.spaceScale.spacing06};\n  }\n`;\r\nconst H1 = styled(Heading) `\n  font-size: ${props => props.theme.typographyVisualStyles.headingSmall.desktop.fontSize};\n  line-height: ${props => props.theme.typographyVisualStyles.headingSmall.desktop.lineHeight};\n  color: ${props => props.isInverse\r\n    ? props.theme.colors.neutral100\r\n    : props.theme.colors.neutral700};\n  margin: 0;\n  padding-right: ${props => props.theme.spaceScale.spacing10};\n  font-weight: 600;\n`;\r\nconst CloseBtn = styled.span `\n  position: absolute;\n  top: 0;\n  right: 0;\n  margin: ${props => props.theme.spaceScale.spacing02};\n`;\r\nexport const Modal = React.forwardRef((props, ref) => {\r\n    const lastFocus = React.useRef();\r\n    const headingRef = React.useRef();\r\n    const bodyRef = React.useRef();\r\n    const id = useGenerateId(props.id);\r\n    const headingId = `${id}_heading`;\r\n    const contentId = `${id}_content`;\r\n    const [isModalOpen, setIsModalOpen] = React.useState(props.isOpen);\r\n    const [isExiting, setIsExiting] = React.useState(false);\r\n    const [currentTarget, setCurrentTarget] = React.useState(null);\r\n    const [modalCount, setModalCount] = React.useState(0);\r\n    const focusTrapElement = useFocusLock(isModalOpen, headingRef, bodyRef);\r\n    const prevOpen = usePrevious(props.isOpen);\r\n    React.useEffect(() => {\r\n        if (props.isModalClosingControlledManually &&\r\n            prevOpen &&\r\n            !props.isOpen &&\r\n            isModalOpen) {\r\n            setIsModalOpen(false);\r\n        }\r\n        else if (!prevOpen && props.isOpen) {\r\n            setIsModalOpen(true);\r\n            if (props.headerRef && typeof props.headerRef === 'function') {\r\n                props.headerRef(headingRef);\r\n            }\r\n        }\r\n        else if (prevOpen && !props.isOpen && isModalOpen) {\r\n            handleClose();\r\n        }\r\n    }, [props.isOpen]);\r\n    React.useEffect(() => {\r\n        if (isModalOpen) {\r\n            lastFocus.current = document.activeElement;\r\n            const count = document.querySelectorAll('[aria-modal=\"true\"]').length;\r\n            setModalCount(count);\r\n            if (!props.isEscKeyDownDisabled) {\r\n                document.body.addEventListener('keydown', handleEscapeKeyDown, false);\r\n            }\r\n        }\r\n        return () => {\r\n            document.body.removeEventListener('keydown', handleEscapeKeyDown, false);\r\n        };\r\n    }, [isModalOpen]);\r\n    function handleModalClick(event) {\r\n        if (!document.getElementById(contentId).contains(event.target) &&\r\n            event.target === currentTarget) {\r\n            handleClose(event);\r\n        }\r\n    }\r\n    function handleModalOnMouseDown(event) {\r\n        setCurrentTarget(event.target);\r\n    }\r\n    function handleEscapeKeyDown(event) {\r\n        if (event.key === 'Escape') {\r\n            event.preventDefault();\r\n            event.stopPropagation();\r\n            props.onEscKeyDown &&\r\n                typeof props.onEscKeyDown === 'function' &&\r\n                props.onEscKeyDown(event);\r\n            //Supports nested modals\r\n            const modalsInDom = document.querySelectorAll('[aria-modal=\"true\"]').length;\r\n            if (modalCount <= 1 && modalsInDom !== 1) {\r\n                if (document.getElementById(id).contains(event.target)) {\r\n                    handleClose(event);\r\n                }\r\n                else {\r\n                    headingRef.current.focus();\r\n                }\r\n            }\r\n            else {\r\n                handleClose(event);\r\n            }\r\n        }\r\n    }\r\n    function handleClose(event) {\r\n        if (event) {\r\n            event.stopPropagation();\r\n        }\r\n        setIsExiting(true);\r\n        setTimeout(() => {\r\n            setIsExiting(false);\r\n            if (!props.isModalClosingControlledManually) {\r\n                setIsModalOpen(false);\r\n            }\r\n            if (lastFocus.current) {\r\n                lastFocus.current.focus();\r\n            }\r\n            props.onClose && typeof props.onClose === 'function' && props.onClose();\r\n        }, 300);\r\n    }\r\n    const { ariaLabel, children, closeAriaLabel, closeButtonSize, containerStyle, containerTransition = { slideTop: true }, isBackgroundClickDisabled, isEscKeyDownDisabled, header, isCloseButtonHidden, isOpen, unmountOnExit = true, testId, ...rest } = props;\r\n    const isInverse = useIsInverse(props.isInverse);\r\n    const other = omit(['onEscKeyDown'], rest);\r\n    const theme = React.useContext(ThemeContext);\r\n    const i18n = React.useContext(I18nContext);\r\n    const CloseIconButton = (React.createElement(CloseIcon, { size: magma.iconSizes[closeButtonSize]\r\n            ? magma.iconSizes[closeButtonSize]\r\n            : magma.iconSizes.medium }));\r\n    return isModalOpen\r\n        ? ReactDOM.createPortal(React.createElement(\"div\", { ref: focusTrapElement },\r\n            React.createElement(Global, { styles: css `\n                html {\n                  overflow: ${isOpen ? 'hidden' : 'auto'};\n                }\n              ` }),\r\n            React.createElement(ModalBackdrop, { \"data-testid\": \"modal-backdrop\", isExiting: isExiting, onMouseDown: isBackgroundClickDisabled\r\n                    ? event => event.preventDefault()\r\n                    : null, fade: true, isOpen: isModalOpen, unmountOnExit: true, theme: theme },\r\n                React.createElement(ModalContainer, Object.assign({ \"aria-labelledby\": header ? headingId : null, \"aria-label\": !header ? ariaLabel : null, \"aria-modal\": true, \"data-testid\": testId, id: id, onClick: isBackgroundClickDisabled ? null : handleModalClick, onMouseDown: isBackgroundClickDisabled ? null : handleModalOnMouseDown, role: \"dialog\", style: containerStyle, theme: theme, isOpen: isModalOpen }, containerTransition, { unmountOnExit: unmountOnExit }),\r\n                    React.createElement(ModalContent, Object.assign({}, other, { \"data-testid\": \"modal-content\", id: contentId, isExiting: isExiting, ref: ref, theme: theme }),\r\n                        header && (React.createElement(ModalHeader, { theme: theme }, header && (React.createElement(H1, { id: headingId, isInverse: isInverse, level: 1, ref: headingRef, visualStyle: TypographyVisualStyle.headingSmall, tabIndex: -1, theme: theme }, header)))),\r\n                        React.createElement(ModalWrapper, { ref: bodyRef, theme: theme }, children),\r\n                        !isCloseButtonHidden && (React.createElement(CloseBtn, { theme: theme },\r\n                            React.createElement(IconButton, { \"aria-label\": closeAriaLabel\r\n                                    ? closeAriaLabel\r\n                                    : i18n.modal.closeAriaLabel, color: ButtonColor.primary, icon: CloseIconButton, isInverse: isInverse, onClick: handleClose, testId: \"modal-closebtn\", variant: ButtonVariant.link }))))))), document.getElementsByTagName('body')[0])\r\n        : null;\r\n});\r\n//# sourceMappingURL=Modal.js.map"]} */"));
10509
+ }, ";}" + ( "/*# sourceMappingURL=data:application/json;charset=utf-8;base64,{"version":3,"sources":["Modal.tsx"],"names":[],"mappings":"AAoFgC","file":"Modal.tsx","sourcesContent":["import * as React from 'react';\r\nimport ReactDOM from 'react-dom';\r\nimport styled from '@emotion/styled';\r\nimport { Global, css } from '@emotion/react';\r\nimport { ThemeContext } from '../../theme/ThemeContext';\r\nimport { magma } from '../../theme/magma';\r\nimport { I18nContext } from '../../i18n';\r\nimport { ButtonColor, ButtonVariant } from '../Button';\r\nimport { IconButton } from '../IconButton';\r\nimport { CloseIcon } from 'react-magma-icons';\r\nimport { Heading } from '../Heading';\r\nimport { TypographyVisualStyle } from '../Typography';\r\nimport { Transition } from '../Transition';\r\nimport { omit, useGenerateId, usePrevious } from '../../utils';\r\nimport { useFocusLock } from '../../hooks/useFocusLock';\r\nimport { transparentize } from 'polished';\r\nimport { useIsInverse } from '../../inverse';\r\nexport var ModalSize;\r\n(function (ModalSize) {\r\n    ModalSize[\"large\"] = \"large\";\r\n    ModalSize[\"medium\"] = \"medium\";\r\n    ModalSize[\"small\"] = \"small\";\r\n})(ModalSize || (ModalSize = {}));\r\nconst ModalContainer = styled(Transition) `\n  bottom: 0;\n  left: 0;\n  overflow-y: auto;\n  padding: ${props => props.theme.spaceScale.spacing03};\n  right: 0;\n  top: 0;\n  z-index: ${props => (props.modalCount >= 2 ? '999' : '998')};\n`;\r\nconst ModalBackdrop = styled(Transition) `\n  backdrop-filter: blur(3px);\n  background: ${props => transparentize(0.4, props.theme.colors.neutral900)};\n  bottom: 0;\n  left: 0;\n  right: 0;\n  top: 0;\n  z-index: 997;\n  position: fixed;\n`;\r\nconst ModalContent = styled.div `\n  background: ${props => props.isInverse\r\n    ? props.theme.colors.primary600\r\n    : props.theme.colors.neutral100};\n  border: 1px solid;\n  border-color: ${props => props.isInverse\r\n    ? transparentize(0.5, props.theme.colors.tertiary)\r\n    : props.theme.colors.neutral};\n  border-radius: ${props => props.theme.borderRadius};\n  box-shadow: ${props => `0 2px 6px ${transparentize(0.85, props.theme.colors.neutral900)}`};\n  color: ${props => props.isInverse\r\n    ? props.theme.colors.neutral100\r\n    : props.theme.colors.neutral700};\n  margin: 0 auto;\n  position: relative;\n  z-index: 1000;\n\n  max-width: ${props => {\r\n    switch (props.size) {\r\n        case 'large':\r\n            return props.theme.modal.width.large;\r\n        case 'small':\r\n            return props.theme.modal.width.small;\r\n        default:\r\n            return props.theme.modal.width.medium;\r\n    }\r\n}};\n\n  @media (min-width: ${props => props.theme.breakpoints.small}px) {\n    margin: ${props => props.theme.spaceScale.spacing08} auto;\n  }\n`;\r\nconst ModalHeader = styled.div `\n  padding: ${props => props.theme.spaceScale.spacing05}\n    ${props => props.theme.spaceScale.spacing05} 0\n    ${props => props.theme.spaceScale.spacing05};\n  @media (min-width: ${props => props.theme.breakpoints.small}px) {\n    padding: ${props => props.theme.spaceScale.spacing06}\n      ${props => props.theme.spaceScale.spacing06} 0\n      ${props => props.theme.spaceScale.spacing06};\n  }\n`;\r\nconst ModalWrapper = styled.div `\n  padding: ${props => props.theme.spaceScale.spacing05};\n  @media (min-width: ${props => props.theme.breakpoints.small}px) {\n    padding: ${props => props.theme.spaceScale.spacing06};\n  }\n`;\r\nconst H1 = styled(Heading) `\n  font-size: ${props => props.theme.typographyVisualStyles.headingSmall.desktop.fontSize};\n  line-height: ${props => props.theme.typographyVisualStyles.headingSmall.desktop.lineHeight};\n  color: ${props => props.isInverse\r\n    ? props.theme.colors.neutral100\r\n    : props.theme.colors.neutral700};\n  margin: 0;\n  padding-right: ${props => props.theme.spaceScale.spacing10};\n  font-weight: 600;\n`;\r\nconst CloseBtn = styled.span `\n  position: absolute;\n  top: 0;\n  right: 0;\n  margin: ${props => props.theme.spaceScale.spacing02};\n`;\r\nexport const Modal = React.forwardRef((props, ref) => {\r\n    const lastFocus = React.useRef();\r\n    const headingRef = React.useRef();\r\n    const bodyRef = React.useRef();\r\n    const id = useGenerateId(props.id);\r\n    const headingId = `${id}_heading`;\r\n    const contentId = `${id}_content`;\r\n    const [isModalOpen, setIsModalOpen] = React.useState(props.isOpen);\r\n    const [isExiting, setIsExiting] = React.useState(false);\r\n    const [currentTarget, setCurrentTarget] = React.useState(null);\r\n    const [modalCount, setModalCount] = React.useState(0);\r\n    const focusTrapElement = useFocusLock(isModalOpen, headingRef, bodyRef);\r\n    const prevOpen = usePrevious(props.isOpen);\r\n    React.useEffect(() => {\r\n        if (props.isModalClosingControlledManually &&\r\n            prevOpen &&\r\n            !props.isOpen &&\r\n            isModalOpen) {\r\n            setIsModalOpen(false);\r\n        }\r\n        else if (!prevOpen && props.isOpen) {\r\n            setIsModalOpen(true);\r\n            if (props.headerRef && typeof props.headerRef === 'function') {\r\n                props.headerRef(headingRef);\r\n            }\r\n        }\r\n        else if (prevOpen && !props.isOpen && isModalOpen) {\r\n            handleClose();\r\n        }\r\n    }, [props.isOpen]);\r\n    React.useEffect(() => {\r\n        if (isModalOpen) {\r\n            lastFocus.current = document.activeElement;\r\n            const count = document.querySelectorAll('[aria-modal=\"true\"]').length;\r\n            setModalCount(count);\r\n            if (!props.isEscKeyDownDisabled) {\r\n                document.body.addEventListener('keydown', handleEscapeKeyDown, false);\r\n            }\r\n        }\r\n        return () => {\r\n            document.body.removeEventListener('keydown', handleEscapeKeyDown, false);\r\n        };\r\n    }, [isModalOpen]);\r\n    function handleModalClick(event) {\r\n        if (!document.getElementById(contentId).contains(event.target) &&\r\n            event.target === currentTarget) {\r\n            handleClose(event);\r\n        }\r\n    }\r\n    function handleModalOnMouseDown(event) {\r\n        setCurrentTarget(event.target);\r\n    }\r\n    function handleEscapeKeyDown(event) {\r\n        if (event.key === 'Escape') {\r\n            event.preventDefault();\r\n            event.stopPropagation();\r\n            props.onEscKeyDown &&\r\n                typeof props.onEscKeyDown === 'function' &&\r\n                props.onEscKeyDown(event);\r\n            //Supports nested modals\r\n            const modalsInDom = document.querySelectorAll('[aria-modal=\"true\"]').length;\r\n            if (modalCount <= 1 && modalsInDom !== 1) {\r\n                if (document.getElementById(id).contains(event.target)) {\r\n                    handleClose(event);\r\n                }\r\n                else {\r\n                    headingRef.current.focus();\r\n                }\r\n            }\r\n            else {\r\n                handleClose(event);\r\n            }\r\n        }\r\n    }\r\n    function handleClose(event) {\r\n        if (event) {\r\n            event.stopPropagation();\r\n        }\r\n        setIsExiting(true);\r\n        setTimeout(() => {\r\n            setIsExiting(false);\r\n            if (!props.isModalClosingControlledManually) {\r\n                setIsModalOpen(false);\r\n            }\r\n            if (lastFocus.current) {\r\n                lastFocus.current.focus();\r\n            }\r\n            props.onClose && typeof props.onClose === 'function' && props.onClose();\r\n        }, 300);\r\n    }\r\n    const { ariaLabel, children, closeAriaLabel, closeButtonSize, containerStyle, containerTransition = { slideTop: true }, isBackgroundClickDisabled, isEscKeyDownDisabled, header, isCloseButtonHidden, isOpen, unmountOnExit = true, testId, ...rest } = props;\r\n    const isInverse = useIsInverse(props.isInverse);\r\n    const other = omit(['onEscKeyDown'], rest);\r\n    const theme = React.useContext(ThemeContext);\r\n    const i18n = React.useContext(I18nContext);\r\n    const CloseIconButton = (React.createElement(CloseIcon, { size: magma.iconSizes[closeButtonSize]\r\n            ? magma.iconSizes[closeButtonSize]\r\n            : magma.iconSizes.medium }));\r\n    return isModalOpen\r\n        ? ReactDOM.createPortal(React.createElement(\"div\", { ref: focusTrapElement },\r\n            React.createElement(Global, { styles: css `\n                html {\n                  overflow: ${isOpen ? 'hidden' : 'auto'};\n                }\n              ` }),\r\n            React.createElement(ModalContainer, Object.assign({ \"aria-labelledby\": header ? headingId : null, \"aria-label\": !header ? ariaLabel : null, \"aria-modal\": true, \"data-testid\": testId, id: id, modalCount: modalCount, onClick: isBackgroundClickDisabled ? null : handleModalClick, onMouseDown: isBackgroundClickDisabled ? null : handleModalOnMouseDown, role: \"dialog\", style: containerStyle, theme: theme, isOpen: isModalOpen }, containerTransition, { unmountOnExit: unmountOnExit }),\r\n                React.createElement(ModalContent, Object.assign({}, other, { \"data-testid\": \"modal-content\", id: contentId, isExiting: isExiting, ref: ref, theme: theme }),\r\n                    header && (React.createElement(ModalHeader, { theme: theme }, header && (React.createElement(H1, { id: headingId, isInverse: isInverse, level: 1, ref: headingRef, visualStyle: TypographyVisualStyle.headingSmall, tabIndex: -1, theme: theme }, header)))),\r\n                    React.createElement(ModalWrapper, { ref: bodyRef, theme: theme }, children),\r\n                    !isCloseButtonHidden && (React.createElement(CloseBtn, { theme: theme },\r\n                        React.createElement(IconButton, { \"aria-label\": closeAriaLabel\r\n                                ? closeAriaLabel\r\n                                : i18n.modal.closeAriaLabel, color: ButtonColor.primary, icon: CloseIconButton, isInverse: isInverse, onClick: handleClose, testId: \"modal-closebtn\", variant: ButtonVariant.link }))))),\r\n            React.createElement(ModalBackdrop, { \"data-testid\": \"modal-backdrop\", isExiting: isExiting, onMouseDown: isBackgroundClickDisabled\r\n                    ? event => event.preventDefault()\r\n                    : null, fade: true, isOpen: isModalOpen, style: modalCount >= 2 && { zIndex: '998' }, unmountOnExit: true, theme: theme })), document.getElementsByTagName('body')[0])\r\n        : null;\r\n});\r\n//# sourceMappingURL=Modal.js.map"]} */"));
10508
10510
  var H1 = /*#__PURE__*/_styled(Heading, {
10509
10511
  target: "e1pxemtw1",
10510
10512
  label: "H1"
@@ -10516,13 +10518,13 @@ var H1 = /*#__PURE__*/_styled(Heading, {
10516
10518
  return props.isInverse ? props.theme.colors.neutral100 : props.theme.colors.neutral700;
10517
10519
  }, ";margin:0;padding-right:", function (props) {
10518
10520
  return props.theme.spaceScale.spacing10;
10519
- }, ";font-weight:600;" + ( "/*# sourceMappingURL=data:application/json;charset=utf-8;base64,{"version":3,"sources":["Modal.tsx"],"names":[],"mappings":"AA0F2B","file":"Modal.tsx","sourcesContent":["import * as React from 'react';\r\nimport ReactDOM from 'react-dom';\r\nimport styled from '@emotion/styled';\r\nimport { Global, css } from '@emotion/react';\r\nimport { ThemeContext } from '../../theme/ThemeContext';\r\nimport { magma } from '../../theme/magma';\r\nimport { I18nContext } from '../../i18n';\r\nimport { ButtonColor, ButtonVariant } from '../Button';\r\nimport { IconButton } from '../IconButton';\r\nimport { CloseIcon } from 'react-magma-icons';\r\nimport { Heading } from '../Heading';\r\nimport { TypographyVisualStyle } from '../Typography';\r\nimport { Transition } from '../Transition';\r\nimport { omit, useGenerateId, usePrevious } from '../../utils';\r\nimport { useFocusLock } from '../../hooks/useFocusLock';\r\nimport { transparentize } from 'polished';\r\nimport { useIsInverse } from '../../inverse';\r\nexport var ModalSize;\r\n(function (ModalSize) {\r\n    ModalSize[\"large\"] = \"large\";\r\n    ModalSize[\"medium\"] = \"medium\";\r\n    ModalSize[\"small\"] = \"small\";\r\n})(ModalSize || (ModalSize = {}));\r\nconst ModalContainer = styled(Transition) `\n  bottom: 0;\n  left: 0;\n  overflow-y: auto;\n  padding: ${props => props.theme.spaceScale.spacing03};\n  right: 0;\n  top: 0;\n  z-index: 998;\n`;\r\nconst ModalBackdrop = styled(Transition) `\n  backdrop-filter: blur(3px);\n  background: ${props => transparentize(0.4, props.theme.colors.neutral900)};\n  bottom: 0;\n  left: 0;\n  right: 0;\n  top: 0;\n  z-index: 997;\n  position: fixed;\n`;\r\nconst ModalContent = styled.div `\n  background: ${props => props.isInverse\r\n    ? props.theme.colors.primary600\r\n    : props.theme.colors.neutral100};\n  border: 1px solid;\n  border-color: ${props => props.isInverse\r\n    ? transparentize(0.5, props.theme.colors.tertiary)\r\n    : props.theme.colors.neutral};\n  border-radius: ${props => props.theme.borderRadius};\n  box-shadow: ${props => `0 2px 6px ${transparentize(0.85, props.theme.colors.neutral900)}`};\n  color: ${props => props.isInverse\r\n    ? props.theme.colors.neutral100\r\n    : props.theme.colors.neutral700};\n  margin: 0 auto;\n  position: relative;\n  z-index: 1000;\n\n  max-width: ${props => {\r\n    switch (props.size) {\r\n        case 'large':\r\n            return props.theme.modal.width.large;\r\n        case 'small':\r\n            return props.theme.modal.width.small;\r\n        default:\r\n            return props.theme.modal.width.medium;\r\n    }\r\n}};\n\n  @media (min-width: ${props => props.theme.breakpoints.small}px) {\n    margin: ${props => props.theme.spaceScale.spacing08} auto;\n  }\n`;\r\nconst ModalHeader = styled.div `\n  padding: ${props => props.theme.spaceScale.spacing05}\n    ${props => props.theme.spaceScale.spacing05} 0\n    ${props => props.theme.spaceScale.spacing05};\n  @media (min-width: ${props => props.theme.breakpoints.small}px) {\n    padding: ${props => props.theme.spaceScale.spacing06}\n      ${props => props.theme.spaceScale.spacing06} 0\n      ${props => props.theme.spaceScale.spacing06};\n  }\n`;\r\nconst ModalWrapper = styled.div `\n  padding: ${props => props.theme.spaceScale.spacing05};\n  @media (min-width: ${props => props.theme.breakpoints.small}px) {\n    padding: ${props => props.theme.spaceScale.spacing06};\n  }\n`;\r\nconst H1 = styled(Heading) `\n  font-size: ${props => props.theme.typographyVisualStyles.headingSmall.desktop.fontSize};\n  line-height: ${props => props.theme.typographyVisualStyles.headingSmall.desktop.lineHeight};\n  color: ${props => props.isInverse\r\n    ? props.theme.colors.neutral100\r\n    : props.theme.colors.neutral700};\n  margin: 0;\n  padding-right: ${props => props.theme.spaceScale.spacing10};\n  font-weight: 600;\n`;\r\nconst CloseBtn = styled.span `\n  position: absolute;\n  top: 0;\n  right: 0;\n  margin: ${props => props.theme.spaceScale.spacing02};\n`;\r\nexport const Modal = React.forwardRef((props, ref) => {\r\n    const lastFocus = React.useRef();\r\n    const headingRef = React.useRef();\r\n    const bodyRef = React.useRef();\r\n    const id = useGenerateId(props.id);\r\n    const headingId = `${id}_heading`;\r\n    const contentId = `${id}_content`;\r\n    const [isModalOpen, setIsModalOpen] = React.useState(props.isOpen);\r\n    const [isExiting, setIsExiting] = React.useState(false);\r\n    const [currentTarget, setCurrentTarget] = React.useState(null);\r\n    const [modalCount, setModalCount] = React.useState(0);\r\n    const focusTrapElement = useFocusLock(isModalOpen, headingRef, bodyRef);\r\n    const prevOpen = usePrevious(props.isOpen);\r\n    React.useEffect(() => {\r\n        if (props.isModalClosingControlledManually &&\r\n            prevOpen &&\r\n            !props.isOpen &&\r\n            isModalOpen) {\r\n            setIsModalOpen(false);\r\n        }\r\n        else if (!prevOpen && props.isOpen) {\r\n            setIsModalOpen(true);\r\n            if (props.headerRef && typeof props.headerRef === 'function') {\r\n                props.headerRef(headingRef);\r\n            }\r\n        }\r\n        else if (prevOpen && !props.isOpen && isModalOpen) {\r\n            handleClose();\r\n        }\r\n    }, [props.isOpen]);\r\n    React.useEffect(() => {\r\n        if (isModalOpen) {\r\n            lastFocus.current = document.activeElement;\r\n            const count = document.querySelectorAll('[aria-modal=\"true\"]').length;\r\n            setModalCount(count);\r\n            if (!props.isEscKeyDownDisabled) {\r\n                document.body.addEventListener('keydown', handleEscapeKeyDown, false);\r\n            }\r\n        }\r\n        return () => {\r\n            document.body.removeEventListener('keydown', handleEscapeKeyDown, false);\r\n        };\r\n    }, [isModalOpen]);\r\n    function handleModalClick(event) {\r\n        if (!document.getElementById(contentId).contains(event.target) &&\r\n            event.target === currentTarget) {\r\n            handleClose(event);\r\n        }\r\n    }\r\n    function handleModalOnMouseDown(event) {\r\n        setCurrentTarget(event.target);\r\n    }\r\n    function handleEscapeKeyDown(event) {\r\n        if (event.key === 'Escape') {\r\n            event.preventDefault();\r\n            event.stopPropagation();\r\n            props.onEscKeyDown &&\r\n                typeof props.onEscKeyDown === 'function' &&\r\n                props.onEscKeyDown(event);\r\n            //Supports nested modals\r\n            const modalsInDom = document.querySelectorAll('[aria-modal=\"true\"]').length;\r\n            if (modalCount <= 1 && modalsInDom !== 1) {\r\n                if (document.getElementById(id).contains(event.target)) {\r\n                    handleClose(event);\r\n                }\r\n                else {\r\n                    headingRef.current.focus();\r\n                }\r\n            }\r\n            else {\r\n                handleClose(event);\r\n            }\r\n        }\r\n    }\r\n    function handleClose(event) {\r\n        if (event) {\r\n            event.stopPropagation();\r\n        }\r\n        setIsExiting(true);\r\n        setTimeout(() => {\r\n            setIsExiting(false);\r\n            if (!props.isModalClosingControlledManually) {\r\n                setIsModalOpen(false);\r\n            }\r\n            if (lastFocus.current) {\r\n                lastFocus.current.focus();\r\n            }\r\n            props.onClose && typeof props.onClose === 'function' && props.onClose();\r\n        }, 300);\r\n    }\r\n    const { ariaLabel, children, closeAriaLabel, closeButtonSize, containerStyle, containerTransition = { slideTop: true }, isBackgroundClickDisabled, isEscKeyDownDisabled, header, isCloseButtonHidden, isOpen, unmountOnExit = true, testId, ...rest } = props;\r\n    const isInverse = useIsInverse(props.isInverse);\r\n    const other = omit(['onEscKeyDown'], rest);\r\n    const theme = React.useContext(ThemeContext);\r\n    const i18n = React.useContext(I18nContext);\r\n    const CloseIconButton = (React.createElement(CloseIcon, { size: magma.iconSizes[closeButtonSize]\r\n            ? magma.iconSizes[closeButtonSize]\r\n            : magma.iconSizes.medium }));\r\n    return isModalOpen\r\n        ? ReactDOM.createPortal(React.createElement(\"div\", { ref: focusTrapElement },\r\n            React.createElement(Global, { styles: css `\n                html {\n                  overflow: ${isOpen ? 'hidden' : 'auto'};\n                }\n              ` }),\r\n            React.createElement(ModalBackdrop, { \"data-testid\": \"modal-backdrop\", isExiting: isExiting, onMouseDown: isBackgroundClickDisabled\r\n                    ? event => event.preventDefault()\r\n                    : null, fade: true, isOpen: isModalOpen, unmountOnExit: true, theme: theme },\r\n                React.createElement(ModalContainer, Object.assign({ \"aria-labelledby\": header ? headingId : null, \"aria-label\": !header ? ariaLabel : null, \"aria-modal\": true, \"data-testid\": testId, id: id, onClick: isBackgroundClickDisabled ? null : handleModalClick, onMouseDown: isBackgroundClickDisabled ? null : handleModalOnMouseDown, role: \"dialog\", style: containerStyle, theme: theme, isOpen: isModalOpen }, containerTransition, { unmountOnExit: unmountOnExit }),\r\n                    React.createElement(ModalContent, Object.assign({}, other, { \"data-testid\": \"modal-content\", id: contentId, isExiting: isExiting, ref: ref, theme: theme }),\r\n                        header && (React.createElement(ModalHeader, { theme: theme }, header && (React.createElement(H1, { id: headingId, isInverse: isInverse, level: 1, ref: headingRef, visualStyle: TypographyVisualStyle.headingSmall, tabIndex: -1, theme: theme }, header)))),\r\n                        React.createElement(ModalWrapper, { ref: bodyRef, theme: theme }, children),\r\n                        !isCloseButtonHidden && (React.createElement(CloseBtn, { theme: theme },\r\n                            React.createElement(IconButton, { \"aria-label\": closeAriaLabel\r\n                                    ? closeAriaLabel\r\n                                    : i18n.modal.closeAriaLabel, color: ButtonColor.primary, icon: CloseIconButton, isInverse: isInverse, onClick: handleClose, testId: \"modal-closebtn\", variant: ButtonVariant.link }))))))), document.getElementsByTagName('body')[0])\r\n        : null;\r\n});\r\n//# sourceMappingURL=Modal.js.map"]} */"));
10521
+ }, ";font-weight:600;" + ( "/*# sourceMappingURL=data:application/json;charset=utf-8;base64,{"version":3,"sources":["Modal.tsx"],"names":[],"mappings":"AA0F2B","file":"Modal.tsx","sourcesContent":["import * as React from 'react';\r\nimport ReactDOM from 'react-dom';\r\nimport styled from '@emotion/styled';\r\nimport { Global, css } from '@emotion/react';\r\nimport { ThemeContext } from '../../theme/ThemeContext';\r\nimport { magma } from '../../theme/magma';\r\nimport { I18nContext } from '../../i18n';\r\nimport { ButtonColor, ButtonVariant } from '../Button';\r\nimport { IconButton } from '../IconButton';\r\nimport { CloseIcon } from 'react-magma-icons';\r\nimport { Heading } from '../Heading';\r\nimport { TypographyVisualStyle } from '../Typography';\r\nimport { Transition } from '../Transition';\r\nimport { omit, useGenerateId, usePrevious } from '../../utils';\r\nimport { useFocusLock } from '../../hooks/useFocusLock';\r\nimport { transparentize } from 'polished';\r\nimport { useIsInverse } from '../../inverse';\r\nexport var ModalSize;\r\n(function (ModalSize) {\r\n    ModalSize[\"large\"] = \"large\";\r\n    ModalSize[\"medium\"] = \"medium\";\r\n    ModalSize[\"small\"] = \"small\";\r\n})(ModalSize || (ModalSize = {}));\r\nconst ModalContainer = styled(Transition) `\n  bottom: 0;\n  left: 0;\n  overflow-y: auto;\n  padding: ${props => props.theme.spaceScale.spacing03};\n  right: 0;\n  top: 0;\n  z-index: ${props => (props.modalCount >= 2 ? '999' : '998')};\n`;\r\nconst ModalBackdrop = styled(Transition) `\n  backdrop-filter: blur(3px);\n  background: ${props => transparentize(0.4, props.theme.colors.neutral900)};\n  bottom: 0;\n  left: 0;\n  right: 0;\n  top: 0;\n  z-index: 997;\n  position: fixed;\n`;\r\nconst ModalContent = styled.div `\n  background: ${props => props.isInverse\r\n    ? props.theme.colors.primary600\r\n    : props.theme.colors.neutral100};\n  border: 1px solid;\n  border-color: ${props => props.isInverse\r\n    ? transparentize(0.5, props.theme.colors.tertiary)\r\n    : props.theme.colors.neutral};\n  border-radius: ${props => props.theme.borderRadius};\n  box-shadow: ${props => `0 2px 6px ${transparentize(0.85, props.theme.colors.neutral900)}`};\n  color: ${props => props.isInverse\r\n    ? props.theme.colors.neutral100\r\n    : props.theme.colors.neutral700};\n  margin: 0 auto;\n  position: relative;\n  z-index: 1000;\n\n  max-width: ${props => {\r\n    switch (props.size) {\r\n        case 'large':\r\n            return props.theme.modal.width.large;\r\n        case 'small':\r\n            return props.theme.modal.width.small;\r\n        default:\r\n            return props.theme.modal.width.medium;\r\n    }\r\n}};\n\n  @media (min-width: ${props => props.theme.breakpoints.small}px) {\n    margin: ${props => props.theme.spaceScale.spacing08} auto;\n  }\n`;\r\nconst ModalHeader = styled.div `\n  padding: ${props => props.theme.spaceScale.spacing05}\n    ${props => props.theme.spaceScale.spacing05} 0\n    ${props => props.theme.spaceScale.spacing05};\n  @media (min-width: ${props => props.theme.breakpoints.small}px) {\n    padding: ${props => props.theme.spaceScale.spacing06}\n      ${props => props.theme.spaceScale.spacing06} 0\n      ${props => props.theme.spaceScale.spacing06};\n  }\n`;\r\nconst ModalWrapper = styled.div `\n  padding: ${props => props.theme.spaceScale.spacing05};\n  @media (min-width: ${props => props.theme.breakpoints.small}px) {\n    padding: ${props => props.theme.spaceScale.spacing06};\n  }\n`;\r\nconst H1 = styled(Heading) `\n  font-size: ${props => props.theme.typographyVisualStyles.headingSmall.desktop.fontSize};\n  line-height: ${props => props.theme.typographyVisualStyles.headingSmall.desktop.lineHeight};\n  color: ${props => props.isInverse\r\n    ? props.theme.colors.neutral100\r\n    : props.theme.colors.neutral700};\n  margin: 0;\n  padding-right: ${props => props.theme.spaceScale.spacing10};\n  font-weight: 600;\n`;\r\nconst CloseBtn = styled.span `\n  position: absolute;\n  top: 0;\n  right: 0;\n  margin: ${props => props.theme.spaceScale.spacing02};\n`;\r\nexport const Modal = React.forwardRef((props, ref) => {\r\n    const lastFocus = React.useRef();\r\n    const headingRef = React.useRef();\r\n    const bodyRef = React.useRef();\r\n    const id = useGenerateId(props.id);\r\n    const headingId = `${id}_heading`;\r\n    const contentId = `${id}_content`;\r\n    const [isModalOpen, setIsModalOpen] = React.useState(props.isOpen);\r\n    const [isExiting, setIsExiting] = React.useState(false);\r\n    const [currentTarget, setCurrentTarget] = React.useState(null);\r\n    const [modalCount, setModalCount] = React.useState(0);\r\n    const focusTrapElement = useFocusLock(isModalOpen, headingRef, bodyRef);\r\n    const prevOpen = usePrevious(props.isOpen);\r\n    React.useEffect(() => {\r\n        if (props.isModalClosingControlledManually &&\r\n            prevOpen &&\r\n            !props.isOpen &&\r\n            isModalOpen) {\r\n            setIsModalOpen(false);\r\n        }\r\n        else if (!prevOpen && props.isOpen) {\r\n            setIsModalOpen(true);\r\n            if (props.headerRef && typeof props.headerRef === 'function') {\r\n                props.headerRef(headingRef);\r\n            }\r\n        }\r\n        else if (prevOpen && !props.isOpen && isModalOpen) {\r\n            handleClose();\r\n        }\r\n    }, [props.isOpen]);\r\n    React.useEffect(() => {\r\n        if (isModalOpen) {\r\n            lastFocus.current = document.activeElement;\r\n            const count = document.querySelectorAll('[aria-modal=\"true\"]').length;\r\n            setModalCount(count);\r\n            if (!props.isEscKeyDownDisabled) {\r\n                document.body.addEventListener('keydown', handleEscapeKeyDown, false);\r\n            }\r\n        }\r\n        return () => {\r\n            document.body.removeEventListener('keydown', handleEscapeKeyDown, false);\r\n        };\r\n    }, [isModalOpen]);\r\n    function handleModalClick(event) {\r\n        if (!document.getElementById(contentId).contains(event.target) &&\r\n            event.target === currentTarget) {\r\n            handleClose(event);\r\n        }\r\n    }\r\n    function handleModalOnMouseDown(event) {\r\n        setCurrentTarget(event.target);\r\n    }\r\n    function handleEscapeKeyDown(event) {\r\n        if (event.key === 'Escape') {\r\n            event.preventDefault();\r\n            event.stopPropagation();\r\n            props.onEscKeyDown &&\r\n                typeof props.onEscKeyDown === 'function' &&\r\n                props.onEscKeyDown(event);\r\n            //Supports nested modals\r\n            const modalsInDom = document.querySelectorAll('[aria-modal=\"true\"]').length;\r\n            if (modalCount <= 1 && modalsInDom !== 1) {\r\n                if (document.getElementById(id).contains(event.target)) {\r\n                    handleClose(event);\r\n                }\r\n                else {\r\n                    headingRef.current.focus();\r\n                }\r\n            }\r\n            else {\r\n                handleClose(event);\r\n            }\r\n        }\r\n    }\r\n    function handleClose(event) {\r\n        if (event) {\r\n            event.stopPropagation();\r\n        }\r\n        setIsExiting(true);\r\n        setTimeout(() => {\r\n            setIsExiting(false);\r\n            if (!props.isModalClosingControlledManually) {\r\n                setIsModalOpen(false);\r\n            }\r\n            if (lastFocus.current) {\r\n                lastFocus.current.focus();\r\n            }\r\n            props.onClose && typeof props.onClose === 'function' && props.onClose();\r\n        }, 300);\r\n    }\r\n    const { ariaLabel, children, closeAriaLabel, closeButtonSize, containerStyle, containerTransition = { slideTop: true }, isBackgroundClickDisabled, isEscKeyDownDisabled, header, isCloseButtonHidden, isOpen, unmountOnExit = true, testId, ...rest } = props;\r\n    const isInverse = useIsInverse(props.isInverse);\r\n    const other = omit(['onEscKeyDown'], rest);\r\n    const theme = React.useContext(ThemeContext);\r\n    const i18n = React.useContext(I18nContext);\r\n    const CloseIconButton = (React.createElement(CloseIcon, { size: magma.iconSizes[closeButtonSize]\r\n            ? magma.iconSizes[closeButtonSize]\r\n            : magma.iconSizes.medium }));\r\n    return isModalOpen\r\n        ? ReactDOM.createPortal(React.createElement(\"div\", { ref: focusTrapElement },\r\n            React.createElement(Global, { styles: css `\n                html {\n                  overflow: ${isOpen ? 'hidden' : 'auto'};\n                }\n              ` }),\r\n            React.createElement(ModalContainer, Object.assign({ \"aria-labelledby\": header ? headingId : null, \"aria-label\": !header ? ariaLabel : null, \"aria-modal\": true, \"data-testid\": testId, id: id, modalCount: modalCount, onClick: isBackgroundClickDisabled ? null : handleModalClick, onMouseDown: isBackgroundClickDisabled ? null : handleModalOnMouseDown, role: \"dialog\", style: containerStyle, theme: theme, isOpen: isModalOpen }, containerTransition, { unmountOnExit: unmountOnExit }),\r\n                React.createElement(ModalContent, Object.assign({}, other, { \"data-testid\": \"modal-content\", id: contentId, isExiting: isExiting, ref: ref, theme: theme }),\r\n                    header && (React.createElement(ModalHeader, { theme: theme }, header && (React.createElement(H1, { id: headingId, isInverse: isInverse, level: 1, ref: headingRef, visualStyle: TypographyVisualStyle.headingSmall, tabIndex: -1, theme: theme }, header)))),\r\n                    React.createElement(ModalWrapper, { ref: bodyRef, theme: theme }, children),\r\n                    !isCloseButtonHidden && (React.createElement(CloseBtn, { theme: theme },\r\n                        React.createElement(IconButton, { \"aria-label\": closeAriaLabel\r\n                                ? closeAriaLabel\r\n                                : i18n.modal.closeAriaLabel, color: ButtonColor.primary, icon: CloseIconButton, isInverse: isInverse, onClick: handleClose, testId: \"modal-closebtn\", variant: ButtonVariant.link }))))),\r\n            React.createElement(ModalBackdrop, { \"data-testid\": \"modal-backdrop\", isExiting: isExiting, onMouseDown: isBackgroundClickDisabled\r\n                    ? event => event.preventDefault()\r\n                    : null, fade: true, isOpen: isModalOpen, style: modalCount >= 2 && { zIndex: '998' }, unmountOnExit: true, theme: theme })), document.getElementsByTagName('body')[0])\r\n        : null;\r\n});\r\n//# sourceMappingURL=Modal.js.map"]} */"));
10520
10522
  var CloseBtn = /*#__PURE__*/_styled("span", {
10521
10523
  target: "e1pxemtw0",
10522
10524
  label: "CloseBtn"
10523
10525
  })("position:absolute;top:0;right:0;margin:", function (props) {
10524
10526
  return props.theme.spaceScale.spacing02;
10525
- }, ";" + ( "/*# sourceMappingURL=data:application/json;charset=utf-8;base64,{"version":3,"sources":["Modal.tsx"],"names":[],"mappings":"AAoG6B","file":"Modal.tsx","sourcesContent":["import * as React from 'react';\r\nimport ReactDOM from 'react-dom';\r\nimport styled from '@emotion/styled';\r\nimport { Global, css } from '@emotion/react';\r\nimport { ThemeContext } from '../../theme/ThemeContext';\r\nimport { magma } from '../../theme/magma';\r\nimport { I18nContext } from '../../i18n';\r\nimport { ButtonColor, ButtonVariant } from '../Button';\r\nimport { IconButton } from '../IconButton';\r\nimport { CloseIcon } from 'react-magma-icons';\r\nimport { Heading } from '../Heading';\r\nimport { TypographyVisualStyle } from '../Typography';\r\nimport { Transition } from '../Transition';\r\nimport { omit, useGenerateId, usePrevious } from '../../utils';\r\nimport { useFocusLock } from '../../hooks/useFocusLock';\r\nimport { transparentize } from 'polished';\r\nimport { useIsInverse } from '../../inverse';\r\nexport var ModalSize;\r\n(function (ModalSize) {\r\n    ModalSize[\"large\"] = \"large\";\r\n    ModalSize[\"medium\"] = \"medium\";\r\n    ModalSize[\"small\"] = \"small\";\r\n})(ModalSize || (ModalSize = {}));\r\nconst ModalContainer = styled(Transition) `\n  bottom: 0;\n  left: 0;\n  overflow-y: auto;\n  padding: ${props => props.theme.spaceScale.spacing03};\n  right: 0;\n  top: 0;\n  z-index: 998;\n`;\r\nconst ModalBackdrop = styled(Transition) `\n  backdrop-filter: blur(3px);\n  background: ${props => transparentize(0.4, props.theme.colors.neutral900)};\n  bottom: 0;\n  left: 0;\n  right: 0;\n  top: 0;\n  z-index: 997;\n  position: fixed;\n`;\r\nconst ModalContent = styled.div `\n  background: ${props => props.isInverse\r\n    ? props.theme.colors.primary600\r\n    : props.theme.colors.neutral100};\n  border: 1px solid;\n  border-color: ${props => props.isInverse\r\n    ? transparentize(0.5, props.theme.colors.tertiary)\r\n    : props.theme.colors.neutral};\n  border-radius: ${props => props.theme.borderRadius};\n  box-shadow: ${props => `0 2px 6px ${transparentize(0.85, props.theme.colors.neutral900)}`};\n  color: ${props => props.isInverse\r\n    ? props.theme.colors.neutral100\r\n    : props.theme.colors.neutral700};\n  margin: 0 auto;\n  position: relative;\n  z-index: 1000;\n\n  max-width: ${props => {\r\n    switch (props.size) {\r\n        case 'large':\r\n            return props.theme.modal.width.large;\r\n        case 'small':\r\n            return props.theme.modal.width.small;\r\n        default:\r\n            return props.theme.modal.width.medium;\r\n    }\r\n}};\n\n  @media (min-width: ${props => props.theme.breakpoints.small}px) {\n    margin: ${props => props.theme.spaceScale.spacing08} auto;\n  }\n`;\r\nconst ModalHeader = styled.div `\n  padding: ${props => props.theme.spaceScale.spacing05}\n    ${props => props.theme.spaceScale.spacing05} 0\n    ${props => props.theme.spaceScale.spacing05};\n  @media (min-width: ${props => props.theme.breakpoints.small}px) {\n    padding: ${props => props.theme.spaceScale.spacing06}\n      ${props => props.theme.spaceScale.spacing06} 0\n      ${props => props.theme.spaceScale.spacing06};\n  }\n`;\r\nconst ModalWrapper = styled.div `\n  padding: ${props => props.theme.spaceScale.spacing05};\n  @media (min-width: ${props => props.theme.breakpoints.small}px) {\n    padding: ${props => props.theme.spaceScale.spacing06};\n  }\n`;\r\nconst H1 = styled(Heading) `\n  font-size: ${props => props.theme.typographyVisualStyles.headingSmall.desktop.fontSize};\n  line-height: ${props => props.theme.typographyVisualStyles.headingSmall.desktop.lineHeight};\n  color: ${props => props.isInverse\r\n    ? props.theme.colors.neutral100\r\n    : props.theme.colors.neutral700};\n  margin: 0;\n  padding-right: ${props => props.theme.spaceScale.spacing10};\n  font-weight: 600;\n`;\r\nconst CloseBtn = styled.span `\n  position: absolute;\n  top: 0;\n  right: 0;\n  margin: ${props => props.theme.spaceScale.spacing02};\n`;\r\nexport const Modal = React.forwardRef((props, ref) => {\r\n    const lastFocus = React.useRef();\r\n    const headingRef = React.useRef();\r\n    const bodyRef = React.useRef();\r\n    const id = useGenerateId(props.id);\r\n    const headingId = `${id}_heading`;\r\n    const contentId = `${id}_content`;\r\n    const [isModalOpen, setIsModalOpen] = React.useState(props.isOpen);\r\n    const [isExiting, setIsExiting] = React.useState(false);\r\n    const [currentTarget, setCurrentTarget] = React.useState(null);\r\n    const [modalCount, setModalCount] = React.useState(0);\r\n    const focusTrapElement = useFocusLock(isModalOpen, headingRef, bodyRef);\r\n    const prevOpen = usePrevious(props.isOpen);\r\n    React.useEffect(() => {\r\n        if (props.isModalClosingControlledManually &&\r\n            prevOpen &&\r\n            !props.isOpen &&\r\n            isModalOpen) {\r\n            setIsModalOpen(false);\r\n        }\r\n        else if (!prevOpen && props.isOpen) {\r\n            setIsModalOpen(true);\r\n            if (props.headerRef && typeof props.headerRef === 'function') {\r\n                props.headerRef(headingRef);\r\n            }\r\n        }\r\n        else if (prevOpen && !props.isOpen && isModalOpen) {\r\n            handleClose();\r\n        }\r\n    }, [props.isOpen]);\r\n    React.useEffect(() => {\r\n        if (isModalOpen) {\r\n            lastFocus.current = document.activeElement;\r\n            const count = document.querySelectorAll('[aria-modal=\"true\"]').length;\r\n            setModalCount(count);\r\n            if (!props.isEscKeyDownDisabled) {\r\n                document.body.addEventListener('keydown', handleEscapeKeyDown, false);\r\n            }\r\n        }\r\n        return () => {\r\n            document.body.removeEventListener('keydown', handleEscapeKeyDown, false);\r\n        };\r\n    }, [isModalOpen]);\r\n    function handleModalClick(event) {\r\n        if (!document.getElementById(contentId).contains(event.target) &&\r\n            event.target === currentTarget) {\r\n            handleClose(event);\r\n        }\r\n    }\r\n    function handleModalOnMouseDown(event) {\r\n        setCurrentTarget(event.target);\r\n    }\r\n    function handleEscapeKeyDown(event) {\r\n        if (event.key === 'Escape') {\r\n            event.preventDefault();\r\n            event.stopPropagation();\r\n            props.onEscKeyDown &&\r\n                typeof props.onEscKeyDown === 'function' &&\r\n                props.onEscKeyDown(event);\r\n            //Supports nested modals\r\n            const modalsInDom = document.querySelectorAll('[aria-modal=\"true\"]').length;\r\n            if (modalCount <= 1 && modalsInDom !== 1) {\r\n                if (document.getElementById(id).contains(event.target)) {\r\n                    handleClose(event);\r\n                }\r\n                else {\r\n                    headingRef.current.focus();\r\n                }\r\n            }\r\n            else {\r\n                handleClose(event);\r\n            }\r\n        }\r\n    }\r\n    function handleClose(event) {\r\n        if (event) {\r\n            event.stopPropagation();\r\n        }\r\n        setIsExiting(true);\r\n        setTimeout(() => {\r\n            setIsExiting(false);\r\n            if (!props.isModalClosingControlledManually) {\r\n                setIsModalOpen(false);\r\n            }\r\n            if (lastFocus.current) {\r\n                lastFocus.current.focus();\r\n            }\r\n            props.onClose && typeof props.onClose === 'function' && props.onClose();\r\n        }, 300);\r\n    }\r\n    const { ariaLabel, children, closeAriaLabel, closeButtonSize, containerStyle, containerTransition = { slideTop: true }, isBackgroundClickDisabled, isEscKeyDownDisabled, header, isCloseButtonHidden, isOpen, unmountOnExit = true, testId, ...rest } = props;\r\n    const isInverse = useIsInverse(props.isInverse);\r\n    const other = omit(['onEscKeyDown'], rest);\r\n    const theme = React.useContext(ThemeContext);\r\n    const i18n = React.useContext(I18nContext);\r\n    const CloseIconButton = (React.createElement(CloseIcon, { size: magma.iconSizes[closeButtonSize]\r\n            ? magma.iconSizes[closeButtonSize]\r\n            : magma.iconSizes.medium }));\r\n    return isModalOpen\r\n        ? ReactDOM.createPortal(React.createElement(\"div\", { ref: focusTrapElement },\r\n            React.createElement(Global, { styles: css `\n                html {\n                  overflow: ${isOpen ? 'hidden' : 'auto'};\n                }\n              ` }),\r\n            React.createElement(ModalBackdrop, { \"data-testid\": \"modal-backdrop\", isExiting: isExiting, onMouseDown: isBackgroundClickDisabled\r\n                    ? event => event.preventDefault()\r\n                    : null, fade: true, isOpen: isModalOpen, unmountOnExit: true, theme: theme },\r\n                React.createElement(ModalContainer, Object.assign({ \"aria-labelledby\": header ? headingId : null, \"aria-label\": !header ? ariaLabel : null, \"aria-modal\": true, \"data-testid\": testId, id: id, onClick: isBackgroundClickDisabled ? null : handleModalClick, onMouseDown: isBackgroundClickDisabled ? null : handleModalOnMouseDown, role: \"dialog\", style: containerStyle, theme: theme, isOpen: isModalOpen }, containerTransition, { unmountOnExit: unmountOnExit }),\r\n                    React.createElement(ModalContent, Object.assign({}, other, { \"data-testid\": \"modal-content\", id: contentId, isExiting: isExiting, ref: ref, theme: theme }),\r\n                        header && (React.createElement(ModalHeader, { theme: theme }, header && (React.createElement(H1, { id: headingId, isInverse: isInverse, level: 1, ref: headingRef, visualStyle: TypographyVisualStyle.headingSmall, tabIndex: -1, theme: theme }, header)))),\r\n                        React.createElement(ModalWrapper, { ref: bodyRef, theme: theme }, children),\r\n                        !isCloseButtonHidden && (React.createElement(CloseBtn, { theme: theme },\r\n                            React.createElement(IconButton, { \"aria-label\": closeAriaLabel\r\n                                    ? closeAriaLabel\r\n                                    : i18n.modal.closeAriaLabel, color: ButtonColor.primary, icon: CloseIconButton, isInverse: isInverse, onClick: handleClose, testId: \"modal-closebtn\", variant: ButtonVariant.link }))))))), document.getElementsByTagName('body')[0])\r\n        : null;\r\n});\r\n//# sourceMappingURL=Modal.js.map"]} */"));
10527
+ }, ";" + ( "/*# sourceMappingURL=data:application/json;charset=utf-8;base64,{"version":3,"sources":["Modal.tsx"],"names":[],"mappings":"AAoG6B","file":"Modal.tsx","sourcesContent":["import * as React from 'react';\r\nimport ReactDOM from 'react-dom';\r\nimport styled from '@emotion/styled';\r\nimport { Global, css } from '@emotion/react';\r\nimport { ThemeContext } from '../../theme/ThemeContext';\r\nimport { magma } from '../../theme/magma';\r\nimport { I18nContext } from '../../i18n';\r\nimport { ButtonColor, ButtonVariant } from '../Button';\r\nimport { IconButton } from '../IconButton';\r\nimport { CloseIcon } from 'react-magma-icons';\r\nimport { Heading } from '../Heading';\r\nimport { TypographyVisualStyle } from '../Typography';\r\nimport { Transition } from '../Transition';\r\nimport { omit, useGenerateId, usePrevious } from '../../utils';\r\nimport { useFocusLock } from '../../hooks/useFocusLock';\r\nimport { transparentize } from 'polished';\r\nimport { useIsInverse } from '../../inverse';\r\nexport var ModalSize;\r\n(function (ModalSize) {\r\n    ModalSize[\"large\"] = \"large\";\r\n    ModalSize[\"medium\"] = \"medium\";\r\n    ModalSize[\"small\"] = \"small\";\r\n})(ModalSize || (ModalSize = {}));\r\nconst ModalContainer = styled(Transition) `\n  bottom: 0;\n  left: 0;\n  overflow-y: auto;\n  padding: ${props => props.theme.spaceScale.spacing03};\n  right: 0;\n  top: 0;\n  z-index: ${props => (props.modalCount >= 2 ? '999' : '998')};\n`;\r\nconst ModalBackdrop = styled(Transition) `\n  backdrop-filter: blur(3px);\n  background: ${props => transparentize(0.4, props.theme.colors.neutral900)};\n  bottom: 0;\n  left: 0;\n  right: 0;\n  top: 0;\n  z-index: 997;\n  position: fixed;\n`;\r\nconst ModalContent = styled.div `\n  background: ${props => props.isInverse\r\n    ? props.theme.colors.primary600\r\n    : props.theme.colors.neutral100};\n  border: 1px solid;\n  border-color: ${props => props.isInverse\r\n    ? transparentize(0.5, props.theme.colors.tertiary)\r\n    : props.theme.colors.neutral};\n  border-radius: ${props => props.theme.borderRadius};\n  box-shadow: ${props => `0 2px 6px ${transparentize(0.85, props.theme.colors.neutral900)}`};\n  color: ${props => props.isInverse\r\n    ? props.theme.colors.neutral100\r\n    : props.theme.colors.neutral700};\n  margin: 0 auto;\n  position: relative;\n  z-index: 1000;\n\n  max-width: ${props => {\r\n    switch (props.size) {\r\n        case 'large':\r\n            return props.theme.modal.width.large;\r\n        case 'small':\r\n            return props.theme.modal.width.small;\r\n        default:\r\n            return props.theme.modal.width.medium;\r\n    }\r\n}};\n\n  @media (min-width: ${props => props.theme.breakpoints.small}px) {\n    margin: ${props => props.theme.spaceScale.spacing08} auto;\n  }\n`;\r\nconst ModalHeader = styled.div `\n  padding: ${props => props.theme.spaceScale.spacing05}\n    ${props => props.theme.spaceScale.spacing05} 0\n    ${props => props.theme.spaceScale.spacing05};\n  @media (min-width: ${props => props.theme.breakpoints.small}px) {\n    padding: ${props => props.theme.spaceScale.spacing06}\n      ${props => props.theme.spaceScale.spacing06} 0\n      ${props => props.theme.spaceScale.spacing06};\n  }\n`;\r\nconst ModalWrapper = styled.div `\n  padding: ${props => props.theme.spaceScale.spacing05};\n  @media (min-width: ${props => props.theme.breakpoints.small}px) {\n    padding: ${props => props.theme.spaceScale.spacing06};\n  }\n`;\r\nconst H1 = styled(Heading) `\n  font-size: ${props => props.theme.typographyVisualStyles.headingSmall.desktop.fontSize};\n  line-height: ${props => props.theme.typographyVisualStyles.headingSmall.desktop.lineHeight};\n  color: ${props => props.isInverse\r\n    ? props.theme.colors.neutral100\r\n    : props.theme.colors.neutral700};\n  margin: 0;\n  padding-right: ${props => props.theme.spaceScale.spacing10};\n  font-weight: 600;\n`;\r\nconst CloseBtn = styled.span `\n  position: absolute;\n  top: 0;\n  right: 0;\n  margin: ${props => props.theme.spaceScale.spacing02};\n`;\r\nexport const Modal = React.forwardRef((props, ref) => {\r\n    const lastFocus = React.useRef();\r\n    const headingRef = React.useRef();\r\n    const bodyRef = React.useRef();\r\n    const id = useGenerateId(props.id);\r\n    const headingId = `${id}_heading`;\r\n    const contentId = `${id}_content`;\r\n    const [isModalOpen, setIsModalOpen] = React.useState(props.isOpen);\r\n    const [isExiting, setIsExiting] = React.useState(false);\r\n    const [currentTarget, setCurrentTarget] = React.useState(null);\r\n    const [modalCount, setModalCount] = React.useState(0);\r\n    const focusTrapElement = useFocusLock(isModalOpen, headingRef, bodyRef);\r\n    const prevOpen = usePrevious(props.isOpen);\r\n    React.useEffect(() => {\r\n        if (props.isModalClosingControlledManually &&\r\n            prevOpen &&\r\n            !props.isOpen &&\r\n            isModalOpen) {\r\n            setIsModalOpen(false);\r\n        }\r\n        else if (!prevOpen && props.isOpen) {\r\n            setIsModalOpen(true);\r\n            if (props.headerRef && typeof props.headerRef === 'function') {\r\n                props.headerRef(headingRef);\r\n            }\r\n        }\r\n        else if (prevOpen && !props.isOpen && isModalOpen) {\r\n            handleClose();\r\n        }\r\n    }, [props.isOpen]);\r\n    React.useEffect(() => {\r\n        if (isModalOpen) {\r\n            lastFocus.current = document.activeElement;\r\n            const count = document.querySelectorAll('[aria-modal=\"true\"]').length;\r\n            setModalCount(count);\r\n            if (!props.isEscKeyDownDisabled) {\r\n                document.body.addEventListener('keydown', handleEscapeKeyDown, false);\r\n            }\r\n        }\r\n        return () => {\r\n            document.body.removeEventListener('keydown', handleEscapeKeyDown, false);\r\n        };\r\n    }, [isModalOpen]);\r\n    function handleModalClick(event) {\r\n        if (!document.getElementById(contentId).contains(event.target) &&\r\n            event.target === currentTarget) {\r\n            handleClose(event);\r\n        }\r\n    }\r\n    function handleModalOnMouseDown(event) {\r\n        setCurrentTarget(event.target);\r\n    }\r\n    function handleEscapeKeyDown(event) {\r\n        if (event.key === 'Escape') {\r\n            event.preventDefault();\r\n            event.stopPropagation();\r\n            props.onEscKeyDown &&\r\n                typeof props.onEscKeyDown === 'function' &&\r\n                props.onEscKeyDown(event);\r\n            //Supports nested modals\r\n            const modalsInDom = document.querySelectorAll('[aria-modal=\"true\"]').length;\r\n            if (modalCount <= 1 && modalsInDom !== 1) {\r\n                if (document.getElementById(id).contains(event.target)) {\r\n                    handleClose(event);\r\n                }\r\n                else {\r\n                    headingRef.current.focus();\r\n                }\r\n            }\r\n            else {\r\n                handleClose(event);\r\n            }\r\n        }\r\n    }\r\n    function handleClose(event) {\r\n        if (event) {\r\n            event.stopPropagation();\r\n        }\r\n        setIsExiting(true);\r\n        setTimeout(() => {\r\n            setIsExiting(false);\r\n            if (!props.isModalClosingControlledManually) {\r\n                setIsModalOpen(false);\r\n            }\r\n            if (lastFocus.current) {\r\n                lastFocus.current.focus();\r\n            }\r\n            props.onClose && typeof props.onClose === 'function' && props.onClose();\r\n        }, 300);\r\n    }\r\n    const { ariaLabel, children, closeAriaLabel, closeButtonSize, containerStyle, containerTransition = { slideTop: true }, isBackgroundClickDisabled, isEscKeyDownDisabled, header, isCloseButtonHidden, isOpen, unmountOnExit = true, testId, ...rest } = props;\r\n    const isInverse = useIsInverse(props.isInverse);\r\n    const other = omit(['onEscKeyDown'], rest);\r\n    const theme = React.useContext(ThemeContext);\r\n    const i18n = React.useContext(I18nContext);\r\n    const CloseIconButton = (React.createElement(CloseIcon, { size: magma.iconSizes[closeButtonSize]\r\n            ? magma.iconSizes[closeButtonSize]\r\n            : magma.iconSizes.medium }));\r\n    return isModalOpen\r\n        ? ReactDOM.createPortal(React.createElement(\"div\", { ref: focusTrapElement },\r\n            React.createElement(Global, { styles: css `\n                html {\n                  overflow: ${isOpen ? 'hidden' : 'auto'};\n                }\n              ` }),\r\n            React.createElement(ModalContainer, Object.assign({ \"aria-labelledby\": header ? headingId : null, \"aria-label\": !header ? ariaLabel : null, \"aria-modal\": true, \"data-testid\": testId, id: id, modalCount: modalCount, onClick: isBackgroundClickDisabled ? null : handleModalClick, onMouseDown: isBackgroundClickDisabled ? null : handleModalOnMouseDown, role: \"dialog\", style: containerStyle, theme: theme, isOpen: isModalOpen }, containerTransition, { unmountOnExit: unmountOnExit }),\r\n                React.createElement(ModalContent, Object.assign({}, other, { \"data-testid\": \"modal-content\", id: contentId, isExiting: isExiting, ref: ref, theme: theme }),\r\n                    header && (React.createElement(ModalHeader, { theme: theme }, header && (React.createElement(H1, { id: headingId, isInverse: isInverse, level: 1, ref: headingRef, visualStyle: TypographyVisualStyle.headingSmall, tabIndex: -1, theme: theme }, header)))),\r\n                    React.createElement(ModalWrapper, { ref: bodyRef, theme: theme }, children),\r\n                    !isCloseButtonHidden && (React.createElement(CloseBtn, { theme: theme },\r\n                        React.createElement(IconButton, { \"aria-label\": closeAriaLabel\r\n                                ? closeAriaLabel\r\n                                : i18n.modal.closeAriaLabel, color: ButtonColor.primary, icon: CloseIconButton, isInverse: isInverse, onClick: handleClose, testId: \"modal-closebtn\", variant: ButtonVariant.link }))))),\r\n            React.createElement(ModalBackdrop, { \"data-testid\": \"modal-backdrop\", isExiting: isExiting, onMouseDown: isBackgroundClickDisabled\r\n                    ? event => event.preventDefault()\r\n                    : null, fade: true, isOpen: isModalOpen, style: modalCount >= 2 && { zIndex: '998' }, unmountOnExit: true, theme: theme })), document.getElementsByTagName('body')[0])\r\n        : null;\r\n});\r\n//# sourceMappingURL=Modal.js.map"]} */"));
10526
10528
  var Modal = /*#__PURE__*/React.forwardRef(function (props, ref) {
10527
10529
  var lastFocus = React.useRef();
10528
10530
  var headingRef = React.useRef();
@@ -10638,23 +10640,14 @@ var Modal = /*#__PURE__*/React.forwardRef(function (props, ref) {
10638
10640
  return isModalOpen ? ReactDOM.createPortal(React.createElement("div", {
10639
10641
  ref: focusTrapElement
10640
10642
  }, React.createElement(react.Global, {
10641
- styles: /*#__PURE__*/react.css("html{overflow:", isOpen ? 'hidden' : 'auto', ";};label:styles;" + ( "/*# sourceMappingURL=data:application/json;charset=utf-8;base64,{"version":3,"sources":["Modal.tsx"],"names":[],"mappings":"AA8MsD","file":"Modal.tsx","sourcesContent":["import * as React from 'react';\r\nimport ReactDOM from 'react-dom';\r\nimport styled from '@emotion/styled';\r\nimport { Global, css } from '@emotion/react';\r\nimport { ThemeContext } from '../../theme/ThemeContext';\r\nimport { magma } from '../../theme/magma';\r\nimport { I18nContext } from '../../i18n';\r\nimport { ButtonColor, ButtonVariant } from '../Button';\r\nimport { IconButton } from '../IconButton';\r\nimport { CloseIcon } from 'react-magma-icons';\r\nimport { Heading } from '../Heading';\r\nimport { TypographyVisualStyle } from '../Typography';\r\nimport { Transition } from '../Transition';\r\nimport { omit, useGenerateId, usePrevious } from '../../utils';\r\nimport { useFocusLock } from '../../hooks/useFocusLock';\r\nimport { transparentize } from 'polished';\r\nimport { useIsInverse } from '../../inverse';\r\nexport var ModalSize;\r\n(function (ModalSize) {\r\n    ModalSize[\"large\"] = \"large\";\r\n    ModalSize[\"medium\"] = \"medium\";\r\n    ModalSize[\"small\"] = \"small\";\r\n})(ModalSize || (ModalSize = {}));\r\nconst ModalContainer = styled(Transition) `\n  bottom: 0;\n  left: 0;\n  overflow-y: auto;\n  padding: ${props => props.theme.spaceScale.spacing03};\n  right: 0;\n  top: 0;\n  z-index: 998;\n`;\r\nconst ModalBackdrop = styled(Transition) `\n  backdrop-filter: blur(3px);\n  background: ${props => transparentize(0.4, props.theme.colors.neutral900)};\n  bottom: 0;\n  left: 0;\n  right: 0;\n  top: 0;\n  z-index: 997;\n  position: fixed;\n`;\r\nconst ModalContent = styled.div `\n  background: ${props => props.isInverse\r\n    ? props.theme.colors.primary600\r\n    : props.theme.colors.neutral100};\n  border: 1px solid;\n  border-color: ${props => props.isInverse\r\n    ? transparentize(0.5, props.theme.colors.tertiary)\r\n    : props.theme.colors.neutral};\n  border-radius: ${props => props.theme.borderRadius};\n  box-shadow: ${props => `0 2px 6px ${transparentize(0.85, props.theme.colors.neutral900)}`};\n  color: ${props => props.isInverse\r\n    ? props.theme.colors.neutral100\r\n    : props.theme.colors.neutral700};\n  margin: 0 auto;\n  position: relative;\n  z-index: 1000;\n\n  max-width: ${props => {\r\n    switch (props.size) {\r\n        case 'large':\r\n            return props.theme.modal.width.large;\r\n        case 'small':\r\n            return props.theme.modal.width.small;\r\n        default:\r\n            return props.theme.modal.width.medium;\r\n    }\r\n}};\n\n  @media (min-width: ${props => props.theme.breakpoints.small}px) {\n    margin: ${props => props.theme.spaceScale.spacing08} auto;\n  }\n`;\r\nconst ModalHeader = styled.div `\n  padding: ${props => props.theme.spaceScale.spacing05}\n    ${props => props.theme.spaceScale.spacing05} 0\n    ${props => props.theme.spaceScale.spacing05};\n  @media (min-width: ${props => props.theme.breakpoints.small}px) {\n    padding: ${props => props.theme.spaceScale.spacing06}\n      ${props => props.theme.spaceScale.spacing06} 0\n      ${props => props.theme.spaceScale.spacing06};\n  }\n`;\r\nconst ModalWrapper = styled.div `\n  padding: ${props => props.theme.spaceScale.spacing05};\n  @media (min-width: ${props => props.theme.breakpoints.small}px) {\n    padding: ${props => props.theme.spaceScale.spacing06};\n  }\n`;\r\nconst H1 = styled(Heading) `\n  font-size: ${props => props.theme.typographyVisualStyles.headingSmall.desktop.fontSize};\n  line-height: ${props => props.theme.typographyVisualStyles.headingSmall.desktop.lineHeight};\n  color: ${props => props.isInverse\r\n    ? props.theme.colors.neutral100\r\n    : props.theme.colors.neutral700};\n  margin: 0;\n  padding-right: ${props => props.theme.spaceScale.spacing10};\n  font-weight: 600;\n`;\r\nconst CloseBtn = styled.span `\n  position: absolute;\n  top: 0;\n  right: 0;\n  margin: ${props => props.theme.spaceScale.spacing02};\n`;\r\nexport const Modal = React.forwardRef((props, ref) => {\r\n    const lastFocus = React.useRef();\r\n    const headingRef = React.useRef();\r\n    const bodyRef = React.useRef();\r\n    const id = useGenerateId(props.id);\r\n    const headingId = `${id}_heading`;\r\n    const contentId = `${id}_content`;\r\n    const [isModalOpen, setIsModalOpen] = React.useState(props.isOpen);\r\n    const [isExiting, setIsExiting] = React.useState(false);\r\n    const [currentTarget, setCurrentTarget] = React.useState(null);\r\n    const [modalCount, setModalCount] = React.useState(0);\r\n    const focusTrapElement = useFocusLock(isModalOpen, headingRef, bodyRef);\r\n    const prevOpen = usePrevious(props.isOpen);\r\n    React.useEffect(() => {\r\n        if (props.isModalClosingControlledManually &&\r\n            prevOpen &&\r\n            !props.isOpen &&\r\n            isModalOpen) {\r\n            setIsModalOpen(false);\r\n        }\r\n        else if (!prevOpen && props.isOpen) {\r\n            setIsModalOpen(true);\r\n            if (props.headerRef && typeof props.headerRef === 'function') {\r\n                props.headerRef(headingRef);\r\n            }\r\n        }\r\n        else if (prevOpen && !props.isOpen && isModalOpen) {\r\n            handleClose();\r\n        }\r\n    }, [props.isOpen]);\r\n    React.useEffect(() => {\r\n        if (isModalOpen) {\r\n            lastFocus.current = document.activeElement;\r\n            const count = document.querySelectorAll('[aria-modal=\"true\"]').length;\r\n            setModalCount(count);\r\n            if (!props.isEscKeyDownDisabled) {\r\n                document.body.addEventListener('keydown', handleEscapeKeyDown, false);\r\n            }\r\n        }\r\n        return () => {\r\n            document.body.removeEventListener('keydown', handleEscapeKeyDown, false);\r\n        };\r\n    }, [isModalOpen]);\r\n    function handleModalClick(event) {\r\n        if (!document.getElementById(contentId).contains(event.target) &&\r\n            event.target === currentTarget) {\r\n            handleClose(event);\r\n        }\r\n    }\r\n    function handleModalOnMouseDown(event) {\r\n        setCurrentTarget(event.target);\r\n    }\r\n    function handleEscapeKeyDown(event) {\r\n        if (event.key === 'Escape') {\r\n            event.preventDefault();\r\n            event.stopPropagation();\r\n            props.onEscKeyDown &&\r\n                typeof props.onEscKeyDown === 'function' &&\r\n                props.onEscKeyDown(event);\r\n            //Supports nested modals\r\n            const modalsInDom = document.querySelectorAll('[aria-modal=\"true\"]').length;\r\n            if (modalCount <= 1 && modalsInDom !== 1) {\r\n                if (document.getElementById(id).contains(event.target)) {\r\n                    handleClose(event);\r\n                }\r\n                else {\r\n                    headingRef.current.focus();\r\n                }\r\n            }\r\n            else {\r\n                handleClose(event);\r\n            }\r\n        }\r\n    }\r\n    function handleClose(event) {\r\n        if (event) {\r\n            event.stopPropagation();\r\n        }\r\n        setIsExiting(true);\r\n        setTimeout(() => {\r\n            setIsExiting(false);\r\n            if (!props.isModalClosingControlledManually) {\r\n                setIsModalOpen(false);\r\n            }\r\n            if (lastFocus.current) {\r\n                lastFocus.current.focus();\r\n            }\r\n            props.onClose && typeof props.onClose === 'function' && props.onClose();\r\n        }, 300);\r\n    }\r\n    const { ariaLabel, children, closeAriaLabel, closeButtonSize, containerStyle, containerTransition = { slideTop: true }, isBackgroundClickDisabled, isEscKeyDownDisabled, header, isCloseButtonHidden, isOpen, unmountOnExit = true, testId, ...rest } = props;\r\n    const isInverse = useIsInverse(props.isInverse);\r\n    const other = omit(['onEscKeyDown'], rest);\r\n    const theme = React.useContext(ThemeContext);\r\n    const i18n = React.useContext(I18nContext);\r\n    const CloseIconButton = (React.createElement(CloseIcon, { size: magma.iconSizes[closeButtonSize]\r\n            ? magma.iconSizes[closeButtonSize]\r\n            : magma.iconSizes.medium }));\r\n    return isModalOpen\r\n        ? ReactDOM.createPortal(React.createElement(\"div\", { ref: focusTrapElement },\r\n            React.createElement(Global, { styles: css `\n                html {\n                  overflow: ${isOpen ? 'hidden' : 'auto'};\n                }\n              ` }),\r\n            React.createElement(ModalBackdrop, { \"data-testid\": \"modal-backdrop\", isExiting: isExiting, onMouseDown: isBackgroundClickDisabled\r\n                    ? event => event.preventDefault()\r\n                    : null, fade: true, isOpen: isModalOpen, unmountOnExit: true, theme: theme },\r\n                React.createElement(ModalContainer, Object.assign({ \"aria-labelledby\": header ? headingId : null, \"aria-label\": !header ? ariaLabel : null, \"aria-modal\": true, \"data-testid\": testId, id: id, onClick: isBackgroundClickDisabled ? null : handleModalClick, onMouseDown: isBackgroundClickDisabled ? null : handleModalOnMouseDown, role: \"dialog\", style: containerStyle, theme: theme, isOpen: isModalOpen }, containerTransition, { unmountOnExit: unmountOnExit }),\r\n                    React.createElement(ModalContent, Object.assign({}, other, { \"data-testid\": \"modal-content\", id: contentId, isExiting: isExiting, ref: ref, theme: theme }),\r\n                        header && (React.createElement(ModalHeader, { theme: theme }, header && (React.createElement(H1, { id: headingId, isInverse: isInverse, level: 1, ref: headingRef, visualStyle: TypographyVisualStyle.headingSmall, tabIndex: -1, theme: theme }, header)))),\r\n                        React.createElement(ModalWrapper, { ref: bodyRef, theme: theme }, children),\r\n                        !isCloseButtonHidden && (React.createElement(CloseBtn, { theme: theme },\r\n                            React.createElement(IconButton, { \"aria-label\": closeAriaLabel\r\n                                    ? closeAriaLabel\r\n                                    : i18n.modal.closeAriaLabel, color: ButtonColor.primary, icon: CloseIconButton, isInverse: isInverse, onClick: handleClose, testId: \"modal-closebtn\", variant: ButtonVariant.link }))))))), document.getElementsByTagName('body')[0])\r\n        : null;\r\n});\r\n//# sourceMappingURL=Modal.js.map"]} */"))
10642
- }), React.createElement(ModalBackdrop, {
10643
- "data-testid": "modal-backdrop",
10644
- isExiting: isExiting,
10645
- onMouseDown: isBackgroundClickDisabled ? function (event) {
10646
- return event.preventDefault();
10647
- } : null,
10648
- fade: true,
10649
- isOpen: isModalOpen,
10650
- unmountOnExit: true,
10651
- theme: theme
10652
- }, React.createElement(ModalContainer, Object.assign({
10643
+ styles: /*#__PURE__*/react.css("html{overflow:", isOpen ? 'hidden' : 'auto', ";};label:styles;" + ( "/*# sourceMappingURL=data:application/json;charset=utf-8;base64,{"version":3,"sources":["Modal.tsx"],"names":[],"mappings":"AA8MsD","file":"Modal.tsx","sourcesContent":["import * as React from 'react';\r\nimport ReactDOM from 'react-dom';\r\nimport styled from '@emotion/styled';\r\nimport { Global, css } from '@emotion/react';\r\nimport { ThemeContext } from '../../theme/ThemeContext';\r\nimport { magma } from '../../theme/magma';\r\nimport { I18nContext } from '../../i18n';\r\nimport { ButtonColor, ButtonVariant } from '../Button';\r\nimport { IconButton } from '../IconButton';\r\nimport { CloseIcon } from 'react-magma-icons';\r\nimport { Heading } from '../Heading';\r\nimport { TypographyVisualStyle } from '../Typography';\r\nimport { Transition } from '../Transition';\r\nimport { omit, useGenerateId, usePrevious } from '../../utils';\r\nimport { useFocusLock } from '../../hooks/useFocusLock';\r\nimport { transparentize } from 'polished';\r\nimport { useIsInverse } from '../../inverse';\r\nexport var ModalSize;\r\n(function (ModalSize) {\r\n    ModalSize[\"large\"] = \"large\";\r\n    ModalSize[\"medium\"] = \"medium\";\r\n    ModalSize[\"small\"] = \"small\";\r\n})(ModalSize || (ModalSize = {}));\r\nconst ModalContainer = styled(Transition) `\n  bottom: 0;\n  left: 0;\n  overflow-y: auto;\n  padding: ${props => props.theme.spaceScale.spacing03};\n  right: 0;\n  top: 0;\n  z-index: ${props => (props.modalCount >= 2 ? '999' : '998')};\n`;\r\nconst ModalBackdrop = styled(Transition) `\n  backdrop-filter: blur(3px);\n  background: ${props => transparentize(0.4, props.theme.colors.neutral900)};\n  bottom: 0;\n  left: 0;\n  right: 0;\n  top: 0;\n  z-index: 997;\n  position: fixed;\n`;\r\nconst ModalContent = styled.div `\n  background: ${props => props.isInverse\r\n    ? props.theme.colors.primary600\r\n    : props.theme.colors.neutral100};\n  border: 1px solid;\n  border-color: ${props => props.isInverse\r\n    ? transparentize(0.5, props.theme.colors.tertiary)\r\n    : props.theme.colors.neutral};\n  border-radius: ${props => props.theme.borderRadius};\n  box-shadow: ${props => `0 2px 6px ${transparentize(0.85, props.theme.colors.neutral900)}`};\n  color: ${props => props.isInverse\r\n    ? props.theme.colors.neutral100\r\n    : props.theme.colors.neutral700};\n  margin: 0 auto;\n  position: relative;\n  z-index: 1000;\n\n  max-width: ${props => {\r\n    switch (props.size) {\r\n        case 'large':\r\n            return props.theme.modal.width.large;\r\n        case 'small':\r\n            return props.theme.modal.width.small;\r\n        default:\r\n            return props.theme.modal.width.medium;\r\n    }\r\n}};\n\n  @media (min-width: ${props => props.theme.breakpoints.small}px) {\n    margin: ${props => props.theme.spaceScale.spacing08} auto;\n  }\n`;\r\nconst ModalHeader = styled.div `\n  padding: ${props => props.theme.spaceScale.spacing05}\n    ${props => props.theme.spaceScale.spacing05} 0\n    ${props => props.theme.spaceScale.spacing05};\n  @media (min-width: ${props => props.theme.breakpoints.small}px) {\n    padding: ${props => props.theme.spaceScale.spacing06}\n      ${props => props.theme.spaceScale.spacing06} 0\n      ${props => props.theme.spaceScale.spacing06};\n  }\n`;\r\nconst ModalWrapper = styled.div `\n  padding: ${props => props.theme.spaceScale.spacing05};\n  @media (min-width: ${props => props.theme.breakpoints.small}px) {\n    padding: ${props => props.theme.spaceScale.spacing06};\n  }\n`;\r\nconst H1 = styled(Heading) `\n  font-size: ${props => props.theme.typographyVisualStyles.headingSmall.desktop.fontSize};\n  line-height: ${props => props.theme.typographyVisualStyles.headingSmall.desktop.lineHeight};\n  color: ${props => props.isInverse\r\n    ? props.theme.colors.neutral100\r\n    : props.theme.colors.neutral700};\n  margin: 0;\n  padding-right: ${props => props.theme.spaceScale.spacing10};\n  font-weight: 600;\n`;\r\nconst CloseBtn = styled.span `\n  position: absolute;\n  top: 0;\n  right: 0;\n  margin: ${props => props.theme.spaceScale.spacing02};\n`;\r\nexport const Modal = React.forwardRef((props, ref) => {\r\n    const lastFocus = React.useRef();\r\n    const headingRef = React.useRef();\r\n    const bodyRef = React.useRef();\r\n    const id = useGenerateId(props.id);\r\n    const headingId = `${id}_heading`;\r\n    const contentId = `${id}_content`;\r\n    const [isModalOpen, setIsModalOpen] = React.useState(props.isOpen);\r\n    const [isExiting, setIsExiting] = React.useState(false);\r\n    const [currentTarget, setCurrentTarget] = React.useState(null);\r\n    const [modalCount, setModalCount] = React.useState(0);\r\n    const focusTrapElement = useFocusLock(isModalOpen, headingRef, bodyRef);\r\n    const prevOpen = usePrevious(props.isOpen);\r\n    React.useEffect(() => {\r\n        if (props.isModalClosingControlledManually &&\r\n            prevOpen &&\r\n            !props.isOpen &&\r\n            isModalOpen) {\r\n            setIsModalOpen(false);\r\n        }\r\n        else if (!prevOpen && props.isOpen) {\r\n            setIsModalOpen(true);\r\n            if (props.headerRef && typeof props.headerRef === 'function') {\r\n                props.headerRef(headingRef);\r\n            }\r\n        }\r\n        else if (prevOpen && !props.isOpen && isModalOpen) {\r\n            handleClose();\r\n        }\r\n    }, [props.isOpen]);\r\n    React.useEffect(() => {\r\n        if (isModalOpen) {\r\n            lastFocus.current = document.activeElement;\r\n            const count = document.querySelectorAll('[aria-modal=\"true\"]').length;\r\n            setModalCount(count);\r\n            if (!props.isEscKeyDownDisabled) {\r\n                document.body.addEventListener('keydown', handleEscapeKeyDown, false);\r\n            }\r\n        }\r\n        return () => {\r\n            document.body.removeEventListener('keydown', handleEscapeKeyDown, false);\r\n        };\r\n    }, [isModalOpen]);\r\n    function handleModalClick(event) {\r\n        if (!document.getElementById(contentId).contains(event.target) &&\r\n            event.target === currentTarget) {\r\n            handleClose(event);\r\n        }\r\n    }\r\n    function handleModalOnMouseDown(event) {\r\n        setCurrentTarget(event.target);\r\n    }\r\n    function handleEscapeKeyDown(event) {\r\n        if (event.key === 'Escape') {\r\n            event.preventDefault();\r\n            event.stopPropagation();\r\n            props.onEscKeyDown &&\r\n                typeof props.onEscKeyDown === 'function' &&\r\n                props.onEscKeyDown(event);\r\n            //Supports nested modals\r\n            const modalsInDom = document.querySelectorAll('[aria-modal=\"true\"]').length;\r\n            if (modalCount <= 1 && modalsInDom !== 1) {\r\n                if (document.getElementById(id).contains(event.target)) {\r\n                    handleClose(event);\r\n                }\r\n                else {\r\n                    headingRef.current.focus();\r\n                }\r\n            }\r\n            else {\r\n                handleClose(event);\r\n            }\r\n        }\r\n    }\r\n    function handleClose(event) {\r\n        if (event) {\r\n            event.stopPropagation();\r\n        }\r\n        setIsExiting(true);\r\n        setTimeout(() => {\r\n            setIsExiting(false);\r\n            if (!props.isModalClosingControlledManually) {\r\n                setIsModalOpen(false);\r\n            }\r\n            if (lastFocus.current) {\r\n                lastFocus.current.focus();\r\n            }\r\n            props.onClose && typeof props.onClose === 'function' && props.onClose();\r\n        }, 300);\r\n    }\r\n    const { ariaLabel, children, closeAriaLabel, closeButtonSize, containerStyle, containerTransition = { slideTop: true }, isBackgroundClickDisabled, isEscKeyDownDisabled, header, isCloseButtonHidden, isOpen, unmountOnExit = true, testId, ...rest } = props;\r\n    const isInverse = useIsInverse(props.isInverse);\r\n    const other = omit(['onEscKeyDown'], rest);\r\n    const theme = React.useContext(ThemeContext);\r\n    const i18n = React.useContext(I18nContext);\r\n    const CloseIconButton = (React.createElement(CloseIcon, { size: magma.iconSizes[closeButtonSize]\r\n            ? magma.iconSizes[closeButtonSize]\r\n            : magma.iconSizes.medium }));\r\n    return isModalOpen\r\n        ? ReactDOM.createPortal(React.createElement(\"div\", { ref: focusTrapElement },\r\n            React.createElement(Global, { styles: css `\n                html {\n                  overflow: ${isOpen ? 'hidden' : 'auto'};\n                }\n              ` }),\r\n            React.createElement(ModalContainer, Object.assign({ \"aria-labelledby\": header ? headingId : null, \"aria-label\": !header ? ariaLabel : null, \"aria-modal\": true, \"data-testid\": testId, id: id, modalCount: modalCount, onClick: isBackgroundClickDisabled ? null : handleModalClick, onMouseDown: isBackgroundClickDisabled ? null : handleModalOnMouseDown, role: \"dialog\", style: containerStyle, theme: theme, isOpen: isModalOpen }, containerTransition, { unmountOnExit: unmountOnExit }),\r\n                React.createElement(ModalContent, Object.assign({}, other, { \"data-testid\": \"modal-content\", id: contentId, isExiting: isExiting, ref: ref, theme: theme }),\r\n                    header && (React.createElement(ModalHeader, { theme: theme }, header && (React.createElement(H1, { id: headingId, isInverse: isInverse, level: 1, ref: headingRef, visualStyle: TypographyVisualStyle.headingSmall, tabIndex: -1, theme: theme }, header)))),\r\n                    React.createElement(ModalWrapper, { ref: bodyRef, theme: theme }, children),\r\n                    !isCloseButtonHidden && (React.createElement(CloseBtn, { theme: theme },\r\n                        React.createElement(IconButton, { \"aria-label\": closeAriaLabel\r\n                                ? closeAriaLabel\r\n                                : i18n.modal.closeAriaLabel, color: ButtonColor.primary, icon: CloseIconButton, isInverse: isInverse, onClick: handleClose, testId: \"modal-closebtn\", variant: ButtonVariant.link }))))),\r\n            React.createElement(ModalBackdrop, { \"data-testid\": \"modal-backdrop\", isExiting: isExiting, onMouseDown: isBackgroundClickDisabled\r\n                    ? event => event.preventDefault()\r\n                    : null, fade: true, isOpen: isModalOpen, style: modalCount >= 2 && { zIndex: '998' }, unmountOnExit: true, theme: theme })), document.getElementsByTagName('body')[0])\r\n        : null;\r\n});\r\n//# sourceMappingURL=Modal.js.map"]} */"))
10644
+ }), React.createElement(ModalContainer, Object.assign({
10653
10645
  "aria-labelledby": header ? headingId : null,
10654
10646
  "aria-label": !header ? ariaLabel : null,
10655
10647
  "aria-modal": true,
10656
10648
  "data-testid": testId,
10657
10649
  id: id,
10650
+ modalCount: modalCount,
10658
10651
  onClick: isBackgroundClickDisabled ? null : handleModalClick,
10659
10652
  onMouseDown: isBackgroundClickDisabled ? null : handleModalOnMouseDown,
10660
10653
  role: "dialog",
@@ -10692,7 +10685,20 @@ var Modal = /*#__PURE__*/React.forwardRef(function (props, ref) {
10692
10685
  onClick: handleClose,
10693
10686
  testId: "modal-closebtn",
10694
10687
  variant: exports.ButtonVariant.link
10695
- })))))), document.getElementsByTagName('body')[0]) : null;
10688
+ })))), React.createElement(ModalBackdrop, {
10689
+ "data-testid": "modal-backdrop",
10690
+ isExiting: isExiting,
10691
+ onMouseDown: isBackgroundClickDisabled ? function (event) {
10692
+ return event.preventDefault();
10693
+ } : null,
10694
+ fade: true,
10695
+ isOpen: isModalOpen,
10696
+ style: modalCount >= 2 && {
10697
+ zIndex: '998'
10698
+ },
10699
+ unmountOnExit: true,
10700
+ theme: theme
10701
+ })), document.getElementsByTagName('body')[0]) : null;
10696
10702
  });
10697
10703
 
10698
10704
  var _excluded$1j = ["iconAriaLabel", "isClearable", "isInverse", "isLoading", "labelText", "placeholder", "onSearch", "onClear"];