react-magma-dom 4.8.0-next.13 → 4.8.0-next.14

This diff represents the content of publicly available package versions that have been released to one of the supported registries. The information contained in this diff is provided for informational purposes only and reflects changes between package versions as they appear in their respective public registries.
package/dist/esm/index.js CHANGED
@@ -3656,20 +3656,20 @@ var StyledAlert = /*#__PURE__*/_styled("div", {
3656
3656
  }, ";}&:focus{outline:2px solid ", function (props) {
3657
3657
  return props.isInverse ? props.theme.colors.focusInverse : props.theme.colors.focus;
3658
3658
  }, ";}", function (props) {
3659
- return props.isToast && /*#__PURE__*/css("animation:", props.isExiting ? "slideout " + transitionDuration + "ms" : "slidein " + transitionDuration + "ms", ";min-width:375px;margin:0 auto;@media (max-width: ", props.theme.breakpoints.small, "px){min-width:0;width:100%;};label:StyledAlert;" + (process.env.NODE_ENV === "production" ? "" : "/*# sourceMappingURL=data:application/json;charset=utf-8;base64,{"version":3,"sources":["index.tsx"],"names":[],"mappings":"AA8JQ","file":"index.tsx","sourcesContent":["import * as React from 'react';\r\nimport { css } from '@emotion/react';\r\nimport isPropValid from '@emotion/is-prop-valid';\r\nimport { transparentize } from 'polished';\r\nimport { ThemeContext } from '../../theme/ThemeContext';\r\nimport { InfoIcon, CheckCircleIcon, WarningIcon, ErrorIcon, CloseIcon, } from 'react-magma-icons';\r\nimport { ButtonVariant } from '../Button';\r\nimport { IconButton } from '../IconButton';\r\nimport { ProgressRing } from '../ProgressRing';\r\nimport { useGenerateId } from '../../utils';\r\nimport { I18nContext } from '../../i18n';\r\nimport { InverseContext, useIsInverse } from '../../inverse';\r\nimport styled from '@emotion/styled';\r\nexport const VARIANT_ICON = {\r\n    info: InfoIcon,\r\n    success: CheckCircleIcon,\r\n    warning: WarningIcon,\r\n    danger: ErrorIcon,\r\n};\r\nexport var AlertVariant;\r\n(function (AlertVariant) {\r\n    AlertVariant[\"info\"] = \"info\";\r\n    AlertVariant[\"success\"] = \"success\";\r\n    AlertVariant[\"warning\"] = \"warning\";\r\n    AlertVariant[\"danger\"] = \"danger\";\r\n})(AlertVariant || (AlertVariant = {}));\r\nexport const transitionDuration = 500;\r\nexport function buildAlertBackground(props) {\r\n    if (props.isInverse) {\r\n        switch (props.variant) {\r\n            case 'success':\r\n                return props.theme.colors.success700;\r\n            case 'warning':\r\n                return props.theme.colors.warning700;\r\n            case 'danger':\r\n                return props.theme.colors.danger700;\r\n            default:\r\n                return props.theme.colors.info700;\r\n        }\r\n    }\r\n    switch (props.variant) {\r\n        case 'success':\r\n            return props.theme.colors.success100;\r\n        case 'warning':\r\n            return props.theme.colors.warning100;\r\n        case 'danger':\r\n            return props.theme.colors.danger100;\r\n        default:\r\n            return props.theme.colors.info100;\r\n    }\r\n}\r\nexport function buildAlertBorder(props) {\r\n    if (props.isInverse) {\r\n        switch (props.variant) {\r\n            case 'success':\r\n                return props.theme.colors.success300;\r\n            case 'warning':\r\n                return props.theme.colors.warning300;\r\n            case 'danger':\r\n                return props.theme.colors.danger200;\r\n            default:\r\n                return props.theme.colors.info300;\r\n        }\r\n    }\r\n    switch (props.variant) {\r\n        case 'success':\r\n            return props.theme.colors.success500;\r\n        case 'warning':\r\n            return props.theme.colors.warning500;\r\n        case 'danger':\r\n            return props.theme.colors.danger500;\r\n        default:\r\n            return props.theme.colors.info500;\r\n    }\r\n}\r\nexport function buildAlertColor(props) {\r\n    if (props.isInverse) {\r\n        return props.theme.colors.neutral100;\r\n    }\r\n    switch (props.variant) {\r\n        case 'success':\r\n            return props.theme.colors.success500;\r\n        case 'warning':\r\n            return props.theme.colors.warning500;\r\n        case 'danger':\r\n            return props.theme.colors.danger500;\r\n        default:\r\n            return props.theme.colors.info500;\r\n    }\r\n}\r\nexport function buildLinkColor(props) {\r\n    if (props.isInverse) {\r\n        switch (props.variant) {\r\n            case 'success':\r\n                return props.theme.colors.success200;\r\n            case 'warning':\r\n                return props.theme.colors.warning200;\r\n            case 'danger':\r\n                return props.theme.colors.danger200;\r\n            default:\r\n                return props.theme.colors.info200;\r\n        }\r\n    }\r\n    switch (props.variant) {\r\n        case 'success':\r\n            return props.theme.colors.success700;\r\n        case 'warning':\r\n            return props.theme.colors.warning700;\r\n        case 'danger':\r\n            return props.theme.colors.danger700;\r\n        default:\r\n            return props.theme.colors.info700;\r\n    }\r\n}\r\nexport function buildLinkHoverColor(props) {\r\n    if (props.isInverse) {\r\n        return props.theme.colors.neutral100;\r\n    }\r\n    switch (props.variant) {\r\n        case 'success':\r\n            return props.theme.colors.success;\r\n        case 'warning':\r\n            return props.theme.colors.warning;\r\n        case 'danger':\r\n            return props.theme.colors.danger;\r\n        default:\r\n            return props.theme.colors.info;\r\n    }\r\n}\r\nconst StyledAlert = styled.div `\n  align-items: stretch;\n  animation: ${props => props.isExiting\r\n    ? `fadeout ${transitionDuration}ms`\r\n    : `fadein ${transitionDuration}ms`};\n  display: flex;\n  flex-direction: column;\n  font-size: ${props => props.theme.typeScale.size03.fontSize};\n  font-family: ${props => props.theme.bodyFont};\n  line-height: ${props => props.theme.typeScale.size03.lineHeight};\n  margin-bottom: ${props => props.theme.spaceScale.spacing06};\n  max-width: 100%;\n  padding: 0;\n  position: relative;\n\n  @media (max-width: ${props => props.theme.breakpoints.small}px) {\n    font-size: ${props => props.theme.typeScale.size02.fontSize};\n    letter-spacing: ${props => props.theme.typeScale.size02.letterSpacing};\n    line-height: ${props => props.theme.typeScale.size02.lineHeight};\n  }\n\n  &:focus {\n    outline: 2px solid\n      ${props => props.isInverse\r\n    ? props.theme.colors.focusInverse\r\n    : props.theme.colors.focus};\n  }\n\n  ${props => props.isToast &&\r\n    css `\n      animation: ${props.isExiting\r\n        ? `slideout ${transitionDuration}ms`\r\n        : `slidein ${transitionDuration}ms`};\n      min-width: 375px;\n      margin: 0 auto;\n\n      @media (max-width: ${props.theme.breakpoints.small}px) {\n        min-width: 0;\n        width: 100%;\n      }\n    `}\n\n  @keyframes fadein {\n    from {\n      opacity: 0;\n    }\n    to {\n      opacity: 1;\n    }\n  }\n\n  @keyframes fadeout {\n    from {\n      opacity: 1;\n    }\n    to {\n      opacity: 0;\n    }\n  }\n\n  @keyframes slidein {\n    from {\n      left: -500px;\n    }\n    to {\n      left: 0;\n    }\n  }\n\n  @keyframes slideout {\n    from {\n      left: 0;\n    }\n    to {\n      left: -500px;\n    }\n  }\n\n  a {\n    color: ${props => buildLinkColor(props)};\n    font-weight: 400;\n    text-decoration: underline;\n    &:not([disabled]) {\n      &:focus,\n      &:hover {\n        color: ${props => buildLinkHoverColor(props)};\n      }\n    }\n  }\n`;\r\nconst StyledAlertInner = styled.div `\n  background: ${buildAlertBackground};\n  border: 1px solid ${buildAlertBorder};\n  border-radius: ${props => props.theme.borderRadius};\n  color: ${buildAlertColor};\n  display: flex;\n  position: relative;\n\n  ${props => props.isToast &&\r\n    css `\n      box-shadow: ${props.isInverse\r\n        ? `0 2px 8px 0 ${transparentize(0.3, props.theme.colors.neutral900)}`\r\n        : `0 2px 8px 0 ${transparentize(0.6, props.theme.colors.neutral900)}`};\n      padding-right: 0;\n      height: ${props.theme.spaceScale.spacing11};\n    `}\n`;\r\nconst AlertContents = styled.div `\n  align-items: ${props => (props.additionalContent ? 'center' : '')};\n  align-self: center;\n  flex-grow: 1;\n  font-family: ${props => props.theme.bodyFont};\n  padding: ${props => props.theme.spaceScale.spacing04} 0;\n  display: ${props => (props.additionalContent ? 'flex' : '')};\n  margin-right: ${props => props.additionalContent && !props.isDismissible\r\n    ? props.theme.spaceScale.spacing03\r\n    : ''};\n  @media (max-width: ${props => props.theme.breakpoints.small}px) {\n    padding-left: 0;\n  }\n`;\r\nexport const AdditionalContentWrapper = styled.div `\n  flex: 1 0 auto;\n  justify-content: flex-end;\n  display: flex;\n  margin-left: ${props => props.theme.spaceScale.spacing05};\n`;\r\nconst IconWrapperStyles = css `\n  align-items: center;\n  display: flex;\n  flex-shrink: 0;\n  margin-right: 1px;\n`;\r\nconst IconWrapper = styled.span `\n  ${IconWrapperStyles}\n  padding: 0 ${props => props.theme.spaceScale.spacing03} 0 ${props => props.theme.spaceScale.spacing04};\n\n  @media (max-width: ${props => props.theme.breakpoints.small}px) {\n    padding: 0 ${props => props.theme.spaceScale.spacing03};\n    svg {\n      width: 20px;\n    }\n  }\n`;\r\nconst ProgressRingWrapper = styled.div `\n  margin-top: 6px;\n  position: absolute;\n  top: auto;\n  right: ${props => props.theme.spaceScale.spacing02};\n`;\r\nconst DismissibleIconWrapper = styled.span `\n  ${IconWrapperStyles}\n  margin-left: ${props => props.additionalContent ? props.theme.spaceScale.spacing03 : ''};\n`;\r\nconst whitelistProps = ['icon', 'isInverse', 'theme', 'variant'];\r\nconst shouldForwardProp = prop => {\r\n    return isPropValid(prop) || whitelistProps.includes(prop);\r\n};\r\nconst DismissButton = styled(IconButton, { shouldForwardProp }) `\n  align-self: stretch;\n  border-radius: 0 ${props => props.theme.borderRadius}\n    ${props => props.theme.borderRadius} 0;\n  color: inherit;\n  height: auto;\n  margin: ${props => (props.isToast ? '4px' : '0 -1px 0 0')};\n  padding: ${props => props.isToast\r\n    ? `0 ${props.theme.spaceScale.spacing04}`\r\n    : `0 ${props.theme.spaceScale.spacing03}`};\n  width: auto;\n  &:not(:disabled):hover {\n    background: none;\n    color: inherit;\n  }\n  &:focus:not(:disabled) {\n    background: none;\n    color: inherit;\n    outline: 2px solid\n      ${props => props.isInverse\r\n    ? props.theme.colors.focusInverse\r\n    : props.theme.colors.focus};\n    outline-offset: 0 !important;\n  }\n  &:not(:disabled):active {\n    background: none;\n    color: inherit;\n  }\n`;\r\nconst AlertSpan = styled.span `\n  white-space: pre-line;\n`;\r\nfunction renderIcon(variant = 'info', isToast, theme) {\r\n    const Icon = VARIANT_ICON[variant];\r\n    return (React.createElement(IconWrapper, { isToast: isToast, theme: theme },\r\n        React.createElement(Icon, { size: theme.iconSizes.medium })));\r\n}\r\nexport const AlertBase = React.forwardRef((props, ref) => {\r\n    const { additionalContent, children, closeAriaLabel, forceDismiss, hasTimerRing, id: defaultId, isDismissed, isDismissible, isExiting: externalIsExiting, isPaused, isToast, onDismiss, testId, toastDuration, variant, ...other } = props;\r\n    const id = useGenerateId(defaultId);\r\n    const [isExiting, setIsExiting] = React.useState(false);\r\n    const isInverse = useIsInverse(props.isInverse);\r\n    React.useEffect(() => {\r\n        if (isExiting) {\r\n            setTimeout(() => {\r\n                setIsExiting(false);\r\n                onDismiss && typeof onDismiss === 'function' && onDismiss();\r\n            }, transitionDuration - 300);\r\n        }\r\n    }, [isExiting]);\r\n    React.useEffect(() => {\r\n        if (isDismissed) {\r\n            handleDismiss();\r\n        }\r\n    }, [isDismissed]);\r\n    function handleDismiss() {\r\n        setIsExiting(true);\r\n    }\r\n    const theme = React.useContext(ThemeContext);\r\n    const i18n = React.useContext(I18nContext);\r\n    function progressRingColor() {\r\n        if (isInverse) {\r\n            return theme.colors.neutral100;\r\n        }\r\n        switch (props.variant) {\r\n            case 'success':\r\n                return theme.colors.success500;\r\n            case 'warning':\r\n                return theme.colors.warning500;\r\n            case 'danger':\r\n                return theme.colors.danger500;\r\n            default:\r\n                return theme.colors.info500;\r\n        }\r\n    }\r\n    return (React.createElement(StyledAlert, Object.assign({}, other, { \"data-testid\": testId, id: id, tabIndex: -1, isInverse: isInverse, isExiting: isExiting, isToast: isToast, ref: ref, theme: theme, variant: variant }),\r\n        React.createElement(InverseContext.Provider, { value: { isInverse } },\r\n            React.createElement(StyledAlertInner, { isInverse: isInverse, isToast: isToast, theme: theme, variant: variant },\r\n                renderIcon(variant, isToast, theme),\r\n                React.createElement(AlertContents, { additionalContent: additionalContent, isDismissible: isDismissible, theme: theme },\r\n                    React.createElement(AlertSpan, null, children),\r\n                    additionalContent && (React.createElement(AdditionalContentWrapper, { theme: theme }, additionalContent))),\r\n                isDismissible && (React.createElement(DismissibleIconWrapper, { isInverse: isInverse, variant: variant, theme: theme },\r\n                    hasTimerRing && isToast && (React.createElement(ProgressRingWrapper, { theme: theme },\r\n                        React.createElement(ProgressRing, { color: progressRingColor(), isActive: !isPaused, duration: toastDuration }))),\r\n                    React.createElement(DismissButton, { alertVariant: variant, \"aria-label\": closeAriaLabel\r\n                            ? closeAriaLabel\r\n                            : i18n.alert.dismissAriaLabel, icon: React.createElement(CloseIcon, { size: hasTimerRing\r\n                                ? theme.iconSizes.xSmall\r\n                                : theme.iconSizes.small }), isInverse: isInverse, isToast: isToast, onClick: forceDismiss || handleDismiss, theme: theme, variant: ButtonVariant.link })))))));\r\n});\r\n//# sourceMappingURL=index.js.map"]} */"));
3659
+ return props.isToast && /*#__PURE__*/css("animation:", props.isExiting ? "slideout " + transitionDuration + "ms" : "slidein " + transitionDuration + "ms", ";min-width:375px;margin:0 auto;@media (max-width: ", props.theme.breakpoints.small, "px){min-width:0;width:100%;};label:StyledAlert;" + (process.env.NODE_ENV === "production" ? "" : "/*# sourceMappingURL=data:application/json;charset=utf-8;base64,{"version":3,"sources":["index.tsx"],"names":[],"mappings":"AA8JQ","file":"index.tsx","sourcesContent":["import * as React from 'react';\r\nimport { css } from '@emotion/react';\r\nimport isPropValid from '@emotion/is-prop-valid';\r\nimport { transparentize } from 'polished';\r\nimport { ThemeContext } from '../../theme/ThemeContext';\r\nimport { InfoIcon, CheckCircleIcon, WarningIcon, ErrorIcon, CloseIcon, } from 'react-magma-icons';\r\nimport { ButtonVariant } from '../Button';\r\nimport { IconButton } from '../IconButton';\r\nimport { ProgressRing } from '../ProgressRing';\r\nimport { useGenerateId } from '../../utils';\r\nimport { I18nContext } from '../../i18n';\r\nimport { InverseContext, useIsInverse } from '../../inverse';\r\nimport styled from '@emotion/styled';\r\nexport const VARIANT_ICON = {\r\n    info: InfoIcon,\r\n    success: CheckCircleIcon,\r\n    warning: WarningIcon,\r\n    danger: ErrorIcon,\r\n};\r\nexport var AlertVariant;\r\n(function (AlertVariant) {\r\n    AlertVariant[\"info\"] = \"info\";\r\n    AlertVariant[\"success\"] = \"success\";\r\n    AlertVariant[\"warning\"] = \"warning\";\r\n    AlertVariant[\"danger\"] = \"danger\";\r\n})(AlertVariant || (AlertVariant = {}));\r\nexport const transitionDuration = 500;\r\nexport function buildAlertBackground(props) {\r\n    if (props.isInverse) {\r\n        switch (props.variant) {\r\n            case 'success':\r\n                return props.theme.colors.success700;\r\n            case 'warning':\r\n                return props.theme.colors.warning700;\r\n            case 'danger':\r\n                return props.theme.colors.danger700;\r\n            default:\r\n                return props.theme.colors.info700;\r\n        }\r\n    }\r\n    switch (props.variant) {\r\n        case 'success':\r\n            return props.theme.colors.success100;\r\n        case 'warning':\r\n            return props.theme.colors.warning100;\r\n        case 'danger':\r\n            return props.theme.colors.danger100;\r\n        default:\r\n            return props.theme.colors.info100;\r\n    }\r\n}\r\nexport function buildAlertBorder(props) {\r\n    if (props.isInverse) {\r\n        switch (props.variant) {\r\n            case 'success':\r\n                return props.theme.colors.success300;\r\n            case 'warning':\r\n                return props.theme.colors.warning300;\r\n            case 'danger':\r\n                return props.theme.colors.danger200;\r\n            default:\r\n                return props.theme.colors.info300;\r\n        }\r\n    }\r\n    switch (props.variant) {\r\n        case 'success':\r\n            return props.theme.colors.success500;\r\n        case 'warning':\r\n            return props.theme.colors.warning500;\r\n        case 'danger':\r\n            return props.theme.colors.danger500;\r\n        default:\r\n            return props.theme.colors.info500;\r\n    }\r\n}\r\nexport function buildAlertColor(props) {\r\n    if (props.isInverse) {\r\n        return props.theme.colors.neutral100;\r\n    }\r\n    switch (props.variant) {\r\n        case 'success':\r\n            return props.theme.colors.success500;\r\n        case 'warning':\r\n            return props.theme.colors.warning500;\r\n        case 'danger':\r\n            return props.theme.colors.danger500;\r\n        default:\r\n            return props.theme.colors.info500;\r\n    }\r\n}\r\nexport function buildLinkColor(props) {\r\n    if (props.isInverse) {\r\n        switch (props.variant) {\r\n            case 'success':\r\n                return props.theme.colors.success200;\r\n            case 'warning':\r\n                return props.theme.colors.warning200;\r\n            case 'danger':\r\n                return props.theme.colors.danger200;\r\n            default:\r\n                return props.theme.colors.info200;\r\n        }\r\n    }\r\n    switch (props.variant) {\r\n        case 'success':\r\n            return props.theme.colors.success700;\r\n        case 'warning':\r\n            return props.theme.colors.warning700;\r\n        case 'danger':\r\n            return props.theme.colors.danger700;\r\n        default:\r\n            return props.theme.colors.info700;\r\n    }\r\n}\r\nexport function buildLinkHoverColor(props) {\r\n    if (props.isInverse) {\r\n        return props.theme.colors.neutral100;\r\n    }\r\n    switch (props.variant) {\r\n        case 'success':\r\n            return props.theme.colors.success;\r\n        case 'warning':\r\n            return props.theme.colors.warning;\r\n        case 'danger':\r\n            return props.theme.colors.danger;\r\n        default:\r\n            return props.theme.colors.info;\r\n    }\r\n}\r\nconst StyledAlert = styled.div `\n  align-items: stretch;\n  animation: ${props => props.isExiting\r\n    ? `fadeout ${transitionDuration}ms`\r\n    : `fadein ${transitionDuration}ms`};\n  display: flex;\n  flex-direction: column;\n  font-size: ${props => props.theme.typeScale.size03.fontSize};\n  font-family: ${props => props.theme.bodyFont};\n  line-height: ${props => props.theme.typeScale.size03.lineHeight};\n  margin-bottom: ${props => props.theme.spaceScale.spacing06};\n  max-width: 100%;\n  padding: 0;\n  position: relative;\n\n  @media (max-width: ${props => props.theme.breakpoints.small}px) {\n    font-size: ${props => props.theme.typeScale.size02.fontSize};\n    letter-spacing: ${props => props.theme.typeScale.size02.letterSpacing};\n    line-height: ${props => props.theme.typeScale.size02.lineHeight};\n  }\n\n  &:focus {\n    outline: 2px solid\n      ${props => props.isInverse\r\n    ? props.theme.colors.focusInverse\r\n    : props.theme.colors.focus};\n  }\n\n  ${props => props.isToast &&\r\n    css `\n      animation: ${props.isExiting\r\n        ? `slideout ${transitionDuration}ms`\r\n        : `slidein ${transitionDuration}ms`};\n      min-width: 375px;\n      margin: 0 auto;\n\n      @media (max-width: ${props.theme.breakpoints.small}px) {\n        min-width: 0;\n        width: 100%;\n      }\n    `}\n\n  @keyframes fadein {\n    from {\n      opacity: 0;\n    }\n    to {\n      opacity: 1;\n    }\n  }\n\n  @keyframes fadeout {\n    from {\n      opacity: 1;\n    }\n    to {\n      opacity: 0;\n    }\n  }\n\n  @keyframes slidein {\n    from {\n      left: -500px;\n    }\n    to {\n      left: 0;\n    }\n  }\n\n  @keyframes slideout {\n    from {\n      left: 0;\n    }\n    to {\n      left: -500px;\n    }\n  }\n\n  a {\n    color: ${props => buildLinkColor(props)};\n    font-weight: 400;\n    text-decoration: underline;\n    &:not([disabled]) {\n      &:focus,\n      &:hover {\n        color: ${props => buildLinkHoverColor(props)};\n      }\n    }\n  }\n`;\r\nconst StyledAlertInner = styled.div `\n  background: ${buildAlertBackground};\n  border: 1px solid ${buildAlertBorder};\n  border-radius: ${props => props.theme.borderRadius};\n  color: ${buildAlertColor};\n  display: flex;\n  position: relative;\n\n  ${props => props.isToast &&\r\n    css `\n      box-shadow: ${props.isInverse\r\n        ? `0 2px 8px 0 ${transparentize(0.3, props.theme.colors.neutral900)}`\r\n        : `0 2px 8px 0 ${transparentize(0.6, props.theme.colors.neutral900)}`};\n      padding-right: 0;\n      height: ${props.theme.spaceScale.spacing11};\n    `}\n`;\r\nconst AlertContents = styled.div `\n  align-items: ${props => (props.additionalContent ? 'center' : '')};\n  align-self: center;\n  flex-grow: 1;\n  font-family: ${props => props.theme.bodyFont};\n  padding: ${props => props.theme.spaceScale.spacing04} 0;\n  display: ${props => (props.additionalContent ? 'flex' : '')};\n  margin-right: ${props => props.additionalContent && !props.isDismissible\r\n    ? props.theme.spaceScale.spacing03\r\n    : ''};\n  @media (max-width: ${props => props.theme.breakpoints.small}px) {\n    padding-left: 0;\n  }\n`;\r\nexport const AdditionalContentWrapper = styled.div `\n  flex: 1 0 auto;\n  justify-content: flex-end;\n  display: flex;\n  margin-left: ${props => props.theme.spaceScale.spacing05};\n`;\r\nconst IconWrapperStyles = css `\n  align-items: center;\n  display: flex;\n  flex-shrink: 0;\n  margin-right: 1px;\n`;\r\nconst IconWrapper = styled.span `\n  ${IconWrapperStyles}\n  padding: 0 ${props => props.theme.spaceScale.spacing03} 0 ${props => props.theme.spaceScale.spacing04};\n\n  @media (max-width: ${props => props.theme.breakpoints.small}px) {\n    padding: 0 ${props => props.theme.spaceScale.spacing03};\n    svg {\n      width: 20px;\n    }\n  }\n`;\r\nconst ProgressRingWrapper = styled.div `\n  margin-top: 6px;\n  position: absolute;\n  top: auto;\n  right: ${props => props.theme.spaceScale.spacing02};\n`;\r\nconst DismissibleIconWrapper = styled.span `\n  ${IconWrapperStyles}\n  margin-left: ${props => props.additionalContent ? props.theme.spaceScale.spacing03 : ''};\n`;\r\nconst whitelistProps = ['icon', 'isInverse', 'theme', 'variant'];\r\nconst shouldForwardProp = prop => {\r\n    return isPropValid(prop) || whitelistProps.includes(prop);\r\n};\r\nconst DismissButton = styled(IconButton, { shouldForwardProp }) `\n  align-self: stretch;\n  border-radius: 0 ${props => props.theme.borderRadius}\n    ${props => props.theme.borderRadius} 0;\n  color: inherit;\n  height: auto;\n  margin: ${props => (props.isToast ? '4px' : '0 -1px 0 0')};\n  padding: ${props => props.isToast\r\n    ? `0 ${props.theme.spaceScale.spacing04}`\r\n    : `0 ${props.theme.spaceScale.spacing03}`};\n  width: auto;\n  &:not(:disabled):hover {\n    background: none;\n    color: inherit;\n  }\n  &:focus:not(:disabled) {\n    background: none;\n    color: inherit;\n    outline: 2px solid\n      ${props => props.isInverse\r\n    ? props.theme.colors.focusInverse\r\n    : props.theme.colors.focus};\n    outline-offset: 0 !important;\n  }\n  &:not(:disabled):active {\n    background: none;\n    color: inherit;\n  }\n`;\r\nconst AlertSpan = styled.span `\n  white-space: pre-line;\n`;\r\nfunction renderIcon(variant = 'info', isToast, theme) {\r\n    const Icon = VARIANT_ICON[variant];\r\n    return (React.createElement(IconWrapper, { isToast: isToast, theme: theme },\r\n        React.createElement(Icon, { size: theme.iconSizes.medium })));\r\n}\r\nexport const AlertBase = React.forwardRef((props, ref) => {\r\n    const { additionalContent, children, closeAriaLabel, forceDismiss, hasTimerRing, id: defaultId, isDismissed, isDismissible, isExiting: externalIsExiting, isPaused, isToast, onDismiss, testId, toastDuration, variant, ...other } = props;\r\n    const id = useGenerateId(defaultId);\r\n    const [isExiting, setIsExiting] = React.useState(false);\r\n    const isInverse = useIsInverse(props.isInverse);\r\n    React.useEffect(() => {\r\n        if (isExiting) {\r\n            setTimeout(() => {\r\n                setIsExiting(false);\r\n                onDismiss && typeof onDismiss === 'function' && onDismiss();\r\n            }, transitionDuration - 300);\r\n        }\r\n    }, [isExiting]);\r\n    React.useEffect(() => {\r\n        if (isDismissed) {\r\n            handleDismiss();\r\n        }\r\n    }, [isDismissed]);\r\n    function handleDismiss() {\r\n        setIsExiting(true);\r\n    }\r\n    const theme = React.useContext(ThemeContext);\r\n    const i18n = React.useContext(I18nContext);\r\n    function progressRingColor() {\r\n        if (isInverse) {\r\n            return theme.colors.neutral100;\r\n        }\r\n        switch (props.variant) {\r\n            case 'success':\r\n                return theme.colors.success500;\r\n            case 'warning':\r\n                return theme.colors.warning500;\r\n            case 'danger':\r\n                return theme.colors.danger500;\r\n            default:\r\n                return theme.colors.info500;\r\n        }\r\n    }\r\n    return (React.createElement(StyledAlert, Object.assign({}, other, { \"data-testid\": testId, id: id, tabIndex: -1, isInverse: isInverse, isExiting: isExiting, isToast: isToast, ref: ref, theme: theme, variant: variant }),\r\n        React.createElement(InverseContext.Provider, { value: { isInverse } },\r\n            React.createElement(StyledAlertInner, { isInverse: isInverse, isToast: isToast, theme: theme, variant: variant },\r\n                renderIcon(variant, isToast, theme),\r\n                React.createElement(AlertContents, { additionalContent: additionalContent, isDismissible: isDismissible, theme: theme },\r\n                    React.createElement(AlertSpan, null, children),\r\n                    additionalContent && (React.createElement(AdditionalContentWrapper, { theme: theme }, additionalContent))),\r\n                isDismissible && (React.createElement(DismissibleIconWrapper, { isInverse: isInverse, variant: variant, theme: theme },\r\n                    hasTimerRing && isToast && (React.createElement(ProgressRingWrapper, { theme: theme },\r\n                        React.createElement(ProgressRing, { color: progressRingColor(), isActive: !isPaused, duration: toastDuration }))),\r\n                    React.createElement(DismissButton, Object.assign({ alertVariant: variant }, (isToast\r\n                        ? { title: closeAriaLabel || i18n.alert.dismissAriaLabel }\r\n                        : {\r\n                            'aria-label': closeAriaLabel || i18n.alert.dismissAriaLabel,\r\n                        }), { icon: React.createElement(CloseIcon, { size: hasTimerRing\r\n                                ? theme.iconSizes.xSmall\r\n                                : theme.iconSizes.small }), isInverse: isInverse, isToast: isToast, onClick: forceDismiss || handleDismiss, theme: theme, variant: ButtonVariant.link }))))))));\r\n});\r\n//# sourceMappingURL=index.js.map"]} */"));
3660
3660
  }, "@keyframes fadein{from{opacity:0;}to{opacity:1;}}@keyframes fadeout{from{opacity:1;}to{opacity:0;}}@keyframes slidein{from{left:-500px;}to{left:0;}}@keyframes slideout{from{left:0;}to{left:-500px;}}a{color:", function (props) {
3661
3661
  return buildLinkColor(props);
3662
3662
  }, ";font-weight:400;text-decoration:underline;&:not([disabled]){&:focus,&:hover{color:", function (props) {
3663
3663
  return buildLinkHoverColor(props);
3664
- }, ";}}}" + (process.env.NODE_ENV === "production" ? "" : "/*# sourceMappingURL=data:application/json;charset=utf-8;base64,{"version":3,"sources":["index.tsx"],"names":[],"mappings":"AAiI+B","file":"index.tsx","sourcesContent":["import * as React from 'react';\r\nimport { css } from '@emotion/react';\r\nimport isPropValid from '@emotion/is-prop-valid';\r\nimport { transparentize } from 'polished';\r\nimport { ThemeContext } from '../../theme/ThemeContext';\r\nimport { InfoIcon, CheckCircleIcon, WarningIcon, ErrorIcon, CloseIcon, } from 'react-magma-icons';\r\nimport { ButtonVariant } from '../Button';\r\nimport { IconButton } from '../IconButton';\r\nimport { ProgressRing } from '../ProgressRing';\r\nimport { useGenerateId } from '../../utils';\r\nimport { I18nContext } from '../../i18n';\r\nimport { InverseContext, useIsInverse } from '../../inverse';\r\nimport styled from '@emotion/styled';\r\nexport const VARIANT_ICON = {\r\n    info: InfoIcon,\r\n    success: CheckCircleIcon,\r\n    warning: WarningIcon,\r\n    danger: ErrorIcon,\r\n};\r\nexport var AlertVariant;\r\n(function (AlertVariant) {\r\n    AlertVariant[\"info\"] = \"info\";\r\n    AlertVariant[\"success\"] = \"success\";\r\n    AlertVariant[\"warning\"] = \"warning\";\r\n    AlertVariant[\"danger\"] = \"danger\";\r\n})(AlertVariant || (AlertVariant = {}));\r\nexport const transitionDuration = 500;\r\nexport function buildAlertBackground(props) {\r\n    if (props.isInverse) {\r\n        switch (props.variant) {\r\n            case 'success':\r\n                return props.theme.colors.success700;\r\n            case 'warning':\r\n                return props.theme.colors.warning700;\r\n            case 'danger':\r\n                return props.theme.colors.danger700;\r\n            default:\r\n                return props.theme.colors.info700;\r\n        }\r\n    }\r\n    switch (props.variant) {\r\n        case 'success':\r\n            return props.theme.colors.success100;\r\n        case 'warning':\r\n            return props.theme.colors.warning100;\r\n        case 'danger':\r\n            return props.theme.colors.danger100;\r\n        default:\r\n            return props.theme.colors.info100;\r\n    }\r\n}\r\nexport function buildAlertBorder(props) {\r\n    if (props.isInverse) {\r\n        switch (props.variant) {\r\n            case 'success':\r\n                return props.theme.colors.success300;\r\n            case 'warning':\r\n                return props.theme.colors.warning300;\r\n            case 'danger':\r\n                return props.theme.colors.danger200;\r\n            default:\r\n                return props.theme.colors.info300;\r\n        }\r\n    }\r\n    switch (props.variant) {\r\n        case 'success':\r\n            return props.theme.colors.success500;\r\n        case 'warning':\r\n            return props.theme.colors.warning500;\r\n        case 'danger':\r\n            return props.theme.colors.danger500;\r\n        default:\r\n            return props.theme.colors.info500;\r\n    }\r\n}\r\nexport function buildAlertColor(props) {\r\n    if (props.isInverse) {\r\n        return props.theme.colors.neutral100;\r\n    }\r\n    switch (props.variant) {\r\n        case 'success':\r\n            return props.theme.colors.success500;\r\n        case 'warning':\r\n            return props.theme.colors.warning500;\r\n        case 'danger':\r\n            return props.theme.colors.danger500;\r\n        default:\r\n            return props.theme.colors.info500;\r\n    }\r\n}\r\nexport function buildLinkColor(props) {\r\n    if (props.isInverse) {\r\n        switch (props.variant) {\r\n            case 'success':\r\n                return props.theme.colors.success200;\r\n            case 'warning':\r\n                return props.theme.colors.warning200;\r\n            case 'danger':\r\n                return props.theme.colors.danger200;\r\n            default:\r\n                return props.theme.colors.info200;\r\n        }\r\n    }\r\n    switch (props.variant) {\r\n        case 'success':\r\n            return props.theme.colors.success700;\r\n        case 'warning':\r\n            return props.theme.colors.warning700;\r\n        case 'danger':\r\n            return props.theme.colors.danger700;\r\n        default:\r\n            return props.theme.colors.info700;\r\n    }\r\n}\r\nexport function buildLinkHoverColor(props) {\r\n    if (props.isInverse) {\r\n        return props.theme.colors.neutral100;\r\n    }\r\n    switch (props.variant) {\r\n        case 'success':\r\n            return props.theme.colors.success;\r\n        case 'warning':\r\n            return props.theme.colors.warning;\r\n        case 'danger':\r\n            return props.theme.colors.danger;\r\n        default:\r\n            return props.theme.colors.info;\r\n    }\r\n}\r\nconst StyledAlert = styled.div `\n  align-items: stretch;\n  animation: ${props => props.isExiting\r\n    ? `fadeout ${transitionDuration}ms`\r\n    : `fadein ${transitionDuration}ms`};\n  display: flex;\n  flex-direction: column;\n  font-size: ${props => props.theme.typeScale.size03.fontSize};\n  font-family: ${props => props.theme.bodyFont};\n  line-height: ${props => props.theme.typeScale.size03.lineHeight};\n  margin-bottom: ${props => props.theme.spaceScale.spacing06};\n  max-width: 100%;\n  padding: 0;\n  position: relative;\n\n  @media (max-width: ${props => props.theme.breakpoints.small}px) {\n    font-size: ${props => props.theme.typeScale.size02.fontSize};\n    letter-spacing: ${props => props.theme.typeScale.size02.letterSpacing};\n    line-height: ${props => props.theme.typeScale.size02.lineHeight};\n  }\n\n  &:focus {\n    outline: 2px solid\n      ${props => props.isInverse\r\n    ? props.theme.colors.focusInverse\r\n    : props.theme.colors.focus};\n  }\n\n  ${props => props.isToast &&\r\n    css `\n      animation: ${props.isExiting\r\n        ? `slideout ${transitionDuration}ms`\r\n        : `slidein ${transitionDuration}ms`};\n      min-width: 375px;\n      margin: 0 auto;\n\n      @media (max-width: ${props.theme.breakpoints.small}px) {\n        min-width: 0;\n        width: 100%;\n      }\n    `}\n\n  @keyframes fadein {\n    from {\n      opacity: 0;\n    }\n    to {\n      opacity: 1;\n    }\n  }\n\n  @keyframes fadeout {\n    from {\n      opacity: 1;\n    }\n    to {\n      opacity: 0;\n    }\n  }\n\n  @keyframes slidein {\n    from {\n      left: -500px;\n    }\n    to {\n      left: 0;\n    }\n  }\n\n  @keyframes slideout {\n    from {\n      left: 0;\n    }\n    to {\n      left: -500px;\n    }\n  }\n\n  a {\n    color: ${props => buildLinkColor(props)};\n    font-weight: 400;\n    text-decoration: underline;\n    &:not([disabled]) {\n      &:focus,\n      &:hover {\n        color: ${props => buildLinkHoverColor(props)};\n      }\n    }\n  }\n`;\r\nconst StyledAlertInner = styled.div `\n  background: ${buildAlertBackground};\n  border: 1px solid ${buildAlertBorder};\n  border-radius: ${props => props.theme.borderRadius};\n  color: ${buildAlertColor};\n  display: flex;\n  position: relative;\n\n  ${props => props.isToast &&\r\n    css `\n      box-shadow: ${props.isInverse\r\n        ? `0 2px 8px 0 ${transparentize(0.3, props.theme.colors.neutral900)}`\r\n        : `0 2px 8px 0 ${transparentize(0.6, props.theme.colors.neutral900)}`};\n      padding-right: 0;\n      height: ${props.theme.spaceScale.spacing11};\n    `}\n`;\r\nconst AlertContents = styled.div `\n  align-items: ${props => (props.additionalContent ? 'center' : '')};\n  align-self: center;\n  flex-grow: 1;\n  font-family: ${props => props.theme.bodyFont};\n  padding: ${props => props.theme.spaceScale.spacing04} 0;\n  display: ${props => (props.additionalContent ? 'flex' : '')};\n  margin-right: ${props => props.additionalContent && !props.isDismissible\r\n    ? props.theme.spaceScale.spacing03\r\n    : ''};\n  @media (max-width: ${props => props.theme.breakpoints.small}px) {\n    padding-left: 0;\n  }\n`;\r\nexport const AdditionalContentWrapper = styled.div `\n  flex: 1 0 auto;\n  justify-content: flex-end;\n  display: flex;\n  margin-left: ${props => props.theme.spaceScale.spacing05};\n`;\r\nconst IconWrapperStyles = css `\n  align-items: center;\n  display: flex;\n  flex-shrink: 0;\n  margin-right: 1px;\n`;\r\nconst IconWrapper = styled.span `\n  ${IconWrapperStyles}\n  padding: 0 ${props => props.theme.spaceScale.spacing03} 0 ${props => props.theme.spaceScale.spacing04};\n\n  @media (max-width: ${props => props.theme.breakpoints.small}px) {\n    padding: 0 ${props => props.theme.spaceScale.spacing03};\n    svg {\n      width: 20px;\n    }\n  }\n`;\r\nconst ProgressRingWrapper = styled.div `\n  margin-top: 6px;\n  position: absolute;\n  top: auto;\n  right: ${props => props.theme.spaceScale.spacing02};\n`;\r\nconst DismissibleIconWrapper = styled.span `\n  ${IconWrapperStyles}\n  margin-left: ${props => props.additionalContent ? props.theme.spaceScale.spacing03 : ''};\n`;\r\nconst whitelistProps = ['icon', 'isInverse', 'theme', 'variant'];\r\nconst shouldForwardProp = prop => {\r\n    return isPropValid(prop) || whitelistProps.includes(prop);\r\n};\r\nconst DismissButton = styled(IconButton, { shouldForwardProp }) `\n  align-self: stretch;\n  border-radius: 0 ${props => props.theme.borderRadius}\n    ${props => props.theme.borderRadius} 0;\n  color: inherit;\n  height: auto;\n  margin: ${props => (props.isToast ? '4px' : '0 -1px 0 0')};\n  padding: ${props => props.isToast\r\n    ? `0 ${props.theme.spaceScale.spacing04}`\r\n    : `0 ${props.theme.spaceScale.spacing03}`};\n  width: auto;\n  &:not(:disabled):hover {\n    background: none;\n    color: inherit;\n  }\n  &:focus:not(:disabled) {\n    background: none;\n    color: inherit;\n    outline: 2px solid\n      ${props => props.isInverse\r\n    ? props.theme.colors.focusInverse\r\n    : props.theme.colors.focus};\n    outline-offset: 0 !important;\n  }\n  &:not(:disabled):active {\n    background: none;\n    color: inherit;\n  }\n`;\r\nconst AlertSpan = styled.span `\n  white-space: pre-line;\n`;\r\nfunction renderIcon(variant = 'info', isToast, theme) {\r\n    const Icon = VARIANT_ICON[variant];\r\n    return (React.createElement(IconWrapper, { isToast: isToast, theme: theme },\r\n        React.createElement(Icon, { size: theme.iconSizes.medium })));\r\n}\r\nexport const AlertBase = React.forwardRef((props, ref) => {\r\n    const { additionalContent, children, closeAriaLabel, forceDismiss, hasTimerRing, id: defaultId, isDismissed, isDismissible, isExiting: externalIsExiting, isPaused, isToast, onDismiss, testId, toastDuration, variant, ...other } = props;\r\n    const id = useGenerateId(defaultId);\r\n    const [isExiting, setIsExiting] = React.useState(false);\r\n    const isInverse = useIsInverse(props.isInverse);\r\n    React.useEffect(() => {\r\n        if (isExiting) {\r\n            setTimeout(() => {\r\n                setIsExiting(false);\r\n                onDismiss && typeof onDismiss === 'function' && onDismiss();\r\n            }, transitionDuration - 300);\r\n        }\r\n    }, [isExiting]);\r\n    React.useEffect(() => {\r\n        if (isDismissed) {\r\n            handleDismiss();\r\n        }\r\n    }, [isDismissed]);\r\n    function handleDismiss() {\r\n        setIsExiting(true);\r\n    }\r\n    const theme = React.useContext(ThemeContext);\r\n    const i18n = React.useContext(I18nContext);\r\n    function progressRingColor() {\r\n        if (isInverse) {\r\n            return theme.colors.neutral100;\r\n        }\r\n        switch (props.variant) {\r\n            case 'success':\r\n                return theme.colors.success500;\r\n            case 'warning':\r\n                return theme.colors.warning500;\r\n            case 'danger':\r\n                return theme.colors.danger500;\r\n            default:\r\n                return theme.colors.info500;\r\n        }\r\n    }\r\n    return (React.createElement(StyledAlert, Object.assign({}, other, { \"data-testid\": testId, id: id, tabIndex: -1, isInverse: isInverse, isExiting: isExiting, isToast: isToast, ref: ref, theme: theme, variant: variant }),\r\n        React.createElement(InverseContext.Provider, { value: { isInverse } },\r\n            React.createElement(StyledAlertInner, { isInverse: isInverse, isToast: isToast, theme: theme, variant: variant },\r\n                renderIcon(variant, isToast, theme),\r\n                React.createElement(AlertContents, { additionalContent: additionalContent, isDismissible: isDismissible, theme: theme },\r\n                    React.createElement(AlertSpan, null, children),\r\n                    additionalContent && (React.createElement(AdditionalContentWrapper, { theme: theme }, additionalContent))),\r\n                isDismissible && (React.createElement(DismissibleIconWrapper, { isInverse: isInverse, variant: variant, theme: theme },\r\n                    hasTimerRing && isToast && (React.createElement(ProgressRingWrapper, { theme: theme },\r\n                        React.createElement(ProgressRing, { color: progressRingColor(), isActive: !isPaused, duration: toastDuration }))),\r\n                    React.createElement(DismissButton, { alertVariant: variant, \"aria-label\": closeAriaLabel\r\n                            ? closeAriaLabel\r\n                            : i18n.alert.dismissAriaLabel, icon: React.createElement(CloseIcon, { size: hasTimerRing\r\n                                ? theme.iconSizes.xSmall\r\n                                : theme.iconSizes.small }), isInverse: isInverse, isToast: isToast, onClick: forceDismiss || handleDismiss, theme: theme, variant: ButtonVariant.link })))))));\r\n});\r\n//# sourceMappingURL=index.js.map"]} */"));
3664
+ }, ";}}}" + (process.env.NODE_ENV === "production" ? "" : "/*# sourceMappingURL=data:application/json;charset=utf-8;base64,{"version":3,"sources":["index.tsx"],"names":[],"mappings":"AAiI+B","file":"index.tsx","sourcesContent":["import * as React from 'react';\r\nimport { css } from '@emotion/react';\r\nimport isPropValid from '@emotion/is-prop-valid';\r\nimport { transparentize } from 'polished';\r\nimport { ThemeContext } from '../../theme/ThemeContext';\r\nimport { InfoIcon, CheckCircleIcon, WarningIcon, ErrorIcon, CloseIcon, } from 'react-magma-icons';\r\nimport { ButtonVariant } from '../Button';\r\nimport { IconButton } from '../IconButton';\r\nimport { ProgressRing } from '../ProgressRing';\r\nimport { useGenerateId } from '../../utils';\r\nimport { I18nContext } from '../../i18n';\r\nimport { InverseContext, useIsInverse } from '../../inverse';\r\nimport styled from '@emotion/styled';\r\nexport const VARIANT_ICON = {\r\n    info: InfoIcon,\r\n    success: CheckCircleIcon,\r\n    warning: WarningIcon,\r\n    danger: ErrorIcon,\r\n};\r\nexport var AlertVariant;\r\n(function (AlertVariant) {\r\n    AlertVariant[\"info\"] = \"info\";\r\n    AlertVariant[\"success\"] = \"success\";\r\n    AlertVariant[\"warning\"] = \"warning\";\r\n    AlertVariant[\"danger\"] = \"danger\";\r\n})(AlertVariant || (AlertVariant = {}));\r\nexport const transitionDuration = 500;\r\nexport function buildAlertBackground(props) {\r\n    if (props.isInverse) {\r\n        switch (props.variant) {\r\n            case 'success':\r\n                return props.theme.colors.success700;\r\n            case 'warning':\r\n                return props.theme.colors.warning700;\r\n            case 'danger':\r\n                return props.theme.colors.danger700;\r\n            default:\r\n                return props.theme.colors.info700;\r\n        }\r\n    }\r\n    switch (props.variant) {\r\n        case 'success':\r\n            return props.theme.colors.success100;\r\n        case 'warning':\r\n            return props.theme.colors.warning100;\r\n        case 'danger':\r\n            return props.theme.colors.danger100;\r\n        default:\r\n            return props.theme.colors.info100;\r\n    }\r\n}\r\nexport function buildAlertBorder(props) {\r\n    if (props.isInverse) {\r\n        switch (props.variant) {\r\n            case 'success':\r\n                return props.theme.colors.success300;\r\n            case 'warning':\r\n                return props.theme.colors.warning300;\r\n            case 'danger':\r\n                return props.theme.colors.danger200;\r\n            default:\r\n                return props.theme.colors.info300;\r\n        }\r\n    }\r\n    switch (props.variant) {\r\n        case 'success':\r\n            return props.theme.colors.success500;\r\n        case 'warning':\r\n            return props.theme.colors.warning500;\r\n        case 'danger':\r\n            return props.theme.colors.danger500;\r\n        default:\r\n            return props.theme.colors.info500;\r\n    }\r\n}\r\nexport function buildAlertColor(props) {\r\n    if (props.isInverse) {\r\n        return props.theme.colors.neutral100;\r\n    }\r\n    switch (props.variant) {\r\n        case 'success':\r\n            return props.theme.colors.success500;\r\n        case 'warning':\r\n            return props.theme.colors.warning500;\r\n        case 'danger':\r\n            return props.theme.colors.danger500;\r\n        default:\r\n            return props.theme.colors.info500;\r\n    }\r\n}\r\nexport function buildLinkColor(props) {\r\n    if (props.isInverse) {\r\n        switch (props.variant) {\r\n            case 'success':\r\n                return props.theme.colors.success200;\r\n            case 'warning':\r\n                return props.theme.colors.warning200;\r\n            case 'danger':\r\n                return props.theme.colors.danger200;\r\n            default:\r\n                return props.theme.colors.info200;\r\n        }\r\n    }\r\n    switch (props.variant) {\r\n        case 'success':\r\n            return props.theme.colors.success700;\r\n        case 'warning':\r\n            return props.theme.colors.warning700;\r\n        case 'danger':\r\n            return props.theme.colors.danger700;\r\n        default:\r\n            return props.theme.colors.info700;\r\n    }\r\n}\r\nexport function buildLinkHoverColor(props) {\r\n    if (props.isInverse) {\r\n        return props.theme.colors.neutral100;\r\n    }\r\n    switch (props.variant) {\r\n        case 'success':\r\n            return props.theme.colors.success;\r\n        case 'warning':\r\n            return props.theme.colors.warning;\r\n        case 'danger':\r\n            return props.theme.colors.danger;\r\n        default:\r\n            return props.theme.colors.info;\r\n    }\r\n}\r\nconst StyledAlert = styled.div `\n  align-items: stretch;\n  animation: ${props => props.isExiting\r\n    ? `fadeout ${transitionDuration}ms`\r\n    : `fadein ${transitionDuration}ms`};\n  display: flex;\n  flex-direction: column;\n  font-size: ${props => props.theme.typeScale.size03.fontSize};\n  font-family: ${props => props.theme.bodyFont};\n  line-height: ${props => props.theme.typeScale.size03.lineHeight};\n  margin-bottom: ${props => props.theme.spaceScale.spacing06};\n  max-width: 100%;\n  padding: 0;\n  position: relative;\n\n  @media (max-width: ${props => props.theme.breakpoints.small}px) {\n    font-size: ${props => props.theme.typeScale.size02.fontSize};\n    letter-spacing: ${props => props.theme.typeScale.size02.letterSpacing};\n    line-height: ${props => props.theme.typeScale.size02.lineHeight};\n  }\n\n  &:focus {\n    outline: 2px solid\n      ${props => props.isInverse\r\n    ? props.theme.colors.focusInverse\r\n    : props.theme.colors.focus};\n  }\n\n  ${props => props.isToast &&\r\n    css `\n      animation: ${props.isExiting\r\n        ? `slideout ${transitionDuration}ms`\r\n        : `slidein ${transitionDuration}ms`};\n      min-width: 375px;\n      margin: 0 auto;\n\n      @media (max-width: ${props.theme.breakpoints.small}px) {\n        min-width: 0;\n        width: 100%;\n      }\n    `}\n\n  @keyframes fadein {\n    from {\n      opacity: 0;\n    }\n    to {\n      opacity: 1;\n    }\n  }\n\n  @keyframes fadeout {\n    from {\n      opacity: 1;\n    }\n    to {\n      opacity: 0;\n    }\n  }\n\n  @keyframes slidein {\n    from {\n      left: -500px;\n    }\n    to {\n      left: 0;\n    }\n  }\n\n  @keyframes slideout {\n    from {\n      left: 0;\n    }\n    to {\n      left: -500px;\n    }\n  }\n\n  a {\n    color: ${props => buildLinkColor(props)};\n    font-weight: 400;\n    text-decoration: underline;\n    &:not([disabled]) {\n      &:focus,\n      &:hover {\n        color: ${props => buildLinkHoverColor(props)};\n      }\n    }\n  }\n`;\r\nconst StyledAlertInner = styled.div `\n  background: ${buildAlertBackground};\n  border: 1px solid ${buildAlertBorder};\n  border-radius: ${props => props.theme.borderRadius};\n  color: ${buildAlertColor};\n  display: flex;\n  position: relative;\n\n  ${props => props.isToast &&\r\n    css `\n      box-shadow: ${props.isInverse\r\n        ? `0 2px 8px 0 ${transparentize(0.3, props.theme.colors.neutral900)}`\r\n        : `0 2px 8px 0 ${transparentize(0.6, props.theme.colors.neutral900)}`};\n      padding-right: 0;\n      height: ${props.theme.spaceScale.spacing11};\n    `}\n`;\r\nconst AlertContents = styled.div `\n  align-items: ${props => (props.additionalContent ? 'center' : '')};\n  align-self: center;\n  flex-grow: 1;\n  font-family: ${props => props.theme.bodyFont};\n  padding: ${props => props.theme.spaceScale.spacing04} 0;\n  display: ${props => (props.additionalContent ? 'flex' : '')};\n  margin-right: ${props => props.additionalContent && !props.isDismissible\r\n    ? props.theme.spaceScale.spacing03\r\n    : ''};\n  @media (max-width: ${props => props.theme.breakpoints.small}px) {\n    padding-left: 0;\n  }\n`;\r\nexport const AdditionalContentWrapper = styled.div `\n  flex: 1 0 auto;\n  justify-content: flex-end;\n  display: flex;\n  margin-left: ${props => props.theme.spaceScale.spacing05};\n`;\r\nconst IconWrapperStyles = css `\n  align-items: center;\n  display: flex;\n  flex-shrink: 0;\n  margin-right: 1px;\n`;\r\nconst IconWrapper = styled.span `\n  ${IconWrapperStyles}\n  padding: 0 ${props => props.theme.spaceScale.spacing03} 0 ${props => props.theme.spaceScale.spacing04};\n\n  @media (max-width: ${props => props.theme.breakpoints.small}px) {\n    padding: 0 ${props => props.theme.spaceScale.spacing03};\n    svg {\n      width: 20px;\n    }\n  }\n`;\r\nconst ProgressRingWrapper = styled.div `\n  margin-top: 6px;\n  position: absolute;\n  top: auto;\n  right: ${props => props.theme.spaceScale.spacing02};\n`;\r\nconst DismissibleIconWrapper = styled.span `\n  ${IconWrapperStyles}\n  margin-left: ${props => props.additionalContent ? props.theme.spaceScale.spacing03 : ''};\n`;\r\nconst whitelistProps = ['icon', 'isInverse', 'theme', 'variant'];\r\nconst shouldForwardProp = prop => {\r\n    return isPropValid(prop) || whitelistProps.includes(prop);\r\n};\r\nconst DismissButton = styled(IconButton, { shouldForwardProp }) `\n  align-self: stretch;\n  border-radius: 0 ${props => props.theme.borderRadius}\n    ${props => props.theme.borderRadius} 0;\n  color: inherit;\n  height: auto;\n  margin: ${props => (props.isToast ? '4px' : '0 -1px 0 0')};\n  padding: ${props => props.isToast\r\n    ? `0 ${props.theme.spaceScale.spacing04}`\r\n    : `0 ${props.theme.spaceScale.spacing03}`};\n  width: auto;\n  &:not(:disabled):hover {\n    background: none;\n    color: inherit;\n  }\n  &:focus:not(:disabled) {\n    background: none;\n    color: inherit;\n    outline: 2px solid\n      ${props => props.isInverse\r\n    ? props.theme.colors.focusInverse\r\n    : props.theme.colors.focus};\n    outline-offset: 0 !important;\n  }\n  &:not(:disabled):active {\n    background: none;\n    color: inherit;\n  }\n`;\r\nconst AlertSpan = styled.span `\n  white-space: pre-line;\n`;\r\nfunction renderIcon(variant = 'info', isToast, theme) {\r\n    const Icon = VARIANT_ICON[variant];\r\n    return (React.createElement(IconWrapper, { isToast: isToast, theme: theme },\r\n        React.createElement(Icon, { size: theme.iconSizes.medium })));\r\n}\r\nexport const AlertBase = React.forwardRef((props, ref) => {\r\n    const { additionalContent, children, closeAriaLabel, forceDismiss, hasTimerRing, id: defaultId, isDismissed, isDismissible, isExiting: externalIsExiting, isPaused, isToast, onDismiss, testId, toastDuration, variant, ...other } = props;\r\n    const id = useGenerateId(defaultId);\r\n    const [isExiting, setIsExiting] = React.useState(false);\r\n    const isInverse = useIsInverse(props.isInverse);\r\n    React.useEffect(() => {\r\n        if (isExiting) {\r\n            setTimeout(() => {\r\n                setIsExiting(false);\r\n                onDismiss && typeof onDismiss === 'function' && onDismiss();\r\n            }, transitionDuration - 300);\r\n        }\r\n    }, [isExiting]);\r\n    React.useEffect(() => {\r\n        if (isDismissed) {\r\n            handleDismiss();\r\n        }\r\n    }, [isDismissed]);\r\n    function handleDismiss() {\r\n        setIsExiting(true);\r\n    }\r\n    const theme = React.useContext(ThemeContext);\r\n    const i18n = React.useContext(I18nContext);\r\n    function progressRingColor() {\r\n        if (isInverse) {\r\n            return theme.colors.neutral100;\r\n        }\r\n        switch (props.variant) {\r\n            case 'success':\r\n                return theme.colors.success500;\r\n            case 'warning':\r\n                return theme.colors.warning500;\r\n            case 'danger':\r\n                return theme.colors.danger500;\r\n            default:\r\n                return theme.colors.info500;\r\n        }\r\n    }\r\n    return (React.createElement(StyledAlert, Object.assign({}, other, { \"data-testid\": testId, id: id, tabIndex: -1, isInverse: isInverse, isExiting: isExiting, isToast: isToast, ref: ref, theme: theme, variant: variant }),\r\n        React.createElement(InverseContext.Provider, { value: { isInverse } },\r\n            React.createElement(StyledAlertInner, { isInverse: isInverse, isToast: isToast, theme: theme, variant: variant },\r\n                renderIcon(variant, isToast, theme),\r\n                React.createElement(AlertContents, { additionalContent: additionalContent, isDismissible: isDismissible, theme: theme },\r\n                    React.createElement(AlertSpan, null, children),\r\n                    additionalContent && (React.createElement(AdditionalContentWrapper, { theme: theme }, additionalContent))),\r\n                isDismissible && (React.createElement(DismissibleIconWrapper, { isInverse: isInverse, variant: variant, theme: theme },\r\n                    hasTimerRing && isToast && (React.createElement(ProgressRingWrapper, { theme: theme },\r\n                        React.createElement(ProgressRing, { color: progressRingColor(), isActive: !isPaused, duration: toastDuration }))),\r\n                    React.createElement(DismissButton, Object.assign({ alertVariant: variant }, (isToast\r\n                        ? { title: closeAriaLabel || i18n.alert.dismissAriaLabel }\r\n                        : {\r\n                            'aria-label': closeAriaLabel || i18n.alert.dismissAriaLabel,\r\n                        }), { icon: React.createElement(CloseIcon, { size: hasTimerRing\r\n                                ? theme.iconSizes.xSmall\r\n                                : theme.iconSizes.small }), isInverse: isInverse, isToast: isToast, onClick: forceDismiss || handleDismiss, theme: theme, variant: ButtonVariant.link }))))))));\r\n});\r\n//# sourceMappingURL=index.js.map"]} */"));
3665
3665
  var StyledAlertInner = /*#__PURE__*/_styled("div", {
3666
3666
  target: "e126n3g87",
3667
3667
  label: "StyledAlertInner"
3668
3668
  })("background:", buildAlertBackground, ";border:1px solid ", buildAlertBorder, ";border-radius:", function (props) {
3669
3669
  return props.theme.borderRadius;
3670
3670
  }, ";color:", buildAlertColor, ";display:flex;position:relative;", function (props) {
3671
- return props.isToast && /*#__PURE__*/css("box-shadow:", props.isInverse ? "0 2px 8px 0 " + curriedTransparentize(0.3, props.theme.colors.neutral900) : "0 2px 8px 0 " + curriedTransparentize(0.6, props.theme.colors.neutral900), ";padding-right:0;height:", props.theme.spaceScale.spacing11, ";;label:StyledAlertInner;" + (process.env.NODE_ENV === "production" ? "" : "/*# sourceMappingURL=data:application/json;charset=utf-8;base64,{"version":3,"sources":["index.tsx"],"names":[],"mappings":"AAoOQ","file":"index.tsx","sourcesContent":["import * as React from 'react';\r\nimport { css } from '@emotion/react';\r\nimport isPropValid from '@emotion/is-prop-valid';\r\nimport { transparentize } from 'polished';\r\nimport { ThemeContext } from '../../theme/ThemeContext';\r\nimport { InfoIcon, CheckCircleIcon, WarningIcon, ErrorIcon, CloseIcon, } from 'react-magma-icons';\r\nimport { ButtonVariant } from '../Button';\r\nimport { IconButton } from '../IconButton';\r\nimport { ProgressRing } from '../ProgressRing';\r\nimport { useGenerateId } from '../../utils';\r\nimport { I18nContext } from '../../i18n';\r\nimport { InverseContext, useIsInverse } from '../../inverse';\r\nimport styled from '@emotion/styled';\r\nexport const VARIANT_ICON = {\r\n    info: InfoIcon,\r\n    success: CheckCircleIcon,\r\n    warning: WarningIcon,\r\n    danger: ErrorIcon,\r\n};\r\nexport var AlertVariant;\r\n(function (AlertVariant) {\r\n    AlertVariant[\"info\"] = \"info\";\r\n    AlertVariant[\"success\"] = \"success\";\r\n    AlertVariant[\"warning\"] = \"warning\";\r\n    AlertVariant[\"danger\"] = \"danger\";\r\n})(AlertVariant || (AlertVariant = {}));\r\nexport const transitionDuration = 500;\r\nexport function buildAlertBackground(props) {\r\n    if (props.isInverse) {\r\n        switch (props.variant) {\r\n            case 'success':\r\n                return props.theme.colors.success700;\r\n            case 'warning':\r\n                return props.theme.colors.warning700;\r\n            case 'danger':\r\n                return props.theme.colors.danger700;\r\n            default:\r\n                return props.theme.colors.info700;\r\n        }\r\n    }\r\n    switch (props.variant) {\r\n        case 'success':\r\n            return props.theme.colors.success100;\r\n        case 'warning':\r\n            return props.theme.colors.warning100;\r\n        case 'danger':\r\n            return props.theme.colors.danger100;\r\n        default:\r\n            return props.theme.colors.info100;\r\n    }\r\n}\r\nexport function buildAlertBorder(props) {\r\n    if (props.isInverse) {\r\n        switch (props.variant) {\r\n            case 'success':\r\n                return props.theme.colors.success300;\r\n            case 'warning':\r\n                return props.theme.colors.warning300;\r\n            case 'danger':\r\n                return props.theme.colors.danger200;\r\n            default:\r\n                return props.theme.colors.info300;\r\n        }\r\n    }\r\n    switch (props.variant) {\r\n        case 'success':\r\n            return props.theme.colors.success500;\r\n        case 'warning':\r\n            return props.theme.colors.warning500;\r\n        case 'danger':\r\n            return props.theme.colors.danger500;\r\n        default:\r\n            return props.theme.colors.info500;\r\n    }\r\n}\r\nexport function buildAlertColor(props) {\r\n    if (props.isInverse) {\r\n        return props.theme.colors.neutral100;\r\n    }\r\n    switch (props.variant) {\r\n        case 'success':\r\n            return props.theme.colors.success500;\r\n        case 'warning':\r\n            return props.theme.colors.warning500;\r\n        case 'danger':\r\n            return props.theme.colors.danger500;\r\n        default:\r\n            return props.theme.colors.info500;\r\n    }\r\n}\r\nexport function buildLinkColor(props) {\r\n    if (props.isInverse) {\r\n        switch (props.variant) {\r\n            case 'success':\r\n                return props.theme.colors.success200;\r\n            case 'warning':\r\n                return props.theme.colors.warning200;\r\n            case 'danger':\r\n                return props.theme.colors.danger200;\r\n            default:\r\n                return props.theme.colors.info200;\r\n        }\r\n    }\r\n    switch (props.variant) {\r\n        case 'success':\r\n            return props.theme.colors.success700;\r\n        case 'warning':\r\n            return props.theme.colors.warning700;\r\n        case 'danger':\r\n            return props.theme.colors.danger700;\r\n        default:\r\n            return props.theme.colors.info700;\r\n    }\r\n}\r\nexport function buildLinkHoverColor(props) {\r\n    if (props.isInverse) {\r\n        return props.theme.colors.neutral100;\r\n    }\r\n    switch (props.variant) {\r\n        case 'success':\r\n            return props.theme.colors.success;\r\n        case 'warning':\r\n            return props.theme.colors.warning;\r\n        case 'danger':\r\n            return props.theme.colors.danger;\r\n        default:\r\n            return props.theme.colors.info;\r\n    }\r\n}\r\nconst StyledAlert = styled.div `\n  align-items: stretch;\n  animation: ${props => props.isExiting\r\n    ? `fadeout ${transitionDuration}ms`\r\n    : `fadein ${transitionDuration}ms`};\n  display: flex;\n  flex-direction: column;\n  font-size: ${props => props.theme.typeScale.size03.fontSize};\n  font-family: ${props => props.theme.bodyFont};\n  line-height: ${props => props.theme.typeScale.size03.lineHeight};\n  margin-bottom: ${props => props.theme.spaceScale.spacing06};\n  max-width: 100%;\n  padding: 0;\n  position: relative;\n\n  @media (max-width: ${props => props.theme.breakpoints.small}px) {\n    font-size: ${props => props.theme.typeScale.size02.fontSize};\n    letter-spacing: ${props => props.theme.typeScale.size02.letterSpacing};\n    line-height: ${props => props.theme.typeScale.size02.lineHeight};\n  }\n\n  &:focus {\n    outline: 2px solid\n      ${props => props.isInverse\r\n    ? props.theme.colors.focusInverse\r\n    : props.theme.colors.focus};\n  }\n\n  ${props => props.isToast &&\r\n    css `\n      animation: ${props.isExiting\r\n        ? `slideout ${transitionDuration}ms`\r\n        : `slidein ${transitionDuration}ms`};\n      min-width: 375px;\n      margin: 0 auto;\n\n      @media (max-width: ${props.theme.breakpoints.small}px) {\n        min-width: 0;\n        width: 100%;\n      }\n    `}\n\n  @keyframes fadein {\n    from {\n      opacity: 0;\n    }\n    to {\n      opacity: 1;\n    }\n  }\n\n  @keyframes fadeout {\n    from {\n      opacity: 1;\n    }\n    to {\n      opacity: 0;\n    }\n  }\n\n  @keyframes slidein {\n    from {\n      left: -500px;\n    }\n    to {\n      left: 0;\n    }\n  }\n\n  @keyframes slideout {\n    from {\n      left: 0;\n    }\n    to {\n      left: -500px;\n    }\n  }\n\n  a {\n    color: ${props => buildLinkColor(props)};\n    font-weight: 400;\n    text-decoration: underline;\n    &:not([disabled]) {\n      &:focus,\n      &:hover {\n        color: ${props => buildLinkHoverColor(props)};\n      }\n    }\n  }\n`;\r\nconst StyledAlertInner = styled.div `\n  background: ${buildAlertBackground};\n  border: 1px solid ${buildAlertBorder};\n  border-radius: ${props => props.theme.borderRadius};\n  color: ${buildAlertColor};\n  display: flex;\n  position: relative;\n\n  ${props => props.isToast &&\r\n    css `\n      box-shadow: ${props.isInverse\r\n        ? `0 2px 8px 0 ${transparentize(0.3, props.theme.colors.neutral900)}`\r\n        : `0 2px 8px 0 ${transparentize(0.6, props.theme.colors.neutral900)}`};\n      padding-right: 0;\n      height: ${props.theme.spaceScale.spacing11};\n    `}\n`;\r\nconst AlertContents = styled.div `\n  align-items: ${props => (props.additionalContent ? 'center' : '')};\n  align-self: center;\n  flex-grow: 1;\n  font-family: ${props => props.theme.bodyFont};\n  padding: ${props => props.theme.spaceScale.spacing04} 0;\n  display: ${props => (props.additionalContent ? 'flex' : '')};\n  margin-right: ${props => props.additionalContent && !props.isDismissible\r\n    ? props.theme.spaceScale.spacing03\r\n    : ''};\n  @media (max-width: ${props => props.theme.breakpoints.small}px) {\n    padding-left: 0;\n  }\n`;\r\nexport const AdditionalContentWrapper = styled.div `\n  flex: 1 0 auto;\n  justify-content: flex-end;\n  display: flex;\n  margin-left: ${props => props.theme.spaceScale.spacing05};\n`;\r\nconst IconWrapperStyles = css `\n  align-items: center;\n  display: flex;\n  flex-shrink: 0;\n  margin-right: 1px;\n`;\r\nconst IconWrapper = styled.span `\n  ${IconWrapperStyles}\n  padding: 0 ${props => props.theme.spaceScale.spacing03} 0 ${props => props.theme.spaceScale.spacing04};\n\n  @media (max-width: ${props => props.theme.breakpoints.small}px) {\n    padding: 0 ${props => props.theme.spaceScale.spacing03};\n    svg {\n      width: 20px;\n    }\n  }\n`;\r\nconst ProgressRingWrapper = styled.div `\n  margin-top: 6px;\n  position: absolute;\n  top: auto;\n  right: ${props => props.theme.spaceScale.spacing02};\n`;\r\nconst DismissibleIconWrapper = styled.span `\n  ${IconWrapperStyles}\n  margin-left: ${props => props.additionalContent ? props.theme.spaceScale.spacing03 : ''};\n`;\r\nconst whitelistProps = ['icon', 'isInverse', 'theme', 'variant'];\r\nconst shouldForwardProp = prop => {\r\n    return isPropValid(prop) || whitelistProps.includes(prop);\r\n};\r\nconst DismissButton = styled(IconButton, { shouldForwardProp }) `\n  align-self: stretch;\n  border-radius: 0 ${props => props.theme.borderRadius}\n    ${props => props.theme.borderRadius} 0;\n  color: inherit;\n  height: auto;\n  margin: ${props => (props.isToast ? '4px' : '0 -1px 0 0')};\n  padding: ${props => props.isToast\r\n    ? `0 ${props.theme.spaceScale.spacing04}`\r\n    : `0 ${props.theme.spaceScale.spacing03}`};\n  width: auto;\n  &:not(:disabled):hover {\n    background: none;\n    color: inherit;\n  }\n  &:focus:not(:disabled) {\n    background: none;\n    color: inherit;\n    outline: 2px solid\n      ${props => props.isInverse\r\n    ? props.theme.colors.focusInverse\r\n    : props.theme.colors.focus};\n    outline-offset: 0 !important;\n  }\n  &:not(:disabled):active {\n    background: none;\n    color: inherit;\n  }\n`;\r\nconst AlertSpan = styled.span `\n  white-space: pre-line;\n`;\r\nfunction renderIcon(variant = 'info', isToast, theme) {\r\n    const Icon = VARIANT_ICON[variant];\r\n    return (React.createElement(IconWrapper, { isToast: isToast, theme: theme },\r\n        React.createElement(Icon, { size: theme.iconSizes.medium })));\r\n}\r\nexport const AlertBase = React.forwardRef((props, ref) => {\r\n    const { additionalContent, children, closeAriaLabel, forceDismiss, hasTimerRing, id: defaultId, isDismissed, isDismissible, isExiting: externalIsExiting, isPaused, isToast, onDismiss, testId, toastDuration, variant, ...other } = props;\r\n    const id = useGenerateId(defaultId);\r\n    const [isExiting, setIsExiting] = React.useState(false);\r\n    const isInverse = useIsInverse(props.isInverse);\r\n    React.useEffect(() => {\r\n        if (isExiting) {\r\n            setTimeout(() => {\r\n                setIsExiting(false);\r\n                onDismiss && typeof onDismiss === 'function' && onDismiss();\r\n            }, transitionDuration - 300);\r\n        }\r\n    }, [isExiting]);\r\n    React.useEffect(() => {\r\n        if (isDismissed) {\r\n            handleDismiss();\r\n        }\r\n    }, [isDismissed]);\r\n    function handleDismiss() {\r\n        setIsExiting(true);\r\n    }\r\n    const theme = React.useContext(ThemeContext);\r\n    const i18n = React.useContext(I18nContext);\r\n    function progressRingColor() {\r\n        if (isInverse) {\r\n            return theme.colors.neutral100;\r\n        }\r\n        switch (props.variant) {\r\n            case 'success':\r\n                return theme.colors.success500;\r\n            case 'warning':\r\n                return theme.colors.warning500;\r\n            case 'danger':\r\n                return theme.colors.danger500;\r\n            default:\r\n                return theme.colors.info500;\r\n        }\r\n    }\r\n    return (React.createElement(StyledAlert, Object.assign({}, other, { \"data-testid\": testId, id: id, tabIndex: -1, isInverse: isInverse, isExiting: isExiting, isToast: isToast, ref: ref, theme: theme, variant: variant }),\r\n        React.createElement(InverseContext.Provider, { value: { isInverse } },\r\n            React.createElement(StyledAlertInner, { isInverse: isInverse, isToast: isToast, theme: theme, variant: variant },\r\n                renderIcon(variant, isToast, theme),\r\n                React.createElement(AlertContents, { additionalContent: additionalContent, isDismissible: isDismissible, theme: theme },\r\n                    React.createElement(AlertSpan, null, children),\r\n                    additionalContent && (React.createElement(AdditionalContentWrapper, { theme: theme }, additionalContent))),\r\n                isDismissible && (React.createElement(DismissibleIconWrapper, { isInverse: isInverse, variant: variant, theme: theme },\r\n                    hasTimerRing && isToast && (React.createElement(ProgressRingWrapper, { theme: theme },\r\n                        React.createElement(ProgressRing, { color: progressRingColor(), isActive: !isPaused, duration: toastDuration }))),\r\n                    React.createElement(DismissButton, { alertVariant: variant, \"aria-label\": closeAriaLabel\r\n                            ? closeAriaLabel\r\n                            : i18n.alert.dismissAriaLabel, icon: React.createElement(CloseIcon, { size: hasTimerRing\r\n                                ? theme.iconSizes.xSmall\r\n                                : theme.iconSizes.small }), isInverse: isInverse, isToast: isToast, onClick: forceDismiss || handleDismiss, theme: theme, variant: ButtonVariant.link })))))));\r\n});\r\n//# sourceMappingURL=index.js.map"]} */"));
3672
- }, ";" + (process.env.NODE_ENV === "production" ? "" : "/*# sourceMappingURL=data:application/json;charset=utf-8;base64,{"version":3,"sources":["index.tsx"],"names":[],"mappings":"AA2NoC","file":"index.tsx","sourcesContent":["import * as React from 'react';\r\nimport { css } from '@emotion/react';\r\nimport isPropValid from '@emotion/is-prop-valid';\r\nimport { transparentize } from 'polished';\r\nimport { ThemeContext } from '../../theme/ThemeContext';\r\nimport { InfoIcon, CheckCircleIcon, WarningIcon, ErrorIcon, CloseIcon, } from 'react-magma-icons';\r\nimport { ButtonVariant } from '../Button';\r\nimport { IconButton } from '../IconButton';\r\nimport { ProgressRing } from '../ProgressRing';\r\nimport { useGenerateId } from '../../utils';\r\nimport { I18nContext } from '../../i18n';\r\nimport { InverseContext, useIsInverse } from '../../inverse';\r\nimport styled from '@emotion/styled';\r\nexport const VARIANT_ICON = {\r\n    info: InfoIcon,\r\n    success: CheckCircleIcon,\r\n    warning: WarningIcon,\r\n    danger: ErrorIcon,\r\n};\r\nexport var AlertVariant;\r\n(function (AlertVariant) {\r\n    AlertVariant[\"info\"] = \"info\";\r\n    AlertVariant[\"success\"] = \"success\";\r\n    AlertVariant[\"warning\"] = \"warning\";\r\n    AlertVariant[\"danger\"] = \"danger\";\r\n})(AlertVariant || (AlertVariant = {}));\r\nexport const transitionDuration = 500;\r\nexport function buildAlertBackground(props) {\r\n    if (props.isInverse) {\r\n        switch (props.variant) {\r\n            case 'success':\r\n                return props.theme.colors.success700;\r\n            case 'warning':\r\n                return props.theme.colors.warning700;\r\n            case 'danger':\r\n                return props.theme.colors.danger700;\r\n            default:\r\n                return props.theme.colors.info700;\r\n        }\r\n    }\r\n    switch (props.variant) {\r\n        case 'success':\r\n            return props.theme.colors.success100;\r\n        case 'warning':\r\n            return props.theme.colors.warning100;\r\n        case 'danger':\r\n            return props.theme.colors.danger100;\r\n        default:\r\n            return props.theme.colors.info100;\r\n    }\r\n}\r\nexport function buildAlertBorder(props) {\r\n    if (props.isInverse) {\r\n        switch (props.variant) {\r\n            case 'success':\r\n                return props.theme.colors.success300;\r\n            case 'warning':\r\n                return props.theme.colors.warning300;\r\n            case 'danger':\r\n                return props.theme.colors.danger200;\r\n            default:\r\n                return props.theme.colors.info300;\r\n        }\r\n    }\r\n    switch (props.variant) {\r\n        case 'success':\r\n            return props.theme.colors.success500;\r\n        case 'warning':\r\n            return props.theme.colors.warning500;\r\n        case 'danger':\r\n            return props.theme.colors.danger500;\r\n        default:\r\n            return props.theme.colors.info500;\r\n    }\r\n}\r\nexport function buildAlertColor(props) {\r\n    if (props.isInverse) {\r\n        return props.theme.colors.neutral100;\r\n    }\r\n    switch (props.variant) {\r\n        case 'success':\r\n            return props.theme.colors.success500;\r\n        case 'warning':\r\n            return props.theme.colors.warning500;\r\n        case 'danger':\r\n            return props.theme.colors.danger500;\r\n        default:\r\n            return props.theme.colors.info500;\r\n    }\r\n}\r\nexport function buildLinkColor(props) {\r\n    if (props.isInverse) {\r\n        switch (props.variant) {\r\n            case 'success':\r\n                return props.theme.colors.success200;\r\n            case 'warning':\r\n                return props.theme.colors.warning200;\r\n            case 'danger':\r\n                return props.theme.colors.danger200;\r\n            default:\r\n                return props.theme.colors.info200;\r\n        }\r\n    }\r\n    switch (props.variant) {\r\n        case 'success':\r\n            return props.theme.colors.success700;\r\n        case 'warning':\r\n            return props.theme.colors.warning700;\r\n        case 'danger':\r\n            return props.theme.colors.danger700;\r\n        default:\r\n            return props.theme.colors.info700;\r\n    }\r\n}\r\nexport function buildLinkHoverColor(props) {\r\n    if (props.isInverse) {\r\n        return props.theme.colors.neutral100;\r\n    }\r\n    switch (props.variant) {\r\n        case 'success':\r\n            return props.theme.colors.success;\r\n        case 'warning':\r\n            return props.theme.colors.warning;\r\n        case 'danger':\r\n            return props.theme.colors.danger;\r\n        default:\r\n            return props.theme.colors.info;\r\n    }\r\n}\r\nconst StyledAlert = styled.div `\n  align-items: stretch;\n  animation: ${props => props.isExiting\r\n    ? `fadeout ${transitionDuration}ms`\r\n    : `fadein ${transitionDuration}ms`};\n  display: flex;\n  flex-direction: column;\n  font-size: ${props => props.theme.typeScale.size03.fontSize};\n  font-family: ${props => props.theme.bodyFont};\n  line-height: ${props => props.theme.typeScale.size03.lineHeight};\n  margin-bottom: ${props => props.theme.spaceScale.spacing06};\n  max-width: 100%;\n  padding: 0;\n  position: relative;\n\n  @media (max-width: ${props => props.theme.breakpoints.small}px) {\n    font-size: ${props => props.theme.typeScale.size02.fontSize};\n    letter-spacing: ${props => props.theme.typeScale.size02.letterSpacing};\n    line-height: ${props => props.theme.typeScale.size02.lineHeight};\n  }\n\n  &:focus {\n    outline: 2px solid\n      ${props => props.isInverse\r\n    ? props.theme.colors.focusInverse\r\n    : props.theme.colors.focus};\n  }\n\n  ${props => props.isToast &&\r\n    css `\n      animation: ${props.isExiting\r\n        ? `slideout ${transitionDuration}ms`\r\n        : `slidein ${transitionDuration}ms`};\n      min-width: 375px;\n      margin: 0 auto;\n\n      @media (max-width: ${props.theme.breakpoints.small}px) {\n        min-width: 0;\n        width: 100%;\n      }\n    `}\n\n  @keyframes fadein {\n    from {\n      opacity: 0;\n    }\n    to {\n      opacity: 1;\n    }\n  }\n\n  @keyframes fadeout {\n    from {\n      opacity: 1;\n    }\n    to {\n      opacity: 0;\n    }\n  }\n\n  @keyframes slidein {\n    from {\n      left: -500px;\n    }\n    to {\n      left: 0;\n    }\n  }\n\n  @keyframes slideout {\n    from {\n      left: 0;\n    }\n    to {\n      left: -500px;\n    }\n  }\n\n  a {\n    color: ${props => buildLinkColor(props)};\n    font-weight: 400;\n    text-decoration: underline;\n    &:not([disabled]) {\n      &:focus,\n      &:hover {\n        color: ${props => buildLinkHoverColor(props)};\n      }\n    }\n  }\n`;\r\nconst StyledAlertInner = styled.div `\n  background: ${buildAlertBackground};\n  border: 1px solid ${buildAlertBorder};\n  border-radius: ${props => props.theme.borderRadius};\n  color: ${buildAlertColor};\n  display: flex;\n  position: relative;\n\n  ${props => props.isToast &&\r\n    css `\n      box-shadow: ${props.isInverse\r\n        ? `0 2px 8px 0 ${transparentize(0.3, props.theme.colors.neutral900)}`\r\n        : `0 2px 8px 0 ${transparentize(0.6, props.theme.colors.neutral900)}`};\n      padding-right: 0;\n      height: ${props.theme.spaceScale.spacing11};\n    `}\n`;\r\nconst AlertContents = styled.div `\n  align-items: ${props => (props.additionalContent ? 'center' : '')};\n  align-self: center;\n  flex-grow: 1;\n  font-family: ${props => props.theme.bodyFont};\n  padding: ${props => props.theme.spaceScale.spacing04} 0;\n  display: ${props => (props.additionalContent ? 'flex' : '')};\n  margin-right: ${props => props.additionalContent && !props.isDismissible\r\n    ? props.theme.spaceScale.spacing03\r\n    : ''};\n  @media (max-width: ${props => props.theme.breakpoints.small}px) {\n    padding-left: 0;\n  }\n`;\r\nexport const AdditionalContentWrapper = styled.div `\n  flex: 1 0 auto;\n  justify-content: flex-end;\n  display: flex;\n  margin-left: ${props => props.theme.spaceScale.spacing05};\n`;\r\nconst IconWrapperStyles = css `\n  align-items: center;\n  display: flex;\n  flex-shrink: 0;\n  margin-right: 1px;\n`;\r\nconst IconWrapper = styled.span `\n  ${IconWrapperStyles}\n  padding: 0 ${props => props.theme.spaceScale.spacing03} 0 ${props => props.theme.spaceScale.spacing04};\n\n  @media (max-width: ${props => props.theme.breakpoints.small}px) {\n    padding: 0 ${props => props.theme.spaceScale.spacing03};\n    svg {\n      width: 20px;\n    }\n  }\n`;\r\nconst ProgressRingWrapper = styled.div `\n  margin-top: 6px;\n  position: absolute;\n  top: auto;\n  right: ${props => props.theme.spaceScale.spacing02};\n`;\r\nconst DismissibleIconWrapper = styled.span `\n  ${IconWrapperStyles}\n  margin-left: ${props => props.additionalContent ? props.theme.spaceScale.spacing03 : ''};\n`;\r\nconst whitelistProps = ['icon', 'isInverse', 'theme', 'variant'];\r\nconst shouldForwardProp = prop => {\r\n    return isPropValid(prop) || whitelistProps.includes(prop);\r\n};\r\nconst DismissButton = styled(IconButton, { shouldForwardProp }) `\n  align-self: stretch;\n  border-radius: 0 ${props => props.theme.borderRadius}\n    ${props => props.theme.borderRadius} 0;\n  color: inherit;\n  height: auto;\n  margin: ${props => (props.isToast ? '4px' : '0 -1px 0 0')};\n  padding: ${props => props.isToast\r\n    ? `0 ${props.theme.spaceScale.spacing04}`\r\n    : `0 ${props.theme.spaceScale.spacing03}`};\n  width: auto;\n  &:not(:disabled):hover {\n    background: none;\n    color: inherit;\n  }\n  &:focus:not(:disabled) {\n    background: none;\n    color: inherit;\n    outline: 2px solid\n      ${props => props.isInverse\r\n    ? props.theme.colors.focusInverse\r\n    : props.theme.colors.focus};\n    outline-offset: 0 !important;\n  }\n  &:not(:disabled):active {\n    background: none;\n    color: inherit;\n  }\n`;\r\nconst AlertSpan = styled.span `\n  white-space: pre-line;\n`;\r\nfunction renderIcon(variant = 'info', isToast, theme) {\r\n    const Icon = VARIANT_ICON[variant];\r\n    return (React.createElement(IconWrapper, { isToast: isToast, theme: theme },\r\n        React.createElement(Icon, { size: theme.iconSizes.medium })));\r\n}\r\nexport const AlertBase = React.forwardRef((props, ref) => {\r\n    const { additionalContent, children, closeAriaLabel, forceDismiss, hasTimerRing, id: defaultId, isDismissed, isDismissible, isExiting: externalIsExiting, isPaused, isToast, onDismiss, testId, toastDuration, variant, ...other } = props;\r\n    const id = useGenerateId(defaultId);\r\n    const [isExiting, setIsExiting] = React.useState(false);\r\n    const isInverse = useIsInverse(props.isInverse);\r\n    React.useEffect(() => {\r\n        if (isExiting) {\r\n            setTimeout(() => {\r\n                setIsExiting(false);\r\n                onDismiss && typeof onDismiss === 'function' && onDismiss();\r\n            }, transitionDuration - 300);\r\n        }\r\n    }, [isExiting]);\r\n    React.useEffect(() => {\r\n        if (isDismissed) {\r\n            handleDismiss();\r\n        }\r\n    }, [isDismissed]);\r\n    function handleDismiss() {\r\n        setIsExiting(true);\r\n    }\r\n    const theme = React.useContext(ThemeContext);\r\n    const i18n = React.useContext(I18nContext);\r\n    function progressRingColor() {\r\n        if (isInverse) {\r\n            return theme.colors.neutral100;\r\n        }\r\n        switch (props.variant) {\r\n            case 'success':\r\n                return theme.colors.success500;\r\n            case 'warning':\r\n                return theme.colors.warning500;\r\n            case 'danger':\r\n                return theme.colors.danger500;\r\n            default:\r\n                return theme.colors.info500;\r\n        }\r\n    }\r\n    return (React.createElement(StyledAlert, Object.assign({}, other, { \"data-testid\": testId, id: id, tabIndex: -1, isInverse: isInverse, isExiting: isExiting, isToast: isToast, ref: ref, theme: theme, variant: variant }),\r\n        React.createElement(InverseContext.Provider, { value: { isInverse } },\r\n            React.createElement(StyledAlertInner, { isInverse: isInverse, isToast: isToast, theme: theme, variant: variant },\r\n                renderIcon(variant, isToast, theme),\r\n                React.createElement(AlertContents, { additionalContent: additionalContent, isDismissible: isDismissible, theme: theme },\r\n                    React.createElement(AlertSpan, null, children),\r\n                    additionalContent && (React.createElement(AdditionalContentWrapper, { theme: theme }, additionalContent))),\r\n                isDismissible && (React.createElement(DismissibleIconWrapper, { isInverse: isInverse, variant: variant, theme: theme },\r\n                    hasTimerRing && isToast && (React.createElement(ProgressRingWrapper, { theme: theme },\r\n                        React.createElement(ProgressRing, { color: progressRingColor(), isActive: !isPaused, duration: toastDuration }))),\r\n                    React.createElement(DismissButton, { alertVariant: variant, \"aria-label\": closeAriaLabel\r\n                            ? closeAriaLabel\r\n                            : i18n.alert.dismissAriaLabel, icon: React.createElement(CloseIcon, { size: hasTimerRing\r\n                                ? theme.iconSizes.xSmall\r\n                                : theme.iconSizes.small }), isInverse: isInverse, isToast: isToast, onClick: forceDismiss || handleDismiss, theme: theme, variant: ButtonVariant.link })))))));\r\n});\r\n//# sourceMappingURL=index.js.map"]} */"));
3671
+ return props.isToast && /*#__PURE__*/css("box-shadow:", props.isInverse ? "0 2px 8px 0 " + curriedTransparentize(0.3, props.theme.colors.neutral900) : "0 2px 8px 0 " + curriedTransparentize(0.6, props.theme.colors.neutral900), ";padding-right:0;height:", props.theme.spaceScale.spacing11, ";;label:StyledAlertInner;" + (process.env.NODE_ENV === "production" ? "" : "/*# sourceMappingURL=data:application/json;charset=utf-8;base64,{"version":3,"sources":["index.tsx"],"names":[],"mappings":"AAoOQ","file":"index.tsx","sourcesContent":["import * as React from 'react';\r\nimport { css } from '@emotion/react';\r\nimport isPropValid from '@emotion/is-prop-valid';\r\nimport { transparentize } from 'polished';\r\nimport { ThemeContext } from '../../theme/ThemeContext';\r\nimport { InfoIcon, CheckCircleIcon, WarningIcon, ErrorIcon, CloseIcon, } from 'react-magma-icons';\r\nimport { ButtonVariant } from '../Button';\r\nimport { IconButton } from '../IconButton';\r\nimport { ProgressRing } from '../ProgressRing';\r\nimport { useGenerateId } from '../../utils';\r\nimport { I18nContext } from '../../i18n';\r\nimport { InverseContext, useIsInverse } from '../../inverse';\r\nimport styled from '@emotion/styled';\r\nexport const VARIANT_ICON = {\r\n    info: InfoIcon,\r\n    success: CheckCircleIcon,\r\n    warning: WarningIcon,\r\n    danger: ErrorIcon,\r\n};\r\nexport var AlertVariant;\r\n(function (AlertVariant) {\r\n    AlertVariant[\"info\"] = \"info\";\r\n    AlertVariant[\"success\"] = \"success\";\r\n    AlertVariant[\"warning\"] = \"warning\";\r\n    AlertVariant[\"danger\"] = \"danger\";\r\n})(AlertVariant || (AlertVariant = {}));\r\nexport const transitionDuration = 500;\r\nexport function buildAlertBackground(props) {\r\n    if (props.isInverse) {\r\n        switch (props.variant) {\r\n            case 'success':\r\n                return props.theme.colors.success700;\r\n            case 'warning':\r\n                return props.theme.colors.warning700;\r\n            case 'danger':\r\n                return props.theme.colors.danger700;\r\n            default:\r\n                return props.theme.colors.info700;\r\n        }\r\n    }\r\n    switch (props.variant) {\r\n        case 'success':\r\n            return props.theme.colors.success100;\r\n        case 'warning':\r\n            return props.theme.colors.warning100;\r\n        case 'danger':\r\n            return props.theme.colors.danger100;\r\n        default:\r\n            return props.theme.colors.info100;\r\n    }\r\n}\r\nexport function buildAlertBorder(props) {\r\n    if (props.isInverse) {\r\n        switch (props.variant) {\r\n            case 'success':\r\n                return props.theme.colors.success300;\r\n            case 'warning':\r\n                return props.theme.colors.warning300;\r\n            case 'danger':\r\n                return props.theme.colors.danger200;\r\n            default:\r\n                return props.theme.colors.info300;\r\n        }\r\n    }\r\n    switch (props.variant) {\r\n        case 'success':\r\n            return props.theme.colors.success500;\r\n        case 'warning':\r\n            return props.theme.colors.warning500;\r\n        case 'danger':\r\n            return props.theme.colors.danger500;\r\n        default:\r\n            return props.theme.colors.info500;\r\n    }\r\n}\r\nexport function buildAlertColor(props) {\r\n    if (props.isInverse) {\r\n        return props.theme.colors.neutral100;\r\n    }\r\n    switch (props.variant) {\r\n        case 'success':\r\n            return props.theme.colors.success500;\r\n        case 'warning':\r\n            return props.theme.colors.warning500;\r\n        case 'danger':\r\n            return props.theme.colors.danger500;\r\n        default:\r\n            return props.theme.colors.info500;\r\n    }\r\n}\r\nexport function buildLinkColor(props) {\r\n    if (props.isInverse) {\r\n        switch (props.variant) {\r\n            case 'success':\r\n                return props.theme.colors.success200;\r\n            case 'warning':\r\n                return props.theme.colors.warning200;\r\n            case 'danger':\r\n                return props.theme.colors.danger200;\r\n            default:\r\n                return props.theme.colors.info200;\r\n        }\r\n    }\r\n    switch (props.variant) {\r\n        case 'success':\r\n            return props.theme.colors.success700;\r\n        case 'warning':\r\n            return props.theme.colors.warning700;\r\n        case 'danger':\r\n            return props.theme.colors.danger700;\r\n        default:\r\n            return props.theme.colors.info700;\r\n    }\r\n}\r\nexport function buildLinkHoverColor(props) {\r\n    if (props.isInverse) {\r\n        return props.theme.colors.neutral100;\r\n    }\r\n    switch (props.variant) {\r\n        case 'success':\r\n            return props.theme.colors.success;\r\n        case 'warning':\r\n            return props.theme.colors.warning;\r\n        case 'danger':\r\n            return props.theme.colors.danger;\r\n        default:\r\n            return props.theme.colors.info;\r\n    }\r\n}\r\nconst StyledAlert = styled.div `\n  align-items: stretch;\n  animation: ${props => props.isExiting\r\n    ? `fadeout ${transitionDuration}ms`\r\n    : `fadein ${transitionDuration}ms`};\n  display: flex;\n  flex-direction: column;\n  font-size: ${props => props.theme.typeScale.size03.fontSize};\n  font-family: ${props => props.theme.bodyFont};\n  line-height: ${props => props.theme.typeScale.size03.lineHeight};\n  margin-bottom: ${props => props.theme.spaceScale.spacing06};\n  max-width: 100%;\n  padding: 0;\n  position: relative;\n\n  @media (max-width: ${props => props.theme.breakpoints.small}px) {\n    font-size: ${props => props.theme.typeScale.size02.fontSize};\n    letter-spacing: ${props => props.theme.typeScale.size02.letterSpacing};\n    line-height: ${props => props.theme.typeScale.size02.lineHeight};\n  }\n\n  &:focus {\n    outline: 2px solid\n      ${props => props.isInverse\r\n    ? props.theme.colors.focusInverse\r\n    : props.theme.colors.focus};\n  }\n\n  ${props => props.isToast &&\r\n    css `\n      animation: ${props.isExiting\r\n        ? `slideout ${transitionDuration}ms`\r\n        : `slidein ${transitionDuration}ms`};\n      min-width: 375px;\n      margin: 0 auto;\n\n      @media (max-width: ${props.theme.breakpoints.small}px) {\n        min-width: 0;\n        width: 100%;\n      }\n    `}\n\n  @keyframes fadein {\n    from {\n      opacity: 0;\n    }\n    to {\n      opacity: 1;\n    }\n  }\n\n  @keyframes fadeout {\n    from {\n      opacity: 1;\n    }\n    to {\n      opacity: 0;\n    }\n  }\n\n  @keyframes slidein {\n    from {\n      left: -500px;\n    }\n    to {\n      left: 0;\n    }\n  }\n\n  @keyframes slideout {\n    from {\n      left: 0;\n    }\n    to {\n      left: -500px;\n    }\n  }\n\n  a {\n    color: ${props => buildLinkColor(props)};\n    font-weight: 400;\n    text-decoration: underline;\n    &:not([disabled]) {\n      &:focus,\n      &:hover {\n        color: ${props => buildLinkHoverColor(props)};\n      }\n    }\n  }\n`;\r\nconst StyledAlertInner = styled.div `\n  background: ${buildAlertBackground};\n  border: 1px solid ${buildAlertBorder};\n  border-radius: ${props => props.theme.borderRadius};\n  color: ${buildAlertColor};\n  display: flex;\n  position: relative;\n\n  ${props => props.isToast &&\r\n    css `\n      box-shadow: ${props.isInverse\r\n        ? `0 2px 8px 0 ${transparentize(0.3, props.theme.colors.neutral900)}`\r\n        : `0 2px 8px 0 ${transparentize(0.6, props.theme.colors.neutral900)}`};\n      padding-right: 0;\n      height: ${props.theme.spaceScale.spacing11};\n    `}\n`;\r\nconst AlertContents = styled.div `\n  align-items: ${props => (props.additionalContent ? 'center' : '')};\n  align-self: center;\n  flex-grow: 1;\n  font-family: ${props => props.theme.bodyFont};\n  padding: ${props => props.theme.spaceScale.spacing04} 0;\n  display: ${props => (props.additionalContent ? 'flex' : '')};\n  margin-right: ${props => props.additionalContent && !props.isDismissible\r\n    ? props.theme.spaceScale.spacing03\r\n    : ''};\n  @media (max-width: ${props => props.theme.breakpoints.small}px) {\n    padding-left: 0;\n  }\n`;\r\nexport const AdditionalContentWrapper = styled.div `\n  flex: 1 0 auto;\n  justify-content: flex-end;\n  display: flex;\n  margin-left: ${props => props.theme.spaceScale.spacing05};\n`;\r\nconst IconWrapperStyles = css `\n  align-items: center;\n  display: flex;\n  flex-shrink: 0;\n  margin-right: 1px;\n`;\r\nconst IconWrapper = styled.span `\n  ${IconWrapperStyles}\n  padding: 0 ${props => props.theme.spaceScale.spacing03} 0 ${props => props.theme.spaceScale.spacing04};\n\n  @media (max-width: ${props => props.theme.breakpoints.small}px) {\n    padding: 0 ${props => props.theme.spaceScale.spacing03};\n    svg {\n      width: 20px;\n    }\n  }\n`;\r\nconst ProgressRingWrapper = styled.div `\n  margin-top: 6px;\n  position: absolute;\n  top: auto;\n  right: ${props => props.theme.spaceScale.spacing02};\n`;\r\nconst DismissibleIconWrapper = styled.span `\n  ${IconWrapperStyles}\n  margin-left: ${props => props.additionalContent ? props.theme.spaceScale.spacing03 : ''};\n`;\r\nconst whitelistProps = ['icon', 'isInverse', 'theme', 'variant'];\r\nconst shouldForwardProp = prop => {\r\n    return isPropValid(prop) || whitelistProps.includes(prop);\r\n};\r\nconst DismissButton = styled(IconButton, { shouldForwardProp }) `\n  align-self: stretch;\n  border-radius: 0 ${props => props.theme.borderRadius}\n    ${props => props.theme.borderRadius} 0;\n  color: inherit;\n  height: auto;\n  margin: ${props => (props.isToast ? '4px' : '0 -1px 0 0')};\n  padding: ${props => props.isToast\r\n    ? `0 ${props.theme.spaceScale.spacing04}`\r\n    : `0 ${props.theme.spaceScale.spacing03}`};\n  width: auto;\n  &:not(:disabled):hover {\n    background: none;\n    color: inherit;\n  }\n  &:focus:not(:disabled) {\n    background: none;\n    color: inherit;\n    outline: 2px solid\n      ${props => props.isInverse\r\n    ? props.theme.colors.focusInverse\r\n    : props.theme.colors.focus};\n    outline-offset: 0 !important;\n  }\n  &:not(:disabled):active {\n    background: none;\n    color: inherit;\n  }\n`;\r\nconst AlertSpan = styled.span `\n  white-space: pre-line;\n`;\r\nfunction renderIcon(variant = 'info', isToast, theme) {\r\n    const Icon = VARIANT_ICON[variant];\r\n    return (React.createElement(IconWrapper, { isToast: isToast, theme: theme },\r\n        React.createElement(Icon, { size: theme.iconSizes.medium })));\r\n}\r\nexport const AlertBase = React.forwardRef((props, ref) => {\r\n    const { additionalContent, children, closeAriaLabel, forceDismiss, hasTimerRing, id: defaultId, isDismissed, isDismissible, isExiting: externalIsExiting, isPaused, isToast, onDismiss, testId, toastDuration, variant, ...other } = props;\r\n    const id = useGenerateId(defaultId);\r\n    const [isExiting, setIsExiting] = React.useState(false);\r\n    const isInverse = useIsInverse(props.isInverse);\r\n    React.useEffect(() => {\r\n        if (isExiting) {\r\n            setTimeout(() => {\r\n                setIsExiting(false);\r\n                onDismiss && typeof onDismiss === 'function' && onDismiss();\r\n            }, transitionDuration - 300);\r\n        }\r\n    }, [isExiting]);\r\n    React.useEffect(() => {\r\n        if (isDismissed) {\r\n            handleDismiss();\r\n        }\r\n    }, [isDismissed]);\r\n    function handleDismiss() {\r\n        setIsExiting(true);\r\n    }\r\n    const theme = React.useContext(ThemeContext);\r\n    const i18n = React.useContext(I18nContext);\r\n    function progressRingColor() {\r\n        if (isInverse) {\r\n            return theme.colors.neutral100;\r\n        }\r\n        switch (props.variant) {\r\n            case 'success':\r\n                return theme.colors.success500;\r\n            case 'warning':\r\n                return theme.colors.warning500;\r\n            case 'danger':\r\n                return theme.colors.danger500;\r\n            default:\r\n                return theme.colors.info500;\r\n        }\r\n    }\r\n    return (React.createElement(StyledAlert, Object.assign({}, other, { \"data-testid\": testId, id: id, tabIndex: -1, isInverse: isInverse, isExiting: isExiting, isToast: isToast, ref: ref, theme: theme, variant: variant }),\r\n        React.createElement(InverseContext.Provider, { value: { isInverse } },\r\n            React.createElement(StyledAlertInner, { isInverse: isInverse, isToast: isToast, theme: theme, variant: variant },\r\n                renderIcon(variant, isToast, theme),\r\n                React.createElement(AlertContents, { additionalContent: additionalContent, isDismissible: isDismissible, theme: theme },\r\n                    React.createElement(AlertSpan, null, children),\r\n                    additionalContent && (React.createElement(AdditionalContentWrapper, { theme: theme }, additionalContent))),\r\n                isDismissible && (React.createElement(DismissibleIconWrapper, { isInverse: isInverse, variant: variant, theme: theme },\r\n                    hasTimerRing && isToast && (React.createElement(ProgressRingWrapper, { theme: theme },\r\n                        React.createElement(ProgressRing, { color: progressRingColor(), isActive: !isPaused, duration: toastDuration }))),\r\n                    React.createElement(DismissButton, Object.assign({ alertVariant: variant }, (isToast\r\n                        ? { title: closeAriaLabel || i18n.alert.dismissAriaLabel }\r\n                        : {\r\n                            'aria-label': closeAriaLabel || i18n.alert.dismissAriaLabel,\r\n                        }), { icon: React.createElement(CloseIcon, { size: hasTimerRing\r\n                                ? theme.iconSizes.xSmall\r\n                                : theme.iconSizes.small }), isInverse: isInverse, isToast: isToast, onClick: forceDismiss || handleDismiss, theme: theme, variant: ButtonVariant.link }))))))));\r\n});\r\n//# sourceMappingURL=index.js.map"]} */"));
3672
+ }, ";" + (process.env.NODE_ENV === "production" ? "" : "/*# sourceMappingURL=data:application/json;charset=utf-8;base64,{"version":3,"sources":["index.tsx"],"names":[],"mappings":"AA2NoC","file":"index.tsx","sourcesContent":["import * as React from 'react';\r\nimport { css } from '@emotion/react';\r\nimport isPropValid from '@emotion/is-prop-valid';\r\nimport { transparentize } from 'polished';\r\nimport { ThemeContext } from '../../theme/ThemeContext';\r\nimport { InfoIcon, CheckCircleIcon, WarningIcon, ErrorIcon, CloseIcon, } from 'react-magma-icons';\r\nimport { ButtonVariant } from '../Button';\r\nimport { IconButton } from '../IconButton';\r\nimport { ProgressRing } from '../ProgressRing';\r\nimport { useGenerateId } from '../../utils';\r\nimport { I18nContext } from '../../i18n';\r\nimport { InverseContext, useIsInverse } from '../../inverse';\r\nimport styled from '@emotion/styled';\r\nexport const VARIANT_ICON = {\r\n    info: InfoIcon,\r\n    success: CheckCircleIcon,\r\n    warning: WarningIcon,\r\n    danger: ErrorIcon,\r\n};\r\nexport var AlertVariant;\r\n(function (AlertVariant) {\r\n    AlertVariant[\"info\"] = \"info\";\r\n    AlertVariant[\"success\"] = \"success\";\r\n    AlertVariant[\"warning\"] = \"warning\";\r\n    AlertVariant[\"danger\"] = \"danger\";\r\n})(AlertVariant || (AlertVariant = {}));\r\nexport const transitionDuration = 500;\r\nexport function buildAlertBackground(props) {\r\n    if (props.isInverse) {\r\n        switch (props.variant) {\r\n            case 'success':\r\n                return props.theme.colors.success700;\r\n            case 'warning':\r\n                return props.theme.colors.warning700;\r\n            case 'danger':\r\n                return props.theme.colors.danger700;\r\n            default:\r\n                return props.theme.colors.info700;\r\n        }\r\n    }\r\n    switch (props.variant) {\r\n        case 'success':\r\n            return props.theme.colors.success100;\r\n        case 'warning':\r\n            return props.theme.colors.warning100;\r\n        case 'danger':\r\n            return props.theme.colors.danger100;\r\n        default:\r\n            return props.theme.colors.info100;\r\n    }\r\n}\r\nexport function buildAlertBorder(props) {\r\n    if (props.isInverse) {\r\n        switch (props.variant) {\r\n            case 'success':\r\n                return props.theme.colors.success300;\r\n            case 'warning':\r\n                return props.theme.colors.warning300;\r\n            case 'danger':\r\n                return props.theme.colors.danger200;\r\n            default:\r\n                return props.theme.colors.info300;\r\n        }\r\n    }\r\n    switch (props.variant) {\r\n        case 'success':\r\n            return props.theme.colors.success500;\r\n        case 'warning':\r\n            return props.theme.colors.warning500;\r\n        case 'danger':\r\n            return props.theme.colors.danger500;\r\n        default:\r\n            return props.theme.colors.info500;\r\n    }\r\n}\r\nexport function buildAlertColor(props) {\r\n    if (props.isInverse) {\r\n        return props.theme.colors.neutral100;\r\n    }\r\n    switch (props.variant) {\r\n        case 'success':\r\n            return props.theme.colors.success500;\r\n        case 'warning':\r\n            return props.theme.colors.warning500;\r\n        case 'danger':\r\n            return props.theme.colors.danger500;\r\n        default:\r\n            return props.theme.colors.info500;\r\n    }\r\n}\r\nexport function buildLinkColor(props) {\r\n    if (props.isInverse) {\r\n        switch (props.variant) {\r\n            case 'success':\r\n                return props.theme.colors.success200;\r\n            case 'warning':\r\n                return props.theme.colors.warning200;\r\n            case 'danger':\r\n                return props.theme.colors.danger200;\r\n            default:\r\n                return props.theme.colors.info200;\r\n        }\r\n    }\r\n    switch (props.variant) {\r\n        case 'success':\r\n            return props.theme.colors.success700;\r\n        case 'warning':\r\n            return props.theme.colors.warning700;\r\n        case 'danger':\r\n            return props.theme.colors.danger700;\r\n        default:\r\n            return props.theme.colors.info700;\r\n    }\r\n}\r\nexport function buildLinkHoverColor(props) {\r\n    if (props.isInverse) {\r\n        return props.theme.colors.neutral100;\r\n    }\r\n    switch (props.variant) {\r\n        case 'success':\r\n            return props.theme.colors.success;\r\n        case 'warning':\r\n            return props.theme.colors.warning;\r\n        case 'danger':\r\n            return props.theme.colors.danger;\r\n        default:\r\n            return props.theme.colors.info;\r\n    }\r\n}\r\nconst StyledAlert = styled.div `\n  align-items: stretch;\n  animation: ${props => props.isExiting\r\n    ? `fadeout ${transitionDuration}ms`\r\n    : `fadein ${transitionDuration}ms`};\n  display: flex;\n  flex-direction: column;\n  font-size: ${props => props.theme.typeScale.size03.fontSize};\n  font-family: ${props => props.theme.bodyFont};\n  line-height: ${props => props.theme.typeScale.size03.lineHeight};\n  margin-bottom: ${props => props.theme.spaceScale.spacing06};\n  max-width: 100%;\n  padding: 0;\n  position: relative;\n\n  @media (max-width: ${props => props.theme.breakpoints.small}px) {\n    font-size: ${props => props.theme.typeScale.size02.fontSize};\n    letter-spacing: ${props => props.theme.typeScale.size02.letterSpacing};\n    line-height: ${props => props.theme.typeScale.size02.lineHeight};\n  }\n\n  &:focus {\n    outline: 2px solid\n      ${props => props.isInverse\r\n    ? props.theme.colors.focusInverse\r\n    : props.theme.colors.focus};\n  }\n\n  ${props => props.isToast &&\r\n    css `\n      animation: ${props.isExiting\r\n        ? `slideout ${transitionDuration}ms`\r\n        : `slidein ${transitionDuration}ms`};\n      min-width: 375px;\n      margin: 0 auto;\n\n      @media (max-width: ${props.theme.breakpoints.small}px) {\n        min-width: 0;\n        width: 100%;\n      }\n    `}\n\n  @keyframes fadein {\n    from {\n      opacity: 0;\n    }\n    to {\n      opacity: 1;\n    }\n  }\n\n  @keyframes fadeout {\n    from {\n      opacity: 1;\n    }\n    to {\n      opacity: 0;\n    }\n  }\n\n  @keyframes slidein {\n    from {\n      left: -500px;\n    }\n    to {\n      left: 0;\n    }\n  }\n\n  @keyframes slideout {\n    from {\n      left: 0;\n    }\n    to {\n      left: -500px;\n    }\n  }\n\n  a {\n    color: ${props => buildLinkColor(props)};\n    font-weight: 400;\n    text-decoration: underline;\n    &:not([disabled]) {\n      &:focus,\n      &:hover {\n        color: ${props => buildLinkHoverColor(props)};\n      }\n    }\n  }\n`;\r\nconst StyledAlertInner = styled.div `\n  background: ${buildAlertBackground};\n  border: 1px solid ${buildAlertBorder};\n  border-radius: ${props => props.theme.borderRadius};\n  color: ${buildAlertColor};\n  display: flex;\n  position: relative;\n\n  ${props => props.isToast &&\r\n    css `\n      box-shadow: ${props.isInverse\r\n        ? `0 2px 8px 0 ${transparentize(0.3, props.theme.colors.neutral900)}`\r\n        : `0 2px 8px 0 ${transparentize(0.6, props.theme.colors.neutral900)}`};\n      padding-right: 0;\n      height: ${props.theme.spaceScale.spacing11};\n    `}\n`;\r\nconst AlertContents = styled.div `\n  align-items: ${props => (props.additionalContent ? 'center' : '')};\n  align-self: center;\n  flex-grow: 1;\n  font-family: ${props => props.theme.bodyFont};\n  padding: ${props => props.theme.spaceScale.spacing04} 0;\n  display: ${props => (props.additionalContent ? 'flex' : '')};\n  margin-right: ${props => props.additionalContent && !props.isDismissible\r\n    ? props.theme.spaceScale.spacing03\r\n    : ''};\n  @media (max-width: ${props => props.theme.breakpoints.small}px) {\n    padding-left: 0;\n  }\n`;\r\nexport const AdditionalContentWrapper = styled.div `\n  flex: 1 0 auto;\n  justify-content: flex-end;\n  display: flex;\n  margin-left: ${props => props.theme.spaceScale.spacing05};\n`;\r\nconst IconWrapperStyles = css `\n  align-items: center;\n  display: flex;\n  flex-shrink: 0;\n  margin-right: 1px;\n`;\r\nconst IconWrapper = styled.span `\n  ${IconWrapperStyles}\n  padding: 0 ${props => props.theme.spaceScale.spacing03} 0 ${props => props.theme.spaceScale.spacing04};\n\n  @media (max-width: ${props => props.theme.breakpoints.small}px) {\n    padding: 0 ${props => props.theme.spaceScale.spacing03};\n    svg {\n      width: 20px;\n    }\n  }\n`;\r\nconst ProgressRingWrapper = styled.div `\n  margin-top: 6px;\n  position: absolute;\n  top: auto;\n  right: ${props => props.theme.spaceScale.spacing02};\n`;\r\nconst DismissibleIconWrapper = styled.span `\n  ${IconWrapperStyles}\n  margin-left: ${props => props.additionalContent ? props.theme.spaceScale.spacing03 : ''};\n`;\r\nconst whitelistProps = ['icon', 'isInverse', 'theme', 'variant'];\r\nconst shouldForwardProp = prop => {\r\n    return isPropValid(prop) || whitelistProps.includes(prop);\r\n};\r\nconst DismissButton = styled(IconButton, { shouldForwardProp }) `\n  align-self: stretch;\n  border-radius: 0 ${props => props.theme.borderRadius}\n    ${props => props.theme.borderRadius} 0;\n  color: inherit;\n  height: auto;\n  margin: ${props => (props.isToast ? '4px' : '0 -1px 0 0')};\n  padding: ${props => props.isToast\r\n    ? `0 ${props.theme.spaceScale.spacing04}`\r\n    : `0 ${props.theme.spaceScale.spacing03}`};\n  width: auto;\n  &:not(:disabled):hover {\n    background: none;\n    color: inherit;\n  }\n  &:focus:not(:disabled) {\n    background: none;\n    color: inherit;\n    outline: 2px solid\n      ${props => props.isInverse\r\n    ? props.theme.colors.focusInverse\r\n    : props.theme.colors.focus};\n    outline-offset: 0 !important;\n  }\n  &:not(:disabled):active {\n    background: none;\n    color: inherit;\n  }\n`;\r\nconst AlertSpan = styled.span `\n  white-space: pre-line;\n`;\r\nfunction renderIcon(variant = 'info', isToast, theme) {\r\n    const Icon = VARIANT_ICON[variant];\r\n    return (React.createElement(IconWrapper, { isToast: isToast, theme: theme },\r\n        React.createElement(Icon, { size: theme.iconSizes.medium })));\r\n}\r\nexport const AlertBase = React.forwardRef((props, ref) => {\r\n    const { additionalContent, children, closeAriaLabel, forceDismiss, hasTimerRing, id: defaultId, isDismissed, isDismissible, isExiting: externalIsExiting, isPaused, isToast, onDismiss, testId, toastDuration, variant, ...other } = props;\r\n    const id = useGenerateId(defaultId);\r\n    const [isExiting, setIsExiting] = React.useState(false);\r\n    const isInverse = useIsInverse(props.isInverse);\r\n    React.useEffect(() => {\r\n        if (isExiting) {\r\n            setTimeout(() => {\r\n                setIsExiting(false);\r\n                onDismiss && typeof onDismiss === 'function' && onDismiss();\r\n            }, transitionDuration - 300);\r\n        }\r\n    }, [isExiting]);\r\n    React.useEffect(() => {\r\n        if (isDismissed) {\r\n            handleDismiss();\r\n        }\r\n    }, [isDismissed]);\r\n    function handleDismiss() {\r\n        setIsExiting(true);\r\n    }\r\n    const theme = React.useContext(ThemeContext);\r\n    const i18n = React.useContext(I18nContext);\r\n    function progressRingColor() {\r\n        if (isInverse) {\r\n            return theme.colors.neutral100;\r\n        }\r\n        switch (props.variant) {\r\n            case 'success':\r\n                return theme.colors.success500;\r\n            case 'warning':\r\n                return theme.colors.warning500;\r\n            case 'danger':\r\n                return theme.colors.danger500;\r\n            default:\r\n                return theme.colors.info500;\r\n        }\r\n    }\r\n    return (React.createElement(StyledAlert, Object.assign({}, other, { \"data-testid\": testId, id: id, tabIndex: -1, isInverse: isInverse, isExiting: isExiting, isToast: isToast, ref: ref, theme: theme, variant: variant }),\r\n        React.createElement(InverseContext.Provider, { value: { isInverse } },\r\n            React.createElement(StyledAlertInner, { isInverse: isInverse, isToast: isToast, theme: theme, variant: variant },\r\n                renderIcon(variant, isToast, theme),\r\n                React.createElement(AlertContents, { additionalContent: additionalContent, isDismissible: isDismissible, theme: theme },\r\n                    React.createElement(AlertSpan, null, children),\r\n                    additionalContent && (React.createElement(AdditionalContentWrapper, { theme: theme }, additionalContent))),\r\n                isDismissible && (React.createElement(DismissibleIconWrapper, { isInverse: isInverse, variant: variant, theme: theme },\r\n                    hasTimerRing && isToast && (React.createElement(ProgressRingWrapper, { theme: theme },\r\n                        React.createElement(ProgressRing, { color: progressRingColor(), isActive: !isPaused, duration: toastDuration }))),\r\n                    React.createElement(DismissButton, Object.assign({ alertVariant: variant }, (isToast\r\n                        ? { title: closeAriaLabel || i18n.alert.dismissAriaLabel }\r\n                        : {\r\n                            'aria-label': closeAriaLabel || i18n.alert.dismissAriaLabel,\r\n                        }), { icon: React.createElement(CloseIcon, { size: hasTimerRing\r\n                                ? theme.iconSizes.xSmall\r\n                                : theme.iconSizes.small }), isInverse: isInverse, isToast: isToast, onClick: forceDismiss || handleDismiss, theme: theme, variant: ButtonVariant.link }))))))));\r\n});\r\n//# sourceMappingURL=index.js.map"]} */"));
3673
3673
  var AlertContents = /*#__PURE__*/_styled("div", {
3674
3674
  target: "e126n3g86",
3675
3675
  label: "AlertContents"
@@ -3685,20 +3685,20 @@ var AlertContents = /*#__PURE__*/_styled("div", {
3685
3685
  return props.additionalContent && !props.isDismissible ? props.theme.spaceScale.spacing03 : '';
3686
3686
  }, ";@media (max-width: ", function (props) {
3687
3687
  return props.theme.breakpoints.small;
3688
- }, "px){padding-left:0;}" + (process.env.NODE_ENV === "production" ? "" : "/*# sourceMappingURL=data:application/json;charset=utf-8;base64,{"version":3,"sources":["index.tsx"],"names":[],"mappings":"AA4OiC","file":"index.tsx","sourcesContent":["import * as React from 'react';\r\nimport { css } from '@emotion/react';\r\nimport isPropValid from '@emotion/is-prop-valid';\r\nimport { transparentize } from 'polished';\r\nimport { ThemeContext } from '../../theme/ThemeContext';\r\nimport { InfoIcon, CheckCircleIcon, WarningIcon, ErrorIcon, CloseIcon, } from 'react-magma-icons';\r\nimport { ButtonVariant } from '../Button';\r\nimport { IconButton } from '../IconButton';\r\nimport { ProgressRing } from '../ProgressRing';\r\nimport { useGenerateId } from '../../utils';\r\nimport { I18nContext } from '../../i18n';\r\nimport { InverseContext, useIsInverse } from '../../inverse';\r\nimport styled from '@emotion/styled';\r\nexport const VARIANT_ICON = {\r\n    info: InfoIcon,\r\n    success: CheckCircleIcon,\r\n    warning: WarningIcon,\r\n    danger: ErrorIcon,\r\n};\r\nexport var AlertVariant;\r\n(function (AlertVariant) {\r\n    AlertVariant[\"info\"] = \"info\";\r\n    AlertVariant[\"success\"] = \"success\";\r\n    AlertVariant[\"warning\"] = \"warning\";\r\n    AlertVariant[\"danger\"] = \"danger\";\r\n})(AlertVariant || (AlertVariant = {}));\r\nexport const transitionDuration = 500;\r\nexport function buildAlertBackground(props) {\r\n    if (props.isInverse) {\r\n        switch (props.variant) {\r\n            case 'success':\r\n                return props.theme.colors.success700;\r\n            case 'warning':\r\n                return props.theme.colors.warning700;\r\n            case 'danger':\r\n                return props.theme.colors.danger700;\r\n            default:\r\n                return props.theme.colors.info700;\r\n        }\r\n    }\r\n    switch (props.variant) {\r\n        case 'success':\r\n            return props.theme.colors.success100;\r\n        case 'warning':\r\n            return props.theme.colors.warning100;\r\n        case 'danger':\r\n            return props.theme.colors.danger100;\r\n        default:\r\n            return props.theme.colors.info100;\r\n    }\r\n}\r\nexport function buildAlertBorder(props) {\r\n    if (props.isInverse) {\r\n        switch (props.variant) {\r\n            case 'success':\r\n                return props.theme.colors.success300;\r\n            case 'warning':\r\n                return props.theme.colors.warning300;\r\n            case 'danger':\r\n                return props.theme.colors.danger200;\r\n            default:\r\n                return props.theme.colors.info300;\r\n        }\r\n    }\r\n    switch (props.variant) {\r\n        case 'success':\r\n            return props.theme.colors.success500;\r\n        case 'warning':\r\n            return props.theme.colors.warning500;\r\n        case 'danger':\r\n            return props.theme.colors.danger500;\r\n        default:\r\n            return props.theme.colors.info500;\r\n    }\r\n}\r\nexport function buildAlertColor(props) {\r\n    if (props.isInverse) {\r\n        return props.theme.colors.neutral100;\r\n    }\r\n    switch (props.variant) {\r\n        case 'success':\r\n            return props.theme.colors.success500;\r\n        case 'warning':\r\n            return props.theme.colors.warning500;\r\n        case 'danger':\r\n            return props.theme.colors.danger500;\r\n        default:\r\n            return props.theme.colors.info500;\r\n    }\r\n}\r\nexport function buildLinkColor(props) {\r\n    if (props.isInverse) {\r\n        switch (props.variant) {\r\n            case 'success':\r\n                return props.theme.colors.success200;\r\n            case 'warning':\r\n                return props.theme.colors.warning200;\r\n            case 'danger':\r\n                return props.theme.colors.danger200;\r\n            default:\r\n                return props.theme.colors.info200;\r\n        }\r\n    }\r\n    switch (props.variant) {\r\n        case 'success':\r\n            return props.theme.colors.success700;\r\n        case 'warning':\r\n            return props.theme.colors.warning700;\r\n        case 'danger':\r\n            return props.theme.colors.danger700;\r\n        default:\r\n            return props.theme.colors.info700;\r\n    }\r\n}\r\nexport function buildLinkHoverColor(props) {\r\n    if (props.isInverse) {\r\n        return props.theme.colors.neutral100;\r\n    }\r\n    switch (props.variant) {\r\n        case 'success':\r\n            return props.theme.colors.success;\r\n        case 'warning':\r\n            return props.theme.colors.warning;\r\n        case 'danger':\r\n            return props.theme.colors.danger;\r\n        default:\r\n            return props.theme.colors.info;\r\n    }\r\n}\r\nconst StyledAlert = styled.div `\n  align-items: stretch;\n  animation: ${props => props.isExiting\r\n    ? `fadeout ${transitionDuration}ms`\r\n    : `fadein ${transitionDuration}ms`};\n  display: flex;\n  flex-direction: column;\n  font-size: ${props => props.theme.typeScale.size03.fontSize};\n  font-family: ${props => props.theme.bodyFont};\n  line-height: ${props => props.theme.typeScale.size03.lineHeight};\n  margin-bottom: ${props => props.theme.spaceScale.spacing06};\n  max-width: 100%;\n  padding: 0;\n  position: relative;\n\n  @media (max-width: ${props => props.theme.breakpoints.small}px) {\n    font-size: ${props => props.theme.typeScale.size02.fontSize};\n    letter-spacing: ${props => props.theme.typeScale.size02.letterSpacing};\n    line-height: ${props => props.theme.typeScale.size02.lineHeight};\n  }\n\n  &:focus {\n    outline: 2px solid\n      ${props => props.isInverse\r\n    ? props.theme.colors.focusInverse\r\n    : props.theme.colors.focus};\n  }\n\n  ${props => props.isToast &&\r\n    css `\n      animation: ${props.isExiting\r\n        ? `slideout ${transitionDuration}ms`\r\n        : `slidein ${transitionDuration}ms`};\n      min-width: 375px;\n      margin: 0 auto;\n\n      @media (max-width: ${props.theme.breakpoints.small}px) {\n        min-width: 0;\n        width: 100%;\n      }\n    `}\n\n  @keyframes fadein {\n    from {\n      opacity: 0;\n    }\n    to {\n      opacity: 1;\n    }\n  }\n\n  @keyframes fadeout {\n    from {\n      opacity: 1;\n    }\n    to {\n      opacity: 0;\n    }\n  }\n\n  @keyframes slidein {\n    from {\n      left: -500px;\n    }\n    to {\n      left: 0;\n    }\n  }\n\n  @keyframes slideout {\n    from {\n      left: 0;\n    }\n    to {\n      left: -500px;\n    }\n  }\n\n  a {\n    color: ${props => buildLinkColor(props)};\n    font-weight: 400;\n    text-decoration: underline;\n    &:not([disabled]) {\n      &:focus,\n      &:hover {\n        color: ${props => buildLinkHoverColor(props)};\n      }\n    }\n  }\n`;\r\nconst StyledAlertInner = styled.div `\n  background: ${buildAlertBackground};\n  border: 1px solid ${buildAlertBorder};\n  border-radius: ${props => props.theme.borderRadius};\n  color: ${buildAlertColor};\n  display: flex;\n  position: relative;\n\n  ${props => props.isToast &&\r\n    css `\n      box-shadow: ${props.isInverse\r\n        ? `0 2px 8px 0 ${transparentize(0.3, props.theme.colors.neutral900)}`\r\n        : `0 2px 8px 0 ${transparentize(0.6, props.theme.colors.neutral900)}`};\n      padding-right: 0;\n      height: ${props.theme.spaceScale.spacing11};\n    `}\n`;\r\nconst AlertContents = styled.div `\n  align-items: ${props => (props.additionalContent ? 'center' : '')};\n  align-self: center;\n  flex-grow: 1;\n  font-family: ${props => props.theme.bodyFont};\n  padding: ${props => props.theme.spaceScale.spacing04} 0;\n  display: ${props => (props.additionalContent ? 'flex' : '')};\n  margin-right: ${props => props.additionalContent && !props.isDismissible\r\n    ? props.theme.spaceScale.spacing03\r\n    : ''};\n  @media (max-width: ${props => props.theme.breakpoints.small}px) {\n    padding-left: 0;\n  }\n`;\r\nexport const AdditionalContentWrapper = styled.div `\n  flex: 1 0 auto;\n  justify-content: flex-end;\n  display: flex;\n  margin-left: ${props => props.theme.spaceScale.spacing05};\n`;\r\nconst IconWrapperStyles = css `\n  align-items: center;\n  display: flex;\n  flex-shrink: 0;\n  margin-right: 1px;\n`;\r\nconst IconWrapper = styled.span `\n  ${IconWrapperStyles}\n  padding: 0 ${props => props.theme.spaceScale.spacing03} 0 ${props => props.theme.spaceScale.spacing04};\n\n  @media (max-width: ${props => props.theme.breakpoints.small}px) {\n    padding: 0 ${props => props.theme.spaceScale.spacing03};\n    svg {\n      width: 20px;\n    }\n  }\n`;\r\nconst ProgressRingWrapper = styled.div `\n  margin-top: 6px;\n  position: absolute;\n  top: auto;\n  right: ${props => props.theme.spaceScale.spacing02};\n`;\r\nconst DismissibleIconWrapper = styled.span `\n  ${IconWrapperStyles}\n  margin-left: ${props => props.additionalContent ? props.theme.spaceScale.spacing03 : ''};\n`;\r\nconst whitelistProps = ['icon', 'isInverse', 'theme', 'variant'];\r\nconst shouldForwardProp = prop => {\r\n    return isPropValid(prop) || whitelistProps.includes(prop);\r\n};\r\nconst DismissButton = styled(IconButton, { shouldForwardProp }) `\n  align-self: stretch;\n  border-radius: 0 ${props => props.theme.borderRadius}\n    ${props => props.theme.borderRadius} 0;\n  color: inherit;\n  height: auto;\n  margin: ${props => (props.isToast ? '4px' : '0 -1px 0 0')};\n  padding: ${props => props.isToast\r\n    ? `0 ${props.theme.spaceScale.spacing04}`\r\n    : `0 ${props.theme.spaceScale.spacing03}`};\n  width: auto;\n  &:not(:disabled):hover {\n    background: none;\n    color: inherit;\n  }\n  &:focus:not(:disabled) {\n    background: none;\n    color: inherit;\n    outline: 2px solid\n      ${props => props.isInverse\r\n    ? props.theme.colors.focusInverse\r\n    : props.theme.colors.focus};\n    outline-offset: 0 !important;\n  }\n  &:not(:disabled):active {\n    background: none;\n    color: inherit;\n  }\n`;\r\nconst AlertSpan = styled.span `\n  white-space: pre-line;\n`;\r\nfunction renderIcon(variant = 'info', isToast, theme) {\r\n    const Icon = VARIANT_ICON[variant];\r\n    return (React.createElement(IconWrapper, { isToast: isToast, theme: theme },\r\n        React.createElement(Icon, { size: theme.iconSizes.medium })));\r\n}\r\nexport const AlertBase = React.forwardRef((props, ref) => {\r\n    const { additionalContent, children, closeAriaLabel, forceDismiss, hasTimerRing, id: defaultId, isDismissed, isDismissible, isExiting: externalIsExiting, isPaused, isToast, onDismiss, testId, toastDuration, variant, ...other } = props;\r\n    const id = useGenerateId(defaultId);\r\n    const [isExiting, setIsExiting] = React.useState(false);\r\n    const isInverse = useIsInverse(props.isInverse);\r\n    React.useEffect(() => {\r\n        if (isExiting) {\r\n            setTimeout(() => {\r\n                setIsExiting(false);\r\n                onDismiss && typeof onDismiss === 'function' && onDismiss();\r\n            }, transitionDuration - 300);\r\n        }\r\n    }, [isExiting]);\r\n    React.useEffect(() => {\r\n        if (isDismissed) {\r\n            handleDismiss();\r\n        }\r\n    }, [isDismissed]);\r\n    function handleDismiss() {\r\n        setIsExiting(true);\r\n    }\r\n    const theme = React.useContext(ThemeContext);\r\n    const i18n = React.useContext(I18nContext);\r\n    function progressRingColor() {\r\n        if (isInverse) {\r\n            return theme.colors.neutral100;\r\n        }\r\n        switch (props.variant) {\r\n            case 'success':\r\n                return theme.colors.success500;\r\n            case 'warning':\r\n                return theme.colors.warning500;\r\n            case 'danger':\r\n                return theme.colors.danger500;\r\n            default:\r\n                return theme.colors.info500;\r\n        }\r\n    }\r\n    return (React.createElement(StyledAlert, Object.assign({}, other, { \"data-testid\": testId, id: id, tabIndex: -1, isInverse: isInverse, isExiting: isExiting, isToast: isToast, ref: ref, theme: theme, variant: variant }),\r\n        React.createElement(InverseContext.Provider, { value: { isInverse } },\r\n            React.createElement(StyledAlertInner, { isInverse: isInverse, isToast: isToast, theme: theme, variant: variant },\r\n                renderIcon(variant, isToast, theme),\r\n                React.createElement(AlertContents, { additionalContent: additionalContent, isDismissible: isDismissible, theme: theme },\r\n                    React.createElement(AlertSpan, null, children),\r\n                    additionalContent && (React.createElement(AdditionalContentWrapper, { theme: theme }, additionalContent))),\r\n                isDismissible && (React.createElement(DismissibleIconWrapper, { isInverse: isInverse, variant: variant, theme: theme },\r\n                    hasTimerRing && isToast && (React.createElement(ProgressRingWrapper, { theme: theme },\r\n                        React.createElement(ProgressRing, { color: progressRingColor(), isActive: !isPaused, duration: toastDuration }))),\r\n                    React.createElement(DismissButton, { alertVariant: variant, \"aria-label\": closeAriaLabel\r\n                            ? closeAriaLabel\r\n                            : i18n.alert.dismissAriaLabel, icon: React.createElement(CloseIcon, { size: hasTimerRing\r\n                                ? theme.iconSizes.xSmall\r\n                                : theme.iconSizes.small }), isInverse: isInverse, isToast: isToast, onClick: forceDismiss || handleDismiss, theme: theme, variant: ButtonVariant.link })))))));\r\n});\r\n//# sourceMappingURL=index.js.map"]} */"));
3688
+ }, "px){padding-left:0;}" + (process.env.NODE_ENV === "production" ? "" : "/*# sourceMappingURL=data:application/json;charset=utf-8;base64,{"version":3,"sources":["index.tsx"],"names":[],"mappings":"AA4OiC","file":"index.tsx","sourcesContent":["import * as React from 'react';\r\nimport { css } from '@emotion/react';\r\nimport isPropValid from '@emotion/is-prop-valid';\r\nimport { transparentize } from 'polished';\r\nimport { ThemeContext } from '../../theme/ThemeContext';\r\nimport { InfoIcon, CheckCircleIcon, WarningIcon, ErrorIcon, CloseIcon, } from 'react-magma-icons';\r\nimport { ButtonVariant } from '../Button';\r\nimport { IconButton } from '../IconButton';\r\nimport { ProgressRing } from '../ProgressRing';\r\nimport { useGenerateId } from '../../utils';\r\nimport { I18nContext } from '../../i18n';\r\nimport { InverseContext, useIsInverse } from '../../inverse';\r\nimport styled from '@emotion/styled';\r\nexport const VARIANT_ICON = {\r\n    info: InfoIcon,\r\n    success: CheckCircleIcon,\r\n    warning: WarningIcon,\r\n    danger: ErrorIcon,\r\n};\r\nexport var AlertVariant;\r\n(function (AlertVariant) {\r\n    AlertVariant[\"info\"] = \"info\";\r\n    AlertVariant[\"success\"] = \"success\";\r\n    AlertVariant[\"warning\"] = \"warning\";\r\n    AlertVariant[\"danger\"] = \"danger\";\r\n})(AlertVariant || (AlertVariant = {}));\r\nexport const transitionDuration = 500;\r\nexport function buildAlertBackground(props) {\r\n    if (props.isInverse) {\r\n        switch (props.variant) {\r\n            case 'success':\r\n                return props.theme.colors.success700;\r\n            case 'warning':\r\n                return props.theme.colors.warning700;\r\n            case 'danger':\r\n                return props.theme.colors.danger700;\r\n            default:\r\n                return props.theme.colors.info700;\r\n        }\r\n    }\r\n    switch (props.variant) {\r\n        case 'success':\r\n            return props.theme.colors.success100;\r\n        case 'warning':\r\n            return props.theme.colors.warning100;\r\n        case 'danger':\r\n            return props.theme.colors.danger100;\r\n        default:\r\n            return props.theme.colors.info100;\r\n    }\r\n}\r\nexport function buildAlertBorder(props) {\r\n    if (props.isInverse) {\r\n        switch (props.variant) {\r\n            case 'success':\r\n                return props.theme.colors.success300;\r\n            case 'warning':\r\n                return props.theme.colors.warning300;\r\n            case 'danger':\r\n                return props.theme.colors.danger200;\r\n            default:\r\n                return props.theme.colors.info300;\r\n        }\r\n    }\r\n    switch (props.variant) {\r\n        case 'success':\r\n            return props.theme.colors.success500;\r\n        case 'warning':\r\n            return props.theme.colors.warning500;\r\n        case 'danger':\r\n            return props.theme.colors.danger500;\r\n        default:\r\n            return props.theme.colors.info500;\r\n    }\r\n}\r\nexport function buildAlertColor(props) {\r\n    if (props.isInverse) {\r\n        return props.theme.colors.neutral100;\r\n    }\r\n    switch (props.variant) {\r\n        case 'success':\r\n            return props.theme.colors.success500;\r\n        case 'warning':\r\n            return props.theme.colors.warning500;\r\n        case 'danger':\r\n            return props.theme.colors.danger500;\r\n        default:\r\n            return props.theme.colors.info500;\r\n    }\r\n}\r\nexport function buildLinkColor(props) {\r\n    if (props.isInverse) {\r\n        switch (props.variant) {\r\n            case 'success':\r\n                return props.theme.colors.success200;\r\n            case 'warning':\r\n                return props.theme.colors.warning200;\r\n            case 'danger':\r\n                return props.theme.colors.danger200;\r\n            default:\r\n                return props.theme.colors.info200;\r\n        }\r\n    }\r\n    switch (props.variant) {\r\n        case 'success':\r\n            return props.theme.colors.success700;\r\n        case 'warning':\r\n            return props.theme.colors.warning700;\r\n        case 'danger':\r\n            return props.theme.colors.danger700;\r\n        default:\r\n            return props.theme.colors.info700;\r\n    }\r\n}\r\nexport function buildLinkHoverColor(props) {\r\n    if (props.isInverse) {\r\n        return props.theme.colors.neutral100;\r\n    }\r\n    switch (props.variant) {\r\n        case 'success':\r\n            return props.theme.colors.success;\r\n        case 'warning':\r\n            return props.theme.colors.warning;\r\n        case 'danger':\r\n            return props.theme.colors.danger;\r\n        default:\r\n            return props.theme.colors.info;\r\n    }\r\n}\r\nconst StyledAlert = styled.div `\n  align-items: stretch;\n  animation: ${props => props.isExiting\r\n    ? `fadeout ${transitionDuration}ms`\r\n    : `fadein ${transitionDuration}ms`};\n  display: flex;\n  flex-direction: column;\n  font-size: ${props => props.theme.typeScale.size03.fontSize};\n  font-family: ${props => props.theme.bodyFont};\n  line-height: ${props => props.theme.typeScale.size03.lineHeight};\n  margin-bottom: ${props => props.theme.spaceScale.spacing06};\n  max-width: 100%;\n  padding: 0;\n  position: relative;\n\n  @media (max-width: ${props => props.theme.breakpoints.small}px) {\n    font-size: ${props => props.theme.typeScale.size02.fontSize};\n    letter-spacing: ${props => props.theme.typeScale.size02.letterSpacing};\n    line-height: ${props => props.theme.typeScale.size02.lineHeight};\n  }\n\n  &:focus {\n    outline: 2px solid\n      ${props => props.isInverse\r\n    ? props.theme.colors.focusInverse\r\n    : props.theme.colors.focus};\n  }\n\n  ${props => props.isToast &&\r\n    css `\n      animation: ${props.isExiting\r\n        ? `slideout ${transitionDuration}ms`\r\n        : `slidein ${transitionDuration}ms`};\n      min-width: 375px;\n      margin: 0 auto;\n\n      @media (max-width: ${props.theme.breakpoints.small}px) {\n        min-width: 0;\n        width: 100%;\n      }\n    `}\n\n  @keyframes fadein {\n    from {\n      opacity: 0;\n    }\n    to {\n      opacity: 1;\n    }\n  }\n\n  @keyframes fadeout {\n    from {\n      opacity: 1;\n    }\n    to {\n      opacity: 0;\n    }\n  }\n\n  @keyframes slidein {\n    from {\n      left: -500px;\n    }\n    to {\n      left: 0;\n    }\n  }\n\n  @keyframes slideout {\n    from {\n      left: 0;\n    }\n    to {\n      left: -500px;\n    }\n  }\n\n  a {\n    color: ${props => buildLinkColor(props)};\n    font-weight: 400;\n    text-decoration: underline;\n    &:not([disabled]) {\n      &:focus,\n      &:hover {\n        color: ${props => buildLinkHoverColor(props)};\n      }\n    }\n  }\n`;\r\nconst StyledAlertInner = styled.div `\n  background: ${buildAlertBackground};\n  border: 1px solid ${buildAlertBorder};\n  border-radius: ${props => props.theme.borderRadius};\n  color: ${buildAlertColor};\n  display: flex;\n  position: relative;\n\n  ${props => props.isToast &&\r\n    css `\n      box-shadow: ${props.isInverse\r\n        ? `0 2px 8px 0 ${transparentize(0.3, props.theme.colors.neutral900)}`\r\n        : `0 2px 8px 0 ${transparentize(0.6, props.theme.colors.neutral900)}`};\n      padding-right: 0;\n      height: ${props.theme.spaceScale.spacing11};\n    `}\n`;\r\nconst AlertContents = styled.div `\n  align-items: ${props => (props.additionalContent ? 'center' : '')};\n  align-self: center;\n  flex-grow: 1;\n  font-family: ${props => props.theme.bodyFont};\n  padding: ${props => props.theme.spaceScale.spacing04} 0;\n  display: ${props => (props.additionalContent ? 'flex' : '')};\n  margin-right: ${props => props.additionalContent && !props.isDismissible\r\n    ? props.theme.spaceScale.spacing03\r\n    : ''};\n  @media (max-width: ${props => props.theme.breakpoints.small}px) {\n    padding-left: 0;\n  }\n`;\r\nexport const AdditionalContentWrapper = styled.div `\n  flex: 1 0 auto;\n  justify-content: flex-end;\n  display: flex;\n  margin-left: ${props => props.theme.spaceScale.spacing05};\n`;\r\nconst IconWrapperStyles = css `\n  align-items: center;\n  display: flex;\n  flex-shrink: 0;\n  margin-right: 1px;\n`;\r\nconst IconWrapper = styled.span `\n  ${IconWrapperStyles}\n  padding: 0 ${props => props.theme.spaceScale.spacing03} 0 ${props => props.theme.spaceScale.spacing04};\n\n  @media (max-width: ${props => props.theme.breakpoints.small}px) {\n    padding: 0 ${props => props.theme.spaceScale.spacing03};\n    svg {\n      width: 20px;\n    }\n  }\n`;\r\nconst ProgressRingWrapper = styled.div `\n  margin-top: 6px;\n  position: absolute;\n  top: auto;\n  right: ${props => props.theme.spaceScale.spacing02};\n`;\r\nconst DismissibleIconWrapper = styled.span `\n  ${IconWrapperStyles}\n  margin-left: ${props => props.additionalContent ? props.theme.spaceScale.spacing03 : ''};\n`;\r\nconst whitelistProps = ['icon', 'isInverse', 'theme', 'variant'];\r\nconst shouldForwardProp = prop => {\r\n    return isPropValid(prop) || whitelistProps.includes(prop);\r\n};\r\nconst DismissButton = styled(IconButton, { shouldForwardProp }) `\n  align-self: stretch;\n  border-radius: 0 ${props => props.theme.borderRadius}\n    ${props => props.theme.borderRadius} 0;\n  color: inherit;\n  height: auto;\n  margin: ${props => (props.isToast ? '4px' : '0 -1px 0 0')};\n  padding: ${props => props.isToast\r\n    ? `0 ${props.theme.spaceScale.spacing04}`\r\n    : `0 ${props.theme.spaceScale.spacing03}`};\n  width: auto;\n  &:not(:disabled):hover {\n    background: none;\n    color: inherit;\n  }\n  &:focus:not(:disabled) {\n    background: none;\n    color: inherit;\n    outline: 2px solid\n      ${props => props.isInverse\r\n    ? props.theme.colors.focusInverse\r\n    : props.theme.colors.focus};\n    outline-offset: 0 !important;\n  }\n  &:not(:disabled):active {\n    background: none;\n    color: inherit;\n  }\n`;\r\nconst AlertSpan = styled.span `\n  white-space: pre-line;\n`;\r\nfunction renderIcon(variant = 'info', isToast, theme) {\r\n    const Icon = VARIANT_ICON[variant];\r\n    return (React.createElement(IconWrapper, { isToast: isToast, theme: theme },\r\n        React.createElement(Icon, { size: theme.iconSizes.medium })));\r\n}\r\nexport const AlertBase = React.forwardRef((props, ref) => {\r\n    const { additionalContent, children, closeAriaLabel, forceDismiss, hasTimerRing, id: defaultId, isDismissed, isDismissible, isExiting: externalIsExiting, isPaused, isToast, onDismiss, testId, toastDuration, variant, ...other } = props;\r\n    const id = useGenerateId(defaultId);\r\n    const [isExiting, setIsExiting] = React.useState(false);\r\n    const isInverse = useIsInverse(props.isInverse);\r\n    React.useEffect(() => {\r\n        if (isExiting) {\r\n            setTimeout(() => {\r\n                setIsExiting(false);\r\n                onDismiss && typeof onDismiss === 'function' && onDismiss();\r\n            }, transitionDuration - 300);\r\n        }\r\n    }, [isExiting]);\r\n    React.useEffect(() => {\r\n        if (isDismissed) {\r\n            handleDismiss();\r\n        }\r\n    }, [isDismissed]);\r\n    function handleDismiss() {\r\n        setIsExiting(true);\r\n    }\r\n    const theme = React.useContext(ThemeContext);\r\n    const i18n = React.useContext(I18nContext);\r\n    function progressRingColor() {\r\n        if (isInverse) {\r\n            return theme.colors.neutral100;\r\n        }\r\n        switch (props.variant) {\r\n            case 'success':\r\n                return theme.colors.success500;\r\n            case 'warning':\r\n                return theme.colors.warning500;\r\n            case 'danger':\r\n                return theme.colors.danger500;\r\n            default:\r\n                return theme.colors.info500;\r\n        }\r\n    }\r\n    return (React.createElement(StyledAlert, Object.assign({}, other, { \"data-testid\": testId, id: id, tabIndex: -1, isInverse: isInverse, isExiting: isExiting, isToast: isToast, ref: ref, theme: theme, variant: variant }),\r\n        React.createElement(InverseContext.Provider, { value: { isInverse } },\r\n            React.createElement(StyledAlertInner, { isInverse: isInverse, isToast: isToast, theme: theme, variant: variant },\r\n                renderIcon(variant, isToast, theme),\r\n                React.createElement(AlertContents, { additionalContent: additionalContent, isDismissible: isDismissible, theme: theme },\r\n                    React.createElement(AlertSpan, null, children),\r\n                    additionalContent && (React.createElement(AdditionalContentWrapper, { theme: theme }, additionalContent))),\r\n                isDismissible && (React.createElement(DismissibleIconWrapper, { isInverse: isInverse, variant: variant, theme: theme },\r\n                    hasTimerRing && isToast && (React.createElement(ProgressRingWrapper, { theme: theme },\r\n                        React.createElement(ProgressRing, { color: progressRingColor(), isActive: !isPaused, duration: toastDuration }))),\r\n                    React.createElement(DismissButton, Object.assign({ alertVariant: variant }, (isToast\r\n                        ? { title: closeAriaLabel || i18n.alert.dismissAriaLabel }\r\n                        : {\r\n                            'aria-label': closeAriaLabel || i18n.alert.dismissAriaLabel,\r\n                        }), { icon: React.createElement(CloseIcon, { size: hasTimerRing\r\n                                ? theme.iconSizes.xSmall\r\n                                : theme.iconSizes.small }), isInverse: isInverse, isToast: isToast, onClick: forceDismiss || handleDismiss, theme: theme, variant: ButtonVariant.link }))))))));\r\n});\r\n//# sourceMappingURL=index.js.map"]} */"));
3689
3689
  var AdditionalContentWrapper = /*#__PURE__*/_styled("div", {
3690
3690
  target: "e126n3g85",
3691
3691
  label: "AdditionalContentWrapper"
3692
3692
  })("flex:1 0 auto;justify-content:flex-end;display:flex;margin-left:", function (props) {
3693
3693
  return props.theme.spaceScale.spacing05;
3694
- }, ";" + (process.env.NODE_ENV === "production" ? "" : "/*# sourceMappingURL=data:application/json;charset=utf-8;base64,{"version":3,"sources":["index.tsx"],"names":[],"mappings":"AA0PmD","file":"index.tsx","sourcesContent":["import * as React from 'react';\r\nimport { css } from '@emotion/react';\r\nimport isPropValid from '@emotion/is-prop-valid';\r\nimport { transparentize } from 'polished';\r\nimport { ThemeContext } from '../../theme/ThemeContext';\r\nimport { InfoIcon, CheckCircleIcon, WarningIcon, ErrorIcon, CloseIcon, } from 'react-magma-icons';\r\nimport { ButtonVariant } from '../Button';\r\nimport { IconButton } from '../IconButton';\r\nimport { ProgressRing } from '../ProgressRing';\r\nimport { useGenerateId } from '../../utils';\r\nimport { I18nContext } from '../../i18n';\r\nimport { InverseContext, useIsInverse } from '../../inverse';\r\nimport styled from '@emotion/styled';\r\nexport const VARIANT_ICON = {\r\n    info: InfoIcon,\r\n    success: CheckCircleIcon,\r\n    warning: WarningIcon,\r\n    danger: ErrorIcon,\r\n};\r\nexport var AlertVariant;\r\n(function (AlertVariant) {\r\n    AlertVariant[\"info\"] = \"info\";\r\n    AlertVariant[\"success\"] = \"success\";\r\n    AlertVariant[\"warning\"] = \"warning\";\r\n    AlertVariant[\"danger\"] = \"danger\";\r\n})(AlertVariant || (AlertVariant = {}));\r\nexport const transitionDuration = 500;\r\nexport function buildAlertBackground(props) {\r\n    if (props.isInverse) {\r\n        switch (props.variant) {\r\n            case 'success':\r\n                return props.theme.colors.success700;\r\n            case 'warning':\r\n                return props.theme.colors.warning700;\r\n            case 'danger':\r\n                return props.theme.colors.danger700;\r\n            default:\r\n                return props.theme.colors.info700;\r\n        }\r\n    }\r\n    switch (props.variant) {\r\n        case 'success':\r\n            return props.theme.colors.success100;\r\n        case 'warning':\r\n            return props.theme.colors.warning100;\r\n        case 'danger':\r\n            return props.theme.colors.danger100;\r\n        default:\r\n            return props.theme.colors.info100;\r\n    }\r\n}\r\nexport function buildAlertBorder(props) {\r\n    if (props.isInverse) {\r\n        switch (props.variant) {\r\n            case 'success':\r\n                return props.theme.colors.success300;\r\n            case 'warning':\r\n                return props.theme.colors.warning300;\r\n            case 'danger':\r\n                return props.theme.colors.danger200;\r\n            default:\r\n                return props.theme.colors.info300;\r\n        }\r\n    }\r\n    switch (props.variant) {\r\n        case 'success':\r\n            return props.theme.colors.success500;\r\n        case 'warning':\r\n            return props.theme.colors.warning500;\r\n        case 'danger':\r\n            return props.theme.colors.danger500;\r\n        default:\r\n            return props.theme.colors.info500;\r\n    }\r\n}\r\nexport function buildAlertColor(props) {\r\n    if (props.isInverse) {\r\n        return props.theme.colors.neutral100;\r\n    }\r\n    switch (props.variant) {\r\n        case 'success':\r\n            return props.theme.colors.success500;\r\n        case 'warning':\r\n            return props.theme.colors.warning500;\r\n        case 'danger':\r\n            return props.theme.colors.danger500;\r\n        default:\r\n            return props.theme.colors.info500;\r\n    }\r\n}\r\nexport function buildLinkColor(props) {\r\n    if (props.isInverse) {\r\n        switch (props.variant) {\r\n            case 'success':\r\n                return props.theme.colors.success200;\r\n            case 'warning':\r\n                return props.theme.colors.warning200;\r\n            case 'danger':\r\n                return props.theme.colors.danger200;\r\n            default:\r\n                return props.theme.colors.info200;\r\n        }\r\n    }\r\n    switch (props.variant) {\r\n        case 'success':\r\n            return props.theme.colors.success700;\r\n        case 'warning':\r\n            return props.theme.colors.warning700;\r\n        case 'danger':\r\n            return props.theme.colors.danger700;\r\n        default:\r\n            return props.theme.colors.info700;\r\n    }\r\n}\r\nexport function buildLinkHoverColor(props) {\r\n    if (props.isInverse) {\r\n        return props.theme.colors.neutral100;\r\n    }\r\n    switch (props.variant) {\r\n        case 'success':\r\n            return props.theme.colors.success;\r\n        case 'warning':\r\n            return props.theme.colors.warning;\r\n        case 'danger':\r\n            return props.theme.colors.danger;\r\n        default:\r\n            return props.theme.colors.info;\r\n    }\r\n}\r\nconst StyledAlert = styled.div `\n  align-items: stretch;\n  animation: ${props => props.isExiting\r\n    ? `fadeout ${transitionDuration}ms`\r\n    : `fadein ${transitionDuration}ms`};\n  display: flex;\n  flex-direction: column;\n  font-size: ${props => props.theme.typeScale.size03.fontSize};\n  font-family: ${props => props.theme.bodyFont};\n  line-height: ${props => props.theme.typeScale.size03.lineHeight};\n  margin-bottom: ${props => props.theme.spaceScale.spacing06};\n  max-width: 100%;\n  padding: 0;\n  position: relative;\n\n  @media (max-width: ${props => props.theme.breakpoints.small}px) {\n    font-size: ${props => props.theme.typeScale.size02.fontSize};\n    letter-spacing: ${props => props.theme.typeScale.size02.letterSpacing};\n    line-height: ${props => props.theme.typeScale.size02.lineHeight};\n  }\n\n  &:focus {\n    outline: 2px solid\n      ${props => props.isInverse\r\n    ? props.theme.colors.focusInverse\r\n    : props.theme.colors.focus};\n  }\n\n  ${props => props.isToast &&\r\n    css `\n      animation: ${props.isExiting\r\n        ? `slideout ${transitionDuration}ms`\r\n        : `slidein ${transitionDuration}ms`};\n      min-width: 375px;\n      margin: 0 auto;\n\n      @media (max-width: ${props.theme.breakpoints.small}px) {\n        min-width: 0;\n        width: 100%;\n      }\n    `}\n\n  @keyframes fadein {\n    from {\n      opacity: 0;\n    }\n    to {\n      opacity: 1;\n    }\n  }\n\n  @keyframes fadeout {\n    from {\n      opacity: 1;\n    }\n    to {\n      opacity: 0;\n    }\n  }\n\n  @keyframes slidein {\n    from {\n      left: -500px;\n    }\n    to {\n      left: 0;\n    }\n  }\n\n  @keyframes slideout {\n    from {\n      left: 0;\n    }\n    to {\n      left: -500px;\n    }\n  }\n\n  a {\n    color: ${props => buildLinkColor(props)};\n    font-weight: 400;\n    text-decoration: underline;\n    &:not([disabled]) {\n      &:focus,\n      &:hover {\n        color: ${props => buildLinkHoverColor(props)};\n      }\n    }\n  }\n`;\r\nconst StyledAlertInner = styled.div `\n  background: ${buildAlertBackground};\n  border: 1px solid ${buildAlertBorder};\n  border-radius: ${props => props.theme.borderRadius};\n  color: ${buildAlertColor};\n  display: flex;\n  position: relative;\n\n  ${props => props.isToast &&\r\n    css `\n      box-shadow: ${props.isInverse\r\n        ? `0 2px 8px 0 ${transparentize(0.3, props.theme.colors.neutral900)}`\r\n        : `0 2px 8px 0 ${transparentize(0.6, props.theme.colors.neutral900)}`};\n      padding-right: 0;\n      height: ${props.theme.spaceScale.spacing11};\n    `}\n`;\r\nconst AlertContents = styled.div `\n  align-items: ${props => (props.additionalContent ? 'center' : '')};\n  align-self: center;\n  flex-grow: 1;\n  font-family: ${props => props.theme.bodyFont};\n  padding: ${props => props.theme.spaceScale.spacing04} 0;\n  display: ${props => (props.additionalContent ? 'flex' : '')};\n  margin-right: ${props => props.additionalContent && !props.isDismissible\r\n    ? props.theme.spaceScale.spacing03\r\n    : ''};\n  @media (max-width: ${props => props.theme.breakpoints.small}px) {\n    padding-left: 0;\n  }\n`;\r\nexport const AdditionalContentWrapper = styled.div `\n  flex: 1 0 auto;\n  justify-content: flex-end;\n  display: flex;\n  margin-left: ${props => props.theme.spaceScale.spacing05};\n`;\r\nconst IconWrapperStyles = css `\n  align-items: center;\n  display: flex;\n  flex-shrink: 0;\n  margin-right: 1px;\n`;\r\nconst IconWrapper = styled.span `\n  ${IconWrapperStyles}\n  padding: 0 ${props => props.theme.spaceScale.spacing03} 0 ${props => props.theme.spaceScale.spacing04};\n\n  @media (max-width: ${props => props.theme.breakpoints.small}px) {\n    padding: 0 ${props => props.theme.spaceScale.spacing03};\n    svg {\n      width: 20px;\n    }\n  }\n`;\r\nconst ProgressRingWrapper = styled.div `\n  margin-top: 6px;\n  position: absolute;\n  top: auto;\n  right: ${props => props.theme.spaceScale.spacing02};\n`;\r\nconst DismissibleIconWrapper = styled.span `\n  ${IconWrapperStyles}\n  margin-left: ${props => props.additionalContent ? props.theme.spaceScale.spacing03 : ''};\n`;\r\nconst whitelistProps = ['icon', 'isInverse', 'theme', 'variant'];\r\nconst shouldForwardProp = prop => {\r\n    return isPropValid(prop) || whitelistProps.includes(prop);\r\n};\r\nconst DismissButton = styled(IconButton, { shouldForwardProp }) `\n  align-self: stretch;\n  border-radius: 0 ${props => props.theme.borderRadius}\n    ${props => props.theme.borderRadius} 0;\n  color: inherit;\n  height: auto;\n  margin: ${props => (props.isToast ? '4px' : '0 -1px 0 0')};\n  padding: ${props => props.isToast\r\n    ? `0 ${props.theme.spaceScale.spacing04}`\r\n    : `0 ${props.theme.spaceScale.spacing03}`};\n  width: auto;\n  &:not(:disabled):hover {\n    background: none;\n    color: inherit;\n  }\n  &:focus:not(:disabled) {\n    background: none;\n    color: inherit;\n    outline: 2px solid\n      ${props => props.isInverse\r\n    ? props.theme.colors.focusInverse\r\n    : props.theme.colors.focus};\n    outline-offset: 0 !important;\n  }\n  &:not(:disabled):active {\n    background: none;\n    color: inherit;\n  }\n`;\r\nconst AlertSpan = styled.span `\n  white-space: pre-line;\n`;\r\nfunction renderIcon(variant = 'info', isToast, theme) {\r\n    const Icon = VARIANT_ICON[variant];\r\n    return (React.createElement(IconWrapper, { isToast: isToast, theme: theme },\r\n        React.createElement(Icon, { size: theme.iconSizes.medium })));\r\n}\r\nexport const AlertBase = React.forwardRef((props, ref) => {\r\n    const { additionalContent, children, closeAriaLabel, forceDismiss, hasTimerRing, id: defaultId, isDismissed, isDismissible, isExiting: externalIsExiting, isPaused, isToast, onDismiss, testId, toastDuration, variant, ...other } = props;\r\n    const id = useGenerateId(defaultId);\r\n    const [isExiting, setIsExiting] = React.useState(false);\r\n    const isInverse = useIsInverse(props.isInverse);\r\n    React.useEffect(() => {\r\n        if (isExiting) {\r\n            setTimeout(() => {\r\n                setIsExiting(false);\r\n                onDismiss && typeof onDismiss === 'function' && onDismiss();\r\n            }, transitionDuration - 300);\r\n        }\r\n    }, [isExiting]);\r\n    React.useEffect(() => {\r\n        if (isDismissed) {\r\n            handleDismiss();\r\n        }\r\n    }, [isDismissed]);\r\n    function handleDismiss() {\r\n        setIsExiting(true);\r\n    }\r\n    const theme = React.useContext(ThemeContext);\r\n    const i18n = React.useContext(I18nContext);\r\n    function progressRingColor() {\r\n        if (isInverse) {\r\n            return theme.colors.neutral100;\r\n        }\r\n        switch (props.variant) {\r\n            case 'success':\r\n                return theme.colors.success500;\r\n            case 'warning':\r\n                return theme.colors.warning500;\r\n            case 'danger':\r\n                return theme.colors.danger500;\r\n            default:\r\n                return theme.colors.info500;\r\n        }\r\n    }\r\n    return (React.createElement(StyledAlert, Object.assign({}, other, { \"data-testid\": testId, id: id, tabIndex: -1, isInverse: isInverse, isExiting: isExiting, isToast: isToast, ref: ref, theme: theme, variant: variant }),\r\n        React.createElement(InverseContext.Provider, { value: { isInverse } },\r\n            React.createElement(StyledAlertInner, { isInverse: isInverse, isToast: isToast, theme: theme, variant: variant },\r\n                renderIcon(variant, isToast, theme),\r\n                React.createElement(AlertContents, { additionalContent: additionalContent, isDismissible: isDismissible, theme: theme },\r\n                    React.createElement(AlertSpan, null, children),\r\n                    additionalContent && (React.createElement(AdditionalContentWrapper, { theme: theme }, additionalContent))),\r\n                isDismissible && (React.createElement(DismissibleIconWrapper, { isInverse: isInverse, variant: variant, theme: theme },\r\n                    hasTimerRing && isToast && (React.createElement(ProgressRingWrapper, { theme: theme },\r\n                        React.createElement(ProgressRing, { color: progressRingColor(), isActive: !isPaused, duration: toastDuration }))),\r\n                    React.createElement(DismissButton, { alertVariant: variant, \"aria-label\": closeAriaLabel\r\n                            ? closeAriaLabel\r\n                            : i18n.alert.dismissAriaLabel, icon: React.createElement(CloseIcon, { size: hasTimerRing\r\n                                ? theme.iconSizes.xSmall\r\n                                : theme.iconSizes.small }), isInverse: isInverse, isToast: isToast, onClick: forceDismiss || handleDismiss, theme: theme, variant: ButtonVariant.link })))))));\r\n});\r\n//# sourceMappingURL=index.js.map"]} */"));
3694
+ }, ";" + (process.env.NODE_ENV === "production" ? "" : "/*# sourceMappingURL=data:application/json;charset=utf-8;base64,{"version":3,"sources":["index.tsx"],"names":[],"mappings":"AA0PmD","file":"index.tsx","sourcesContent":["import * as React from 'react';\r\nimport { css } from '@emotion/react';\r\nimport isPropValid from '@emotion/is-prop-valid';\r\nimport { transparentize } from 'polished';\r\nimport { ThemeContext } from '../../theme/ThemeContext';\r\nimport { InfoIcon, CheckCircleIcon, WarningIcon, ErrorIcon, CloseIcon, } from 'react-magma-icons';\r\nimport { ButtonVariant } from '../Button';\r\nimport { IconButton } from '../IconButton';\r\nimport { ProgressRing } from '../ProgressRing';\r\nimport { useGenerateId } from '../../utils';\r\nimport { I18nContext } from '../../i18n';\r\nimport { InverseContext, useIsInverse } from '../../inverse';\r\nimport styled from '@emotion/styled';\r\nexport const VARIANT_ICON = {\r\n    info: InfoIcon,\r\n    success: CheckCircleIcon,\r\n    warning: WarningIcon,\r\n    danger: ErrorIcon,\r\n};\r\nexport var AlertVariant;\r\n(function (AlertVariant) {\r\n    AlertVariant[\"info\"] = \"info\";\r\n    AlertVariant[\"success\"] = \"success\";\r\n    AlertVariant[\"warning\"] = \"warning\";\r\n    AlertVariant[\"danger\"] = \"danger\";\r\n})(AlertVariant || (AlertVariant = {}));\r\nexport const transitionDuration = 500;\r\nexport function buildAlertBackground(props) {\r\n    if (props.isInverse) {\r\n        switch (props.variant) {\r\n            case 'success':\r\n                return props.theme.colors.success700;\r\n            case 'warning':\r\n                return props.theme.colors.warning700;\r\n            case 'danger':\r\n                return props.theme.colors.danger700;\r\n            default:\r\n                return props.theme.colors.info700;\r\n        }\r\n    }\r\n    switch (props.variant) {\r\n        case 'success':\r\n            return props.theme.colors.success100;\r\n        case 'warning':\r\n            return props.theme.colors.warning100;\r\n        case 'danger':\r\n            return props.theme.colors.danger100;\r\n        default:\r\n            return props.theme.colors.info100;\r\n    }\r\n}\r\nexport function buildAlertBorder(props) {\r\n    if (props.isInverse) {\r\n        switch (props.variant) {\r\n            case 'success':\r\n                return props.theme.colors.success300;\r\n            case 'warning':\r\n                return props.theme.colors.warning300;\r\n            case 'danger':\r\n                return props.theme.colors.danger200;\r\n            default:\r\n                return props.theme.colors.info300;\r\n        }\r\n    }\r\n    switch (props.variant) {\r\n        case 'success':\r\n            return props.theme.colors.success500;\r\n        case 'warning':\r\n            return props.theme.colors.warning500;\r\n        case 'danger':\r\n            return props.theme.colors.danger500;\r\n        default:\r\n            return props.theme.colors.info500;\r\n    }\r\n}\r\nexport function buildAlertColor(props) {\r\n    if (props.isInverse) {\r\n        return props.theme.colors.neutral100;\r\n    }\r\n    switch (props.variant) {\r\n        case 'success':\r\n            return props.theme.colors.success500;\r\n        case 'warning':\r\n            return props.theme.colors.warning500;\r\n        case 'danger':\r\n            return props.theme.colors.danger500;\r\n        default:\r\n            return props.theme.colors.info500;\r\n    }\r\n}\r\nexport function buildLinkColor(props) {\r\n    if (props.isInverse) {\r\n        switch (props.variant) {\r\n            case 'success':\r\n                return props.theme.colors.success200;\r\n            case 'warning':\r\n                return props.theme.colors.warning200;\r\n            case 'danger':\r\n                return props.theme.colors.danger200;\r\n            default:\r\n                return props.theme.colors.info200;\r\n        }\r\n    }\r\n    switch (props.variant) {\r\n        case 'success':\r\n            return props.theme.colors.success700;\r\n        case 'warning':\r\n            return props.theme.colors.warning700;\r\n        case 'danger':\r\n            return props.theme.colors.danger700;\r\n        default:\r\n            return props.theme.colors.info700;\r\n    }\r\n}\r\nexport function buildLinkHoverColor(props) {\r\n    if (props.isInverse) {\r\n        return props.theme.colors.neutral100;\r\n    }\r\n    switch (props.variant) {\r\n        case 'success':\r\n            return props.theme.colors.success;\r\n        case 'warning':\r\n            return props.theme.colors.warning;\r\n        case 'danger':\r\n            return props.theme.colors.danger;\r\n        default:\r\n            return props.theme.colors.info;\r\n    }\r\n}\r\nconst StyledAlert = styled.div `\n  align-items: stretch;\n  animation: ${props => props.isExiting\r\n    ? `fadeout ${transitionDuration}ms`\r\n    : `fadein ${transitionDuration}ms`};\n  display: flex;\n  flex-direction: column;\n  font-size: ${props => props.theme.typeScale.size03.fontSize};\n  font-family: ${props => props.theme.bodyFont};\n  line-height: ${props => props.theme.typeScale.size03.lineHeight};\n  margin-bottom: ${props => props.theme.spaceScale.spacing06};\n  max-width: 100%;\n  padding: 0;\n  position: relative;\n\n  @media (max-width: ${props => props.theme.breakpoints.small}px) {\n    font-size: ${props => props.theme.typeScale.size02.fontSize};\n    letter-spacing: ${props => props.theme.typeScale.size02.letterSpacing};\n    line-height: ${props => props.theme.typeScale.size02.lineHeight};\n  }\n\n  &:focus {\n    outline: 2px solid\n      ${props => props.isInverse\r\n    ? props.theme.colors.focusInverse\r\n    : props.theme.colors.focus};\n  }\n\n  ${props => props.isToast &&\r\n    css `\n      animation: ${props.isExiting\r\n        ? `slideout ${transitionDuration}ms`\r\n        : `slidein ${transitionDuration}ms`};\n      min-width: 375px;\n      margin: 0 auto;\n\n      @media (max-width: ${props.theme.breakpoints.small}px) {\n        min-width: 0;\n        width: 100%;\n      }\n    `}\n\n  @keyframes fadein {\n    from {\n      opacity: 0;\n    }\n    to {\n      opacity: 1;\n    }\n  }\n\n  @keyframes fadeout {\n    from {\n      opacity: 1;\n    }\n    to {\n      opacity: 0;\n    }\n  }\n\n  @keyframes slidein {\n    from {\n      left: -500px;\n    }\n    to {\n      left: 0;\n    }\n  }\n\n  @keyframes slideout {\n    from {\n      left: 0;\n    }\n    to {\n      left: -500px;\n    }\n  }\n\n  a {\n    color: ${props => buildLinkColor(props)};\n    font-weight: 400;\n    text-decoration: underline;\n    &:not([disabled]) {\n      &:focus,\n      &:hover {\n        color: ${props => buildLinkHoverColor(props)};\n      }\n    }\n  }\n`;\r\nconst StyledAlertInner = styled.div `\n  background: ${buildAlertBackground};\n  border: 1px solid ${buildAlertBorder};\n  border-radius: ${props => props.theme.borderRadius};\n  color: ${buildAlertColor};\n  display: flex;\n  position: relative;\n\n  ${props => props.isToast &&\r\n    css `\n      box-shadow: ${props.isInverse\r\n        ? `0 2px 8px 0 ${transparentize(0.3, props.theme.colors.neutral900)}`\r\n        : `0 2px 8px 0 ${transparentize(0.6, props.theme.colors.neutral900)}`};\n      padding-right: 0;\n      height: ${props.theme.spaceScale.spacing11};\n    `}\n`;\r\nconst AlertContents = styled.div `\n  align-items: ${props => (props.additionalContent ? 'center' : '')};\n  align-self: center;\n  flex-grow: 1;\n  font-family: ${props => props.theme.bodyFont};\n  padding: ${props => props.theme.spaceScale.spacing04} 0;\n  display: ${props => (props.additionalContent ? 'flex' : '')};\n  margin-right: ${props => props.additionalContent && !props.isDismissible\r\n    ? props.theme.spaceScale.spacing03\r\n    : ''};\n  @media (max-width: ${props => props.theme.breakpoints.small}px) {\n    padding-left: 0;\n  }\n`;\r\nexport const AdditionalContentWrapper = styled.div `\n  flex: 1 0 auto;\n  justify-content: flex-end;\n  display: flex;\n  margin-left: ${props => props.theme.spaceScale.spacing05};\n`;\r\nconst IconWrapperStyles = css `\n  align-items: center;\n  display: flex;\n  flex-shrink: 0;\n  margin-right: 1px;\n`;\r\nconst IconWrapper = styled.span `\n  ${IconWrapperStyles}\n  padding: 0 ${props => props.theme.spaceScale.spacing03} 0 ${props => props.theme.spaceScale.spacing04};\n\n  @media (max-width: ${props => props.theme.breakpoints.small}px) {\n    padding: 0 ${props => props.theme.spaceScale.spacing03};\n    svg {\n      width: 20px;\n    }\n  }\n`;\r\nconst ProgressRingWrapper = styled.div `\n  margin-top: 6px;\n  position: absolute;\n  top: auto;\n  right: ${props => props.theme.spaceScale.spacing02};\n`;\r\nconst DismissibleIconWrapper = styled.span `\n  ${IconWrapperStyles}\n  margin-left: ${props => props.additionalContent ? props.theme.spaceScale.spacing03 : ''};\n`;\r\nconst whitelistProps = ['icon', 'isInverse', 'theme', 'variant'];\r\nconst shouldForwardProp = prop => {\r\n    return isPropValid(prop) || whitelistProps.includes(prop);\r\n};\r\nconst DismissButton = styled(IconButton, { shouldForwardProp }) `\n  align-self: stretch;\n  border-radius: 0 ${props => props.theme.borderRadius}\n    ${props => props.theme.borderRadius} 0;\n  color: inherit;\n  height: auto;\n  margin: ${props => (props.isToast ? '4px' : '0 -1px 0 0')};\n  padding: ${props => props.isToast\r\n    ? `0 ${props.theme.spaceScale.spacing04}`\r\n    : `0 ${props.theme.spaceScale.spacing03}`};\n  width: auto;\n  &:not(:disabled):hover {\n    background: none;\n    color: inherit;\n  }\n  &:focus:not(:disabled) {\n    background: none;\n    color: inherit;\n    outline: 2px solid\n      ${props => props.isInverse\r\n    ? props.theme.colors.focusInverse\r\n    : props.theme.colors.focus};\n    outline-offset: 0 !important;\n  }\n  &:not(:disabled):active {\n    background: none;\n    color: inherit;\n  }\n`;\r\nconst AlertSpan = styled.span `\n  white-space: pre-line;\n`;\r\nfunction renderIcon(variant = 'info', isToast, theme) {\r\n    const Icon = VARIANT_ICON[variant];\r\n    return (React.createElement(IconWrapper, { isToast: isToast, theme: theme },\r\n        React.createElement(Icon, { size: theme.iconSizes.medium })));\r\n}\r\nexport const AlertBase = React.forwardRef((props, ref) => {\r\n    const { additionalContent, children, closeAriaLabel, forceDismiss, hasTimerRing, id: defaultId, isDismissed, isDismissible, isExiting: externalIsExiting, isPaused, isToast, onDismiss, testId, toastDuration, variant, ...other } = props;\r\n    const id = useGenerateId(defaultId);\r\n    const [isExiting, setIsExiting] = React.useState(false);\r\n    const isInverse = useIsInverse(props.isInverse);\r\n    React.useEffect(() => {\r\n        if (isExiting) {\r\n            setTimeout(() => {\r\n                setIsExiting(false);\r\n                onDismiss && typeof onDismiss === 'function' && onDismiss();\r\n            }, transitionDuration - 300);\r\n        }\r\n    }, [isExiting]);\r\n    React.useEffect(() => {\r\n        if (isDismissed) {\r\n            handleDismiss();\r\n        }\r\n    }, [isDismissed]);\r\n    function handleDismiss() {\r\n        setIsExiting(true);\r\n    }\r\n    const theme = React.useContext(ThemeContext);\r\n    const i18n = React.useContext(I18nContext);\r\n    function progressRingColor() {\r\n        if (isInverse) {\r\n            return theme.colors.neutral100;\r\n        }\r\n        switch (props.variant) {\r\n            case 'success':\r\n                return theme.colors.success500;\r\n            case 'warning':\r\n                return theme.colors.warning500;\r\n            case 'danger':\r\n                return theme.colors.danger500;\r\n            default:\r\n                return theme.colors.info500;\r\n        }\r\n    }\r\n    return (React.createElement(StyledAlert, Object.assign({}, other, { \"data-testid\": testId, id: id, tabIndex: -1, isInverse: isInverse, isExiting: isExiting, isToast: isToast, ref: ref, theme: theme, variant: variant }),\r\n        React.createElement(InverseContext.Provider, { value: { isInverse } },\r\n            React.createElement(StyledAlertInner, { isInverse: isInverse, isToast: isToast, theme: theme, variant: variant },\r\n                renderIcon(variant, isToast, theme),\r\n                React.createElement(AlertContents, { additionalContent: additionalContent, isDismissible: isDismissible, theme: theme },\r\n                    React.createElement(AlertSpan, null, children),\r\n                    additionalContent && (React.createElement(AdditionalContentWrapper, { theme: theme }, additionalContent))),\r\n                isDismissible && (React.createElement(DismissibleIconWrapper, { isInverse: isInverse, variant: variant, theme: theme },\r\n                    hasTimerRing && isToast && (React.createElement(ProgressRingWrapper, { theme: theme },\r\n                        React.createElement(ProgressRing, { color: progressRingColor(), isActive: !isPaused, duration: toastDuration }))),\r\n                    React.createElement(DismissButton, Object.assign({ alertVariant: variant }, (isToast\r\n                        ? { title: closeAriaLabel || i18n.alert.dismissAriaLabel }\r\n                        : {\r\n                            'aria-label': closeAriaLabel || i18n.alert.dismissAriaLabel,\r\n                        }), { icon: React.createElement(CloseIcon, { size: hasTimerRing\r\n                                ? theme.iconSizes.xSmall\r\n                                : theme.iconSizes.small }), isInverse: isInverse, isToast: isToast, onClick: forceDismiss || handleDismiss, theme: theme, variant: ButtonVariant.link }))))))));\r\n});\r\n//# sourceMappingURL=index.js.map"]} */"));
3695
3695
  var IconWrapperStyles = process.env.NODE_ENV === "production" ? {
3696
3696
  name: "1tjzeyt-IconWrapperStyles",
3697
3697
  styles: "align-items:center;display:flex;flex-shrink:0;margin-right:1px;label:IconWrapperStyles;"
3698
3698
  } : {
3699
3699
  name: "1tjzeyt-IconWrapperStyles",
3700
3700
  styles: "align-items:center;display:flex;flex-shrink:0;margin-right:1px;label:IconWrapperStyles;",
3701
- map: "/*# sourceMappingURL=data:application/json;charset=utf-8;base64,{"version":3,"sources":["index.tsx"],"names":[],"mappings":"AAgQ8B","file":"index.tsx","sourcesContent":["import * as React from 'react';\r\nimport { css } from '@emotion/react';\r\nimport isPropValid from '@emotion/is-prop-valid';\r\nimport { transparentize } from 'polished';\r\nimport { ThemeContext } from '../../theme/ThemeContext';\r\nimport { InfoIcon, CheckCircleIcon, WarningIcon, ErrorIcon, CloseIcon, } from 'react-magma-icons';\r\nimport { ButtonVariant } from '../Button';\r\nimport { IconButton } from '../IconButton';\r\nimport { ProgressRing } from '../ProgressRing';\r\nimport { useGenerateId } from '../../utils';\r\nimport { I18nContext } from '../../i18n';\r\nimport { InverseContext, useIsInverse } from '../../inverse';\r\nimport styled from '@emotion/styled';\r\nexport const VARIANT_ICON = {\r\n    info: InfoIcon,\r\n    success: CheckCircleIcon,\r\n    warning: WarningIcon,\r\n    danger: ErrorIcon,\r\n};\r\nexport var AlertVariant;\r\n(function (AlertVariant) {\r\n    AlertVariant[\"info\"] = \"info\";\r\n    AlertVariant[\"success\"] = \"success\";\r\n    AlertVariant[\"warning\"] = \"warning\";\r\n    AlertVariant[\"danger\"] = \"danger\";\r\n})(AlertVariant || (AlertVariant = {}));\r\nexport const transitionDuration = 500;\r\nexport function buildAlertBackground(props) {\r\n    if (props.isInverse) {\r\n        switch (props.variant) {\r\n            case 'success':\r\n                return props.theme.colors.success700;\r\n            case 'warning':\r\n                return props.theme.colors.warning700;\r\n            case 'danger':\r\n                return props.theme.colors.danger700;\r\n            default:\r\n                return props.theme.colors.info700;\r\n        }\r\n    }\r\n    switch (props.variant) {\r\n        case 'success':\r\n            return props.theme.colors.success100;\r\n        case 'warning':\r\n            return props.theme.colors.warning100;\r\n        case 'danger':\r\n            return props.theme.colors.danger100;\r\n        default:\r\n            return props.theme.colors.info100;\r\n    }\r\n}\r\nexport function buildAlertBorder(props) {\r\n    if (props.isInverse) {\r\n        switch (props.variant) {\r\n            case 'success':\r\n                return props.theme.colors.success300;\r\n            case 'warning':\r\n                return props.theme.colors.warning300;\r\n            case 'danger':\r\n                return props.theme.colors.danger200;\r\n            default:\r\n                return props.theme.colors.info300;\r\n        }\r\n    }\r\n    switch (props.variant) {\r\n        case 'success':\r\n            return props.theme.colors.success500;\r\n        case 'warning':\r\n            return props.theme.colors.warning500;\r\n        case 'danger':\r\n            return props.theme.colors.danger500;\r\n        default:\r\n            return props.theme.colors.info500;\r\n    }\r\n}\r\nexport function buildAlertColor(props) {\r\n    if (props.isInverse) {\r\n        return props.theme.colors.neutral100;\r\n    }\r\n    switch (props.variant) {\r\n        case 'success':\r\n            return props.theme.colors.success500;\r\n        case 'warning':\r\n            return props.theme.colors.warning500;\r\n        case 'danger':\r\n            return props.theme.colors.danger500;\r\n        default:\r\n            return props.theme.colors.info500;\r\n    }\r\n}\r\nexport function buildLinkColor(props) {\r\n    if (props.isInverse) {\r\n        switch (props.variant) {\r\n            case 'success':\r\n                return props.theme.colors.success200;\r\n            case 'warning':\r\n                return props.theme.colors.warning200;\r\n            case 'danger':\r\n                return props.theme.colors.danger200;\r\n            default:\r\n                return props.theme.colors.info200;\r\n        }\r\n    }\r\n    switch (props.variant) {\r\n        case 'success':\r\n            return props.theme.colors.success700;\r\n        case 'warning':\r\n            return props.theme.colors.warning700;\r\n        case 'danger':\r\n            return props.theme.colors.danger700;\r\n        default:\r\n            return props.theme.colors.info700;\r\n    }\r\n}\r\nexport function buildLinkHoverColor(props) {\r\n    if (props.isInverse) {\r\n        return props.theme.colors.neutral100;\r\n    }\r\n    switch (props.variant) {\r\n        case 'success':\r\n            return props.theme.colors.success;\r\n        case 'warning':\r\n            return props.theme.colors.warning;\r\n        case 'danger':\r\n            return props.theme.colors.danger;\r\n        default:\r\n            return props.theme.colors.info;\r\n    }\r\n}\r\nconst StyledAlert = styled.div `\n  align-items: stretch;\n  animation: ${props => props.isExiting\r\n    ? `fadeout ${transitionDuration}ms`\r\n    : `fadein ${transitionDuration}ms`};\n  display: flex;\n  flex-direction: column;\n  font-size: ${props => props.theme.typeScale.size03.fontSize};\n  font-family: ${props => props.theme.bodyFont};\n  line-height: ${props => props.theme.typeScale.size03.lineHeight};\n  margin-bottom: ${props => props.theme.spaceScale.spacing06};\n  max-width: 100%;\n  padding: 0;\n  position: relative;\n\n  @media (max-width: ${props => props.theme.breakpoints.small}px) {\n    font-size: ${props => props.theme.typeScale.size02.fontSize};\n    letter-spacing: ${props => props.theme.typeScale.size02.letterSpacing};\n    line-height: ${props => props.theme.typeScale.size02.lineHeight};\n  }\n\n  &:focus {\n    outline: 2px solid\n      ${props => props.isInverse\r\n    ? props.theme.colors.focusInverse\r\n    : props.theme.colors.focus};\n  }\n\n  ${props => props.isToast &&\r\n    css `\n      animation: ${props.isExiting\r\n        ? `slideout ${transitionDuration}ms`\r\n        : `slidein ${transitionDuration}ms`};\n      min-width: 375px;\n      margin: 0 auto;\n\n      @media (max-width: ${props.theme.breakpoints.small}px) {\n        min-width: 0;\n        width: 100%;\n      }\n    `}\n\n  @keyframes fadein {\n    from {\n      opacity: 0;\n    }\n    to {\n      opacity: 1;\n    }\n  }\n\n  @keyframes fadeout {\n    from {\n      opacity: 1;\n    }\n    to {\n      opacity: 0;\n    }\n  }\n\n  @keyframes slidein {\n    from {\n      left: -500px;\n    }\n    to {\n      left: 0;\n    }\n  }\n\n  @keyframes slideout {\n    from {\n      left: 0;\n    }\n    to {\n      left: -500px;\n    }\n  }\n\n  a {\n    color: ${props => buildLinkColor(props)};\n    font-weight: 400;\n    text-decoration: underline;\n    &:not([disabled]) {\n      &:focus,\n      &:hover {\n        color: ${props => buildLinkHoverColor(props)};\n      }\n    }\n  }\n`;\r\nconst StyledAlertInner = styled.div `\n  background: ${buildAlertBackground};\n  border: 1px solid ${buildAlertBorder};\n  border-radius: ${props => props.theme.borderRadius};\n  color: ${buildAlertColor};\n  display: flex;\n  position: relative;\n\n  ${props => props.isToast &&\r\n    css `\n      box-shadow: ${props.isInverse\r\n        ? `0 2px 8px 0 ${transparentize(0.3, props.theme.colors.neutral900)}`\r\n        : `0 2px 8px 0 ${transparentize(0.6, props.theme.colors.neutral900)}`};\n      padding-right: 0;\n      height: ${props.theme.spaceScale.spacing11};\n    `}\n`;\r\nconst AlertContents = styled.div `\n  align-items: ${props => (props.additionalContent ? 'center' : '')};\n  align-self: center;\n  flex-grow: 1;\n  font-family: ${props => props.theme.bodyFont};\n  padding: ${props => props.theme.spaceScale.spacing04} 0;\n  display: ${props => (props.additionalContent ? 'flex' : '')};\n  margin-right: ${props => props.additionalContent && !props.isDismissible\r\n    ? props.theme.spaceScale.spacing03\r\n    : ''};\n  @media (max-width: ${props => props.theme.breakpoints.small}px) {\n    padding-left: 0;\n  }\n`;\r\nexport const AdditionalContentWrapper = styled.div `\n  flex: 1 0 auto;\n  justify-content: flex-end;\n  display: flex;\n  margin-left: ${props => props.theme.spaceScale.spacing05};\n`;\r\nconst IconWrapperStyles = css `\n  align-items: center;\n  display: flex;\n  flex-shrink: 0;\n  margin-right: 1px;\n`;\r\nconst IconWrapper = styled.span `\n  ${IconWrapperStyles}\n  padding: 0 ${props => props.theme.spaceScale.spacing03} 0 ${props => props.theme.spaceScale.spacing04};\n\n  @media (max-width: ${props => props.theme.breakpoints.small}px) {\n    padding: 0 ${props => props.theme.spaceScale.spacing03};\n    svg {\n      width: 20px;\n    }\n  }\n`;\r\nconst ProgressRingWrapper = styled.div `\n  margin-top: 6px;\n  position: absolute;\n  top: auto;\n  right: ${props => props.theme.spaceScale.spacing02};\n`;\r\nconst DismissibleIconWrapper = styled.span `\n  ${IconWrapperStyles}\n  margin-left: ${props => props.additionalContent ? props.theme.spaceScale.spacing03 : ''};\n`;\r\nconst whitelistProps = ['icon', 'isInverse', 'theme', 'variant'];\r\nconst shouldForwardProp = prop => {\r\n    return isPropValid(prop) || whitelistProps.includes(prop);\r\n};\r\nconst DismissButton = styled(IconButton, { shouldForwardProp }) `\n  align-self: stretch;\n  border-radius: 0 ${props => props.theme.borderRadius}\n    ${props => props.theme.borderRadius} 0;\n  color: inherit;\n  height: auto;\n  margin: ${props => (props.isToast ? '4px' : '0 -1px 0 0')};\n  padding: ${props => props.isToast\r\n    ? `0 ${props.theme.spaceScale.spacing04}`\r\n    : `0 ${props.theme.spaceScale.spacing03}`};\n  width: auto;\n  &:not(:disabled):hover {\n    background: none;\n    color: inherit;\n  }\n  &:focus:not(:disabled) {\n    background: none;\n    color: inherit;\n    outline: 2px solid\n      ${props => props.isInverse\r\n    ? props.theme.colors.focusInverse\r\n    : props.theme.colors.focus};\n    outline-offset: 0 !important;\n  }\n  &:not(:disabled):active {\n    background: none;\n    color: inherit;\n  }\n`;\r\nconst AlertSpan = styled.span `\n  white-space: pre-line;\n`;\r\nfunction renderIcon(variant = 'info', isToast, theme) {\r\n    const Icon = VARIANT_ICON[variant];\r\n    return (React.createElement(IconWrapper, { isToast: isToast, theme: theme },\r\n        React.createElement(Icon, { size: theme.iconSizes.medium })));\r\n}\r\nexport const AlertBase = React.forwardRef((props, ref) => {\r\n    const { additionalContent, children, closeAriaLabel, forceDismiss, hasTimerRing, id: defaultId, isDismissed, isDismissible, isExiting: externalIsExiting, isPaused, isToast, onDismiss, testId, toastDuration, variant, ...other } = props;\r\n    const id = useGenerateId(defaultId);\r\n    const [isExiting, setIsExiting] = React.useState(false);\r\n    const isInverse = useIsInverse(props.isInverse);\r\n    React.useEffect(() => {\r\n        if (isExiting) {\r\n            setTimeout(() => {\r\n                setIsExiting(false);\r\n                onDismiss && typeof onDismiss === 'function' && onDismiss();\r\n            }, transitionDuration - 300);\r\n        }\r\n    }, [isExiting]);\r\n    React.useEffect(() => {\r\n        if (isDismissed) {\r\n            handleDismiss();\r\n        }\r\n    }, [isDismissed]);\r\n    function handleDismiss() {\r\n        setIsExiting(true);\r\n    }\r\n    const theme = React.useContext(ThemeContext);\r\n    const i18n = React.useContext(I18nContext);\r\n    function progressRingColor() {\r\n        if (isInverse) {\r\n            return theme.colors.neutral100;\r\n        }\r\n        switch (props.variant) {\r\n            case 'success':\r\n                return theme.colors.success500;\r\n            case 'warning':\r\n                return theme.colors.warning500;\r\n            case 'danger':\r\n                return theme.colors.danger500;\r\n            default:\r\n                return theme.colors.info500;\r\n        }\r\n    }\r\n    return (React.createElement(StyledAlert, Object.assign({}, other, { \"data-testid\": testId, id: id, tabIndex: -1, isInverse: isInverse, isExiting: isExiting, isToast: isToast, ref: ref, theme: theme, variant: variant }),\r\n        React.createElement(InverseContext.Provider, { value: { isInverse } },\r\n            React.createElement(StyledAlertInner, { isInverse: isInverse, isToast: isToast, theme: theme, variant: variant },\r\n                renderIcon(variant, isToast, theme),\r\n                React.createElement(AlertContents, { additionalContent: additionalContent, isDismissible: isDismissible, theme: theme },\r\n                    React.createElement(AlertSpan, null, children),\r\n                    additionalContent && (React.createElement(AdditionalContentWrapper, { theme: theme }, additionalContent))),\r\n                isDismissible && (React.createElement(DismissibleIconWrapper, { isInverse: isInverse, variant: variant, theme: theme },\r\n                    hasTimerRing && isToast && (React.createElement(ProgressRingWrapper, { theme: theme },\r\n                        React.createElement(ProgressRing, { color: progressRingColor(), isActive: !isPaused, duration: toastDuration }))),\r\n                    React.createElement(DismissButton, { alertVariant: variant, \"aria-label\": closeAriaLabel\r\n                            ? closeAriaLabel\r\n                            : i18n.alert.dismissAriaLabel, icon: React.createElement(CloseIcon, { size: hasTimerRing\r\n                                ? theme.iconSizes.xSmall\r\n                                : theme.iconSizes.small }), isInverse: isInverse, isToast: isToast, onClick: forceDismiss || handleDismiss, theme: theme, variant: ButtonVariant.link })))))));\r\n});\r\n//# sourceMappingURL=index.js.map"]} */",
3701
+ map: "/*# sourceMappingURL=data:application/json;charset=utf-8;base64,{"version":3,"sources":["index.tsx"],"names":[],"mappings":"AAgQ8B","file":"index.tsx","sourcesContent":["import * as React from 'react';\r\nimport { css } from '@emotion/react';\r\nimport isPropValid from '@emotion/is-prop-valid';\r\nimport { transparentize } from 'polished';\r\nimport { ThemeContext } from '../../theme/ThemeContext';\r\nimport { InfoIcon, CheckCircleIcon, WarningIcon, ErrorIcon, CloseIcon, } from 'react-magma-icons';\r\nimport { ButtonVariant } from '../Button';\r\nimport { IconButton } from '../IconButton';\r\nimport { ProgressRing } from '../ProgressRing';\r\nimport { useGenerateId } from '../../utils';\r\nimport { I18nContext } from '../../i18n';\r\nimport { InverseContext, useIsInverse } from '../../inverse';\r\nimport styled from '@emotion/styled';\r\nexport const VARIANT_ICON = {\r\n    info: InfoIcon,\r\n    success: CheckCircleIcon,\r\n    warning: WarningIcon,\r\n    danger: ErrorIcon,\r\n};\r\nexport var AlertVariant;\r\n(function (AlertVariant) {\r\n    AlertVariant[\"info\"] = \"info\";\r\n    AlertVariant[\"success\"] = \"success\";\r\n    AlertVariant[\"warning\"] = \"warning\";\r\n    AlertVariant[\"danger\"] = \"danger\";\r\n})(AlertVariant || (AlertVariant = {}));\r\nexport const transitionDuration = 500;\r\nexport function buildAlertBackground(props) {\r\n    if (props.isInverse) {\r\n        switch (props.variant) {\r\n            case 'success':\r\n                return props.theme.colors.success700;\r\n            case 'warning':\r\n                return props.theme.colors.warning700;\r\n            case 'danger':\r\n                return props.theme.colors.danger700;\r\n            default:\r\n                return props.theme.colors.info700;\r\n        }\r\n    }\r\n    switch (props.variant) {\r\n        case 'success':\r\n            return props.theme.colors.success100;\r\n        case 'warning':\r\n            return props.theme.colors.warning100;\r\n        case 'danger':\r\n            return props.theme.colors.danger100;\r\n        default:\r\n            return props.theme.colors.info100;\r\n    }\r\n}\r\nexport function buildAlertBorder(props) {\r\n    if (props.isInverse) {\r\n        switch (props.variant) {\r\n            case 'success':\r\n                return props.theme.colors.success300;\r\n            case 'warning':\r\n                return props.theme.colors.warning300;\r\n            case 'danger':\r\n                return props.theme.colors.danger200;\r\n            default:\r\n                return props.theme.colors.info300;\r\n        }\r\n    }\r\n    switch (props.variant) {\r\n        case 'success':\r\n            return props.theme.colors.success500;\r\n        case 'warning':\r\n            return props.theme.colors.warning500;\r\n        case 'danger':\r\n            return props.theme.colors.danger500;\r\n        default:\r\n            return props.theme.colors.info500;\r\n    }\r\n}\r\nexport function buildAlertColor(props) {\r\n    if (props.isInverse) {\r\n        return props.theme.colors.neutral100;\r\n    }\r\n    switch (props.variant) {\r\n        case 'success':\r\n            return props.theme.colors.success500;\r\n        case 'warning':\r\n            return props.theme.colors.warning500;\r\n        case 'danger':\r\n            return props.theme.colors.danger500;\r\n        default:\r\n            return props.theme.colors.info500;\r\n    }\r\n}\r\nexport function buildLinkColor(props) {\r\n    if (props.isInverse) {\r\n        switch (props.variant) {\r\n            case 'success':\r\n                return props.theme.colors.success200;\r\n            case 'warning':\r\n                return props.theme.colors.warning200;\r\n            case 'danger':\r\n                return props.theme.colors.danger200;\r\n            default:\r\n                return props.theme.colors.info200;\r\n        }\r\n    }\r\n    switch (props.variant) {\r\n        case 'success':\r\n            return props.theme.colors.success700;\r\n        case 'warning':\r\n            return props.theme.colors.warning700;\r\n        case 'danger':\r\n            return props.theme.colors.danger700;\r\n        default:\r\n            return props.theme.colors.info700;\r\n    }\r\n}\r\nexport function buildLinkHoverColor(props) {\r\n    if (props.isInverse) {\r\n        return props.theme.colors.neutral100;\r\n    }\r\n    switch (props.variant) {\r\n        case 'success':\r\n            return props.theme.colors.success;\r\n        case 'warning':\r\n            return props.theme.colors.warning;\r\n        case 'danger':\r\n            return props.theme.colors.danger;\r\n        default:\r\n            return props.theme.colors.info;\r\n    }\r\n}\r\nconst StyledAlert = styled.div `\n  align-items: stretch;\n  animation: ${props => props.isExiting\r\n    ? `fadeout ${transitionDuration}ms`\r\n    : `fadein ${transitionDuration}ms`};\n  display: flex;\n  flex-direction: column;\n  font-size: ${props => props.theme.typeScale.size03.fontSize};\n  font-family: ${props => props.theme.bodyFont};\n  line-height: ${props => props.theme.typeScale.size03.lineHeight};\n  margin-bottom: ${props => props.theme.spaceScale.spacing06};\n  max-width: 100%;\n  padding: 0;\n  position: relative;\n\n  @media (max-width: ${props => props.theme.breakpoints.small}px) {\n    font-size: ${props => props.theme.typeScale.size02.fontSize};\n    letter-spacing: ${props => props.theme.typeScale.size02.letterSpacing};\n    line-height: ${props => props.theme.typeScale.size02.lineHeight};\n  }\n\n  &:focus {\n    outline: 2px solid\n      ${props => props.isInverse\r\n    ? props.theme.colors.focusInverse\r\n    : props.theme.colors.focus};\n  }\n\n  ${props => props.isToast &&\r\n    css `\n      animation: ${props.isExiting\r\n        ? `slideout ${transitionDuration}ms`\r\n        : `slidein ${transitionDuration}ms`};\n      min-width: 375px;\n      margin: 0 auto;\n\n      @media (max-width: ${props.theme.breakpoints.small}px) {\n        min-width: 0;\n        width: 100%;\n      }\n    `}\n\n  @keyframes fadein {\n    from {\n      opacity: 0;\n    }\n    to {\n      opacity: 1;\n    }\n  }\n\n  @keyframes fadeout {\n    from {\n      opacity: 1;\n    }\n    to {\n      opacity: 0;\n    }\n  }\n\n  @keyframes slidein {\n    from {\n      left: -500px;\n    }\n    to {\n      left: 0;\n    }\n  }\n\n  @keyframes slideout {\n    from {\n      left: 0;\n    }\n    to {\n      left: -500px;\n    }\n  }\n\n  a {\n    color: ${props => buildLinkColor(props)};\n    font-weight: 400;\n    text-decoration: underline;\n    &:not([disabled]) {\n      &:focus,\n      &:hover {\n        color: ${props => buildLinkHoverColor(props)};\n      }\n    }\n  }\n`;\r\nconst StyledAlertInner = styled.div `\n  background: ${buildAlertBackground};\n  border: 1px solid ${buildAlertBorder};\n  border-radius: ${props => props.theme.borderRadius};\n  color: ${buildAlertColor};\n  display: flex;\n  position: relative;\n\n  ${props => props.isToast &&\r\n    css `\n      box-shadow: ${props.isInverse\r\n        ? `0 2px 8px 0 ${transparentize(0.3, props.theme.colors.neutral900)}`\r\n        : `0 2px 8px 0 ${transparentize(0.6, props.theme.colors.neutral900)}`};\n      padding-right: 0;\n      height: ${props.theme.spaceScale.spacing11};\n    `}\n`;\r\nconst AlertContents = styled.div `\n  align-items: ${props => (props.additionalContent ? 'center' : '')};\n  align-self: center;\n  flex-grow: 1;\n  font-family: ${props => props.theme.bodyFont};\n  padding: ${props => props.theme.spaceScale.spacing04} 0;\n  display: ${props => (props.additionalContent ? 'flex' : '')};\n  margin-right: ${props => props.additionalContent && !props.isDismissible\r\n    ? props.theme.spaceScale.spacing03\r\n    : ''};\n  @media (max-width: ${props => props.theme.breakpoints.small}px) {\n    padding-left: 0;\n  }\n`;\r\nexport const AdditionalContentWrapper = styled.div `\n  flex: 1 0 auto;\n  justify-content: flex-end;\n  display: flex;\n  margin-left: ${props => props.theme.spaceScale.spacing05};\n`;\r\nconst IconWrapperStyles = css `\n  align-items: center;\n  display: flex;\n  flex-shrink: 0;\n  margin-right: 1px;\n`;\r\nconst IconWrapper = styled.span `\n  ${IconWrapperStyles}\n  padding: 0 ${props => props.theme.spaceScale.spacing03} 0 ${props => props.theme.spaceScale.spacing04};\n\n  @media (max-width: ${props => props.theme.breakpoints.small}px) {\n    padding: 0 ${props => props.theme.spaceScale.spacing03};\n    svg {\n      width: 20px;\n    }\n  }\n`;\r\nconst ProgressRingWrapper = styled.div `\n  margin-top: 6px;\n  position: absolute;\n  top: auto;\n  right: ${props => props.theme.spaceScale.spacing02};\n`;\r\nconst DismissibleIconWrapper = styled.span `\n  ${IconWrapperStyles}\n  margin-left: ${props => props.additionalContent ? props.theme.spaceScale.spacing03 : ''};\n`;\r\nconst whitelistProps = ['icon', 'isInverse', 'theme', 'variant'];\r\nconst shouldForwardProp = prop => {\r\n    return isPropValid(prop) || whitelistProps.includes(prop);\r\n};\r\nconst DismissButton = styled(IconButton, { shouldForwardProp }) `\n  align-self: stretch;\n  border-radius: 0 ${props => props.theme.borderRadius}\n    ${props => props.theme.borderRadius} 0;\n  color: inherit;\n  height: auto;\n  margin: ${props => (props.isToast ? '4px' : '0 -1px 0 0')};\n  padding: ${props => props.isToast\r\n    ? `0 ${props.theme.spaceScale.spacing04}`\r\n    : `0 ${props.theme.spaceScale.spacing03}`};\n  width: auto;\n  &:not(:disabled):hover {\n    background: none;\n    color: inherit;\n  }\n  &:focus:not(:disabled) {\n    background: none;\n    color: inherit;\n    outline: 2px solid\n      ${props => props.isInverse\r\n    ? props.theme.colors.focusInverse\r\n    : props.theme.colors.focus};\n    outline-offset: 0 !important;\n  }\n  &:not(:disabled):active {\n    background: none;\n    color: inherit;\n  }\n`;\r\nconst AlertSpan = styled.span `\n  white-space: pre-line;\n`;\r\nfunction renderIcon(variant = 'info', isToast, theme) {\r\n    const Icon = VARIANT_ICON[variant];\r\n    return (React.createElement(IconWrapper, { isToast: isToast, theme: theme },\r\n        React.createElement(Icon, { size: theme.iconSizes.medium })));\r\n}\r\nexport const AlertBase = React.forwardRef((props, ref) => {\r\n    const { additionalContent, children, closeAriaLabel, forceDismiss, hasTimerRing, id: defaultId, isDismissed, isDismissible, isExiting: externalIsExiting, isPaused, isToast, onDismiss, testId, toastDuration, variant, ...other } = props;\r\n    const id = useGenerateId(defaultId);\r\n    const [isExiting, setIsExiting] = React.useState(false);\r\n    const isInverse = useIsInverse(props.isInverse);\r\n    React.useEffect(() => {\r\n        if (isExiting) {\r\n            setTimeout(() => {\r\n                setIsExiting(false);\r\n                onDismiss && typeof onDismiss === 'function' && onDismiss();\r\n            }, transitionDuration - 300);\r\n        }\r\n    }, [isExiting]);\r\n    React.useEffect(() => {\r\n        if (isDismissed) {\r\n            handleDismiss();\r\n        }\r\n    }, [isDismissed]);\r\n    function handleDismiss() {\r\n        setIsExiting(true);\r\n    }\r\n    const theme = React.useContext(ThemeContext);\r\n    const i18n = React.useContext(I18nContext);\r\n    function progressRingColor() {\r\n        if (isInverse) {\r\n            return theme.colors.neutral100;\r\n        }\r\n        switch (props.variant) {\r\n            case 'success':\r\n                return theme.colors.success500;\r\n            case 'warning':\r\n                return theme.colors.warning500;\r\n            case 'danger':\r\n                return theme.colors.danger500;\r\n            default:\r\n                return theme.colors.info500;\r\n        }\r\n    }\r\n    return (React.createElement(StyledAlert, Object.assign({}, other, { \"data-testid\": testId, id: id, tabIndex: -1, isInverse: isInverse, isExiting: isExiting, isToast: isToast, ref: ref, theme: theme, variant: variant }),\r\n        React.createElement(InverseContext.Provider, { value: { isInverse } },\r\n            React.createElement(StyledAlertInner, { isInverse: isInverse, isToast: isToast, theme: theme, variant: variant },\r\n                renderIcon(variant, isToast, theme),\r\n                React.createElement(AlertContents, { additionalContent: additionalContent, isDismissible: isDismissible, theme: theme },\r\n                    React.createElement(AlertSpan, null, children),\r\n                    additionalContent && (React.createElement(AdditionalContentWrapper, { theme: theme }, additionalContent))),\r\n                isDismissible && (React.createElement(DismissibleIconWrapper, { isInverse: isInverse, variant: variant, theme: theme },\r\n                    hasTimerRing && isToast && (React.createElement(ProgressRingWrapper, { theme: theme },\r\n                        React.createElement(ProgressRing, { color: progressRingColor(), isActive: !isPaused, duration: toastDuration }))),\r\n                    React.createElement(DismissButton, Object.assign({ alertVariant: variant }, (isToast\r\n                        ? { title: closeAriaLabel || i18n.alert.dismissAriaLabel }\r\n                        : {\r\n                            'aria-label': closeAriaLabel || i18n.alert.dismissAriaLabel,\r\n                        }), { icon: React.createElement(CloseIcon, { size: hasTimerRing\r\n                                ? theme.iconSizes.xSmall\r\n                                : theme.iconSizes.small }), isInverse: isInverse, isToast: isToast, onClick: forceDismiss || handleDismiss, theme: theme, variant: ButtonVariant.link }))))))));\r\n});\r\n//# sourceMappingURL=index.js.map"]} */",
3702
3702
  toString: _EMOTION_STRINGIFIED_CSS_ERROR__$4
3703
3703
  };
3704
3704
  var IconWrapper = /*#__PURE__*/_styled("span", {
@@ -3712,19 +3712,19 @@ var IconWrapper = /*#__PURE__*/_styled("span", {
3712
3712
  return props.theme.breakpoints.small;
3713
3713
  }, "px){padding:0 ", function (props) {
3714
3714
  return props.theme.spaceScale.spacing03;
3715
- }, ";svg{width:20px;}}" + (process.env.NODE_ENV === "production" ? "" : "/*# sourceMappingURL=data:application/json;charset=utf-8;base64,{"version":3,"sources":["index.tsx"],"names":[],"mappings":"AAsQgC","file":"index.tsx","sourcesContent":["import * as React from 'react';\r\nimport { css } from '@emotion/react';\r\nimport isPropValid from '@emotion/is-prop-valid';\r\nimport { transparentize } from 'polished';\r\nimport { ThemeContext } from '../../theme/ThemeContext';\r\nimport { InfoIcon, CheckCircleIcon, WarningIcon, ErrorIcon, CloseIcon, } from 'react-magma-icons';\r\nimport { ButtonVariant } from '../Button';\r\nimport { IconButton } from '../IconButton';\r\nimport { ProgressRing } from '../ProgressRing';\r\nimport { useGenerateId } from '../../utils';\r\nimport { I18nContext } from '../../i18n';\r\nimport { InverseContext, useIsInverse } from '../../inverse';\r\nimport styled from '@emotion/styled';\r\nexport const VARIANT_ICON = {\r\n    info: InfoIcon,\r\n    success: CheckCircleIcon,\r\n    warning: WarningIcon,\r\n    danger: ErrorIcon,\r\n};\r\nexport var AlertVariant;\r\n(function (AlertVariant) {\r\n    AlertVariant[\"info\"] = \"info\";\r\n    AlertVariant[\"success\"] = \"success\";\r\n    AlertVariant[\"warning\"] = \"warning\";\r\n    AlertVariant[\"danger\"] = \"danger\";\r\n})(AlertVariant || (AlertVariant = {}));\r\nexport const transitionDuration = 500;\r\nexport function buildAlertBackground(props) {\r\n    if (props.isInverse) {\r\n        switch (props.variant) {\r\n            case 'success':\r\n                return props.theme.colors.success700;\r\n            case 'warning':\r\n                return props.theme.colors.warning700;\r\n            case 'danger':\r\n                return props.theme.colors.danger700;\r\n            default:\r\n                return props.theme.colors.info700;\r\n        }\r\n    }\r\n    switch (props.variant) {\r\n        case 'success':\r\n            return props.theme.colors.success100;\r\n        case 'warning':\r\n            return props.theme.colors.warning100;\r\n        case 'danger':\r\n            return props.theme.colors.danger100;\r\n        default:\r\n            return props.theme.colors.info100;\r\n    }\r\n}\r\nexport function buildAlertBorder(props) {\r\n    if (props.isInverse) {\r\n        switch (props.variant) {\r\n            case 'success':\r\n                return props.theme.colors.success300;\r\n            case 'warning':\r\n                return props.theme.colors.warning300;\r\n            case 'danger':\r\n                return props.theme.colors.danger200;\r\n            default:\r\n                return props.theme.colors.info300;\r\n        }\r\n    }\r\n    switch (props.variant) {\r\n        case 'success':\r\n            return props.theme.colors.success500;\r\n        case 'warning':\r\n            return props.theme.colors.warning500;\r\n        case 'danger':\r\n            return props.theme.colors.danger500;\r\n        default:\r\n            return props.theme.colors.info500;\r\n    }\r\n}\r\nexport function buildAlertColor(props) {\r\n    if (props.isInverse) {\r\n        return props.theme.colors.neutral100;\r\n    }\r\n    switch (props.variant) {\r\n        case 'success':\r\n            return props.theme.colors.success500;\r\n        case 'warning':\r\n            return props.theme.colors.warning500;\r\n        case 'danger':\r\n            return props.theme.colors.danger500;\r\n        default:\r\n            return props.theme.colors.info500;\r\n    }\r\n}\r\nexport function buildLinkColor(props) {\r\n    if (props.isInverse) {\r\n        switch (props.variant) {\r\n            case 'success':\r\n                return props.theme.colors.success200;\r\n            case 'warning':\r\n                return props.theme.colors.warning200;\r\n            case 'danger':\r\n                return props.theme.colors.danger200;\r\n            default:\r\n                return props.theme.colors.info200;\r\n        }\r\n    }\r\n    switch (props.variant) {\r\n        case 'success':\r\n            return props.theme.colors.success700;\r\n        case 'warning':\r\n            return props.theme.colors.warning700;\r\n        case 'danger':\r\n            return props.theme.colors.danger700;\r\n        default:\r\n            return props.theme.colors.info700;\r\n    }\r\n}\r\nexport function buildLinkHoverColor(props) {\r\n    if (props.isInverse) {\r\n        return props.theme.colors.neutral100;\r\n    }\r\n    switch (props.variant) {\r\n        case 'success':\r\n            return props.theme.colors.success;\r\n        case 'warning':\r\n            return props.theme.colors.warning;\r\n        case 'danger':\r\n            return props.theme.colors.danger;\r\n        default:\r\n            return props.theme.colors.info;\r\n    }\r\n}\r\nconst StyledAlert = styled.div `\n  align-items: stretch;\n  animation: ${props => props.isExiting\r\n    ? `fadeout ${transitionDuration}ms`\r\n    : `fadein ${transitionDuration}ms`};\n  display: flex;\n  flex-direction: column;\n  font-size: ${props => props.theme.typeScale.size03.fontSize};\n  font-family: ${props => props.theme.bodyFont};\n  line-height: ${props => props.theme.typeScale.size03.lineHeight};\n  margin-bottom: ${props => props.theme.spaceScale.spacing06};\n  max-width: 100%;\n  padding: 0;\n  position: relative;\n\n  @media (max-width: ${props => props.theme.breakpoints.small}px) {\n    font-size: ${props => props.theme.typeScale.size02.fontSize};\n    letter-spacing: ${props => props.theme.typeScale.size02.letterSpacing};\n    line-height: ${props => props.theme.typeScale.size02.lineHeight};\n  }\n\n  &:focus {\n    outline: 2px solid\n      ${props => props.isInverse\r\n    ? props.theme.colors.focusInverse\r\n    : props.theme.colors.focus};\n  }\n\n  ${props => props.isToast &&\r\n    css `\n      animation: ${props.isExiting\r\n        ? `slideout ${transitionDuration}ms`\r\n        : `slidein ${transitionDuration}ms`};\n      min-width: 375px;\n      margin: 0 auto;\n\n      @media (max-width: ${props.theme.breakpoints.small}px) {\n        min-width: 0;\n        width: 100%;\n      }\n    `}\n\n  @keyframes fadein {\n    from {\n      opacity: 0;\n    }\n    to {\n      opacity: 1;\n    }\n  }\n\n  @keyframes fadeout {\n    from {\n      opacity: 1;\n    }\n    to {\n      opacity: 0;\n    }\n  }\n\n  @keyframes slidein {\n    from {\n      left: -500px;\n    }\n    to {\n      left: 0;\n    }\n  }\n\n  @keyframes slideout {\n    from {\n      left: 0;\n    }\n    to {\n      left: -500px;\n    }\n  }\n\n  a {\n    color: ${props => buildLinkColor(props)};\n    font-weight: 400;\n    text-decoration: underline;\n    &:not([disabled]) {\n      &:focus,\n      &:hover {\n        color: ${props => buildLinkHoverColor(props)};\n      }\n    }\n  }\n`;\r\nconst StyledAlertInner = styled.div `\n  background: ${buildAlertBackground};\n  border: 1px solid ${buildAlertBorder};\n  border-radius: ${props => props.theme.borderRadius};\n  color: ${buildAlertColor};\n  display: flex;\n  position: relative;\n\n  ${props => props.isToast &&\r\n    css `\n      box-shadow: ${props.isInverse\r\n        ? `0 2px 8px 0 ${transparentize(0.3, props.theme.colors.neutral900)}`\r\n        : `0 2px 8px 0 ${transparentize(0.6, props.theme.colors.neutral900)}`};\n      padding-right: 0;\n      height: ${props.theme.spaceScale.spacing11};\n    `}\n`;\r\nconst AlertContents = styled.div `\n  align-items: ${props => (props.additionalContent ? 'center' : '')};\n  align-self: center;\n  flex-grow: 1;\n  font-family: ${props => props.theme.bodyFont};\n  padding: ${props => props.theme.spaceScale.spacing04} 0;\n  display: ${props => (props.additionalContent ? 'flex' : '')};\n  margin-right: ${props => props.additionalContent && !props.isDismissible\r\n    ? props.theme.spaceScale.spacing03\r\n    : ''};\n  @media (max-width: ${props => props.theme.breakpoints.small}px) {\n    padding-left: 0;\n  }\n`;\r\nexport const AdditionalContentWrapper = styled.div `\n  flex: 1 0 auto;\n  justify-content: flex-end;\n  display: flex;\n  margin-left: ${props => props.theme.spaceScale.spacing05};\n`;\r\nconst IconWrapperStyles = css `\n  align-items: center;\n  display: flex;\n  flex-shrink: 0;\n  margin-right: 1px;\n`;\r\nconst IconWrapper = styled.span `\n  ${IconWrapperStyles}\n  padding: 0 ${props => props.theme.spaceScale.spacing03} 0 ${props => props.theme.spaceScale.spacing04};\n\n  @media (max-width: ${props => props.theme.breakpoints.small}px) {\n    padding: 0 ${props => props.theme.spaceScale.spacing03};\n    svg {\n      width: 20px;\n    }\n  }\n`;\r\nconst ProgressRingWrapper = styled.div `\n  margin-top: 6px;\n  position: absolute;\n  top: auto;\n  right: ${props => props.theme.spaceScale.spacing02};\n`;\r\nconst DismissibleIconWrapper = styled.span `\n  ${IconWrapperStyles}\n  margin-left: ${props => props.additionalContent ? props.theme.spaceScale.spacing03 : ''};\n`;\r\nconst whitelistProps = ['icon', 'isInverse', 'theme', 'variant'];\r\nconst shouldForwardProp = prop => {\r\n    return isPropValid(prop) || whitelistProps.includes(prop);\r\n};\r\nconst DismissButton = styled(IconButton, { shouldForwardProp }) `\n  align-self: stretch;\n  border-radius: 0 ${props => props.theme.borderRadius}\n    ${props => props.theme.borderRadius} 0;\n  color: inherit;\n  height: auto;\n  margin: ${props => (props.isToast ? '4px' : '0 -1px 0 0')};\n  padding: ${props => props.isToast\r\n    ? `0 ${props.theme.spaceScale.spacing04}`\r\n    : `0 ${props.theme.spaceScale.spacing03}`};\n  width: auto;\n  &:not(:disabled):hover {\n    background: none;\n    color: inherit;\n  }\n  &:focus:not(:disabled) {\n    background: none;\n    color: inherit;\n    outline: 2px solid\n      ${props => props.isInverse\r\n    ? props.theme.colors.focusInverse\r\n    : props.theme.colors.focus};\n    outline-offset: 0 !important;\n  }\n  &:not(:disabled):active {\n    background: none;\n    color: inherit;\n  }\n`;\r\nconst AlertSpan = styled.span `\n  white-space: pre-line;\n`;\r\nfunction renderIcon(variant = 'info', isToast, theme) {\r\n    const Icon = VARIANT_ICON[variant];\r\n    return (React.createElement(IconWrapper, { isToast: isToast, theme: theme },\r\n        React.createElement(Icon, { size: theme.iconSizes.medium })));\r\n}\r\nexport const AlertBase = React.forwardRef((props, ref) => {\r\n    const { additionalContent, children, closeAriaLabel, forceDismiss, hasTimerRing, id: defaultId, isDismissed, isDismissible, isExiting: externalIsExiting, isPaused, isToast, onDismiss, testId, toastDuration, variant, ...other } = props;\r\n    const id = useGenerateId(defaultId);\r\n    const [isExiting, setIsExiting] = React.useState(false);\r\n    const isInverse = useIsInverse(props.isInverse);\r\n    React.useEffect(() => {\r\n        if (isExiting) {\r\n            setTimeout(() => {\r\n                setIsExiting(false);\r\n                onDismiss && typeof onDismiss === 'function' && onDismiss();\r\n            }, transitionDuration - 300);\r\n        }\r\n    }, [isExiting]);\r\n    React.useEffect(() => {\r\n        if (isDismissed) {\r\n            handleDismiss();\r\n        }\r\n    }, [isDismissed]);\r\n    function handleDismiss() {\r\n        setIsExiting(true);\r\n    }\r\n    const theme = React.useContext(ThemeContext);\r\n    const i18n = React.useContext(I18nContext);\r\n    function progressRingColor() {\r\n        if (isInverse) {\r\n            return theme.colors.neutral100;\r\n        }\r\n        switch (props.variant) {\r\n            case 'success':\r\n                return theme.colors.success500;\r\n            case 'warning':\r\n                return theme.colors.warning500;\r\n            case 'danger':\r\n                return theme.colors.danger500;\r\n            default:\r\n                return theme.colors.info500;\r\n        }\r\n    }\r\n    return (React.createElement(StyledAlert, Object.assign({}, other, { \"data-testid\": testId, id: id, tabIndex: -1, isInverse: isInverse, isExiting: isExiting, isToast: isToast, ref: ref, theme: theme, variant: variant }),\r\n        React.createElement(InverseContext.Provider, { value: { isInverse } },\r\n            React.createElement(StyledAlertInner, { isInverse: isInverse, isToast: isToast, theme: theme, variant: variant },\r\n                renderIcon(variant, isToast, theme),\r\n                React.createElement(AlertContents, { additionalContent: additionalContent, isDismissible: isDismissible, theme: theme },\r\n                    React.createElement(AlertSpan, null, children),\r\n                    additionalContent && (React.createElement(AdditionalContentWrapper, { theme: theme }, additionalContent))),\r\n                isDismissible && (React.createElement(DismissibleIconWrapper, { isInverse: isInverse, variant: variant, theme: theme },\r\n                    hasTimerRing && isToast && (React.createElement(ProgressRingWrapper, { theme: theme },\r\n                        React.createElement(ProgressRing, { color: progressRingColor(), isActive: !isPaused, duration: toastDuration }))),\r\n                    React.createElement(DismissButton, { alertVariant: variant, \"aria-label\": closeAriaLabel\r\n                            ? closeAriaLabel\r\n                            : i18n.alert.dismissAriaLabel, icon: React.createElement(CloseIcon, { size: hasTimerRing\r\n                                ? theme.iconSizes.xSmall\r\n                                : theme.iconSizes.small }), isInverse: isInverse, isToast: isToast, onClick: forceDismiss || handleDismiss, theme: theme, variant: ButtonVariant.link })))))));\r\n});\r\n//# sourceMappingURL=index.js.map"]} */"));
3715
+ }, ";svg{width:20px;}}" + (process.env.NODE_ENV === "production" ? "" : "/*# sourceMappingURL=data:application/json;charset=utf-8;base64,{"version":3,"sources":["index.tsx"],"names":[],"mappings":"AAsQgC","file":"index.tsx","sourcesContent":["import * as React from 'react';\r\nimport { css } from '@emotion/react';\r\nimport isPropValid from '@emotion/is-prop-valid';\r\nimport { transparentize } from 'polished';\r\nimport { ThemeContext } from '../../theme/ThemeContext';\r\nimport { InfoIcon, CheckCircleIcon, WarningIcon, ErrorIcon, CloseIcon, } from 'react-magma-icons';\r\nimport { ButtonVariant } from '../Button';\r\nimport { IconButton } from '../IconButton';\r\nimport { ProgressRing } from '../ProgressRing';\r\nimport { useGenerateId } from '../../utils';\r\nimport { I18nContext } from '../../i18n';\r\nimport { InverseContext, useIsInverse } from '../../inverse';\r\nimport styled from '@emotion/styled';\r\nexport const VARIANT_ICON = {\r\n    info: InfoIcon,\r\n    success: CheckCircleIcon,\r\n    warning: WarningIcon,\r\n    danger: ErrorIcon,\r\n};\r\nexport var AlertVariant;\r\n(function (AlertVariant) {\r\n    AlertVariant[\"info\"] = \"info\";\r\n    AlertVariant[\"success\"] = \"success\";\r\n    AlertVariant[\"warning\"] = \"warning\";\r\n    AlertVariant[\"danger\"] = \"danger\";\r\n})(AlertVariant || (AlertVariant = {}));\r\nexport const transitionDuration = 500;\r\nexport function buildAlertBackground(props) {\r\n    if (props.isInverse) {\r\n        switch (props.variant) {\r\n            case 'success':\r\n                return props.theme.colors.success700;\r\n            case 'warning':\r\n                return props.theme.colors.warning700;\r\n            case 'danger':\r\n                return props.theme.colors.danger700;\r\n            default:\r\n                return props.theme.colors.info700;\r\n        }\r\n    }\r\n    switch (props.variant) {\r\n        case 'success':\r\n            return props.theme.colors.success100;\r\n        case 'warning':\r\n            return props.theme.colors.warning100;\r\n        case 'danger':\r\n            return props.theme.colors.danger100;\r\n        default:\r\n            return props.theme.colors.info100;\r\n    }\r\n}\r\nexport function buildAlertBorder(props) {\r\n    if (props.isInverse) {\r\n        switch (props.variant) {\r\n            case 'success':\r\n                return props.theme.colors.success300;\r\n            case 'warning':\r\n                return props.theme.colors.warning300;\r\n            case 'danger':\r\n                return props.theme.colors.danger200;\r\n            default:\r\n                return props.theme.colors.info300;\r\n        }\r\n    }\r\n    switch (props.variant) {\r\n        case 'success':\r\n            return props.theme.colors.success500;\r\n        case 'warning':\r\n            return props.theme.colors.warning500;\r\n        case 'danger':\r\n            return props.theme.colors.danger500;\r\n        default:\r\n            return props.theme.colors.info500;\r\n    }\r\n}\r\nexport function buildAlertColor(props) {\r\n    if (props.isInverse) {\r\n        return props.theme.colors.neutral100;\r\n    }\r\n    switch (props.variant) {\r\n        case 'success':\r\n            return props.theme.colors.success500;\r\n        case 'warning':\r\n            return props.theme.colors.warning500;\r\n        case 'danger':\r\n            return props.theme.colors.danger500;\r\n        default:\r\n            return props.theme.colors.info500;\r\n    }\r\n}\r\nexport function buildLinkColor(props) {\r\n    if (props.isInverse) {\r\n        switch (props.variant) {\r\n            case 'success':\r\n                return props.theme.colors.success200;\r\n            case 'warning':\r\n                return props.theme.colors.warning200;\r\n            case 'danger':\r\n                return props.theme.colors.danger200;\r\n            default:\r\n                return props.theme.colors.info200;\r\n        }\r\n    }\r\n    switch (props.variant) {\r\n        case 'success':\r\n            return props.theme.colors.success700;\r\n        case 'warning':\r\n            return props.theme.colors.warning700;\r\n        case 'danger':\r\n            return props.theme.colors.danger700;\r\n        default:\r\n            return props.theme.colors.info700;\r\n    }\r\n}\r\nexport function buildLinkHoverColor(props) {\r\n    if (props.isInverse) {\r\n        return props.theme.colors.neutral100;\r\n    }\r\n    switch (props.variant) {\r\n        case 'success':\r\n            return props.theme.colors.success;\r\n        case 'warning':\r\n            return props.theme.colors.warning;\r\n        case 'danger':\r\n            return props.theme.colors.danger;\r\n        default:\r\n            return props.theme.colors.info;\r\n    }\r\n}\r\nconst StyledAlert = styled.div `\n  align-items: stretch;\n  animation: ${props => props.isExiting\r\n    ? `fadeout ${transitionDuration}ms`\r\n    : `fadein ${transitionDuration}ms`};\n  display: flex;\n  flex-direction: column;\n  font-size: ${props => props.theme.typeScale.size03.fontSize};\n  font-family: ${props => props.theme.bodyFont};\n  line-height: ${props => props.theme.typeScale.size03.lineHeight};\n  margin-bottom: ${props => props.theme.spaceScale.spacing06};\n  max-width: 100%;\n  padding: 0;\n  position: relative;\n\n  @media (max-width: ${props => props.theme.breakpoints.small}px) {\n    font-size: ${props => props.theme.typeScale.size02.fontSize};\n    letter-spacing: ${props => props.theme.typeScale.size02.letterSpacing};\n    line-height: ${props => props.theme.typeScale.size02.lineHeight};\n  }\n\n  &:focus {\n    outline: 2px solid\n      ${props => props.isInverse\r\n    ? props.theme.colors.focusInverse\r\n    : props.theme.colors.focus};\n  }\n\n  ${props => props.isToast &&\r\n    css `\n      animation: ${props.isExiting\r\n        ? `slideout ${transitionDuration}ms`\r\n        : `slidein ${transitionDuration}ms`};\n      min-width: 375px;\n      margin: 0 auto;\n\n      @media (max-width: ${props.theme.breakpoints.small}px) {\n        min-width: 0;\n        width: 100%;\n      }\n    `}\n\n  @keyframes fadein {\n    from {\n      opacity: 0;\n    }\n    to {\n      opacity: 1;\n    }\n  }\n\n  @keyframes fadeout {\n    from {\n      opacity: 1;\n    }\n    to {\n      opacity: 0;\n    }\n  }\n\n  @keyframes slidein {\n    from {\n      left: -500px;\n    }\n    to {\n      left: 0;\n    }\n  }\n\n  @keyframes slideout {\n    from {\n      left: 0;\n    }\n    to {\n      left: -500px;\n    }\n  }\n\n  a {\n    color: ${props => buildLinkColor(props)};\n    font-weight: 400;\n    text-decoration: underline;\n    &:not([disabled]) {\n      &:focus,\n      &:hover {\n        color: ${props => buildLinkHoverColor(props)};\n      }\n    }\n  }\n`;\r\nconst StyledAlertInner = styled.div `\n  background: ${buildAlertBackground};\n  border: 1px solid ${buildAlertBorder};\n  border-radius: ${props => props.theme.borderRadius};\n  color: ${buildAlertColor};\n  display: flex;\n  position: relative;\n\n  ${props => props.isToast &&\r\n    css `\n      box-shadow: ${props.isInverse\r\n        ? `0 2px 8px 0 ${transparentize(0.3, props.theme.colors.neutral900)}`\r\n        : `0 2px 8px 0 ${transparentize(0.6, props.theme.colors.neutral900)}`};\n      padding-right: 0;\n      height: ${props.theme.spaceScale.spacing11};\n    `}\n`;\r\nconst AlertContents = styled.div `\n  align-items: ${props => (props.additionalContent ? 'center' : '')};\n  align-self: center;\n  flex-grow: 1;\n  font-family: ${props => props.theme.bodyFont};\n  padding: ${props => props.theme.spaceScale.spacing04} 0;\n  display: ${props => (props.additionalContent ? 'flex' : '')};\n  margin-right: ${props => props.additionalContent && !props.isDismissible\r\n    ? props.theme.spaceScale.spacing03\r\n    : ''};\n  @media (max-width: ${props => props.theme.breakpoints.small}px) {\n    padding-left: 0;\n  }\n`;\r\nexport const AdditionalContentWrapper = styled.div `\n  flex: 1 0 auto;\n  justify-content: flex-end;\n  display: flex;\n  margin-left: ${props => props.theme.spaceScale.spacing05};\n`;\r\nconst IconWrapperStyles = css `\n  align-items: center;\n  display: flex;\n  flex-shrink: 0;\n  margin-right: 1px;\n`;\r\nconst IconWrapper = styled.span `\n  ${IconWrapperStyles}\n  padding: 0 ${props => props.theme.spaceScale.spacing03} 0 ${props => props.theme.spaceScale.spacing04};\n\n  @media (max-width: ${props => props.theme.breakpoints.small}px) {\n    padding: 0 ${props => props.theme.spaceScale.spacing03};\n    svg {\n      width: 20px;\n    }\n  }\n`;\r\nconst ProgressRingWrapper = styled.div `\n  margin-top: 6px;\n  position: absolute;\n  top: auto;\n  right: ${props => props.theme.spaceScale.spacing02};\n`;\r\nconst DismissibleIconWrapper = styled.span `\n  ${IconWrapperStyles}\n  margin-left: ${props => props.additionalContent ? props.theme.spaceScale.spacing03 : ''};\n`;\r\nconst whitelistProps = ['icon', 'isInverse', 'theme', 'variant'];\r\nconst shouldForwardProp = prop => {\r\n    return isPropValid(prop) || whitelistProps.includes(prop);\r\n};\r\nconst DismissButton = styled(IconButton, { shouldForwardProp }) `\n  align-self: stretch;\n  border-radius: 0 ${props => props.theme.borderRadius}\n    ${props => props.theme.borderRadius} 0;\n  color: inherit;\n  height: auto;\n  margin: ${props => (props.isToast ? '4px' : '0 -1px 0 0')};\n  padding: ${props => props.isToast\r\n    ? `0 ${props.theme.spaceScale.spacing04}`\r\n    : `0 ${props.theme.spaceScale.spacing03}`};\n  width: auto;\n  &:not(:disabled):hover {\n    background: none;\n    color: inherit;\n  }\n  &:focus:not(:disabled) {\n    background: none;\n    color: inherit;\n    outline: 2px solid\n      ${props => props.isInverse\r\n    ? props.theme.colors.focusInverse\r\n    : props.theme.colors.focus};\n    outline-offset: 0 !important;\n  }\n  &:not(:disabled):active {\n    background: none;\n    color: inherit;\n  }\n`;\r\nconst AlertSpan = styled.span `\n  white-space: pre-line;\n`;\r\nfunction renderIcon(variant = 'info', isToast, theme) {\r\n    const Icon = VARIANT_ICON[variant];\r\n    return (React.createElement(IconWrapper, { isToast: isToast, theme: theme },\r\n        React.createElement(Icon, { size: theme.iconSizes.medium })));\r\n}\r\nexport const AlertBase = React.forwardRef((props, ref) => {\r\n    const { additionalContent, children, closeAriaLabel, forceDismiss, hasTimerRing, id: defaultId, isDismissed, isDismissible, isExiting: externalIsExiting, isPaused, isToast, onDismiss, testId, toastDuration, variant, ...other } = props;\r\n    const id = useGenerateId(defaultId);\r\n    const [isExiting, setIsExiting] = React.useState(false);\r\n    const isInverse = useIsInverse(props.isInverse);\r\n    React.useEffect(() => {\r\n        if (isExiting) {\r\n            setTimeout(() => {\r\n                setIsExiting(false);\r\n                onDismiss && typeof onDismiss === 'function' && onDismiss();\r\n            }, transitionDuration - 300);\r\n        }\r\n    }, [isExiting]);\r\n    React.useEffect(() => {\r\n        if (isDismissed) {\r\n            handleDismiss();\r\n        }\r\n    }, [isDismissed]);\r\n    function handleDismiss() {\r\n        setIsExiting(true);\r\n    }\r\n    const theme = React.useContext(ThemeContext);\r\n    const i18n = React.useContext(I18nContext);\r\n    function progressRingColor() {\r\n        if (isInverse) {\r\n            return theme.colors.neutral100;\r\n        }\r\n        switch (props.variant) {\r\n            case 'success':\r\n                return theme.colors.success500;\r\n            case 'warning':\r\n                return theme.colors.warning500;\r\n            case 'danger':\r\n                return theme.colors.danger500;\r\n            default:\r\n                return theme.colors.info500;\r\n        }\r\n    }\r\n    return (React.createElement(StyledAlert, Object.assign({}, other, { \"data-testid\": testId, id: id, tabIndex: -1, isInverse: isInverse, isExiting: isExiting, isToast: isToast, ref: ref, theme: theme, variant: variant }),\r\n        React.createElement(InverseContext.Provider, { value: { isInverse } },\r\n            React.createElement(StyledAlertInner, { isInverse: isInverse, isToast: isToast, theme: theme, variant: variant },\r\n                renderIcon(variant, isToast, theme),\r\n                React.createElement(AlertContents, { additionalContent: additionalContent, isDismissible: isDismissible, theme: theme },\r\n                    React.createElement(AlertSpan, null, children),\r\n                    additionalContent && (React.createElement(AdditionalContentWrapper, { theme: theme }, additionalContent))),\r\n                isDismissible && (React.createElement(DismissibleIconWrapper, { isInverse: isInverse, variant: variant, theme: theme },\r\n                    hasTimerRing && isToast && (React.createElement(ProgressRingWrapper, { theme: theme },\r\n                        React.createElement(ProgressRing, { color: progressRingColor(), isActive: !isPaused, duration: toastDuration }))),\r\n                    React.createElement(DismissButton, Object.assign({ alertVariant: variant }, (isToast\r\n                        ? { title: closeAriaLabel || i18n.alert.dismissAriaLabel }\r\n                        : {\r\n                            'aria-label': closeAriaLabel || i18n.alert.dismissAriaLabel,\r\n                        }), { icon: React.createElement(CloseIcon, { size: hasTimerRing\r\n                                ? theme.iconSizes.xSmall\r\n                                : theme.iconSizes.small }), isInverse: isInverse, isToast: isToast, onClick: forceDismiss || handleDismiss, theme: theme, variant: ButtonVariant.link }))))))));\r\n});\r\n//# sourceMappingURL=index.js.map"]} */"));
3716
3716
  var ProgressRingWrapper = /*#__PURE__*/_styled("div", {
3717
3717
  target: "e126n3g83",
3718
3718
  label: "ProgressRingWrapper"
3719
3719
  })("margin-top:6px;position:absolute;top:auto;right:", function (props) {
3720
3720
  return props.theme.spaceScale.spacing02;
3721
- }, ";" + (process.env.NODE_ENV === "production" ? "" : "/*# sourceMappingURL=data:application/json;charset=utf-8;base64,{"version":3,"sources":["index.tsx"],"names":[],"mappings":"AAiRuC","file":"index.tsx","sourcesContent":["import * as React from 'react';\r\nimport { css } from '@emotion/react';\r\nimport isPropValid from '@emotion/is-prop-valid';\r\nimport { transparentize } from 'polished';\r\nimport { ThemeContext } from '../../theme/ThemeContext';\r\nimport { InfoIcon, CheckCircleIcon, WarningIcon, ErrorIcon, CloseIcon, } from 'react-magma-icons';\r\nimport { ButtonVariant } from '../Button';\r\nimport { IconButton } from '../IconButton';\r\nimport { ProgressRing } from '../ProgressRing';\r\nimport { useGenerateId } from '../../utils';\r\nimport { I18nContext } from '../../i18n';\r\nimport { InverseContext, useIsInverse } from '../../inverse';\r\nimport styled from '@emotion/styled';\r\nexport const VARIANT_ICON = {\r\n    info: InfoIcon,\r\n    success: CheckCircleIcon,\r\n    warning: WarningIcon,\r\n    danger: ErrorIcon,\r\n};\r\nexport var AlertVariant;\r\n(function (AlertVariant) {\r\n    AlertVariant[\"info\"] = \"info\";\r\n    AlertVariant[\"success\"] = \"success\";\r\n    AlertVariant[\"warning\"] = \"warning\";\r\n    AlertVariant[\"danger\"] = \"danger\";\r\n})(AlertVariant || (AlertVariant = {}));\r\nexport const transitionDuration = 500;\r\nexport function buildAlertBackground(props) {\r\n    if (props.isInverse) {\r\n        switch (props.variant) {\r\n            case 'success':\r\n                return props.theme.colors.success700;\r\n            case 'warning':\r\n                return props.theme.colors.warning700;\r\n            case 'danger':\r\n                return props.theme.colors.danger700;\r\n            default:\r\n                return props.theme.colors.info700;\r\n        }\r\n    }\r\n    switch (props.variant) {\r\n        case 'success':\r\n            return props.theme.colors.success100;\r\n        case 'warning':\r\n            return props.theme.colors.warning100;\r\n        case 'danger':\r\n            return props.theme.colors.danger100;\r\n        default:\r\n            return props.theme.colors.info100;\r\n    }\r\n}\r\nexport function buildAlertBorder(props) {\r\n    if (props.isInverse) {\r\n        switch (props.variant) {\r\n            case 'success':\r\n                return props.theme.colors.success300;\r\n            case 'warning':\r\n                return props.theme.colors.warning300;\r\n            case 'danger':\r\n                return props.theme.colors.danger200;\r\n            default:\r\n                return props.theme.colors.info300;\r\n        }\r\n    }\r\n    switch (props.variant) {\r\n        case 'success':\r\n            return props.theme.colors.success500;\r\n        case 'warning':\r\n            return props.theme.colors.warning500;\r\n        case 'danger':\r\n            return props.theme.colors.danger500;\r\n        default:\r\n            return props.theme.colors.info500;\r\n    }\r\n}\r\nexport function buildAlertColor(props) {\r\n    if (props.isInverse) {\r\n        return props.theme.colors.neutral100;\r\n    }\r\n    switch (props.variant) {\r\n        case 'success':\r\n            return props.theme.colors.success500;\r\n        case 'warning':\r\n            return props.theme.colors.warning500;\r\n        case 'danger':\r\n            return props.theme.colors.danger500;\r\n        default:\r\n            return props.theme.colors.info500;\r\n    }\r\n}\r\nexport function buildLinkColor(props) {\r\n    if (props.isInverse) {\r\n        switch (props.variant) {\r\n            case 'success':\r\n                return props.theme.colors.success200;\r\n            case 'warning':\r\n                return props.theme.colors.warning200;\r\n            case 'danger':\r\n                return props.theme.colors.danger200;\r\n            default:\r\n                return props.theme.colors.info200;\r\n        }\r\n    }\r\n    switch (props.variant) {\r\n        case 'success':\r\n            return props.theme.colors.success700;\r\n        case 'warning':\r\n            return props.theme.colors.warning700;\r\n        case 'danger':\r\n            return props.theme.colors.danger700;\r\n        default:\r\n            return props.theme.colors.info700;\r\n    }\r\n}\r\nexport function buildLinkHoverColor(props) {\r\n    if (props.isInverse) {\r\n        return props.theme.colors.neutral100;\r\n    }\r\n    switch (props.variant) {\r\n        case 'success':\r\n            return props.theme.colors.success;\r\n        case 'warning':\r\n            return props.theme.colors.warning;\r\n        case 'danger':\r\n            return props.theme.colors.danger;\r\n        default:\r\n            return props.theme.colors.info;\r\n    }\r\n}\r\nconst StyledAlert = styled.div `\n  align-items: stretch;\n  animation: ${props => props.isExiting\r\n    ? `fadeout ${transitionDuration}ms`\r\n    : `fadein ${transitionDuration}ms`};\n  display: flex;\n  flex-direction: column;\n  font-size: ${props => props.theme.typeScale.size03.fontSize};\n  font-family: ${props => props.theme.bodyFont};\n  line-height: ${props => props.theme.typeScale.size03.lineHeight};\n  margin-bottom: ${props => props.theme.spaceScale.spacing06};\n  max-width: 100%;\n  padding: 0;\n  position: relative;\n\n  @media (max-width: ${props => props.theme.breakpoints.small}px) {\n    font-size: ${props => props.theme.typeScale.size02.fontSize};\n    letter-spacing: ${props => props.theme.typeScale.size02.letterSpacing};\n    line-height: ${props => props.theme.typeScale.size02.lineHeight};\n  }\n\n  &:focus {\n    outline: 2px solid\n      ${props => props.isInverse\r\n    ? props.theme.colors.focusInverse\r\n    : props.theme.colors.focus};\n  }\n\n  ${props => props.isToast &&\r\n    css `\n      animation: ${props.isExiting\r\n        ? `slideout ${transitionDuration}ms`\r\n        : `slidein ${transitionDuration}ms`};\n      min-width: 375px;\n      margin: 0 auto;\n\n      @media (max-width: ${props.theme.breakpoints.small}px) {\n        min-width: 0;\n        width: 100%;\n      }\n    `}\n\n  @keyframes fadein {\n    from {\n      opacity: 0;\n    }\n    to {\n      opacity: 1;\n    }\n  }\n\n  @keyframes fadeout {\n    from {\n      opacity: 1;\n    }\n    to {\n      opacity: 0;\n    }\n  }\n\n  @keyframes slidein {\n    from {\n      left: -500px;\n    }\n    to {\n      left: 0;\n    }\n  }\n\n  @keyframes slideout {\n    from {\n      left: 0;\n    }\n    to {\n      left: -500px;\n    }\n  }\n\n  a {\n    color: ${props => buildLinkColor(props)};\n    font-weight: 400;\n    text-decoration: underline;\n    &:not([disabled]) {\n      &:focus,\n      &:hover {\n        color: ${props => buildLinkHoverColor(props)};\n      }\n    }\n  }\n`;\r\nconst StyledAlertInner = styled.div `\n  background: ${buildAlertBackground};\n  border: 1px solid ${buildAlertBorder};\n  border-radius: ${props => props.theme.borderRadius};\n  color: ${buildAlertColor};\n  display: flex;\n  position: relative;\n\n  ${props => props.isToast &&\r\n    css `\n      box-shadow: ${props.isInverse\r\n        ? `0 2px 8px 0 ${transparentize(0.3, props.theme.colors.neutral900)}`\r\n        : `0 2px 8px 0 ${transparentize(0.6, props.theme.colors.neutral900)}`};\n      padding-right: 0;\n      height: ${props.theme.spaceScale.spacing11};\n    `}\n`;\r\nconst AlertContents = styled.div `\n  align-items: ${props => (props.additionalContent ? 'center' : '')};\n  align-self: center;\n  flex-grow: 1;\n  font-family: ${props => props.theme.bodyFont};\n  padding: ${props => props.theme.spaceScale.spacing04} 0;\n  display: ${props => (props.additionalContent ? 'flex' : '')};\n  margin-right: ${props => props.additionalContent && !props.isDismissible\r\n    ? props.theme.spaceScale.spacing03\r\n    : ''};\n  @media (max-width: ${props => props.theme.breakpoints.small}px) {\n    padding-left: 0;\n  }\n`;\r\nexport const AdditionalContentWrapper = styled.div `\n  flex: 1 0 auto;\n  justify-content: flex-end;\n  display: flex;\n  margin-left: ${props => props.theme.spaceScale.spacing05};\n`;\r\nconst IconWrapperStyles = css `\n  align-items: center;\n  display: flex;\n  flex-shrink: 0;\n  margin-right: 1px;\n`;\r\nconst IconWrapper = styled.span `\n  ${IconWrapperStyles}\n  padding: 0 ${props => props.theme.spaceScale.spacing03} 0 ${props => props.theme.spaceScale.spacing04};\n\n  @media (max-width: ${props => props.theme.breakpoints.small}px) {\n    padding: 0 ${props => props.theme.spaceScale.spacing03};\n    svg {\n      width: 20px;\n    }\n  }\n`;\r\nconst ProgressRingWrapper = styled.div `\n  margin-top: 6px;\n  position: absolute;\n  top: auto;\n  right: ${props => props.theme.spaceScale.spacing02};\n`;\r\nconst DismissibleIconWrapper = styled.span `\n  ${IconWrapperStyles}\n  margin-left: ${props => props.additionalContent ? props.theme.spaceScale.spacing03 : ''};\n`;\r\nconst whitelistProps = ['icon', 'isInverse', 'theme', 'variant'];\r\nconst shouldForwardProp = prop => {\r\n    return isPropValid(prop) || whitelistProps.includes(prop);\r\n};\r\nconst DismissButton = styled(IconButton, { shouldForwardProp }) `\n  align-self: stretch;\n  border-radius: 0 ${props => props.theme.borderRadius}\n    ${props => props.theme.borderRadius} 0;\n  color: inherit;\n  height: auto;\n  margin: ${props => (props.isToast ? '4px' : '0 -1px 0 0')};\n  padding: ${props => props.isToast\r\n    ? `0 ${props.theme.spaceScale.spacing04}`\r\n    : `0 ${props.theme.spaceScale.spacing03}`};\n  width: auto;\n  &:not(:disabled):hover {\n    background: none;\n    color: inherit;\n  }\n  &:focus:not(:disabled) {\n    background: none;\n    color: inherit;\n    outline: 2px solid\n      ${props => props.isInverse\r\n    ? props.theme.colors.focusInverse\r\n    : props.theme.colors.focus};\n    outline-offset: 0 !important;\n  }\n  &:not(:disabled):active {\n    background: none;\n    color: inherit;\n  }\n`;\r\nconst AlertSpan = styled.span `\n  white-space: pre-line;\n`;\r\nfunction renderIcon(variant = 'info', isToast, theme) {\r\n    const Icon = VARIANT_ICON[variant];\r\n    return (React.createElement(IconWrapper, { isToast: isToast, theme: theme },\r\n        React.createElement(Icon, { size: theme.iconSizes.medium })));\r\n}\r\nexport const AlertBase = React.forwardRef((props, ref) => {\r\n    const { additionalContent, children, closeAriaLabel, forceDismiss, hasTimerRing, id: defaultId, isDismissed, isDismissible, isExiting: externalIsExiting, isPaused, isToast, onDismiss, testId, toastDuration, variant, ...other } = props;\r\n    const id = useGenerateId(defaultId);\r\n    const [isExiting, setIsExiting] = React.useState(false);\r\n    const isInverse = useIsInverse(props.isInverse);\r\n    React.useEffect(() => {\r\n        if (isExiting) {\r\n            setTimeout(() => {\r\n                setIsExiting(false);\r\n                onDismiss && typeof onDismiss === 'function' && onDismiss();\r\n            }, transitionDuration - 300);\r\n        }\r\n    }, [isExiting]);\r\n    React.useEffect(() => {\r\n        if (isDismissed) {\r\n            handleDismiss();\r\n        }\r\n    }, [isDismissed]);\r\n    function handleDismiss() {\r\n        setIsExiting(true);\r\n    }\r\n    const theme = React.useContext(ThemeContext);\r\n    const i18n = React.useContext(I18nContext);\r\n    function progressRingColor() {\r\n        if (isInverse) {\r\n            return theme.colors.neutral100;\r\n        }\r\n        switch (props.variant) {\r\n            case 'success':\r\n                return theme.colors.success500;\r\n            case 'warning':\r\n                return theme.colors.warning500;\r\n            case 'danger':\r\n                return theme.colors.danger500;\r\n            default:\r\n                return theme.colors.info500;\r\n        }\r\n    }\r\n    return (React.createElement(StyledAlert, Object.assign({}, other, { \"data-testid\": testId, id: id, tabIndex: -1, isInverse: isInverse, isExiting: isExiting, isToast: isToast, ref: ref, theme: theme, variant: variant }),\r\n        React.createElement(InverseContext.Provider, { value: { isInverse } },\r\n            React.createElement(StyledAlertInner, { isInverse: isInverse, isToast: isToast, theme: theme, variant: variant },\r\n                renderIcon(variant, isToast, theme),\r\n                React.createElement(AlertContents, { additionalContent: additionalContent, isDismissible: isDismissible, theme: theme },\r\n                    React.createElement(AlertSpan, null, children),\r\n                    additionalContent && (React.createElement(AdditionalContentWrapper, { theme: theme }, additionalContent))),\r\n                isDismissible && (React.createElement(DismissibleIconWrapper, { isInverse: isInverse, variant: variant, theme: theme },\r\n                    hasTimerRing && isToast && (React.createElement(ProgressRingWrapper, { theme: theme },\r\n                        React.createElement(ProgressRing, { color: progressRingColor(), isActive: !isPaused, duration: toastDuration }))),\r\n                    React.createElement(DismissButton, { alertVariant: variant, \"aria-label\": closeAriaLabel\r\n                            ? closeAriaLabel\r\n                            : i18n.alert.dismissAriaLabel, icon: React.createElement(CloseIcon, { size: hasTimerRing\r\n                                ? theme.iconSizes.xSmall\r\n                                : theme.iconSizes.small }), isInverse: isInverse, isToast: isToast, onClick: forceDismiss || handleDismiss, theme: theme, variant: ButtonVariant.link })))))));\r\n});\r\n//# sourceMappingURL=index.js.map"]} */"));
3721
+ }, ";" + (process.env.NODE_ENV === "production" ? "" : "/*# sourceMappingURL=data:application/json;charset=utf-8;base64,{"version":3,"sources":["index.tsx"],"names":[],"mappings":"AAiRuC","file":"index.tsx","sourcesContent":["import * as React from 'react';\r\nimport { css } from '@emotion/react';\r\nimport isPropValid from '@emotion/is-prop-valid';\r\nimport { transparentize } from 'polished';\r\nimport { ThemeContext } from '../../theme/ThemeContext';\r\nimport { InfoIcon, CheckCircleIcon, WarningIcon, ErrorIcon, CloseIcon, } from 'react-magma-icons';\r\nimport { ButtonVariant } from '../Button';\r\nimport { IconButton } from '../IconButton';\r\nimport { ProgressRing } from '../ProgressRing';\r\nimport { useGenerateId } from '../../utils';\r\nimport { I18nContext } from '../../i18n';\r\nimport { InverseContext, useIsInverse } from '../../inverse';\r\nimport styled from '@emotion/styled';\r\nexport const VARIANT_ICON = {\r\n    info: InfoIcon,\r\n    success: CheckCircleIcon,\r\n    warning: WarningIcon,\r\n    danger: ErrorIcon,\r\n};\r\nexport var AlertVariant;\r\n(function (AlertVariant) {\r\n    AlertVariant[\"info\"] = \"info\";\r\n    AlertVariant[\"success\"] = \"success\";\r\n    AlertVariant[\"warning\"] = \"warning\";\r\n    AlertVariant[\"danger\"] = \"danger\";\r\n})(AlertVariant || (AlertVariant = {}));\r\nexport const transitionDuration = 500;\r\nexport function buildAlertBackground(props) {\r\n    if (props.isInverse) {\r\n        switch (props.variant) {\r\n            case 'success':\r\n                return props.theme.colors.success700;\r\n            case 'warning':\r\n                return props.theme.colors.warning700;\r\n            case 'danger':\r\n                return props.theme.colors.danger700;\r\n            default:\r\n                return props.theme.colors.info700;\r\n        }\r\n    }\r\n    switch (props.variant) {\r\n        case 'success':\r\n            return props.theme.colors.success100;\r\n        case 'warning':\r\n            return props.theme.colors.warning100;\r\n        case 'danger':\r\n            return props.theme.colors.danger100;\r\n        default:\r\n            return props.theme.colors.info100;\r\n    }\r\n}\r\nexport function buildAlertBorder(props) {\r\n    if (props.isInverse) {\r\n        switch (props.variant) {\r\n            case 'success':\r\n                return props.theme.colors.success300;\r\n            case 'warning':\r\n                return props.theme.colors.warning300;\r\n            case 'danger':\r\n                return props.theme.colors.danger200;\r\n            default:\r\n                return props.theme.colors.info300;\r\n        }\r\n    }\r\n    switch (props.variant) {\r\n        case 'success':\r\n            return props.theme.colors.success500;\r\n        case 'warning':\r\n            return props.theme.colors.warning500;\r\n        case 'danger':\r\n            return props.theme.colors.danger500;\r\n        default:\r\n            return props.theme.colors.info500;\r\n    }\r\n}\r\nexport function buildAlertColor(props) {\r\n    if (props.isInverse) {\r\n        return props.theme.colors.neutral100;\r\n    }\r\n    switch (props.variant) {\r\n        case 'success':\r\n            return props.theme.colors.success500;\r\n        case 'warning':\r\n            return props.theme.colors.warning500;\r\n        case 'danger':\r\n            return props.theme.colors.danger500;\r\n        default:\r\n            return props.theme.colors.info500;\r\n    }\r\n}\r\nexport function buildLinkColor(props) {\r\n    if (props.isInverse) {\r\n        switch (props.variant) {\r\n            case 'success':\r\n                return props.theme.colors.success200;\r\n            case 'warning':\r\n                return props.theme.colors.warning200;\r\n            case 'danger':\r\n                return props.theme.colors.danger200;\r\n            default:\r\n                return props.theme.colors.info200;\r\n        }\r\n    }\r\n    switch (props.variant) {\r\n        case 'success':\r\n            return props.theme.colors.success700;\r\n        case 'warning':\r\n            return props.theme.colors.warning700;\r\n        case 'danger':\r\n            return props.theme.colors.danger700;\r\n        default:\r\n            return props.theme.colors.info700;\r\n    }\r\n}\r\nexport function buildLinkHoverColor(props) {\r\n    if (props.isInverse) {\r\n        return props.theme.colors.neutral100;\r\n    }\r\n    switch (props.variant) {\r\n        case 'success':\r\n            return props.theme.colors.success;\r\n        case 'warning':\r\n            return props.theme.colors.warning;\r\n        case 'danger':\r\n            return props.theme.colors.danger;\r\n        default:\r\n            return props.theme.colors.info;\r\n    }\r\n}\r\nconst StyledAlert = styled.div `\n  align-items: stretch;\n  animation: ${props => props.isExiting\r\n    ? `fadeout ${transitionDuration}ms`\r\n    : `fadein ${transitionDuration}ms`};\n  display: flex;\n  flex-direction: column;\n  font-size: ${props => props.theme.typeScale.size03.fontSize};\n  font-family: ${props => props.theme.bodyFont};\n  line-height: ${props => props.theme.typeScale.size03.lineHeight};\n  margin-bottom: ${props => props.theme.spaceScale.spacing06};\n  max-width: 100%;\n  padding: 0;\n  position: relative;\n\n  @media (max-width: ${props => props.theme.breakpoints.small}px) {\n    font-size: ${props => props.theme.typeScale.size02.fontSize};\n    letter-spacing: ${props => props.theme.typeScale.size02.letterSpacing};\n    line-height: ${props => props.theme.typeScale.size02.lineHeight};\n  }\n\n  &:focus {\n    outline: 2px solid\n      ${props => props.isInverse\r\n    ? props.theme.colors.focusInverse\r\n    : props.theme.colors.focus};\n  }\n\n  ${props => props.isToast &&\r\n    css `\n      animation: ${props.isExiting\r\n        ? `slideout ${transitionDuration}ms`\r\n        : `slidein ${transitionDuration}ms`};\n      min-width: 375px;\n      margin: 0 auto;\n\n      @media (max-width: ${props.theme.breakpoints.small}px) {\n        min-width: 0;\n        width: 100%;\n      }\n    `}\n\n  @keyframes fadein {\n    from {\n      opacity: 0;\n    }\n    to {\n      opacity: 1;\n    }\n  }\n\n  @keyframes fadeout {\n    from {\n      opacity: 1;\n    }\n    to {\n      opacity: 0;\n    }\n  }\n\n  @keyframes slidein {\n    from {\n      left: -500px;\n    }\n    to {\n      left: 0;\n    }\n  }\n\n  @keyframes slideout {\n    from {\n      left: 0;\n    }\n    to {\n      left: -500px;\n    }\n  }\n\n  a {\n    color: ${props => buildLinkColor(props)};\n    font-weight: 400;\n    text-decoration: underline;\n    &:not([disabled]) {\n      &:focus,\n      &:hover {\n        color: ${props => buildLinkHoverColor(props)};\n      }\n    }\n  }\n`;\r\nconst StyledAlertInner = styled.div `\n  background: ${buildAlertBackground};\n  border: 1px solid ${buildAlertBorder};\n  border-radius: ${props => props.theme.borderRadius};\n  color: ${buildAlertColor};\n  display: flex;\n  position: relative;\n\n  ${props => props.isToast &&\r\n    css `\n      box-shadow: ${props.isInverse\r\n        ? `0 2px 8px 0 ${transparentize(0.3, props.theme.colors.neutral900)}`\r\n        : `0 2px 8px 0 ${transparentize(0.6, props.theme.colors.neutral900)}`};\n      padding-right: 0;\n      height: ${props.theme.spaceScale.spacing11};\n    `}\n`;\r\nconst AlertContents = styled.div `\n  align-items: ${props => (props.additionalContent ? 'center' : '')};\n  align-self: center;\n  flex-grow: 1;\n  font-family: ${props => props.theme.bodyFont};\n  padding: ${props => props.theme.spaceScale.spacing04} 0;\n  display: ${props => (props.additionalContent ? 'flex' : '')};\n  margin-right: ${props => props.additionalContent && !props.isDismissible\r\n    ? props.theme.spaceScale.spacing03\r\n    : ''};\n  @media (max-width: ${props => props.theme.breakpoints.small}px) {\n    padding-left: 0;\n  }\n`;\r\nexport const AdditionalContentWrapper = styled.div `\n  flex: 1 0 auto;\n  justify-content: flex-end;\n  display: flex;\n  margin-left: ${props => props.theme.spaceScale.spacing05};\n`;\r\nconst IconWrapperStyles = css `\n  align-items: center;\n  display: flex;\n  flex-shrink: 0;\n  margin-right: 1px;\n`;\r\nconst IconWrapper = styled.span `\n  ${IconWrapperStyles}\n  padding: 0 ${props => props.theme.spaceScale.spacing03} 0 ${props => props.theme.spaceScale.spacing04};\n\n  @media (max-width: ${props => props.theme.breakpoints.small}px) {\n    padding: 0 ${props => props.theme.spaceScale.spacing03};\n    svg {\n      width: 20px;\n    }\n  }\n`;\r\nconst ProgressRingWrapper = styled.div `\n  margin-top: 6px;\n  position: absolute;\n  top: auto;\n  right: ${props => props.theme.spaceScale.spacing02};\n`;\r\nconst DismissibleIconWrapper = styled.span `\n  ${IconWrapperStyles}\n  margin-left: ${props => props.additionalContent ? props.theme.spaceScale.spacing03 : ''};\n`;\r\nconst whitelistProps = ['icon', 'isInverse', 'theme', 'variant'];\r\nconst shouldForwardProp = prop => {\r\n    return isPropValid(prop) || whitelistProps.includes(prop);\r\n};\r\nconst DismissButton = styled(IconButton, { shouldForwardProp }) `\n  align-self: stretch;\n  border-radius: 0 ${props => props.theme.borderRadius}\n    ${props => props.theme.borderRadius} 0;\n  color: inherit;\n  height: auto;\n  margin: ${props => (props.isToast ? '4px' : '0 -1px 0 0')};\n  padding: ${props => props.isToast\r\n    ? `0 ${props.theme.spaceScale.spacing04}`\r\n    : `0 ${props.theme.spaceScale.spacing03}`};\n  width: auto;\n  &:not(:disabled):hover {\n    background: none;\n    color: inherit;\n  }\n  &:focus:not(:disabled) {\n    background: none;\n    color: inherit;\n    outline: 2px solid\n      ${props => props.isInverse\r\n    ? props.theme.colors.focusInverse\r\n    : props.theme.colors.focus};\n    outline-offset: 0 !important;\n  }\n  &:not(:disabled):active {\n    background: none;\n    color: inherit;\n  }\n`;\r\nconst AlertSpan = styled.span `\n  white-space: pre-line;\n`;\r\nfunction renderIcon(variant = 'info', isToast, theme) {\r\n    const Icon = VARIANT_ICON[variant];\r\n    return (React.createElement(IconWrapper, { isToast: isToast, theme: theme },\r\n        React.createElement(Icon, { size: theme.iconSizes.medium })));\r\n}\r\nexport const AlertBase = React.forwardRef((props, ref) => {\r\n    const { additionalContent, children, closeAriaLabel, forceDismiss, hasTimerRing, id: defaultId, isDismissed, isDismissible, isExiting: externalIsExiting, isPaused, isToast, onDismiss, testId, toastDuration, variant, ...other } = props;\r\n    const id = useGenerateId(defaultId);\r\n    const [isExiting, setIsExiting] = React.useState(false);\r\n    const isInverse = useIsInverse(props.isInverse);\r\n    React.useEffect(() => {\r\n        if (isExiting) {\r\n            setTimeout(() => {\r\n                setIsExiting(false);\r\n                onDismiss && typeof onDismiss === 'function' && onDismiss();\r\n            }, transitionDuration - 300);\r\n        }\r\n    }, [isExiting]);\r\n    React.useEffect(() => {\r\n        if (isDismissed) {\r\n            handleDismiss();\r\n        }\r\n    }, [isDismissed]);\r\n    function handleDismiss() {\r\n        setIsExiting(true);\r\n    }\r\n    const theme = React.useContext(ThemeContext);\r\n    const i18n = React.useContext(I18nContext);\r\n    function progressRingColor() {\r\n        if (isInverse) {\r\n            return theme.colors.neutral100;\r\n        }\r\n        switch (props.variant) {\r\n            case 'success':\r\n                return theme.colors.success500;\r\n            case 'warning':\r\n                return theme.colors.warning500;\r\n            case 'danger':\r\n                return theme.colors.danger500;\r\n            default:\r\n                return theme.colors.info500;\r\n        }\r\n    }\r\n    return (React.createElement(StyledAlert, Object.assign({}, other, { \"data-testid\": testId, id: id, tabIndex: -1, isInverse: isInverse, isExiting: isExiting, isToast: isToast, ref: ref, theme: theme, variant: variant }),\r\n        React.createElement(InverseContext.Provider, { value: { isInverse } },\r\n            React.createElement(StyledAlertInner, { isInverse: isInverse, isToast: isToast, theme: theme, variant: variant },\r\n                renderIcon(variant, isToast, theme),\r\n                React.createElement(AlertContents, { additionalContent: additionalContent, isDismissible: isDismissible, theme: theme },\r\n                    React.createElement(AlertSpan, null, children),\r\n                    additionalContent && (React.createElement(AdditionalContentWrapper, { theme: theme }, additionalContent))),\r\n                isDismissible && (React.createElement(DismissibleIconWrapper, { isInverse: isInverse, variant: variant, theme: theme },\r\n                    hasTimerRing && isToast && (React.createElement(ProgressRingWrapper, { theme: theme },\r\n                        React.createElement(ProgressRing, { color: progressRingColor(), isActive: !isPaused, duration: toastDuration }))),\r\n                    React.createElement(DismissButton, Object.assign({ alertVariant: variant }, (isToast\r\n                        ? { title: closeAriaLabel || i18n.alert.dismissAriaLabel }\r\n                        : {\r\n                            'aria-label': closeAriaLabel || i18n.alert.dismissAriaLabel,\r\n                        }), { icon: React.createElement(CloseIcon, { size: hasTimerRing\r\n                                ? theme.iconSizes.xSmall\r\n                                : theme.iconSizes.small }), isInverse: isInverse, isToast: isToast, onClick: forceDismiss || handleDismiss, theme: theme, variant: ButtonVariant.link }))))))));\r\n});\r\n//# sourceMappingURL=index.js.map"]} */"));
3722
3722
  var DismissibleIconWrapper = /*#__PURE__*/_styled("span", {
3723
3723
  target: "e126n3g82",
3724
3724
  label: "DismissibleIconWrapper"
3725
3725
  })(IconWrapperStyles, " margin-left:", function (props) {
3726
3726
  return props.additionalContent ? props.theme.spaceScale.spacing03 : '';
3727
- }, ";" + (process.env.NODE_ENV === "production" ? "" : "/*# sourceMappingURL=data:application/json;charset=utf-8;base64,{"version":3,"sources":["index.tsx"],"names":[],"mappings":"AAuR2C","file":"index.tsx","sourcesContent":["import * as React from 'react';\r\nimport { css } from '@emotion/react';\r\nimport isPropValid from '@emotion/is-prop-valid';\r\nimport { transparentize } from 'polished';\r\nimport { ThemeContext } from '../../theme/ThemeContext';\r\nimport { InfoIcon, CheckCircleIcon, WarningIcon, ErrorIcon, CloseIcon, } from 'react-magma-icons';\r\nimport { ButtonVariant } from '../Button';\r\nimport { IconButton } from '../IconButton';\r\nimport { ProgressRing } from '../ProgressRing';\r\nimport { useGenerateId } from '../../utils';\r\nimport { I18nContext } from '../../i18n';\r\nimport { InverseContext, useIsInverse } from '../../inverse';\r\nimport styled from '@emotion/styled';\r\nexport const VARIANT_ICON = {\r\n    info: InfoIcon,\r\n    success: CheckCircleIcon,\r\n    warning: WarningIcon,\r\n    danger: ErrorIcon,\r\n};\r\nexport var AlertVariant;\r\n(function (AlertVariant) {\r\n    AlertVariant[\"info\"] = \"info\";\r\n    AlertVariant[\"success\"] = \"success\";\r\n    AlertVariant[\"warning\"] = \"warning\";\r\n    AlertVariant[\"danger\"] = \"danger\";\r\n})(AlertVariant || (AlertVariant = {}));\r\nexport const transitionDuration = 500;\r\nexport function buildAlertBackground(props) {\r\n    if (props.isInverse) {\r\n        switch (props.variant) {\r\n            case 'success':\r\n                return props.theme.colors.success700;\r\n            case 'warning':\r\n                return props.theme.colors.warning700;\r\n            case 'danger':\r\n                return props.theme.colors.danger700;\r\n            default:\r\n                return props.theme.colors.info700;\r\n        }\r\n    }\r\n    switch (props.variant) {\r\n        case 'success':\r\n            return props.theme.colors.success100;\r\n        case 'warning':\r\n            return props.theme.colors.warning100;\r\n        case 'danger':\r\n            return props.theme.colors.danger100;\r\n        default:\r\n            return props.theme.colors.info100;\r\n    }\r\n}\r\nexport function buildAlertBorder(props) {\r\n    if (props.isInverse) {\r\n        switch (props.variant) {\r\n            case 'success':\r\n                return props.theme.colors.success300;\r\n            case 'warning':\r\n                return props.theme.colors.warning300;\r\n            case 'danger':\r\n                return props.theme.colors.danger200;\r\n            default:\r\n                return props.theme.colors.info300;\r\n        }\r\n    }\r\n    switch (props.variant) {\r\n        case 'success':\r\n            return props.theme.colors.success500;\r\n        case 'warning':\r\n            return props.theme.colors.warning500;\r\n        case 'danger':\r\n            return props.theme.colors.danger500;\r\n        default:\r\n            return props.theme.colors.info500;\r\n    }\r\n}\r\nexport function buildAlertColor(props) {\r\n    if (props.isInverse) {\r\n        return props.theme.colors.neutral100;\r\n    }\r\n    switch (props.variant) {\r\n        case 'success':\r\n            return props.theme.colors.success500;\r\n        case 'warning':\r\n            return props.theme.colors.warning500;\r\n        case 'danger':\r\n            return props.theme.colors.danger500;\r\n        default:\r\n            return props.theme.colors.info500;\r\n    }\r\n}\r\nexport function buildLinkColor(props) {\r\n    if (props.isInverse) {\r\n        switch (props.variant) {\r\n            case 'success':\r\n                return props.theme.colors.success200;\r\n            case 'warning':\r\n                return props.theme.colors.warning200;\r\n            case 'danger':\r\n                return props.theme.colors.danger200;\r\n            default:\r\n                return props.theme.colors.info200;\r\n        }\r\n    }\r\n    switch (props.variant) {\r\n        case 'success':\r\n            return props.theme.colors.success700;\r\n        case 'warning':\r\n            return props.theme.colors.warning700;\r\n        case 'danger':\r\n            return props.theme.colors.danger700;\r\n        default:\r\n            return props.theme.colors.info700;\r\n    }\r\n}\r\nexport function buildLinkHoverColor(props) {\r\n    if (props.isInverse) {\r\n        return props.theme.colors.neutral100;\r\n    }\r\n    switch (props.variant) {\r\n        case 'success':\r\n            return props.theme.colors.success;\r\n        case 'warning':\r\n            return props.theme.colors.warning;\r\n        case 'danger':\r\n            return props.theme.colors.danger;\r\n        default:\r\n            return props.theme.colors.info;\r\n    }\r\n}\r\nconst StyledAlert = styled.div `\n  align-items: stretch;\n  animation: ${props => props.isExiting\r\n    ? `fadeout ${transitionDuration}ms`\r\n    : `fadein ${transitionDuration}ms`};\n  display: flex;\n  flex-direction: column;\n  font-size: ${props => props.theme.typeScale.size03.fontSize};\n  font-family: ${props => props.theme.bodyFont};\n  line-height: ${props => props.theme.typeScale.size03.lineHeight};\n  margin-bottom: ${props => props.theme.spaceScale.spacing06};\n  max-width: 100%;\n  padding: 0;\n  position: relative;\n\n  @media (max-width: ${props => props.theme.breakpoints.small}px) {\n    font-size: ${props => props.theme.typeScale.size02.fontSize};\n    letter-spacing: ${props => props.theme.typeScale.size02.letterSpacing};\n    line-height: ${props => props.theme.typeScale.size02.lineHeight};\n  }\n\n  &:focus {\n    outline: 2px solid\n      ${props => props.isInverse\r\n    ? props.theme.colors.focusInverse\r\n    : props.theme.colors.focus};\n  }\n\n  ${props => props.isToast &&\r\n    css `\n      animation: ${props.isExiting\r\n        ? `slideout ${transitionDuration}ms`\r\n        : `slidein ${transitionDuration}ms`};\n      min-width: 375px;\n      margin: 0 auto;\n\n      @media (max-width: ${props.theme.breakpoints.small}px) {\n        min-width: 0;\n        width: 100%;\n      }\n    `}\n\n  @keyframes fadein {\n    from {\n      opacity: 0;\n    }\n    to {\n      opacity: 1;\n    }\n  }\n\n  @keyframes fadeout {\n    from {\n      opacity: 1;\n    }\n    to {\n      opacity: 0;\n    }\n  }\n\n  @keyframes slidein {\n    from {\n      left: -500px;\n    }\n    to {\n      left: 0;\n    }\n  }\n\n  @keyframes slideout {\n    from {\n      left: 0;\n    }\n    to {\n      left: -500px;\n    }\n  }\n\n  a {\n    color: ${props => buildLinkColor(props)};\n    font-weight: 400;\n    text-decoration: underline;\n    &:not([disabled]) {\n      &:focus,\n      &:hover {\n        color: ${props => buildLinkHoverColor(props)};\n      }\n    }\n  }\n`;\r\nconst StyledAlertInner = styled.div `\n  background: ${buildAlertBackground};\n  border: 1px solid ${buildAlertBorder};\n  border-radius: ${props => props.theme.borderRadius};\n  color: ${buildAlertColor};\n  display: flex;\n  position: relative;\n\n  ${props => props.isToast &&\r\n    css `\n      box-shadow: ${props.isInverse\r\n        ? `0 2px 8px 0 ${transparentize(0.3, props.theme.colors.neutral900)}`\r\n        : `0 2px 8px 0 ${transparentize(0.6, props.theme.colors.neutral900)}`};\n      padding-right: 0;\n      height: ${props.theme.spaceScale.spacing11};\n    `}\n`;\r\nconst AlertContents = styled.div `\n  align-items: ${props => (props.additionalContent ? 'center' : '')};\n  align-self: center;\n  flex-grow: 1;\n  font-family: ${props => props.theme.bodyFont};\n  padding: ${props => props.theme.spaceScale.spacing04} 0;\n  display: ${props => (props.additionalContent ? 'flex' : '')};\n  margin-right: ${props => props.additionalContent && !props.isDismissible\r\n    ? props.theme.spaceScale.spacing03\r\n    : ''};\n  @media (max-width: ${props => props.theme.breakpoints.small}px) {\n    padding-left: 0;\n  }\n`;\r\nexport const AdditionalContentWrapper = styled.div `\n  flex: 1 0 auto;\n  justify-content: flex-end;\n  display: flex;\n  margin-left: ${props => props.theme.spaceScale.spacing05};\n`;\r\nconst IconWrapperStyles = css `\n  align-items: center;\n  display: flex;\n  flex-shrink: 0;\n  margin-right: 1px;\n`;\r\nconst IconWrapper = styled.span `\n  ${IconWrapperStyles}\n  padding: 0 ${props => props.theme.spaceScale.spacing03} 0 ${props => props.theme.spaceScale.spacing04};\n\n  @media (max-width: ${props => props.theme.breakpoints.small}px) {\n    padding: 0 ${props => props.theme.spaceScale.spacing03};\n    svg {\n      width: 20px;\n    }\n  }\n`;\r\nconst ProgressRingWrapper = styled.div `\n  margin-top: 6px;\n  position: absolute;\n  top: auto;\n  right: ${props => props.theme.spaceScale.spacing02};\n`;\r\nconst DismissibleIconWrapper = styled.span `\n  ${IconWrapperStyles}\n  margin-left: ${props => props.additionalContent ? props.theme.spaceScale.spacing03 : ''};\n`;\r\nconst whitelistProps = ['icon', 'isInverse', 'theme', 'variant'];\r\nconst shouldForwardProp = prop => {\r\n    return isPropValid(prop) || whitelistProps.includes(prop);\r\n};\r\nconst DismissButton = styled(IconButton, { shouldForwardProp }) `\n  align-self: stretch;\n  border-radius: 0 ${props => props.theme.borderRadius}\n    ${props => props.theme.borderRadius} 0;\n  color: inherit;\n  height: auto;\n  margin: ${props => (props.isToast ? '4px' : '0 -1px 0 0')};\n  padding: ${props => props.isToast\r\n    ? `0 ${props.theme.spaceScale.spacing04}`\r\n    : `0 ${props.theme.spaceScale.spacing03}`};\n  width: auto;\n  &:not(:disabled):hover {\n    background: none;\n    color: inherit;\n  }\n  &:focus:not(:disabled) {\n    background: none;\n    color: inherit;\n    outline: 2px solid\n      ${props => props.isInverse\r\n    ? props.theme.colors.focusInverse\r\n    : props.theme.colors.focus};\n    outline-offset: 0 !important;\n  }\n  &:not(:disabled):active {\n    background: none;\n    color: inherit;\n  }\n`;\r\nconst AlertSpan = styled.span `\n  white-space: pre-line;\n`;\r\nfunction renderIcon(variant = 'info', isToast, theme) {\r\n    const Icon = VARIANT_ICON[variant];\r\n    return (React.createElement(IconWrapper, { isToast: isToast, theme: theme },\r\n        React.createElement(Icon, { size: theme.iconSizes.medium })));\r\n}\r\nexport const AlertBase = React.forwardRef((props, ref) => {\r\n    const { additionalContent, children, closeAriaLabel, forceDismiss, hasTimerRing, id: defaultId, isDismissed, isDismissible, isExiting: externalIsExiting, isPaused, isToast, onDismiss, testId, toastDuration, variant, ...other } = props;\r\n    const id = useGenerateId(defaultId);\r\n    const [isExiting, setIsExiting] = React.useState(false);\r\n    const isInverse = useIsInverse(props.isInverse);\r\n    React.useEffect(() => {\r\n        if (isExiting) {\r\n            setTimeout(() => {\r\n                setIsExiting(false);\r\n                onDismiss && typeof onDismiss === 'function' && onDismiss();\r\n            }, transitionDuration - 300);\r\n        }\r\n    }, [isExiting]);\r\n    React.useEffect(() => {\r\n        if (isDismissed) {\r\n            handleDismiss();\r\n        }\r\n    }, [isDismissed]);\r\n    function handleDismiss() {\r\n        setIsExiting(true);\r\n    }\r\n    const theme = React.useContext(ThemeContext);\r\n    const i18n = React.useContext(I18nContext);\r\n    function progressRingColor() {\r\n        if (isInverse) {\r\n            return theme.colors.neutral100;\r\n        }\r\n        switch (props.variant) {\r\n            case 'success':\r\n                return theme.colors.success500;\r\n            case 'warning':\r\n                return theme.colors.warning500;\r\n            case 'danger':\r\n                return theme.colors.danger500;\r\n            default:\r\n                return theme.colors.info500;\r\n        }\r\n    }\r\n    return (React.createElement(StyledAlert, Object.assign({}, other, { \"data-testid\": testId, id: id, tabIndex: -1, isInverse: isInverse, isExiting: isExiting, isToast: isToast, ref: ref, theme: theme, variant: variant }),\r\n        React.createElement(InverseContext.Provider, { value: { isInverse } },\r\n            React.createElement(StyledAlertInner, { isInverse: isInverse, isToast: isToast, theme: theme, variant: variant },\r\n                renderIcon(variant, isToast, theme),\r\n                React.createElement(AlertContents, { additionalContent: additionalContent, isDismissible: isDismissible, theme: theme },\r\n                    React.createElement(AlertSpan, null, children),\r\n                    additionalContent && (React.createElement(AdditionalContentWrapper, { theme: theme }, additionalContent))),\r\n                isDismissible && (React.createElement(DismissibleIconWrapper, { isInverse: isInverse, variant: variant, theme: theme },\r\n                    hasTimerRing && isToast && (React.createElement(ProgressRingWrapper, { theme: theme },\r\n                        React.createElement(ProgressRing, { color: progressRingColor(), isActive: !isPaused, duration: toastDuration }))),\r\n                    React.createElement(DismissButton, { alertVariant: variant, \"aria-label\": closeAriaLabel\r\n                            ? closeAriaLabel\r\n                            : i18n.alert.dismissAriaLabel, icon: React.createElement(CloseIcon, { size: hasTimerRing\r\n                                ? theme.iconSizes.xSmall\r\n                                : theme.iconSizes.small }), isInverse: isInverse, isToast: isToast, onClick: forceDismiss || handleDismiss, theme: theme, variant: ButtonVariant.link })))))));\r\n});\r\n//# sourceMappingURL=index.js.map"]} */"));
3727
+ }, ";" + (process.env.NODE_ENV === "production" ? "" : "/*# sourceMappingURL=data:application/json;charset=utf-8;base64,{"version":3,"sources":["index.tsx"],"names":[],"mappings":"AAuR2C","file":"index.tsx","sourcesContent":["import * as React from 'react';\r\nimport { css } from '@emotion/react';\r\nimport isPropValid from '@emotion/is-prop-valid';\r\nimport { transparentize } from 'polished';\r\nimport { ThemeContext } from '../../theme/ThemeContext';\r\nimport { InfoIcon, CheckCircleIcon, WarningIcon, ErrorIcon, CloseIcon, } from 'react-magma-icons';\r\nimport { ButtonVariant } from '../Button';\r\nimport { IconButton } from '../IconButton';\r\nimport { ProgressRing } from '../ProgressRing';\r\nimport { useGenerateId } from '../../utils';\r\nimport { I18nContext } from '../../i18n';\r\nimport { InverseContext, useIsInverse } from '../../inverse';\r\nimport styled from '@emotion/styled';\r\nexport const VARIANT_ICON = {\r\n    info: InfoIcon,\r\n    success: CheckCircleIcon,\r\n    warning: WarningIcon,\r\n    danger: ErrorIcon,\r\n};\r\nexport var AlertVariant;\r\n(function (AlertVariant) {\r\n    AlertVariant[\"info\"] = \"info\";\r\n    AlertVariant[\"success\"] = \"success\";\r\n    AlertVariant[\"warning\"] = \"warning\";\r\n    AlertVariant[\"danger\"] = \"danger\";\r\n})(AlertVariant || (AlertVariant = {}));\r\nexport const transitionDuration = 500;\r\nexport function buildAlertBackground(props) {\r\n    if (props.isInverse) {\r\n        switch (props.variant) {\r\n            case 'success':\r\n                return props.theme.colors.success700;\r\n            case 'warning':\r\n                return props.theme.colors.warning700;\r\n            case 'danger':\r\n                return props.theme.colors.danger700;\r\n            default:\r\n                return props.theme.colors.info700;\r\n        }\r\n    }\r\n    switch (props.variant) {\r\n        case 'success':\r\n            return props.theme.colors.success100;\r\n        case 'warning':\r\n            return props.theme.colors.warning100;\r\n        case 'danger':\r\n            return props.theme.colors.danger100;\r\n        default:\r\n            return props.theme.colors.info100;\r\n    }\r\n}\r\nexport function buildAlertBorder(props) {\r\n    if (props.isInverse) {\r\n        switch (props.variant) {\r\n            case 'success':\r\n                return props.theme.colors.success300;\r\n            case 'warning':\r\n                return props.theme.colors.warning300;\r\n            case 'danger':\r\n                return props.theme.colors.danger200;\r\n            default:\r\n                return props.theme.colors.info300;\r\n        }\r\n    }\r\n    switch (props.variant) {\r\n        case 'success':\r\n            return props.theme.colors.success500;\r\n        case 'warning':\r\n            return props.theme.colors.warning500;\r\n        case 'danger':\r\n            return props.theme.colors.danger500;\r\n        default:\r\n            return props.theme.colors.info500;\r\n    }\r\n}\r\nexport function buildAlertColor(props) {\r\n    if (props.isInverse) {\r\n        return props.theme.colors.neutral100;\r\n    }\r\n    switch (props.variant) {\r\n        case 'success':\r\n            return props.theme.colors.success500;\r\n        case 'warning':\r\n            return props.theme.colors.warning500;\r\n        case 'danger':\r\n            return props.theme.colors.danger500;\r\n        default:\r\n            return props.theme.colors.info500;\r\n    }\r\n}\r\nexport function buildLinkColor(props) {\r\n    if (props.isInverse) {\r\n        switch (props.variant) {\r\n            case 'success':\r\n                return props.theme.colors.success200;\r\n            case 'warning':\r\n                return props.theme.colors.warning200;\r\n            case 'danger':\r\n                return props.theme.colors.danger200;\r\n            default:\r\n                return props.theme.colors.info200;\r\n        }\r\n    }\r\n    switch (props.variant) {\r\n        case 'success':\r\n            return props.theme.colors.success700;\r\n        case 'warning':\r\n            return props.theme.colors.warning700;\r\n        case 'danger':\r\n            return props.theme.colors.danger700;\r\n        default:\r\n            return props.theme.colors.info700;\r\n    }\r\n}\r\nexport function buildLinkHoverColor(props) {\r\n    if (props.isInverse) {\r\n        return props.theme.colors.neutral100;\r\n    }\r\n    switch (props.variant) {\r\n        case 'success':\r\n            return props.theme.colors.success;\r\n        case 'warning':\r\n            return props.theme.colors.warning;\r\n        case 'danger':\r\n            return props.theme.colors.danger;\r\n        default:\r\n            return props.theme.colors.info;\r\n    }\r\n}\r\nconst StyledAlert = styled.div `\n  align-items: stretch;\n  animation: ${props => props.isExiting\r\n    ? `fadeout ${transitionDuration}ms`\r\n    : `fadein ${transitionDuration}ms`};\n  display: flex;\n  flex-direction: column;\n  font-size: ${props => props.theme.typeScale.size03.fontSize};\n  font-family: ${props => props.theme.bodyFont};\n  line-height: ${props => props.theme.typeScale.size03.lineHeight};\n  margin-bottom: ${props => props.theme.spaceScale.spacing06};\n  max-width: 100%;\n  padding: 0;\n  position: relative;\n\n  @media (max-width: ${props => props.theme.breakpoints.small}px) {\n    font-size: ${props => props.theme.typeScale.size02.fontSize};\n    letter-spacing: ${props => props.theme.typeScale.size02.letterSpacing};\n    line-height: ${props => props.theme.typeScale.size02.lineHeight};\n  }\n\n  &:focus {\n    outline: 2px solid\n      ${props => props.isInverse\r\n    ? props.theme.colors.focusInverse\r\n    : props.theme.colors.focus};\n  }\n\n  ${props => props.isToast &&\r\n    css `\n      animation: ${props.isExiting\r\n        ? `slideout ${transitionDuration}ms`\r\n        : `slidein ${transitionDuration}ms`};\n      min-width: 375px;\n      margin: 0 auto;\n\n      @media (max-width: ${props.theme.breakpoints.small}px) {\n        min-width: 0;\n        width: 100%;\n      }\n    `}\n\n  @keyframes fadein {\n    from {\n      opacity: 0;\n    }\n    to {\n      opacity: 1;\n    }\n  }\n\n  @keyframes fadeout {\n    from {\n      opacity: 1;\n    }\n    to {\n      opacity: 0;\n    }\n  }\n\n  @keyframes slidein {\n    from {\n      left: -500px;\n    }\n    to {\n      left: 0;\n    }\n  }\n\n  @keyframes slideout {\n    from {\n      left: 0;\n    }\n    to {\n      left: -500px;\n    }\n  }\n\n  a {\n    color: ${props => buildLinkColor(props)};\n    font-weight: 400;\n    text-decoration: underline;\n    &:not([disabled]) {\n      &:focus,\n      &:hover {\n        color: ${props => buildLinkHoverColor(props)};\n      }\n    }\n  }\n`;\r\nconst StyledAlertInner = styled.div `\n  background: ${buildAlertBackground};\n  border: 1px solid ${buildAlertBorder};\n  border-radius: ${props => props.theme.borderRadius};\n  color: ${buildAlertColor};\n  display: flex;\n  position: relative;\n\n  ${props => props.isToast &&\r\n    css `\n      box-shadow: ${props.isInverse\r\n        ? `0 2px 8px 0 ${transparentize(0.3, props.theme.colors.neutral900)}`\r\n        : `0 2px 8px 0 ${transparentize(0.6, props.theme.colors.neutral900)}`};\n      padding-right: 0;\n      height: ${props.theme.spaceScale.spacing11};\n    `}\n`;\r\nconst AlertContents = styled.div `\n  align-items: ${props => (props.additionalContent ? 'center' : '')};\n  align-self: center;\n  flex-grow: 1;\n  font-family: ${props => props.theme.bodyFont};\n  padding: ${props => props.theme.spaceScale.spacing04} 0;\n  display: ${props => (props.additionalContent ? 'flex' : '')};\n  margin-right: ${props => props.additionalContent && !props.isDismissible\r\n    ? props.theme.spaceScale.spacing03\r\n    : ''};\n  @media (max-width: ${props => props.theme.breakpoints.small}px) {\n    padding-left: 0;\n  }\n`;\r\nexport const AdditionalContentWrapper = styled.div `\n  flex: 1 0 auto;\n  justify-content: flex-end;\n  display: flex;\n  margin-left: ${props => props.theme.spaceScale.spacing05};\n`;\r\nconst IconWrapperStyles = css `\n  align-items: center;\n  display: flex;\n  flex-shrink: 0;\n  margin-right: 1px;\n`;\r\nconst IconWrapper = styled.span `\n  ${IconWrapperStyles}\n  padding: 0 ${props => props.theme.spaceScale.spacing03} 0 ${props => props.theme.spaceScale.spacing04};\n\n  @media (max-width: ${props => props.theme.breakpoints.small}px) {\n    padding: 0 ${props => props.theme.spaceScale.spacing03};\n    svg {\n      width: 20px;\n    }\n  }\n`;\r\nconst ProgressRingWrapper = styled.div `\n  margin-top: 6px;\n  position: absolute;\n  top: auto;\n  right: ${props => props.theme.spaceScale.spacing02};\n`;\r\nconst DismissibleIconWrapper = styled.span `\n  ${IconWrapperStyles}\n  margin-left: ${props => props.additionalContent ? props.theme.spaceScale.spacing03 : ''};\n`;\r\nconst whitelistProps = ['icon', 'isInverse', 'theme', 'variant'];\r\nconst shouldForwardProp = prop => {\r\n    return isPropValid(prop) || whitelistProps.includes(prop);\r\n};\r\nconst DismissButton = styled(IconButton, { shouldForwardProp }) `\n  align-self: stretch;\n  border-radius: 0 ${props => props.theme.borderRadius}\n    ${props => props.theme.borderRadius} 0;\n  color: inherit;\n  height: auto;\n  margin: ${props => (props.isToast ? '4px' : '0 -1px 0 0')};\n  padding: ${props => props.isToast\r\n    ? `0 ${props.theme.spaceScale.spacing04}`\r\n    : `0 ${props.theme.spaceScale.spacing03}`};\n  width: auto;\n  &:not(:disabled):hover {\n    background: none;\n    color: inherit;\n  }\n  &:focus:not(:disabled) {\n    background: none;\n    color: inherit;\n    outline: 2px solid\n      ${props => props.isInverse\r\n    ? props.theme.colors.focusInverse\r\n    : props.theme.colors.focus};\n    outline-offset: 0 !important;\n  }\n  &:not(:disabled):active {\n    background: none;\n    color: inherit;\n  }\n`;\r\nconst AlertSpan = styled.span `\n  white-space: pre-line;\n`;\r\nfunction renderIcon(variant = 'info', isToast, theme) {\r\n    const Icon = VARIANT_ICON[variant];\r\n    return (React.createElement(IconWrapper, { isToast: isToast, theme: theme },\r\n        React.createElement(Icon, { size: theme.iconSizes.medium })));\r\n}\r\nexport const AlertBase = React.forwardRef((props, ref) => {\r\n    const { additionalContent, children, closeAriaLabel, forceDismiss, hasTimerRing, id: defaultId, isDismissed, isDismissible, isExiting: externalIsExiting, isPaused, isToast, onDismiss, testId, toastDuration, variant, ...other } = props;\r\n    const id = useGenerateId(defaultId);\r\n    const [isExiting, setIsExiting] = React.useState(false);\r\n    const isInverse = useIsInverse(props.isInverse);\r\n    React.useEffect(() => {\r\n        if (isExiting) {\r\n            setTimeout(() => {\r\n                setIsExiting(false);\r\n                onDismiss && typeof onDismiss === 'function' && onDismiss();\r\n            }, transitionDuration - 300);\r\n        }\r\n    }, [isExiting]);\r\n    React.useEffect(() => {\r\n        if (isDismissed) {\r\n            handleDismiss();\r\n        }\r\n    }, [isDismissed]);\r\n    function handleDismiss() {\r\n        setIsExiting(true);\r\n    }\r\n    const theme = React.useContext(ThemeContext);\r\n    const i18n = React.useContext(I18nContext);\r\n    function progressRingColor() {\r\n        if (isInverse) {\r\n            return theme.colors.neutral100;\r\n        }\r\n        switch (props.variant) {\r\n            case 'success':\r\n                return theme.colors.success500;\r\n            case 'warning':\r\n                return theme.colors.warning500;\r\n            case 'danger':\r\n                return theme.colors.danger500;\r\n            default:\r\n                return theme.colors.info500;\r\n        }\r\n    }\r\n    return (React.createElement(StyledAlert, Object.assign({}, other, { \"data-testid\": testId, id: id, tabIndex: -1, isInverse: isInverse, isExiting: isExiting, isToast: isToast, ref: ref, theme: theme, variant: variant }),\r\n        React.createElement(InverseContext.Provider, { value: { isInverse } },\r\n            React.createElement(StyledAlertInner, { isInverse: isInverse, isToast: isToast, theme: theme, variant: variant },\r\n                renderIcon(variant, isToast, theme),\r\n                React.createElement(AlertContents, { additionalContent: additionalContent, isDismissible: isDismissible, theme: theme },\r\n                    React.createElement(AlertSpan, null, children),\r\n                    additionalContent && (React.createElement(AdditionalContentWrapper, { theme: theme }, additionalContent))),\r\n                isDismissible && (React.createElement(DismissibleIconWrapper, { isInverse: isInverse, variant: variant, theme: theme },\r\n                    hasTimerRing && isToast && (React.createElement(ProgressRingWrapper, { theme: theme },\r\n                        React.createElement(ProgressRing, { color: progressRingColor(), isActive: !isPaused, duration: toastDuration }))),\r\n                    React.createElement(DismissButton, Object.assign({ alertVariant: variant }, (isToast\r\n                        ? { title: closeAriaLabel || i18n.alert.dismissAriaLabel }\r\n                        : {\r\n                            'aria-label': closeAriaLabel || i18n.alert.dismissAriaLabel,\r\n                        }), { icon: React.createElement(CloseIcon, { size: hasTimerRing\r\n                                ? theme.iconSizes.xSmall\r\n                                : theme.iconSizes.small }), isInverse: isInverse, isToast: isToast, onClick: forceDismiss || handleDismiss, theme: theme, variant: ButtonVariant.link }))))))));\r\n});\r\n//# sourceMappingURL=index.js.map"]} */"));
3728
3728
  var whitelistProps = ['icon', 'isInverse', 'theme', 'variant'];
3729
3729
  var shouldForwardProp = function shouldForwardProp(prop) {
3730
3730
  return isPropValid(prop) || whitelistProps.includes(prop);
@@ -3743,7 +3743,7 @@ var DismissButton = /*#__PURE__*/_styled(IconButton, {
3743
3743
  return props.isToast ? "0 " + props.theme.spaceScale.spacing04 : "0 " + props.theme.spaceScale.spacing03;
3744
3744
  }, ";width:auto;&:not(:disabled):hover{background:none;color:inherit;}&:focus:not(:disabled){background:none;color:inherit;outline:2px solid ", function (props) {
3745
3745
  return props.isInverse ? props.theme.colors.focusInverse : props.theme.colors.focus;
3746
- }, ";outline-offset:0!important;}&:not(:disabled):active{background:none;color:inherit;}" + (process.env.NODE_ENV === "production" ? "" : "/*# sourceMappingURL=data:application/json;charset=utf-8;base64,{"version":3,"sources":["index.tsx"],"names":[],"mappings":"AA+RgE","file":"index.tsx","sourcesContent":["import * as React from 'react';\r\nimport { css } from '@emotion/react';\r\nimport isPropValid from '@emotion/is-prop-valid';\r\nimport { transparentize } from 'polished';\r\nimport { ThemeContext } from '../../theme/ThemeContext';\r\nimport { InfoIcon, CheckCircleIcon, WarningIcon, ErrorIcon, CloseIcon, } from 'react-magma-icons';\r\nimport { ButtonVariant } from '../Button';\r\nimport { IconButton } from '../IconButton';\r\nimport { ProgressRing } from '../ProgressRing';\r\nimport { useGenerateId } from '../../utils';\r\nimport { I18nContext } from '../../i18n';\r\nimport { InverseContext, useIsInverse } from '../../inverse';\r\nimport styled from '@emotion/styled';\r\nexport const VARIANT_ICON = {\r\n    info: InfoIcon,\r\n    success: CheckCircleIcon,\r\n    warning: WarningIcon,\r\n    danger: ErrorIcon,\r\n};\r\nexport var AlertVariant;\r\n(function (AlertVariant) {\r\n    AlertVariant[\"info\"] = \"info\";\r\n    AlertVariant[\"success\"] = \"success\";\r\n    AlertVariant[\"warning\"] = \"warning\";\r\n    AlertVariant[\"danger\"] = \"danger\";\r\n})(AlertVariant || (AlertVariant = {}));\r\nexport const transitionDuration = 500;\r\nexport function buildAlertBackground(props) {\r\n    if (props.isInverse) {\r\n        switch (props.variant) {\r\n            case 'success':\r\n                return props.theme.colors.success700;\r\n            case 'warning':\r\n                return props.theme.colors.warning700;\r\n            case 'danger':\r\n                return props.theme.colors.danger700;\r\n            default:\r\n                return props.theme.colors.info700;\r\n        }\r\n    }\r\n    switch (props.variant) {\r\n        case 'success':\r\n            return props.theme.colors.success100;\r\n        case 'warning':\r\n            return props.theme.colors.warning100;\r\n        case 'danger':\r\n            return props.theme.colors.danger100;\r\n        default:\r\n            return props.theme.colors.info100;\r\n    }\r\n}\r\nexport function buildAlertBorder(props) {\r\n    if (props.isInverse) {\r\n        switch (props.variant) {\r\n            case 'success':\r\n                return props.theme.colors.success300;\r\n            case 'warning':\r\n                return props.theme.colors.warning300;\r\n            case 'danger':\r\n                return props.theme.colors.danger200;\r\n            default:\r\n                return props.theme.colors.info300;\r\n        }\r\n    }\r\n    switch (props.variant) {\r\n        case 'success':\r\n            return props.theme.colors.success500;\r\n        case 'warning':\r\n            return props.theme.colors.warning500;\r\n        case 'danger':\r\n            return props.theme.colors.danger500;\r\n        default:\r\n            return props.theme.colors.info500;\r\n    }\r\n}\r\nexport function buildAlertColor(props) {\r\n    if (props.isInverse) {\r\n        return props.theme.colors.neutral100;\r\n    }\r\n    switch (props.variant) {\r\n        case 'success':\r\n            return props.theme.colors.success500;\r\n        case 'warning':\r\n            return props.theme.colors.warning500;\r\n        case 'danger':\r\n            return props.theme.colors.danger500;\r\n        default:\r\n            return props.theme.colors.info500;\r\n    }\r\n}\r\nexport function buildLinkColor(props) {\r\n    if (props.isInverse) {\r\n        switch (props.variant) {\r\n            case 'success':\r\n                return props.theme.colors.success200;\r\n            case 'warning':\r\n                return props.theme.colors.warning200;\r\n            case 'danger':\r\n                return props.theme.colors.danger200;\r\n            default:\r\n                return props.theme.colors.info200;\r\n        }\r\n    }\r\n    switch (props.variant) {\r\n        case 'success':\r\n            return props.theme.colors.success700;\r\n        case 'warning':\r\n            return props.theme.colors.warning700;\r\n        case 'danger':\r\n            return props.theme.colors.danger700;\r\n        default:\r\n            return props.theme.colors.info700;\r\n    }\r\n}\r\nexport function buildLinkHoverColor(props) {\r\n    if (props.isInverse) {\r\n        return props.theme.colors.neutral100;\r\n    }\r\n    switch (props.variant) {\r\n        case 'success':\r\n            return props.theme.colors.success;\r\n        case 'warning':\r\n            return props.theme.colors.warning;\r\n        case 'danger':\r\n            return props.theme.colors.danger;\r\n        default:\r\n            return props.theme.colors.info;\r\n    }\r\n}\r\nconst StyledAlert = styled.div `\n  align-items: stretch;\n  animation: ${props => props.isExiting\r\n    ? `fadeout ${transitionDuration}ms`\r\n    : `fadein ${transitionDuration}ms`};\n  display: flex;\n  flex-direction: column;\n  font-size: ${props => props.theme.typeScale.size03.fontSize};\n  font-family: ${props => props.theme.bodyFont};\n  line-height: ${props => props.theme.typeScale.size03.lineHeight};\n  margin-bottom: ${props => props.theme.spaceScale.spacing06};\n  max-width: 100%;\n  padding: 0;\n  position: relative;\n\n  @media (max-width: ${props => props.theme.breakpoints.small}px) {\n    font-size: ${props => props.theme.typeScale.size02.fontSize};\n    letter-spacing: ${props => props.theme.typeScale.size02.letterSpacing};\n    line-height: ${props => props.theme.typeScale.size02.lineHeight};\n  }\n\n  &:focus {\n    outline: 2px solid\n      ${props => props.isInverse\r\n    ? props.theme.colors.focusInverse\r\n    : props.theme.colors.focus};\n  }\n\n  ${props => props.isToast &&\r\n    css `\n      animation: ${props.isExiting\r\n        ? `slideout ${transitionDuration}ms`\r\n        : `slidein ${transitionDuration}ms`};\n      min-width: 375px;\n      margin: 0 auto;\n\n      @media (max-width: ${props.theme.breakpoints.small}px) {\n        min-width: 0;\n        width: 100%;\n      }\n    `}\n\n  @keyframes fadein {\n    from {\n      opacity: 0;\n    }\n    to {\n      opacity: 1;\n    }\n  }\n\n  @keyframes fadeout {\n    from {\n      opacity: 1;\n    }\n    to {\n      opacity: 0;\n    }\n  }\n\n  @keyframes slidein {\n    from {\n      left: -500px;\n    }\n    to {\n      left: 0;\n    }\n  }\n\n  @keyframes slideout {\n    from {\n      left: 0;\n    }\n    to {\n      left: -500px;\n    }\n  }\n\n  a {\n    color: ${props => buildLinkColor(props)};\n    font-weight: 400;\n    text-decoration: underline;\n    &:not([disabled]) {\n      &:focus,\n      &:hover {\n        color: ${props => buildLinkHoverColor(props)};\n      }\n    }\n  }\n`;\r\nconst StyledAlertInner = styled.div `\n  background: ${buildAlertBackground};\n  border: 1px solid ${buildAlertBorder};\n  border-radius: ${props => props.theme.borderRadius};\n  color: ${buildAlertColor};\n  display: flex;\n  position: relative;\n\n  ${props => props.isToast &&\r\n    css `\n      box-shadow: ${props.isInverse\r\n        ? `0 2px 8px 0 ${transparentize(0.3, props.theme.colors.neutral900)}`\r\n        : `0 2px 8px 0 ${transparentize(0.6, props.theme.colors.neutral900)}`};\n      padding-right: 0;\n      height: ${props.theme.spaceScale.spacing11};\n    `}\n`;\r\nconst AlertContents = styled.div `\n  align-items: ${props => (props.additionalContent ? 'center' : '')};\n  align-self: center;\n  flex-grow: 1;\n  font-family: ${props => props.theme.bodyFont};\n  padding: ${props => props.theme.spaceScale.spacing04} 0;\n  display: ${props => (props.additionalContent ? 'flex' : '')};\n  margin-right: ${props => props.additionalContent && !props.isDismissible\r\n    ? props.theme.spaceScale.spacing03\r\n    : ''};\n  @media (max-width: ${props => props.theme.breakpoints.small}px) {\n    padding-left: 0;\n  }\n`;\r\nexport const AdditionalContentWrapper = styled.div `\n  flex: 1 0 auto;\n  justify-content: flex-end;\n  display: flex;\n  margin-left: ${props => props.theme.spaceScale.spacing05};\n`;\r\nconst IconWrapperStyles = css `\n  align-items: center;\n  display: flex;\n  flex-shrink: 0;\n  margin-right: 1px;\n`;\r\nconst IconWrapper = styled.span `\n  ${IconWrapperStyles}\n  padding: 0 ${props => props.theme.spaceScale.spacing03} 0 ${props => props.theme.spaceScale.spacing04};\n\n  @media (max-width: ${props => props.theme.breakpoints.small}px) {\n    padding: 0 ${props => props.theme.spaceScale.spacing03};\n    svg {\n      width: 20px;\n    }\n  }\n`;\r\nconst ProgressRingWrapper = styled.div `\n  margin-top: 6px;\n  position: absolute;\n  top: auto;\n  right: ${props => props.theme.spaceScale.spacing02};\n`;\r\nconst DismissibleIconWrapper = styled.span `\n  ${IconWrapperStyles}\n  margin-left: ${props => props.additionalContent ? props.theme.spaceScale.spacing03 : ''};\n`;\r\nconst whitelistProps = ['icon', 'isInverse', 'theme', 'variant'];\r\nconst shouldForwardProp = prop => {\r\n    return isPropValid(prop) || whitelistProps.includes(prop);\r\n};\r\nconst DismissButton = styled(IconButton, { shouldForwardProp }) `\n  align-self: stretch;\n  border-radius: 0 ${props => props.theme.borderRadius}\n    ${props => props.theme.borderRadius} 0;\n  color: inherit;\n  height: auto;\n  margin: ${props => (props.isToast ? '4px' : '0 -1px 0 0')};\n  padding: ${props => props.isToast\r\n    ? `0 ${props.theme.spaceScale.spacing04}`\r\n    : `0 ${props.theme.spaceScale.spacing03}`};\n  width: auto;\n  &:not(:disabled):hover {\n    background: none;\n    color: inherit;\n  }\n  &:focus:not(:disabled) {\n    background: none;\n    color: inherit;\n    outline: 2px solid\n      ${props => props.isInverse\r\n    ? props.theme.colors.focusInverse\r\n    : props.theme.colors.focus};\n    outline-offset: 0 !important;\n  }\n  &:not(:disabled):active {\n    background: none;\n    color: inherit;\n  }\n`;\r\nconst AlertSpan = styled.span `\n  white-space: pre-line;\n`;\r\nfunction renderIcon(variant = 'info', isToast, theme) {\r\n    const Icon = VARIANT_ICON[variant];\r\n    return (React.createElement(IconWrapper, { isToast: isToast, theme: theme },\r\n        React.createElement(Icon, { size: theme.iconSizes.medium })));\r\n}\r\nexport const AlertBase = React.forwardRef((props, ref) => {\r\n    const { additionalContent, children, closeAriaLabel, forceDismiss, hasTimerRing, id: defaultId, isDismissed, isDismissible, isExiting: externalIsExiting, isPaused, isToast, onDismiss, testId, toastDuration, variant, ...other } = props;\r\n    const id = useGenerateId(defaultId);\r\n    const [isExiting, setIsExiting] = React.useState(false);\r\n    const isInverse = useIsInverse(props.isInverse);\r\n    React.useEffect(() => {\r\n        if (isExiting) {\r\n            setTimeout(() => {\r\n                setIsExiting(false);\r\n                onDismiss && typeof onDismiss === 'function' && onDismiss();\r\n            }, transitionDuration - 300);\r\n        }\r\n    }, [isExiting]);\r\n    React.useEffect(() => {\r\n        if (isDismissed) {\r\n            handleDismiss();\r\n        }\r\n    }, [isDismissed]);\r\n    function handleDismiss() {\r\n        setIsExiting(true);\r\n    }\r\n    const theme = React.useContext(ThemeContext);\r\n    const i18n = React.useContext(I18nContext);\r\n    function progressRingColor() {\r\n        if (isInverse) {\r\n            return theme.colors.neutral100;\r\n        }\r\n        switch (props.variant) {\r\n            case 'success':\r\n                return theme.colors.success500;\r\n            case 'warning':\r\n                return theme.colors.warning500;\r\n            case 'danger':\r\n                return theme.colors.danger500;\r\n            default:\r\n                return theme.colors.info500;\r\n        }\r\n    }\r\n    return (React.createElement(StyledAlert, Object.assign({}, other, { \"data-testid\": testId, id: id, tabIndex: -1, isInverse: isInverse, isExiting: isExiting, isToast: isToast, ref: ref, theme: theme, variant: variant }),\r\n        React.createElement(InverseContext.Provider, { value: { isInverse } },\r\n            React.createElement(StyledAlertInner, { isInverse: isInverse, isToast: isToast, theme: theme, variant: variant },\r\n                renderIcon(variant, isToast, theme),\r\n                React.createElement(AlertContents, { additionalContent: additionalContent, isDismissible: isDismissible, theme: theme },\r\n                    React.createElement(AlertSpan, null, children),\r\n                    additionalContent && (React.createElement(AdditionalContentWrapper, { theme: theme }, additionalContent))),\r\n                isDismissible && (React.createElement(DismissibleIconWrapper, { isInverse: isInverse, variant: variant, theme: theme },\r\n                    hasTimerRing && isToast && (React.createElement(ProgressRingWrapper, { theme: theme },\r\n                        React.createElement(ProgressRing, { color: progressRingColor(), isActive: !isPaused, duration: toastDuration }))),\r\n                    React.createElement(DismissButton, { alertVariant: variant, \"aria-label\": closeAriaLabel\r\n                            ? closeAriaLabel\r\n                            : i18n.alert.dismissAriaLabel, icon: React.createElement(CloseIcon, { size: hasTimerRing\r\n                                ? theme.iconSizes.xSmall\r\n                                : theme.iconSizes.small }), isInverse: isInverse, isToast: isToast, onClick: forceDismiss || handleDismiss, theme: theme, variant: ButtonVariant.link })))))));\r\n});\r\n//# sourceMappingURL=index.js.map"]} */"));
3746
+ }, ";outline-offset:0!important;}&:not(:disabled):active{background:none;color:inherit;}" + (process.env.NODE_ENV === "production" ? "" : "/*# sourceMappingURL=data:application/json;charset=utf-8;base64,{"version":3,"sources":["index.tsx"],"names":[],"mappings":"AA+RgE","file":"index.tsx","sourcesContent":["import * as React from 'react';\r\nimport { css } from '@emotion/react';\r\nimport isPropValid from '@emotion/is-prop-valid';\r\nimport { transparentize } from 'polished';\r\nimport { ThemeContext } from '../../theme/ThemeContext';\r\nimport { InfoIcon, CheckCircleIcon, WarningIcon, ErrorIcon, CloseIcon, } from 'react-magma-icons';\r\nimport { ButtonVariant } from '../Button';\r\nimport { IconButton } from '../IconButton';\r\nimport { ProgressRing } from '../ProgressRing';\r\nimport { useGenerateId } from '../../utils';\r\nimport { I18nContext } from '../../i18n';\r\nimport { InverseContext, useIsInverse } from '../../inverse';\r\nimport styled from '@emotion/styled';\r\nexport const VARIANT_ICON = {\r\n    info: InfoIcon,\r\n    success: CheckCircleIcon,\r\n    warning: WarningIcon,\r\n    danger: ErrorIcon,\r\n};\r\nexport var AlertVariant;\r\n(function (AlertVariant) {\r\n    AlertVariant[\"info\"] = \"info\";\r\n    AlertVariant[\"success\"] = \"success\";\r\n    AlertVariant[\"warning\"] = \"warning\";\r\n    AlertVariant[\"danger\"] = \"danger\";\r\n})(AlertVariant || (AlertVariant = {}));\r\nexport const transitionDuration = 500;\r\nexport function buildAlertBackground(props) {\r\n    if (props.isInverse) {\r\n        switch (props.variant) {\r\n            case 'success':\r\n                return props.theme.colors.success700;\r\n            case 'warning':\r\n                return props.theme.colors.warning700;\r\n            case 'danger':\r\n                return props.theme.colors.danger700;\r\n            default:\r\n                return props.theme.colors.info700;\r\n        }\r\n    }\r\n    switch (props.variant) {\r\n        case 'success':\r\n            return props.theme.colors.success100;\r\n        case 'warning':\r\n            return props.theme.colors.warning100;\r\n        case 'danger':\r\n            return props.theme.colors.danger100;\r\n        default:\r\n            return props.theme.colors.info100;\r\n    }\r\n}\r\nexport function buildAlertBorder(props) {\r\n    if (props.isInverse) {\r\n        switch (props.variant) {\r\n            case 'success':\r\n                return props.theme.colors.success300;\r\n            case 'warning':\r\n                return props.theme.colors.warning300;\r\n            case 'danger':\r\n                return props.theme.colors.danger200;\r\n            default:\r\n                return props.theme.colors.info300;\r\n        }\r\n    }\r\n    switch (props.variant) {\r\n        case 'success':\r\n            return props.theme.colors.success500;\r\n        case 'warning':\r\n            return props.theme.colors.warning500;\r\n        case 'danger':\r\n            return props.theme.colors.danger500;\r\n        default:\r\n            return props.theme.colors.info500;\r\n    }\r\n}\r\nexport function buildAlertColor(props) {\r\n    if (props.isInverse) {\r\n        return props.theme.colors.neutral100;\r\n    }\r\n    switch (props.variant) {\r\n        case 'success':\r\n            return props.theme.colors.success500;\r\n        case 'warning':\r\n            return props.theme.colors.warning500;\r\n        case 'danger':\r\n            return props.theme.colors.danger500;\r\n        default:\r\n            return props.theme.colors.info500;\r\n    }\r\n}\r\nexport function buildLinkColor(props) {\r\n    if (props.isInverse) {\r\n        switch (props.variant) {\r\n            case 'success':\r\n                return props.theme.colors.success200;\r\n            case 'warning':\r\n                return props.theme.colors.warning200;\r\n            case 'danger':\r\n                return props.theme.colors.danger200;\r\n            default:\r\n                return props.theme.colors.info200;\r\n        }\r\n    }\r\n    switch (props.variant) {\r\n        case 'success':\r\n            return props.theme.colors.success700;\r\n        case 'warning':\r\n            return props.theme.colors.warning700;\r\n        case 'danger':\r\n            return props.theme.colors.danger700;\r\n        default:\r\n            return props.theme.colors.info700;\r\n    }\r\n}\r\nexport function buildLinkHoverColor(props) {\r\n    if (props.isInverse) {\r\n        return props.theme.colors.neutral100;\r\n    }\r\n    switch (props.variant) {\r\n        case 'success':\r\n            return props.theme.colors.success;\r\n        case 'warning':\r\n            return props.theme.colors.warning;\r\n        case 'danger':\r\n            return props.theme.colors.danger;\r\n        default:\r\n            return props.theme.colors.info;\r\n    }\r\n}\r\nconst StyledAlert = styled.div `\n  align-items: stretch;\n  animation: ${props => props.isExiting\r\n    ? `fadeout ${transitionDuration}ms`\r\n    : `fadein ${transitionDuration}ms`};\n  display: flex;\n  flex-direction: column;\n  font-size: ${props => props.theme.typeScale.size03.fontSize};\n  font-family: ${props => props.theme.bodyFont};\n  line-height: ${props => props.theme.typeScale.size03.lineHeight};\n  margin-bottom: ${props => props.theme.spaceScale.spacing06};\n  max-width: 100%;\n  padding: 0;\n  position: relative;\n\n  @media (max-width: ${props => props.theme.breakpoints.small}px) {\n    font-size: ${props => props.theme.typeScale.size02.fontSize};\n    letter-spacing: ${props => props.theme.typeScale.size02.letterSpacing};\n    line-height: ${props => props.theme.typeScale.size02.lineHeight};\n  }\n\n  &:focus {\n    outline: 2px solid\n      ${props => props.isInverse\r\n    ? props.theme.colors.focusInverse\r\n    : props.theme.colors.focus};\n  }\n\n  ${props => props.isToast &&\r\n    css `\n      animation: ${props.isExiting\r\n        ? `slideout ${transitionDuration}ms`\r\n        : `slidein ${transitionDuration}ms`};\n      min-width: 375px;\n      margin: 0 auto;\n\n      @media (max-width: ${props.theme.breakpoints.small}px) {\n        min-width: 0;\n        width: 100%;\n      }\n    `}\n\n  @keyframes fadein {\n    from {\n      opacity: 0;\n    }\n    to {\n      opacity: 1;\n    }\n  }\n\n  @keyframes fadeout {\n    from {\n      opacity: 1;\n    }\n    to {\n      opacity: 0;\n    }\n  }\n\n  @keyframes slidein {\n    from {\n      left: -500px;\n    }\n    to {\n      left: 0;\n    }\n  }\n\n  @keyframes slideout {\n    from {\n      left: 0;\n    }\n    to {\n      left: -500px;\n    }\n  }\n\n  a {\n    color: ${props => buildLinkColor(props)};\n    font-weight: 400;\n    text-decoration: underline;\n    &:not([disabled]) {\n      &:focus,\n      &:hover {\n        color: ${props => buildLinkHoverColor(props)};\n      }\n    }\n  }\n`;\r\nconst StyledAlertInner = styled.div `\n  background: ${buildAlertBackground};\n  border: 1px solid ${buildAlertBorder};\n  border-radius: ${props => props.theme.borderRadius};\n  color: ${buildAlertColor};\n  display: flex;\n  position: relative;\n\n  ${props => props.isToast &&\r\n    css `\n      box-shadow: ${props.isInverse\r\n        ? `0 2px 8px 0 ${transparentize(0.3, props.theme.colors.neutral900)}`\r\n        : `0 2px 8px 0 ${transparentize(0.6, props.theme.colors.neutral900)}`};\n      padding-right: 0;\n      height: ${props.theme.spaceScale.spacing11};\n    `}\n`;\r\nconst AlertContents = styled.div `\n  align-items: ${props => (props.additionalContent ? 'center' : '')};\n  align-self: center;\n  flex-grow: 1;\n  font-family: ${props => props.theme.bodyFont};\n  padding: ${props => props.theme.spaceScale.spacing04} 0;\n  display: ${props => (props.additionalContent ? 'flex' : '')};\n  margin-right: ${props => props.additionalContent && !props.isDismissible\r\n    ? props.theme.spaceScale.spacing03\r\n    : ''};\n  @media (max-width: ${props => props.theme.breakpoints.small}px) {\n    padding-left: 0;\n  }\n`;\r\nexport const AdditionalContentWrapper = styled.div `\n  flex: 1 0 auto;\n  justify-content: flex-end;\n  display: flex;\n  margin-left: ${props => props.theme.spaceScale.spacing05};\n`;\r\nconst IconWrapperStyles = css `\n  align-items: center;\n  display: flex;\n  flex-shrink: 0;\n  margin-right: 1px;\n`;\r\nconst IconWrapper = styled.span `\n  ${IconWrapperStyles}\n  padding: 0 ${props => props.theme.spaceScale.spacing03} 0 ${props => props.theme.spaceScale.spacing04};\n\n  @media (max-width: ${props => props.theme.breakpoints.small}px) {\n    padding: 0 ${props => props.theme.spaceScale.spacing03};\n    svg {\n      width: 20px;\n    }\n  }\n`;\r\nconst ProgressRingWrapper = styled.div `\n  margin-top: 6px;\n  position: absolute;\n  top: auto;\n  right: ${props => props.theme.spaceScale.spacing02};\n`;\r\nconst DismissibleIconWrapper = styled.span `\n  ${IconWrapperStyles}\n  margin-left: ${props => props.additionalContent ? props.theme.spaceScale.spacing03 : ''};\n`;\r\nconst whitelistProps = ['icon', 'isInverse', 'theme', 'variant'];\r\nconst shouldForwardProp = prop => {\r\n    return isPropValid(prop) || whitelistProps.includes(prop);\r\n};\r\nconst DismissButton = styled(IconButton, { shouldForwardProp }) `\n  align-self: stretch;\n  border-radius: 0 ${props => props.theme.borderRadius}\n    ${props => props.theme.borderRadius} 0;\n  color: inherit;\n  height: auto;\n  margin: ${props => (props.isToast ? '4px' : '0 -1px 0 0')};\n  padding: ${props => props.isToast\r\n    ? `0 ${props.theme.spaceScale.spacing04}`\r\n    : `0 ${props.theme.spaceScale.spacing03}`};\n  width: auto;\n  &:not(:disabled):hover {\n    background: none;\n    color: inherit;\n  }\n  &:focus:not(:disabled) {\n    background: none;\n    color: inherit;\n    outline: 2px solid\n      ${props => props.isInverse\r\n    ? props.theme.colors.focusInverse\r\n    : props.theme.colors.focus};\n    outline-offset: 0 !important;\n  }\n  &:not(:disabled):active {\n    background: none;\n    color: inherit;\n  }\n`;\r\nconst AlertSpan = styled.span `\n  white-space: pre-line;\n`;\r\nfunction renderIcon(variant = 'info', isToast, theme) {\r\n    const Icon = VARIANT_ICON[variant];\r\n    return (React.createElement(IconWrapper, { isToast: isToast, theme: theme },\r\n        React.createElement(Icon, { size: theme.iconSizes.medium })));\r\n}\r\nexport const AlertBase = React.forwardRef((props, ref) => {\r\n    const { additionalContent, children, closeAriaLabel, forceDismiss, hasTimerRing, id: defaultId, isDismissed, isDismissible, isExiting: externalIsExiting, isPaused, isToast, onDismiss, testId, toastDuration, variant, ...other } = props;\r\n    const id = useGenerateId(defaultId);\r\n    const [isExiting, setIsExiting] = React.useState(false);\r\n    const isInverse = useIsInverse(props.isInverse);\r\n    React.useEffect(() => {\r\n        if (isExiting) {\r\n            setTimeout(() => {\r\n                setIsExiting(false);\r\n                onDismiss && typeof onDismiss === 'function' && onDismiss();\r\n            }, transitionDuration - 300);\r\n        }\r\n    }, [isExiting]);\r\n    React.useEffect(() => {\r\n        if (isDismissed) {\r\n            handleDismiss();\r\n        }\r\n    }, [isDismissed]);\r\n    function handleDismiss() {\r\n        setIsExiting(true);\r\n    }\r\n    const theme = React.useContext(ThemeContext);\r\n    const i18n = React.useContext(I18nContext);\r\n    function progressRingColor() {\r\n        if (isInverse) {\r\n            return theme.colors.neutral100;\r\n        }\r\n        switch (props.variant) {\r\n            case 'success':\r\n                return theme.colors.success500;\r\n            case 'warning':\r\n                return theme.colors.warning500;\r\n            case 'danger':\r\n                return theme.colors.danger500;\r\n            default:\r\n                return theme.colors.info500;\r\n        }\r\n    }\r\n    return (React.createElement(StyledAlert, Object.assign({}, other, { \"data-testid\": testId, id: id, tabIndex: -1, isInverse: isInverse, isExiting: isExiting, isToast: isToast, ref: ref, theme: theme, variant: variant }),\r\n        React.createElement(InverseContext.Provider, { value: { isInverse } },\r\n            React.createElement(StyledAlertInner, { isInverse: isInverse, isToast: isToast, theme: theme, variant: variant },\r\n                renderIcon(variant, isToast, theme),\r\n                React.createElement(AlertContents, { additionalContent: additionalContent, isDismissible: isDismissible, theme: theme },\r\n                    React.createElement(AlertSpan, null, children),\r\n                    additionalContent && (React.createElement(AdditionalContentWrapper, { theme: theme }, additionalContent))),\r\n                isDismissible && (React.createElement(DismissibleIconWrapper, { isInverse: isInverse, variant: variant, theme: theme },\r\n                    hasTimerRing && isToast && (React.createElement(ProgressRingWrapper, { theme: theme },\r\n                        React.createElement(ProgressRing, { color: progressRingColor(), isActive: !isPaused, duration: toastDuration }))),\r\n                    React.createElement(DismissButton, Object.assign({ alertVariant: variant }, (isToast\r\n                        ? { title: closeAriaLabel || i18n.alert.dismissAriaLabel }\r\n                        : {\r\n                            'aria-label': closeAriaLabel || i18n.alert.dismissAriaLabel,\r\n                        }), { icon: React.createElement(CloseIcon, { size: hasTimerRing\r\n                                ? theme.iconSizes.xSmall\r\n                                : theme.iconSizes.small }), isInverse: isInverse, isToast: isToast, onClick: forceDismiss || handleDismiss, theme: theme, variant: ButtonVariant.link }))))))));\r\n});\r\n//# sourceMappingURL=index.js.map"]} */"));
3747
3747
  var AlertSpan = /*#__PURE__*/_styled("span", {
3748
3748
  target: "e126n3g80",
3749
3749
  label: "AlertSpan"
@@ -3753,7 +3753,7 @@ var AlertSpan = /*#__PURE__*/_styled("span", {
3753
3753
  } : {
3754
3754
  name: "1l0p3iw",
3755
3755
  styles: "white-space:pre-line",
3756
- map: "/*# sourceMappingURL=data:application/json;charset=utf-8;base64,{"version":3,"sources":["index.tsx"],"names":[],"mappings":"AA4T8B","file":"index.tsx","sourcesContent":["import * as React from 'react';\r\nimport { css } from '@emotion/react';\r\nimport isPropValid from '@emotion/is-prop-valid';\r\nimport { transparentize } from 'polished';\r\nimport { ThemeContext } from '../../theme/ThemeContext';\r\nimport { InfoIcon, CheckCircleIcon, WarningIcon, ErrorIcon, CloseIcon, } from 'react-magma-icons';\r\nimport { ButtonVariant } from '../Button';\r\nimport { IconButton } from '../IconButton';\r\nimport { ProgressRing } from '../ProgressRing';\r\nimport { useGenerateId } from '../../utils';\r\nimport { I18nContext } from '../../i18n';\r\nimport { InverseContext, useIsInverse } from '../../inverse';\r\nimport styled from '@emotion/styled';\r\nexport const VARIANT_ICON = {\r\n    info: InfoIcon,\r\n    success: CheckCircleIcon,\r\n    warning: WarningIcon,\r\n    danger: ErrorIcon,\r\n};\r\nexport var AlertVariant;\r\n(function (AlertVariant) {\r\n    AlertVariant[\"info\"] = \"info\";\r\n    AlertVariant[\"success\"] = \"success\";\r\n    AlertVariant[\"warning\"] = \"warning\";\r\n    AlertVariant[\"danger\"] = \"danger\";\r\n})(AlertVariant || (AlertVariant = {}));\r\nexport const transitionDuration = 500;\r\nexport function buildAlertBackground(props) {\r\n    if (props.isInverse) {\r\n        switch (props.variant) {\r\n            case 'success':\r\n                return props.theme.colors.success700;\r\n            case 'warning':\r\n                return props.theme.colors.warning700;\r\n            case 'danger':\r\n                return props.theme.colors.danger700;\r\n            default:\r\n                return props.theme.colors.info700;\r\n        }\r\n    }\r\n    switch (props.variant) {\r\n        case 'success':\r\n            return props.theme.colors.success100;\r\n        case 'warning':\r\n            return props.theme.colors.warning100;\r\n        case 'danger':\r\n            return props.theme.colors.danger100;\r\n        default:\r\n            return props.theme.colors.info100;\r\n    }\r\n}\r\nexport function buildAlertBorder(props) {\r\n    if (props.isInverse) {\r\n        switch (props.variant) {\r\n            case 'success':\r\n                return props.theme.colors.success300;\r\n            case 'warning':\r\n                return props.theme.colors.warning300;\r\n            case 'danger':\r\n                return props.theme.colors.danger200;\r\n            default:\r\n                return props.theme.colors.info300;\r\n        }\r\n    }\r\n    switch (props.variant) {\r\n        case 'success':\r\n            return props.theme.colors.success500;\r\n        case 'warning':\r\n            return props.theme.colors.warning500;\r\n        case 'danger':\r\n            return props.theme.colors.danger500;\r\n        default:\r\n            return props.theme.colors.info500;\r\n    }\r\n}\r\nexport function buildAlertColor(props) {\r\n    if (props.isInverse) {\r\n        return props.theme.colors.neutral100;\r\n    }\r\n    switch (props.variant) {\r\n        case 'success':\r\n            return props.theme.colors.success500;\r\n        case 'warning':\r\n            return props.theme.colors.warning500;\r\n        case 'danger':\r\n            return props.theme.colors.danger500;\r\n        default:\r\n            return props.theme.colors.info500;\r\n    }\r\n}\r\nexport function buildLinkColor(props) {\r\n    if (props.isInverse) {\r\n        switch (props.variant) {\r\n            case 'success':\r\n                return props.theme.colors.success200;\r\n            case 'warning':\r\n                return props.theme.colors.warning200;\r\n            case 'danger':\r\n                return props.theme.colors.danger200;\r\n            default:\r\n                return props.theme.colors.info200;\r\n        }\r\n    }\r\n    switch (props.variant) {\r\n        case 'success':\r\n            return props.theme.colors.success700;\r\n        case 'warning':\r\n            return props.theme.colors.warning700;\r\n        case 'danger':\r\n            return props.theme.colors.danger700;\r\n        default:\r\n            return props.theme.colors.info700;\r\n    }\r\n}\r\nexport function buildLinkHoverColor(props) {\r\n    if (props.isInverse) {\r\n        return props.theme.colors.neutral100;\r\n    }\r\n    switch (props.variant) {\r\n        case 'success':\r\n            return props.theme.colors.success;\r\n        case 'warning':\r\n            return props.theme.colors.warning;\r\n        case 'danger':\r\n            return props.theme.colors.danger;\r\n        default:\r\n            return props.theme.colors.info;\r\n    }\r\n}\r\nconst StyledAlert = styled.div `\n  align-items: stretch;\n  animation: ${props => props.isExiting\r\n    ? `fadeout ${transitionDuration}ms`\r\n    : `fadein ${transitionDuration}ms`};\n  display: flex;\n  flex-direction: column;\n  font-size: ${props => props.theme.typeScale.size03.fontSize};\n  font-family: ${props => props.theme.bodyFont};\n  line-height: ${props => props.theme.typeScale.size03.lineHeight};\n  margin-bottom: ${props => props.theme.spaceScale.spacing06};\n  max-width: 100%;\n  padding: 0;\n  position: relative;\n\n  @media (max-width: ${props => props.theme.breakpoints.small}px) {\n    font-size: ${props => props.theme.typeScale.size02.fontSize};\n    letter-spacing: ${props => props.theme.typeScale.size02.letterSpacing};\n    line-height: ${props => props.theme.typeScale.size02.lineHeight};\n  }\n\n  &:focus {\n    outline: 2px solid\n      ${props => props.isInverse\r\n    ? props.theme.colors.focusInverse\r\n    : props.theme.colors.focus};\n  }\n\n  ${props => props.isToast &&\r\n    css `\n      animation: ${props.isExiting\r\n        ? `slideout ${transitionDuration}ms`\r\n        : `slidein ${transitionDuration}ms`};\n      min-width: 375px;\n      margin: 0 auto;\n\n      @media (max-width: ${props.theme.breakpoints.small}px) {\n        min-width: 0;\n        width: 100%;\n      }\n    `}\n\n  @keyframes fadein {\n    from {\n      opacity: 0;\n    }\n    to {\n      opacity: 1;\n    }\n  }\n\n  @keyframes fadeout {\n    from {\n      opacity: 1;\n    }\n    to {\n      opacity: 0;\n    }\n  }\n\n  @keyframes slidein {\n    from {\n      left: -500px;\n    }\n    to {\n      left: 0;\n    }\n  }\n\n  @keyframes slideout {\n    from {\n      left: 0;\n    }\n    to {\n      left: -500px;\n    }\n  }\n\n  a {\n    color: ${props => buildLinkColor(props)};\n    font-weight: 400;\n    text-decoration: underline;\n    &:not([disabled]) {\n      &:focus,\n      &:hover {\n        color: ${props => buildLinkHoverColor(props)};\n      }\n    }\n  }\n`;\r\nconst StyledAlertInner = styled.div `\n  background: ${buildAlertBackground};\n  border: 1px solid ${buildAlertBorder};\n  border-radius: ${props => props.theme.borderRadius};\n  color: ${buildAlertColor};\n  display: flex;\n  position: relative;\n\n  ${props => props.isToast &&\r\n    css `\n      box-shadow: ${props.isInverse\r\n        ? `0 2px 8px 0 ${transparentize(0.3, props.theme.colors.neutral900)}`\r\n        : `0 2px 8px 0 ${transparentize(0.6, props.theme.colors.neutral900)}`};\n      padding-right: 0;\n      height: ${props.theme.spaceScale.spacing11};\n    `}\n`;\r\nconst AlertContents = styled.div `\n  align-items: ${props => (props.additionalContent ? 'center' : '')};\n  align-self: center;\n  flex-grow: 1;\n  font-family: ${props => props.theme.bodyFont};\n  padding: ${props => props.theme.spaceScale.spacing04} 0;\n  display: ${props => (props.additionalContent ? 'flex' : '')};\n  margin-right: ${props => props.additionalContent && !props.isDismissible\r\n    ? props.theme.spaceScale.spacing03\r\n    : ''};\n  @media (max-width: ${props => props.theme.breakpoints.small}px) {\n    padding-left: 0;\n  }\n`;\r\nexport const AdditionalContentWrapper = styled.div `\n  flex: 1 0 auto;\n  justify-content: flex-end;\n  display: flex;\n  margin-left: ${props => props.theme.spaceScale.spacing05};\n`;\r\nconst IconWrapperStyles = css `\n  align-items: center;\n  display: flex;\n  flex-shrink: 0;\n  margin-right: 1px;\n`;\r\nconst IconWrapper = styled.span `\n  ${IconWrapperStyles}\n  padding: 0 ${props => props.theme.spaceScale.spacing03} 0 ${props => props.theme.spaceScale.spacing04};\n\n  @media (max-width: ${props => props.theme.breakpoints.small}px) {\n    padding: 0 ${props => props.theme.spaceScale.spacing03};\n    svg {\n      width: 20px;\n    }\n  }\n`;\r\nconst ProgressRingWrapper = styled.div `\n  margin-top: 6px;\n  position: absolute;\n  top: auto;\n  right: ${props => props.theme.spaceScale.spacing02};\n`;\r\nconst DismissibleIconWrapper = styled.span `\n  ${IconWrapperStyles}\n  margin-left: ${props => props.additionalContent ? props.theme.spaceScale.spacing03 : ''};\n`;\r\nconst whitelistProps = ['icon', 'isInverse', 'theme', 'variant'];\r\nconst shouldForwardProp = prop => {\r\n    return isPropValid(prop) || whitelistProps.includes(prop);\r\n};\r\nconst DismissButton = styled(IconButton, { shouldForwardProp }) `\n  align-self: stretch;\n  border-radius: 0 ${props => props.theme.borderRadius}\n    ${props => props.theme.borderRadius} 0;\n  color: inherit;\n  height: auto;\n  margin: ${props => (props.isToast ? '4px' : '0 -1px 0 0')};\n  padding: ${props => props.isToast\r\n    ? `0 ${props.theme.spaceScale.spacing04}`\r\n    : `0 ${props.theme.spaceScale.spacing03}`};\n  width: auto;\n  &:not(:disabled):hover {\n    background: none;\n    color: inherit;\n  }\n  &:focus:not(:disabled) {\n    background: none;\n    color: inherit;\n    outline: 2px solid\n      ${props => props.isInverse\r\n    ? props.theme.colors.focusInverse\r\n    : props.theme.colors.focus};\n    outline-offset: 0 !important;\n  }\n  &:not(:disabled):active {\n    background: none;\n    color: inherit;\n  }\n`;\r\nconst AlertSpan = styled.span `\n  white-space: pre-line;\n`;\r\nfunction renderIcon(variant = 'info', isToast, theme) {\r\n    const Icon = VARIANT_ICON[variant];\r\n    return (React.createElement(IconWrapper, { isToast: isToast, theme: theme },\r\n        React.createElement(Icon, { size: theme.iconSizes.medium })));\r\n}\r\nexport const AlertBase = React.forwardRef((props, ref) => {\r\n    const { additionalContent, children, closeAriaLabel, forceDismiss, hasTimerRing, id: defaultId, isDismissed, isDismissible, isExiting: externalIsExiting, isPaused, isToast, onDismiss, testId, toastDuration, variant, ...other } = props;\r\n    const id = useGenerateId(defaultId);\r\n    const [isExiting, setIsExiting] = React.useState(false);\r\n    const isInverse = useIsInverse(props.isInverse);\r\n    React.useEffect(() => {\r\n        if (isExiting) {\r\n            setTimeout(() => {\r\n                setIsExiting(false);\r\n                onDismiss && typeof onDismiss === 'function' && onDismiss();\r\n            }, transitionDuration - 300);\r\n        }\r\n    }, [isExiting]);\r\n    React.useEffect(() => {\r\n        if (isDismissed) {\r\n            handleDismiss();\r\n        }\r\n    }, [isDismissed]);\r\n    function handleDismiss() {\r\n        setIsExiting(true);\r\n    }\r\n    const theme = React.useContext(ThemeContext);\r\n    const i18n = React.useContext(I18nContext);\r\n    function progressRingColor() {\r\n        if (isInverse) {\r\n            return theme.colors.neutral100;\r\n        }\r\n        switch (props.variant) {\r\n            case 'success':\r\n                return theme.colors.success500;\r\n            case 'warning':\r\n                return theme.colors.warning500;\r\n            case 'danger':\r\n                return theme.colors.danger500;\r\n            default:\r\n                return theme.colors.info500;\r\n        }\r\n    }\r\n    return (React.createElement(StyledAlert, Object.assign({}, other, { \"data-testid\": testId, id: id, tabIndex: -1, isInverse: isInverse, isExiting: isExiting, isToast: isToast, ref: ref, theme: theme, variant: variant }),\r\n        React.createElement(InverseContext.Provider, { value: { isInverse } },\r\n            React.createElement(StyledAlertInner, { isInverse: isInverse, isToast: isToast, theme: theme, variant: variant },\r\n                renderIcon(variant, isToast, theme),\r\n                React.createElement(AlertContents, { additionalContent: additionalContent, isDismissible: isDismissible, theme: theme },\r\n                    React.createElement(AlertSpan, null, children),\r\n                    additionalContent && (React.createElement(AdditionalContentWrapper, { theme: theme }, additionalContent))),\r\n                isDismissible && (React.createElement(DismissibleIconWrapper, { isInverse: isInverse, variant: variant, theme: theme },\r\n                    hasTimerRing && isToast && (React.createElement(ProgressRingWrapper, { theme: theme },\r\n                        React.createElement(ProgressRing, { color: progressRingColor(), isActive: !isPaused, duration: toastDuration }))),\r\n                    React.createElement(DismissButton, { alertVariant: variant, \"aria-label\": closeAriaLabel\r\n                            ? closeAriaLabel\r\n                            : i18n.alert.dismissAriaLabel, icon: React.createElement(CloseIcon, { size: hasTimerRing\r\n                                ? theme.iconSizes.xSmall\r\n                                : theme.iconSizes.small }), isInverse: isInverse, isToast: isToast, onClick: forceDismiss || handleDismiss, theme: theme, variant: ButtonVariant.link })))))));\r\n});\r\n//# sourceMappingURL=index.js.map"]} */",
3756
+ map: "/*# sourceMappingURL=data:application/json;charset=utf-8;base64,{"version":3,"sources":["index.tsx"],"names":[],"mappings":"AA4T8B","file":"index.tsx","sourcesContent":["import * as React from 'react';\r\nimport { css } from '@emotion/react';\r\nimport isPropValid from '@emotion/is-prop-valid';\r\nimport { transparentize } from 'polished';\r\nimport { ThemeContext } from '../../theme/ThemeContext';\r\nimport { InfoIcon, CheckCircleIcon, WarningIcon, ErrorIcon, CloseIcon, } from 'react-magma-icons';\r\nimport { ButtonVariant } from '../Button';\r\nimport { IconButton } from '../IconButton';\r\nimport { ProgressRing } from '../ProgressRing';\r\nimport { useGenerateId } from '../../utils';\r\nimport { I18nContext } from '../../i18n';\r\nimport { InverseContext, useIsInverse } from '../../inverse';\r\nimport styled from '@emotion/styled';\r\nexport const VARIANT_ICON = {\r\n    info: InfoIcon,\r\n    success: CheckCircleIcon,\r\n    warning: WarningIcon,\r\n    danger: ErrorIcon,\r\n};\r\nexport var AlertVariant;\r\n(function (AlertVariant) {\r\n    AlertVariant[\"info\"] = \"info\";\r\n    AlertVariant[\"success\"] = \"success\";\r\n    AlertVariant[\"warning\"] = \"warning\";\r\n    AlertVariant[\"danger\"] = \"danger\";\r\n})(AlertVariant || (AlertVariant = {}));\r\nexport const transitionDuration = 500;\r\nexport function buildAlertBackground(props) {\r\n    if (props.isInverse) {\r\n        switch (props.variant) {\r\n            case 'success':\r\n                return props.theme.colors.success700;\r\n            case 'warning':\r\n                return props.theme.colors.warning700;\r\n            case 'danger':\r\n                return props.theme.colors.danger700;\r\n            default:\r\n                return props.theme.colors.info700;\r\n        }\r\n    }\r\n    switch (props.variant) {\r\n        case 'success':\r\n            return props.theme.colors.success100;\r\n        case 'warning':\r\n            return props.theme.colors.warning100;\r\n        case 'danger':\r\n            return props.theme.colors.danger100;\r\n        default:\r\n            return props.theme.colors.info100;\r\n    }\r\n}\r\nexport function buildAlertBorder(props) {\r\n    if (props.isInverse) {\r\n        switch (props.variant) {\r\n            case 'success':\r\n                return props.theme.colors.success300;\r\n            case 'warning':\r\n                return props.theme.colors.warning300;\r\n            case 'danger':\r\n                return props.theme.colors.danger200;\r\n            default:\r\n                return props.theme.colors.info300;\r\n        }\r\n    }\r\n    switch (props.variant) {\r\n        case 'success':\r\n            return props.theme.colors.success500;\r\n        case 'warning':\r\n            return props.theme.colors.warning500;\r\n        case 'danger':\r\n            return props.theme.colors.danger500;\r\n        default:\r\n            return props.theme.colors.info500;\r\n    }\r\n}\r\nexport function buildAlertColor(props) {\r\n    if (props.isInverse) {\r\n        return props.theme.colors.neutral100;\r\n    }\r\n    switch (props.variant) {\r\n        case 'success':\r\n            return props.theme.colors.success500;\r\n        case 'warning':\r\n            return props.theme.colors.warning500;\r\n        case 'danger':\r\n            return props.theme.colors.danger500;\r\n        default:\r\n            return props.theme.colors.info500;\r\n    }\r\n}\r\nexport function buildLinkColor(props) {\r\n    if (props.isInverse) {\r\n        switch (props.variant) {\r\n            case 'success':\r\n                return props.theme.colors.success200;\r\n            case 'warning':\r\n                return props.theme.colors.warning200;\r\n            case 'danger':\r\n                return props.theme.colors.danger200;\r\n            default:\r\n                return props.theme.colors.info200;\r\n        }\r\n    }\r\n    switch (props.variant) {\r\n        case 'success':\r\n            return props.theme.colors.success700;\r\n        case 'warning':\r\n            return props.theme.colors.warning700;\r\n        case 'danger':\r\n            return props.theme.colors.danger700;\r\n        default:\r\n            return props.theme.colors.info700;\r\n    }\r\n}\r\nexport function buildLinkHoverColor(props) {\r\n    if (props.isInverse) {\r\n        return props.theme.colors.neutral100;\r\n    }\r\n    switch (props.variant) {\r\n        case 'success':\r\n            return props.theme.colors.success;\r\n        case 'warning':\r\n            return props.theme.colors.warning;\r\n        case 'danger':\r\n            return props.theme.colors.danger;\r\n        default:\r\n            return props.theme.colors.info;\r\n    }\r\n}\r\nconst StyledAlert = styled.div `\n  align-items: stretch;\n  animation: ${props => props.isExiting\r\n    ? `fadeout ${transitionDuration}ms`\r\n    : `fadein ${transitionDuration}ms`};\n  display: flex;\n  flex-direction: column;\n  font-size: ${props => props.theme.typeScale.size03.fontSize};\n  font-family: ${props => props.theme.bodyFont};\n  line-height: ${props => props.theme.typeScale.size03.lineHeight};\n  margin-bottom: ${props => props.theme.spaceScale.spacing06};\n  max-width: 100%;\n  padding: 0;\n  position: relative;\n\n  @media (max-width: ${props => props.theme.breakpoints.small}px) {\n    font-size: ${props => props.theme.typeScale.size02.fontSize};\n    letter-spacing: ${props => props.theme.typeScale.size02.letterSpacing};\n    line-height: ${props => props.theme.typeScale.size02.lineHeight};\n  }\n\n  &:focus {\n    outline: 2px solid\n      ${props => props.isInverse\r\n    ? props.theme.colors.focusInverse\r\n    : props.theme.colors.focus};\n  }\n\n  ${props => props.isToast &&\r\n    css `\n      animation: ${props.isExiting\r\n        ? `slideout ${transitionDuration}ms`\r\n        : `slidein ${transitionDuration}ms`};\n      min-width: 375px;\n      margin: 0 auto;\n\n      @media (max-width: ${props.theme.breakpoints.small}px) {\n        min-width: 0;\n        width: 100%;\n      }\n    `}\n\n  @keyframes fadein {\n    from {\n      opacity: 0;\n    }\n    to {\n      opacity: 1;\n    }\n  }\n\n  @keyframes fadeout {\n    from {\n      opacity: 1;\n    }\n    to {\n      opacity: 0;\n    }\n  }\n\n  @keyframes slidein {\n    from {\n      left: -500px;\n    }\n    to {\n      left: 0;\n    }\n  }\n\n  @keyframes slideout {\n    from {\n      left: 0;\n    }\n    to {\n      left: -500px;\n    }\n  }\n\n  a {\n    color: ${props => buildLinkColor(props)};\n    font-weight: 400;\n    text-decoration: underline;\n    &:not([disabled]) {\n      &:focus,\n      &:hover {\n        color: ${props => buildLinkHoverColor(props)};\n      }\n    }\n  }\n`;\r\nconst StyledAlertInner = styled.div `\n  background: ${buildAlertBackground};\n  border: 1px solid ${buildAlertBorder};\n  border-radius: ${props => props.theme.borderRadius};\n  color: ${buildAlertColor};\n  display: flex;\n  position: relative;\n\n  ${props => props.isToast &&\r\n    css `\n      box-shadow: ${props.isInverse\r\n        ? `0 2px 8px 0 ${transparentize(0.3, props.theme.colors.neutral900)}`\r\n        : `0 2px 8px 0 ${transparentize(0.6, props.theme.colors.neutral900)}`};\n      padding-right: 0;\n      height: ${props.theme.spaceScale.spacing11};\n    `}\n`;\r\nconst AlertContents = styled.div `\n  align-items: ${props => (props.additionalContent ? 'center' : '')};\n  align-self: center;\n  flex-grow: 1;\n  font-family: ${props => props.theme.bodyFont};\n  padding: ${props => props.theme.spaceScale.spacing04} 0;\n  display: ${props => (props.additionalContent ? 'flex' : '')};\n  margin-right: ${props => props.additionalContent && !props.isDismissible\r\n    ? props.theme.spaceScale.spacing03\r\n    : ''};\n  @media (max-width: ${props => props.theme.breakpoints.small}px) {\n    padding-left: 0;\n  }\n`;\r\nexport const AdditionalContentWrapper = styled.div `\n  flex: 1 0 auto;\n  justify-content: flex-end;\n  display: flex;\n  margin-left: ${props => props.theme.spaceScale.spacing05};\n`;\r\nconst IconWrapperStyles = css `\n  align-items: center;\n  display: flex;\n  flex-shrink: 0;\n  margin-right: 1px;\n`;\r\nconst IconWrapper = styled.span `\n  ${IconWrapperStyles}\n  padding: 0 ${props => props.theme.spaceScale.spacing03} 0 ${props => props.theme.spaceScale.spacing04};\n\n  @media (max-width: ${props => props.theme.breakpoints.small}px) {\n    padding: 0 ${props => props.theme.spaceScale.spacing03};\n    svg {\n      width: 20px;\n    }\n  }\n`;\r\nconst ProgressRingWrapper = styled.div `\n  margin-top: 6px;\n  position: absolute;\n  top: auto;\n  right: ${props => props.theme.spaceScale.spacing02};\n`;\r\nconst DismissibleIconWrapper = styled.span `\n  ${IconWrapperStyles}\n  margin-left: ${props => props.additionalContent ? props.theme.spaceScale.spacing03 : ''};\n`;\r\nconst whitelistProps = ['icon', 'isInverse', 'theme', 'variant'];\r\nconst shouldForwardProp = prop => {\r\n    return isPropValid(prop) || whitelistProps.includes(prop);\r\n};\r\nconst DismissButton = styled(IconButton, { shouldForwardProp }) `\n  align-self: stretch;\n  border-radius: 0 ${props => props.theme.borderRadius}\n    ${props => props.theme.borderRadius} 0;\n  color: inherit;\n  height: auto;\n  margin: ${props => (props.isToast ? '4px' : '0 -1px 0 0')};\n  padding: ${props => props.isToast\r\n    ? `0 ${props.theme.spaceScale.spacing04}`\r\n    : `0 ${props.theme.spaceScale.spacing03}`};\n  width: auto;\n  &:not(:disabled):hover {\n    background: none;\n    color: inherit;\n  }\n  &:focus:not(:disabled) {\n    background: none;\n    color: inherit;\n    outline: 2px solid\n      ${props => props.isInverse\r\n    ? props.theme.colors.focusInverse\r\n    : props.theme.colors.focus};\n    outline-offset: 0 !important;\n  }\n  &:not(:disabled):active {\n    background: none;\n    color: inherit;\n  }\n`;\r\nconst AlertSpan = styled.span `\n  white-space: pre-line;\n`;\r\nfunction renderIcon(variant = 'info', isToast, theme) {\r\n    const Icon = VARIANT_ICON[variant];\r\n    return (React.createElement(IconWrapper, { isToast: isToast, theme: theme },\r\n        React.createElement(Icon, { size: theme.iconSizes.medium })));\r\n}\r\nexport const AlertBase = React.forwardRef((props, ref) => {\r\n    const { additionalContent, children, closeAriaLabel, forceDismiss, hasTimerRing, id: defaultId, isDismissed, isDismissible, isExiting: externalIsExiting, isPaused, isToast, onDismiss, testId, toastDuration, variant, ...other } = props;\r\n    const id = useGenerateId(defaultId);\r\n    const [isExiting, setIsExiting] = React.useState(false);\r\n    const isInverse = useIsInverse(props.isInverse);\r\n    React.useEffect(() => {\r\n        if (isExiting) {\r\n            setTimeout(() => {\r\n                setIsExiting(false);\r\n                onDismiss && typeof onDismiss === 'function' && onDismiss();\r\n            }, transitionDuration - 300);\r\n        }\r\n    }, [isExiting]);\r\n    React.useEffect(() => {\r\n        if (isDismissed) {\r\n            handleDismiss();\r\n        }\r\n    }, [isDismissed]);\r\n    function handleDismiss() {\r\n        setIsExiting(true);\r\n    }\r\n    const theme = React.useContext(ThemeContext);\r\n    const i18n = React.useContext(I18nContext);\r\n    function progressRingColor() {\r\n        if (isInverse) {\r\n            return theme.colors.neutral100;\r\n        }\r\n        switch (props.variant) {\r\n            case 'success':\r\n                return theme.colors.success500;\r\n            case 'warning':\r\n                return theme.colors.warning500;\r\n            case 'danger':\r\n                return theme.colors.danger500;\r\n            default:\r\n                return theme.colors.info500;\r\n        }\r\n    }\r\n    return (React.createElement(StyledAlert, Object.assign({}, other, { \"data-testid\": testId, id: id, tabIndex: -1, isInverse: isInverse, isExiting: isExiting, isToast: isToast, ref: ref, theme: theme, variant: variant }),\r\n        React.createElement(InverseContext.Provider, { value: { isInverse } },\r\n            React.createElement(StyledAlertInner, { isInverse: isInverse, isToast: isToast, theme: theme, variant: variant },\r\n                renderIcon(variant, isToast, theme),\r\n                React.createElement(AlertContents, { additionalContent: additionalContent, isDismissible: isDismissible, theme: theme },\r\n                    React.createElement(AlertSpan, null, children),\r\n                    additionalContent && (React.createElement(AdditionalContentWrapper, { theme: theme }, additionalContent))),\r\n                isDismissible && (React.createElement(DismissibleIconWrapper, { isInverse: isInverse, variant: variant, theme: theme },\r\n                    hasTimerRing && isToast && (React.createElement(ProgressRingWrapper, { theme: theme },\r\n                        React.createElement(ProgressRing, { color: progressRingColor(), isActive: !isPaused, duration: toastDuration }))),\r\n                    React.createElement(DismissButton, Object.assign({ alertVariant: variant }, (isToast\r\n                        ? { title: closeAriaLabel || i18n.alert.dismissAriaLabel }\r\n                        : {\r\n                            'aria-label': closeAriaLabel || i18n.alert.dismissAriaLabel,\r\n                        }), { icon: React.createElement(CloseIcon, { size: hasTimerRing\r\n                                ? theme.iconSizes.xSmall\r\n                                : theme.iconSizes.small }), isInverse: isInverse, isToast: isToast, onClick: forceDismiss || handleDismiss, theme: theme, variant: ButtonVariant.link }))))))));\r\n});\r\n//# sourceMappingURL=index.js.map"]} */",
3757
3757
  toString: _EMOTION_STRINGIFIED_CSS_ERROR__$4
3758
3758
  });
3759
3759
  function renderIcon(variant, isToast, theme) {
@@ -3857,9 +3857,13 @@ var AlertBase = /*#__PURE__*/forwardRef(function (props, ref) {
3857
3857
  color: progressRingColor(),
3858
3858
  isActive: !isPaused,
3859
3859
  duration: toastDuration
3860
- })), createElement(DismissButton, {
3861
- alertVariant: variant,
3862
- "aria-label": closeAriaLabel ? closeAriaLabel : i18n.alert.dismissAriaLabel,
3860
+ })), createElement(DismissButton, Object.assign({
3861
+ alertVariant: variant
3862
+ }, isToast ? {
3863
+ title: closeAriaLabel || i18n.alert.dismissAriaLabel
3864
+ } : {
3865
+ 'aria-label': closeAriaLabel || i18n.alert.dismissAriaLabel
3866
+ }, {
3863
3867
  icon: createElement(CloseIcon, {
3864
3868
  size: hasTimerRing ? theme.iconSizes.xSmall : theme.iconSizes.small
3865
3869
  }),
@@ -3868,7 +3872,7 @@ var AlertBase = /*#__PURE__*/forwardRef(function (props, ref) {
3868
3872
  onClick: forceDismiss || handleDismiss,
3869
3873
  theme: theme,
3870
3874
  variant: ButtonVariant.link
3871
- })))));
3875
+ }))))));
3872
3876
  });
3873
3877
 
3874
3878
  var Alert = /*#__PURE__*/forwardRef(function (props, ref) {
@@ -24490,7 +24494,7 @@ var SelectContainerElement = /*#__PURE__*/_styled("div", {
24490
24494
  return props.labelPosition === LabelPosition.left || props.isLabelVisuallyHidden && LabelPosition.top ? 'row' : 'column';
24491
24495
  }, ";position:relative;label{flex-basis:", function (props) {
24492
24496
  return props.labelWidth && props.labelPosition === LabelPosition.left ? props.labelWidth + "%" : '';
24493
- }, ";}" + (process.env.NODE_ENV === "production" ? "" : "/*# sourceMappingURL=data:application/json;charset=utf-8;base64,eyJ2ZXJzaW9uIjozLCJzb3VyY2VzIjpbIlNlbGVjdENvbnRhaW5lci50c3giXSwibmFtZXMiOltdLCJtYXBwaW5ncyI6IkFBTWlEIiwiZmlsZSI6IlNlbGVjdENvbnRhaW5lci50c3giLCJzb3VyY2VzQ29udGVudCI6WyJpbXBvcnQgUmVhY3QgZnJvbSAncmVhY3QnO1xyXG5pbXBvcnQgc3R5bGVkIGZyb20gJ0BlbW90aW9uL3N0eWxlZCc7XHJcbmltcG9ydCB7IExhYmVsLCBMYWJlbFBvc2l0aW9uIH0gZnJvbSAnLi4vTGFiZWwnO1xyXG5pbXBvcnQgeyBWaXN1YWxseUhpZGRlbiB9IGZyb20gJy4uL1Zpc3VhbGx5SGlkZGVuJztcclxuaW1wb3J0IHsgSW5wdXRNZXNzYWdlIH0gZnJvbSAnLi4vSW5wdXQvSW5wdXRNZXNzYWdlJztcclxuaW1wb3J0IHsgVGhlbWVDb250ZXh0IH0gZnJvbSAnLi4vLi4vdGhlbWUvVGhlbWVDb250ZXh0JztcclxuZXhwb3J0IGNvbnN0IFNlbGVjdENvbnRhaW5lckVsZW1lbnQgPSBzdHlsZWQuZGl2IGBcbiAgZGlzcGxheTogZmxleDtcbiAgZmxleC1kaXJlY3Rpb246ICR7cHJvcHMgPT4gcHJvcHMubGFiZWxQb3NpdGlvbiA9PT0gTGFiZWxQb3NpdGlvbi5sZWZ0IHx8XHJcbiAgICAocHJvcHMuaXNMYWJlbFZpc3VhbGx5SGlkZGVuICYmIExhYmVsUG9zaXRpb24udG9wKVxyXG4gICAgPyAncm93J1xyXG4gICAgOiAnY29sdW1uJ307XG4gIHBvc2l0aW9uOiByZWxhdGl2ZTtcbiAgbGFiZWwge1xuICAgIGZsZXgtYmFzaXM6ICR7cHJvcHMgPT4gcHJvcHMubGFiZWxXaWR0aCAmJiBwcm9wcy5sYWJlbFBvc2l0aW9uID09PSBMYWJlbFBvc2l0aW9uLmxlZnRcclxuICAgID8gYCR7cHJvcHMubGFiZWxXaWR0aH0lYFxyXG4gICAgOiAnJ307XG4gIH1cbmA7XHJcbmNvbnN0IElucHV0TWVzc2FnZUNvbnRhaW5lciA9IHN0eWxlZC5kaXYgYFxuICBmbGV4LWdyb3c6IDE7XG4gIHBhZGRpbmc6IDAuMjVlbTtcbiAgbWFyZ2luOiAtMC4yNWVtO1xuICBtaW4td2lkdGg6IDAlO1xuICBwb3NpdGlvbjogcmVsYXRpdmU7XG5gO1xyXG5jb25zdCBTdHlsZWRBZGRpdGlvbmFsQ29udGVudFdyYXBwZXIgPSBzdHlsZWQuZGl2IGBcbiAgYWxpZ24taXRlbXM6IGNlbnRlcjtcbiAgZGlzcGxheTogZmxleDtcbiAgZmxleDogMTtcbiAganVzdGlmeS1jb250ZW50OiBzcGFjZS1iZXR3ZWVuO1xuICBsYWJlbCB7XG4gICAgbWFyZ2luOiAke3Byb3BzID0+IHByb3BzLmxhYmVsUG9zaXRpb24gPT09IExhYmVsUG9zaXRpb24ubGVmdFxyXG4gICAgPyBgMCAke3Byb3BzLnRoZW1lLnNwYWNlU2NhbGUuc3BhY2luZzAzfSAwIDBgXHJcbiAgICA6ICcnfTtcbiAgfVxuICBidXR0b24ge1xuICAgIGJvdHRvbTogJHtwcm9wcyA9PiBwcm9wcy5sYWJlbFBvc2l0aW9uICE9PSBMYWJlbFBvc2l0aW9uLmxlZnQgPyBgNnB4YCA6ICcnfTtcbiAgfVxuYDtcclxuY29uc3QgU3R5bGVkQWRkaXRpb25hbENvbnRlbnQgPSBzdHlsZWQuZGl2IGBcbiAgZGlzcGxheTogZmxleDtcbiAgYWxpZ24taXRlbXM6IGNlbnRlcjtcbiAgYnV0dG9uIHtcbiAgICBtYXJnaW46ICR7cHJvcHMgPT4gcHJvcHMubGFiZWxQb3NpdGlvbiA9PT0gTGFiZWxQb3NpdGlvbi5sZWZ0XHJcbiAgICA/IGAwIDAgMCAke3Byb3BzLnRoZW1lLnNwYWNlU2NhbGUuc3BhY2luZzAzfWBcclxuICAgIDogJyd9O1xuICB9XG5gO1xyXG5jb25zdCBGb3JtRmllbGQgPSBzdHlsZWQuZm9ybSBgXG4gIGZsZXg6IDEgMSBhdXRvO1xuICBtaW4td2lkdGg6IDAlO1xuYDtcclxuZXhwb3J0IGZ1bmN0aW9uIFNlbGVjdENvbnRhaW5lcihwcm9wcykge1xyXG4gICAgY29uc3QgeyBhZGRpdGlvbmFsQ29udGVudCwgY2hpbGRyZW4sIGRlc2NyaXB0aW9uSWQsIGVycm9yTWVzc2FnZSwgZ2V0TGFiZWxQcm9wcywgaGVscGVyTWVzc2FnZSwgaXNJbnZlcnNlLCBpc0xhYmVsVmlzdWFsbHlIaWRkZW4sIGxhYmVsUG9zaXRpb24sIGxhYmVsU3R5bGUsIGxhYmVsVGV4dCwgbGFiZWxXaWR0aCwgbWVzc2FnZVN0eWxlLCB9ID0gcHJvcHM7XHJcbiAgICBjb25zdCBoYXNFcnJvciA9ICEhZXJyb3JNZXNzYWdlO1xyXG4gICAgY29uc3QgdGhlbWUgPSBSZWFjdC51c2VDb250ZXh0KFRoZW1lQ29udGV4dCk7XHJcbiAgICAvLyBJZiB0aGUgbGFiZWxQb3NpdGlvbiBpcyBzZXQgdG8gJ3RvcCcgKGRlZmF1bHQpIHRoZW4gYSA8ZGl2PiB3cmFwcyB0aGUgTGFiZWwgYW5kIGFkZGl0aW9uYWwgY29udGVudCBmb3IgcHJvcGVyIHN0eWxpbmcgYWxpZ25tZW50LlxyXG4gICAgZnVuY3Rpb24gQWRkaXRpb25hbENvbnRlbnRXcmFwcGVyKHByb3BzKSB7XHJcbiAgICAgICAgaWYgKGxhYmVsUG9zaXRpb24gIT09IExhYmVsUG9zaXRpb24ubGVmdCAmJlxyXG4gICAgICAgICAgICAhaXNMYWJlbFZpc3VhbGx5SGlkZGVuICYmXHJcbiAgICAgICAgICAgIGFkZGl0aW9uYWxDb250ZW50KSB7XHJcbiAgICAgICAgICAgIHJldHVybiAoUmVhY3QuY3JlYXRlRWxlbWVudChTdHlsZWRBZGRpdGlvbmFsQ29udGVudFdyYXBwZXIsIHsgbGFiZWxQb3NpdGlvbjogbGFiZWxQb3NpdGlvbiwgdGhlbWU6IHRoZW1lIH0sXHJcbiAgICAgICAgICAgICAgICBwcm9wcy5jaGlsZHJlbixcclxuICAgICAgICAgICAgICAgIGFkZGl0aW9uYWxDb250ZW50KSk7XHJcbiAgICAgICAgfVxyXG4gICAgICAgIHJldHVybiBwcm9wcy5jaGlsZHJlbjtcclxuICAgIH1cclxuICAgIC8vIElmIHRoZSBsYWJlbFBvc2l0aW9uIGlzIHNldCB0byBMYWJlbFBvc2l0aW9uLmxlZnQgdGhlbiB0aGUgbGFiZWwsIHNlbGVjdCwgYW5kIGFkZGl0aW9uYWwgY29udGVudCBkaXNwbGF5IGlubGluZS5cclxuICAgIGZ1bmN0aW9uIGFkZGl0aW9uYWxJdGVtUmlnaHRBbGlnbigpIHtcclxuICAgICAgICBpZiAoKGxhYmVsUG9zaXRpb24gPT09IExhYmVsUG9zaXRpb24ubGVmdCAmJiBhZGRpdGlvbmFsQ29udGVudCkgfHxcclxuICAgICAgICAgICAgKGxhYmVsUG9zaXRpb24gJiYgaXNMYWJlbFZpc3VhbGx5SGlkZGVuICYmIGFkZGl0aW9uYWxDb250ZW50KSkge1xyXG4gICAgICAgICAgICByZXR1cm4gKFJlYWN0LmNyZWF0ZUVsZW1lbnQoU3R5bGVkQWRkaXRpb25hbENvbnRlbnQsIHsgbGFiZWxQb3NpdGlvbjogbGFiZWxQb3NpdGlvbiwgdGhlbWU6IHRoZW1lIH0sIGFkZGl0aW9uYWxDb250ZW50KSk7XHJcbiAgICAgICAgfVxyXG4gICAgfVxyXG4gICAgcmV0dXJuIChSZWFjdC5jcmVhdGVFbGVtZW50KFNlbGVjdENvbnRhaW5lckVsZW1lbnQsIHsgaXNMYWJlbFZpc3VhbGx5SGlkZGVuOiBpc0xhYmVsVmlzdWFsbHlIaWRkZW4sIGxhYmVsUG9zaXRpb246IGxhYmVsUG9zaXRpb24sIGxhYmVsV2lkdGg6IGxhYmVsV2lkdGgsIFwiZGF0YS10ZXN0aWRcIjogXCJzZWxlY3RDb250YWluZXJFbGVtZW50XCIgfSxcclxuICAgICAgICBSZWFjdC5jcmVhdGVFbGVtZW50KEFkZGl0aW9uYWxDb250ZW50V3JhcHBlciwgeyBsYWJlbFBvc2l0aW9uOiBsYWJlbFBvc2l0aW9uIH0sXHJcbiAgICAgICAgICAgIFJlYWN0LmNyZWF0ZUVsZW1lbnQoTGFiZWwsIE9iamVjdC5hc3NpZ24oe30sIGdldExhYmVsUHJvcHMoKSwgeyBpc0ludmVyc2U6IGlzSW52ZXJzZSwgbGFiZWxQb3NpdGlvbjogbGFiZWxQb3NpdGlvbiwgc3R5bGU6IGxhYmVsU3R5bGUgfSksIGlzTGFiZWxWaXN1YWxseUhpZGRlbiA/IChSZWFjdC5jcmVhdGVFbGVtZW50KFZpc3VhbGx5SGlkZGVuLCBudWxsLCBsYWJlbFRleHQpKSA6IChsYWJlbFRleHQpKSksXHJcbiAgICAgICAgUmVhY3QuY3JlYXRlRWxlbWVudChGb3JtRmllbGQsIG51bGwsXHJcbiAgICAgICAgICAgIFJlYWN0LmNyZWF0ZUVsZW1lbnQoSW5wdXRNZXNzYWdlQ29udGFpbmVyLCBudWxsLCBjaGlsZHJlbiksXHJcbiAgICAgICAgICAgICEobGFiZWxQb3NpdGlvbiA9PT0gTGFiZWxQb3NpdGlvbi5sZWZ0ICYmXHJcbiAgICAgICAgICAgICAgICAhKGVycm9yTWVzc2FnZSB8fCBoZWxwZXJNZXNzYWdlKSkgJiZcclxuICAgICAgICAgICAgICAgIChlcnJvck1lc3NhZ2UgfHwgaGVscGVyTWVzc2FnZSkgJiYgKFJlYWN0LmNyZWF0ZUVsZW1lbnQoSW5wdXRNZXNzYWdlLCB7IGlkOiBkZXNjcmlwdGlvbklkLCBpc0ludmVyc2U6IGlzSW52ZXJzZSwgaGFzRXJyb3I6IGhhc0Vycm9yLCBzdHlsZTogbWVzc2FnZVN0eWxlIH0sIChlcnJvck1lc3NhZ2UgfHwgaGVscGVyTWVzc2FnZSkgJiYgKFJlYWN0LmNyZWF0ZUVsZW1lbnQoUmVhY3QuRnJhZ21lbnQsIG51bGwsIGVycm9yTWVzc2FnZSA/IGVycm9yTWVzc2FnZSA6IGhlbHBlck1lc3NhZ2UpKSkpKSxcclxuICAgICAgICBhZGRpdGlvbmFsSXRlbVJpZ2h0QWxpZ24oKSkpO1xyXG59XHJcbi8vIyBzb3VyY2VNYXBwaW5nVVJMPVNlbGVjdENvbnRhaW5lci5qcy5tYXAiXX0= */"));
24497
+ }, ";}" + (process.env.NODE_ENV === "production" ? "" : "/*# sourceMappingURL=data:application/json;charset=utf-8;base64,eyJ2ZXJzaW9uIjozLCJzb3VyY2VzIjpbIlNlbGVjdENvbnRhaW5lci50c3giXSwibmFtZXMiOltdLCJtYXBwaW5ncyI6IkFBTWlEIiwiZmlsZSI6IlNlbGVjdENvbnRhaW5lci50c3giLCJzb3VyY2VzQ29udGVudCI6WyJpbXBvcnQgUmVhY3QgZnJvbSAncmVhY3QnO1xyXG5pbXBvcnQgc3R5bGVkIGZyb20gJ0BlbW90aW9uL3N0eWxlZCc7XHJcbmltcG9ydCB7IExhYmVsLCBMYWJlbFBvc2l0aW9uIH0gZnJvbSAnLi4vTGFiZWwnO1xyXG5pbXBvcnQgeyBWaXN1YWxseUhpZGRlbiB9IGZyb20gJy4uL1Zpc3VhbGx5SGlkZGVuJztcclxuaW1wb3J0IHsgSW5wdXRNZXNzYWdlIH0gZnJvbSAnLi4vSW5wdXQvSW5wdXRNZXNzYWdlJztcclxuaW1wb3J0IHsgVGhlbWVDb250ZXh0IH0gZnJvbSAnLi4vLi4vdGhlbWUvVGhlbWVDb250ZXh0JztcclxuZXhwb3J0IGNvbnN0IFNlbGVjdENvbnRhaW5lckVsZW1lbnQgPSBzdHlsZWQuZGl2IGBcbiAgZGlzcGxheTogZmxleDtcbiAgZmxleC1kaXJlY3Rpb246ICR7cHJvcHMgPT4gcHJvcHMubGFiZWxQb3NpdGlvbiA9PT0gTGFiZWxQb3NpdGlvbi5sZWZ0IHx8XHJcbiAgICAocHJvcHMuaXNMYWJlbFZpc3VhbGx5SGlkZGVuICYmIExhYmVsUG9zaXRpb24udG9wKVxyXG4gICAgPyAncm93J1xyXG4gICAgOiAnY29sdW1uJ307XG4gIHBvc2l0aW9uOiByZWxhdGl2ZTtcbiAgbGFiZWwge1xuICAgIGZsZXgtYmFzaXM6ICR7cHJvcHMgPT4gcHJvcHMubGFiZWxXaWR0aCAmJiBwcm9wcy5sYWJlbFBvc2l0aW9uID09PSBMYWJlbFBvc2l0aW9uLmxlZnRcclxuICAgID8gYCR7cHJvcHMubGFiZWxXaWR0aH0lYFxyXG4gICAgOiAnJ307XG4gIH1cbmA7XHJcbmNvbnN0IElucHV0TWVzc2FnZUNvbnRhaW5lciA9IHN0eWxlZC5kaXYgYFxuICBmbGV4LWdyb3c6IDE7XG4gIHBhZGRpbmc6IDAuMjVlbTtcbiAgbWFyZ2luOiAtMC4yNWVtO1xuICBtaW4td2lkdGg6IDAlO1xuICBwb3NpdGlvbjogcmVsYXRpdmU7XG5gO1xyXG5jb25zdCBTdHlsZWRBZGRpdGlvbmFsQ29udGVudFdyYXBwZXIgPSBzdHlsZWQuZGl2IGBcbiAgYWxpZ24taXRlbXM6IGNlbnRlcjtcbiAgZGlzcGxheTogZmxleDtcbiAgZmxleDogMTtcbiAganVzdGlmeS1jb250ZW50OiBzcGFjZS1iZXR3ZWVuO1xuICBsYWJlbCB7XG4gICAgbWFyZ2luOiAke3Byb3BzID0+IHByb3BzLmxhYmVsUG9zaXRpb24gPT09IExhYmVsUG9zaXRpb24ubGVmdFxyXG4gICAgPyBgMCAke3Byb3BzLnRoZW1lLnNwYWNlU2NhbGUuc3BhY2luZzAzfSAwIDBgXHJcbiAgICA6ICcnfTtcbiAgfVxuICBidXR0b24ge1xuICAgIGJvdHRvbTogJHtwcm9wcyA9PiBwcm9wcy5sYWJlbFBvc2l0aW9uICE9PSBMYWJlbFBvc2l0aW9uLmxlZnQgPyBgNnB4YCA6ICcnfTtcbiAgfVxuYDtcclxuY29uc3QgU3R5bGVkQWRkaXRpb25hbENvbnRlbnQgPSBzdHlsZWQuZGl2IGBcbiAgZGlzcGxheTogZmxleDtcbiAgYWxpZ24taXRlbXM6IGNlbnRlcjtcbiAgYnV0dG9uIHtcbiAgICBtYXJnaW46ICR7cHJvcHMgPT4gcHJvcHMubGFiZWxQb3NpdGlvbiA9PT0gTGFiZWxQb3NpdGlvbi5sZWZ0XHJcbiAgICA/IGAwIDAgMCAke3Byb3BzLnRoZW1lLnNwYWNlU2NhbGUuc3BhY2luZzAzfWBcclxuICAgIDogJyd9O1xuICB9XG5gO1xyXG5jb25zdCBGaWVsZENvbnRhaW5lciA9IHN0eWxlZC5kaXYgYFxuICBmbGV4OiAxIDEgYXV0bztcbiAgbWluLXdpZHRoOiAwJTtcbmA7XHJcbmV4cG9ydCBmdW5jdGlvbiBTZWxlY3RDb250YWluZXIocHJvcHMpIHtcclxuICAgIGNvbnN0IHsgYWRkaXRpb25hbENvbnRlbnQsIGNoaWxkcmVuLCBkZXNjcmlwdGlvbklkLCBlcnJvck1lc3NhZ2UsIGdldExhYmVsUHJvcHMsIGhlbHBlck1lc3NhZ2UsIGlzSW52ZXJzZSwgaXNMYWJlbFZpc3VhbGx5SGlkZGVuLCBsYWJlbFBvc2l0aW9uLCBsYWJlbFN0eWxlLCBsYWJlbFRleHQsIGxhYmVsV2lkdGgsIG1lc3NhZ2VTdHlsZSwgfSA9IHByb3BzO1xyXG4gICAgY29uc3QgaGFzRXJyb3IgPSAhIWVycm9yTWVzc2FnZTtcclxuICAgIGNvbnN0IHRoZW1lID0gUmVhY3QudXNlQ29udGV4dChUaGVtZUNvbnRleHQpO1xyXG4gICAgLy8gSWYgdGhlIGxhYmVsUG9zaXRpb24gaXMgc2V0IHRvICd0b3AnIChkZWZhdWx0KSB0aGVuIGEgPGRpdj4gd3JhcHMgdGhlIExhYmVsIGFuZCBhZGRpdGlvbmFsIGNvbnRlbnQgZm9yIHByb3BlciBzdHlsaW5nIGFsaWdubWVudC5cclxuICAgIGZ1bmN0aW9uIEFkZGl0aW9uYWxDb250ZW50V3JhcHBlcihwcm9wcykge1xyXG4gICAgICAgIGlmIChsYWJlbFBvc2l0aW9uICE9PSBMYWJlbFBvc2l0aW9uLmxlZnQgJiZcclxuICAgICAgICAgICAgIWlzTGFiZWxWaXN1YWxseUhpZGRlbiAmJlxyXG4gICAgICAgICAgICBhZGRpdGlvbmFsQ29udGVudCkge1xyXG4gICAgICAgICAgICByZXR1cm4gKFJlYWN0LmNyZWF0ZUVsZW1lbnQoU3R5bGVkQWRkaXRpb25hbENvbnRlbnRXcmFwcGVyLCB7IGxhYmVsUG9zaXRpb246IGxhYmVsUG9zaXRpb24sIHRoZW1lOiB0aGVtZSB9LFxyXG4gICAgICAgICAgICAgICAgcHJvcHMuY2hpbGRyZW4sXHJcbiAgICAgICAgICAgICAgICBhZGRpdGlvbmFsQ29udGVudCkpO1xyXG4gICAgICAgIH1cclxuICAgICAgICByZXR1cm4gcHJvcHMuY2hpbGRyZW47XHJcbiAgICB9XHJcbiAgICAvLyBJZiB0aGUgbGFiZWxQb3NpdGlvbiBpcyBzZXQgdG8gTGFiZWxQb3NpdGlvbi5sZWZ0IHRoZW4gdGhlIGxhYmVsLCBzZWxlY3QsIGFuZCBhZGRpdGlvbmFsIGNvbnRlbnQgZGlzcGxheSBpbmxpbmUuXHJcbiAgICBmdW5jdGlvbiBhZGRpdGlvbmFsSXRlbVJpZ2h0QWxpZ24oKSB7XHJcbiAgICAgICAgaWYgKChsYWJlbFBvc2l0aW9uID09PSBMYWJlbFBvc2l0aW9uLmxlZnQgJiYgYWRkaXRpb25hbENvbnRlbnQpIHx8XHJcbiAgICAgICAgICAgIChsYWJlbFBvc2l0aW9uICYmIGlzTGFiZWxWaXN1YWxseUhpZGRlbiAmJiBhZGRpdGlvbmFsQ29udGVudCkpIHtcclxuICAgICAgICAgICAgcmV0dXJuIChSZWFjdC5jcmVhdGVFbGVtZW50KFN0eWxlZEFkZGl0aW9uYWxDb250ZW50LCB7IGxhYmVsUG9zaXRpb246IGxhYmVsUG9zaXRpb24sIHRoZW1lOiB0aGVtZSB9LCBhZGRpdGlvbmFsQ29udGVudCkpO1xyXG4gICAgICAgIH1cclxuICAgIH1cclxuICAgIHJldHVybiAoUmVhY3QuY3JlYXRlRWxlbWVudChTZWxlY3RDb250YWluZXJFbGVtZW50LCB7IGlzTGFiZWxWaXN1YWxseUhpZGRlbjogaXNMYWJlbFZpc3VhbGx5SGlkZGVuLCBsYWJlbFBvc2l0aW9uOiBsYWJlbFBvc2l0aW9uLCBsYWJlbFdpZHRoOiBsYWJlbFdpZHRoLCBcImRhdGEtdGVzdGlkXCI6IFwic2VsZWN0Q29udGFpbmVyRWxlbWVudFwiIH0sXHJcbiAgICAgICAgUmVhY3QuY3JlYXRlRWxlbWVudChBZGRpdGlvbmFsQ29udGVudFdyYXBwZXIsIHsgbGFiZWxQb3NpdGlvbjogbGFiZWxQb3NpdGlvbiB9LFxyXG4gICAgICAgICAgICBSZWFjdC5jcmVhdGVFbGVtZW50KExhYmVsLCBPYmplY3QuYXNzaWduKHt9LCBnZXRMYWJlbFByb3BzKCksIHsgaXNJbnZlcnNlOiBpc0ludmVyc2UsIGxhYmVsUG9zaXRpb246IGxhYmVsUG9zaXRpb24sIHN0eWxlOiBsYWJlbFN0eWxlIH0pLCBpc0xhYmVsVmlzdWFsbHlIaWRkZW4gPyAoUmVhY3QuY3JlYXRlRWxlbWVudChWaXN1YWxseUhpZGRlbiwgbnVsbCwgbGFiZWxUZXh0KSkgOiAobGFiZWxUZXh0KSkpLFxyXG4gICAgICAgIFJlYWN0LmNyZWF0ZUVsZW1lbnQoRmllbGRDb250YWluZXIsIG51bGwsXHJcbiAgICAgICAgICAgIFJlYWN0LmNyZWF0ZUVsZW1lbnQoSW5wdXRNZXNzYWdlQ29udGFpbmVyLCBudWxsLCBjaGlsZHJlbiksXHJcbiAgICAgICAgICAgICEobGFiZWxQb3NpdGlvbiA9PT0gTGFiZWxQb3NpdGlvbi5sZWZ0ICYmXHJcbiAgICAgICAgICAgICAgICAhKGVycm9yTWVzc2FnZSB8fCBoZWxwZXJNZXNzYWdlKSkgJiZcclxuICAgICAgICAgICAgICAgIChlcnJvck1lc3NhZ2UgfHwgaGVscGVyTWVzc2FnZSkgJiYgKFJlYWN0LmNyZWF0ZUVsZW1lbnQoSW5wdXRNZXNzYWdlLCB7IGlkOiBkZXNjcmlwdGlvbklkLCBpc0ludmVyc2U6IGlzSW52ZXJzZSwgaGFzRXJyb3I6IGhhc0Vycm9yLCBzdHlsZTogbWVzc2FnZVN0eWxlIH0sIChlcnJvck1lc3NhZ2UgfHwgaGVscGVyTWVzc2FnZSkgJiYgKFJlYWN0LmNyZWF0ZUVsZW1lbnQoUmVhY3QuRnJhZ21lbnQsIG51bGwsIGVycm9yTWVzc2FnZSA/IGVycm9yTWVzc2FnZSA6IGhlbHBlck1lc3NhZ2UpKSkpKSxcclxuICAgICAgICBhZGRpdGlvbmFsSXRlbVJpZ2h0QWxpZ24oKSkpO1xyXG59XHJcbi8vIyBzb3VyY2VNYXBwaW5nVVJMPVNlbGVjdENvbnRhaW5lci5qcy5tYXAiXX0= */"));
24494
24498
  var InputMessageContainer = /*#__PURE__*/_styled("div", {
24495
24499
  target: "eh2jlnx3",
24496
24500
  label: "InputMessageContainer"
@@ -24500,7 +24504,7 @@ var InputMessageContainer = /*#__PURE__*/_styled("div", {
24500
24504
  } : {
24501
24505
  name: "1qbleiw",
24502
24506
  styles: "flex-grow:1;padding:0.25em;margin:-0.25em;min-width:0%;position:relative",
24503
- map: "/*# sourceMappingURL=data:application/json;charset=utf-8;base64,eyJ2ZXJzaW9uIjozLCJzb3VyY2VzIjpbIlNlbGVjdENvbnRhaW5lci50c3giXSwibmFtZXMiOltdLCJtYXBwaW5ncyI6IkFBbUJ5QyIsImZpbGUiOiJTZWxlY3RDb250YWluZXIudHN4Iiwic291cmNlc0NvbnRlbnQiOlsiaW1wb3J0IFJlYWN0IGZyb20gJ3JlYWN0JztcclxuaW1wb3J0IHN0eWxlZCBmcm9tICdAZW1vdGlvbi9zdHlsZWQnO1xyXG5pbXBvcnQgeyBMYWJlbCwgTGFiZWxQb3NpdGlvbiB9IGZyb20gJy4uL0xhYmVsJztcclxuaW1wb3J0IHsgVmlzdWFsbHlIaWRkZW4gfSBmcm9tICcuLi9WaXN1YWxseUhpZGRlbic7XHJcbmltcG9ydCB7IElucHV0TWVzc2FnZSB9IGZyb20gJy4uL0lucHV0L0lucHV0TWVzc2FnZSc7XHJcbmltcG9ydCB7IFRoZW1lQ29udGV4dCB9IGZyb20gJy4uLy4uL3RoZW1lL1RoZW1lQ29udGV4dCc7XHJcbmV4cG9ydCBjb25zdCBTZWxlY3RDb250YWluZXJFbGVtZW50ID0gc3R5bGVkLmRpdiBgXG4gIGRpc3BsYXk6IGZsZXg7XG4gIGZsZXgtZGlyZWN0aW9uOiAke3Byb3BzID0+IHByb3BzLmxhYmVsUG9zaXRpb24gPT09IExhYmVsUG9zaXRpb24ubGVmdCB8fFxyXG4gICAgKHByb3BzLmlzTGFiZWxWaXN1YWxseUhpZGRlbiAmJiBMYWJlbFBvc2l0aW9uLnRvcClcclxuICAgID8gJ3JvdydcclxuICAgIDogJ2NvbHVtbid9O1xuICBwb3NpdGlvbjogcmVsYXRpdmU7XG4gIGxhYmVsIHtcbiAgICBmbGV4LWJhc2lzOiAke3Byb3BzID0+IHByb3BzLmxhYmVsV2lkdGggJiYgcHJvcHMubGFiZWxQb3NpdGlvbiA9PT0gTGFiZWxQb3NpdGlvbi5sZWZ0XHJcbiAgICA/IGAke3Byb3BzLmxhYmVsV2lkdGh9JWBcclxuICAgIDogJyd9O1xuICB9XG5gO1xyXG5jb25zdCBJbnB1dE1lc3NhZ2VDb250YWluZXIgPSBzdHlsZWQuZGl2IGBcbiAgZmxleC1ncm93OiAxO1xuICBwYWRkaW5nOiAwLjI1ZW07XG4gIG1hcmdpbjogLTAuMjVlbTtcbiAgbWluLXdpZHRoOiAwJTtcbiAgcG9zaXRpb246IHJlbGF0aXZlO1xuYDtcclxuY29uc3QgU3R5bGVkQWRkaXRpb25hbENvbnRlbnRXcmFwcGVyID0gc3R5bGVkLmRpdiBgXG4gIGFsaWduLWl0ZW1zOiBjZW50ZXI7XG4gIGRpc3BsYXk6IGZsZXg7XG4gIGZsZXg6IDE7XG4gIGp1c3RpZnktY29udGVudDogc3BhY2UtYmV0d2VlbjtcbiAgbGFiZWwge1xuICAgIG1hcmdpbjogJHtwcm9wcyA9PiBwcm9wcy5sYWJlbFBvc2l0aW9uID09PSBMYWJlbFBvc2l0aW9uLmxlZnRcclxuICAgID8gYDAgJHtwcm9wcy50aGVtZS5zcGFjZVNjYWxlLnNwYWNpbmcwM30gMCAwYFxyXG4gICAgOiAnJ307XG4gIH1cbiAgYnV0dG9uIHtcbiAgICBib3R0b206ICR7cHJvcHMgPT4gcHJvcHMubGFiZWxQb3NpdGlvbiAhPT0gTGFiZWxQb3NpdGlvbi5sZWZ0ID8gYDZweGAgOiAnJ307XG4gIH1cbmA7XHJcbmNvbnN0IFN0eWxlZEFkZGl0aW9uYWxDb250ZW50ID0gc3R5bGVkLmRpdiBgXG4gIGRpc3BsYXk6IGZsZXg7XG4gIGFsaWduLWl0ZW1zOiBjZW50ZXI7XG4gIGJ1dHRvbiB7XG4gICAgbWFyZ2luOiAke3Byb3BzID0+IHByb3BzLmxhYmVsUG9zaXRpb24gPT09IExhYmVsUG9zaXRpb24ubGVmdFxyXG4gICAgPyBgMCAwIDAgJHtwcm9wcy50aGVtZS5zcGFjZVNjYWxlLnNwYWNpbmcwM31gXHJcbiAgICA6ICcnfTtcbiAgfVxuYDtcclxuY29uc3QgRm9ybUZpZWxkID0gc3R5bGVkLmZvcm0gYFxuICBmbGV4OiAxIDEgYXV0bztcbiAgbWluLXdpZHRoOiAwJTtcbmA7XHJcbmV4cG9ydCBmdW5jdGlvbiBTZWxlY3RDb250YWluZXIocHJvcHMpIHtcclxuICAgIGNvbnN0IHsgYWRkaXRpb25hbENvbnRlbnQsIGNoaWxkcmVuLCBkZXNjcmlwdGlvbklkLCBlcnJvck1lc3NhZ2UsIGdldExhYmVsUHJvcHMsIGhlbHBlck1lc3NhZ2UsIGlzSW52ZXJzZSwgaXNMYWJlbFZpc3VhbGx5SGlkZGVuLCBsYWJlbFBvc2l0aW9uLCBsYWJlbFN0eWxlLCBsYWJlbFRleHQsIGxhYmVsV2lkdGgsIG1lc3NhZ2VTdHlsZSwgfSA9IHByb3BzO1xyXG4gICAgY29uc3QgaGFzRXJyb3IgPSAhIWVycm9yTWVzc2FnZTtcclxuICAgIGNvbnN0IHRoZW1lID0gUmVhY3QudXNlQ29udGV4dChUaGVtZUNvbnRleHQpO1xyXG4gICAgLy8gSWYgdGhlIGxhYmVsUG9zaXRpb24gaXMgc2V0IHRvICd0b3AnIChkZWZhdWx0KSB0aGVuIGEgPGRpdj4gd3JhcHMgdGhlIExhYmVsIGFuZCBhZGRpdGlvbmFsIGNvbnRlbnQgZm9yIHByb3BlciBzdHlsaW5nIGFsaWdubWVudC5cclxuICAgIGZ1bmN0aW9uIEFkZGl0aW9uYWxDb250ZW50V3JhcHBlcihwcm9wcykge1xyXG4gICAgICAgIGlmIChsYWJlbFBvc2l0aW9uICE9PSBMYWJlbFBvc2l0aW9uLmxlZnQgJiZcclxuICAgICAgICAgICAgIWlzTGFiZWxWaXN1YWxseUhpZGRlbiAmJlxyXG4gICAgICAgICAgICBhZGRpdGlvbmFsQ29udGVudCkge1xyXG4gICAgICAgICAgICByZXR1cm4gKFJlYWN0LmNyZWF0ZUVsZW1lbnQoU3R5bGVkQWRkaXRpb25hbENvbnRlbnRXcmFwcGVyLCB7IGxhYmVsUG9zaXRpb246IGxhYmVsUG9zaXRpb24sIHRoZW1lOiB0aGVtZSB9LFxyXG4gICAgICAgICAgICAgICAgcHJvcHMuY2hpbGRyZW4sXHJcbiAgICAgICAgICAgICAgICBhZGRpdGlvbmFsQ29udGVudCkpO1xyXG4gICAgICAgIH1cclxuICAgICAgICByZXR1cm4gcHJvcHMuY2hpbGRyZW47XHJcbiAgICB9XHJcbiAgICAvLyBJZiB0aGUgbGFiZWxQb3NpdGlvbiBpcyBzZXQgdG8gTGFiZWxQb3NpdGlvbi5sZWZ0IHRoZW4gdGhlIGxhYmVsLCBzZWxlY3QsIGFuZCBhZGRpdGlvbmFsIGNvbnRlbnQgZGlzcGxheSBpbmxpbmUuXHJcbiAgICBmdW5jdGlvbiBhZGRpdGlvbmFsSXRlbVJpZ2h0QWxpZ24oKSB7XHJcbiAgICAgICAgaWYgKChsYWJlbFBvc2l0aW9uID09PSBMYWJlbFBvc2l0aW9uLmxlZnQgJiYgYWRkaXRpb25hbENvbnRlbnQpIHx8XHJcbiAgICAgICAgICAgIChsYWJlbFBvc2l0aW9uICYmIGlzTGFiZWxWaXN1YWxseUhpZGRlbiAmJiBhZGRpdGlvbmFsQ29udGVudCkpIHtcclxuICAgICAgICAgICAgcmV0dXJuIChSZWFjdC5jcmVhdGVFbGVtZW50KFN0eWxlZEFkZGl0aW9uYWxDb250ZW50LCB7IGxhYmVsUG9zaXRpb246IGxhYmVsUG9zaXRpb24sIHRoZW1lOiB0aGVtZSB9LCBhZGRpdGlvbmFsQ29udGVudCkpO1xyXG4gICAgICAgIH1cclxuICAgIH1cclxuICAgIHJldHVybiAoUmVhY3QuY3JlYXRlRWxlbWVudChTZWxlY3RDb250YWluZXJFbGVtZW50LCB7IGlzTGFiZWxWaXN1YWxseUhpZGRlbjogaXNMYWJlbFZpc3VhbGx5SGlkZGVuLCBsYWJlbFBvc2l0aW9uOiBsYWJlbFBvc2l0aW9uLCBsYWJlbFdpZHRoOiBsYWJlbFdpZHRoLCBcImRhdGEtdGVzdGlkXCI6IFwic2VsZWN0Q29udGFpbmVyRWxlbWVudFwiIH0sXHJcbiAgICAgICAgUmVhY3QuY3JlYXRlRWxlbWVudChBZGRpdGlvbmFsQ29udGVudFdyYXBwZXIsIHsgbGFiZWxQb3NpdGlvbjogbGFiZWxQb3NpdGlvbiB9LFxyXG4gICAgICAgICAgICBSZWFjdC5jcmVhdGVFbGVtZW50KExhYmVsLCBPYmplY3QuYXNzaWduKHt9LCBnZXRMYWJlbFByb3BzKCksIHsgaXNJbnZlcnNlOiBpc0ludmVyc2UsIGxhYmVsUG9zaXRpb246IGxhYmVsUG9zaXRpb24sIHN0eWxlOiBsYWJlbFN0eWxlIH0pLCBpc0xhYmVsVmlzdWFsbHlIaWRkZW4gPyAoUmVhY3QuY3JlYXRlRWxlbWVudChWaXN1YWxseUhpZGRlbiwgbnVsbCwgbGFiZWxUZXh0KSkgOiAobGFiZWxUZXh0KSkpLFxyXG4gICAgICAgIFJlYWN0LmNyZWF0ZUVsZW1lbnQoRm9ybUZpZWxkLCBudWxsLFxyXG4gICAgICAgICAgICBSZWFjdC5jcmVhdGVFbGVtZW50KElucHV0TWVzc2FnZUNvbnRhaW5lciwgbnVsbCwgY2hpbGRyZW4pLFxyXG4gICAgICAgICAgICAhKGxhYmVsUG9zaXRpb24gPT09IExhYmVsUG9zaXRpb24ubGVmdCAmJlxyXG4gICAgICAgICAgICAgICAgIShlcnJvck1lc3NhZ2UgfHwgaGVscGVyTWVzc2FnZSkpICYmXHJcbiAgICAgICAgICAgICAgICAoZXJyb3JNZXNzYWdlIHx8IGhlbHBlck1lc3NhZ2UpICYmIChSZWFjdC5jcmVhdGVFbGVtZW50KElucHV0TWVzc2FnZSwgeyBpZDogZGVzY3JpcHRpb25JZCwgaXNJbnZlcnNlOiBpc0ludmVyc2UsIGhhc0Vycm9yOiBoYXNFcnJvciwgc3R5bGU6IG1lc3NhZ2VTdHlsZSB9LCAoZXJyb3JNZXNzYWdlIHx8IGhlbHBlck1lc3NhZ2UpICYmIChSZWFjdC5jcmVhdGVFbGVtZW50KFJlYWN0LkZyYWdtZW50LCBudWxsLCBlcnJvck1lc3NhZ2UgPyBlcnJvck1lc3NhZ2UgOiBoZWxwZXJNZXNzYWdlKSkpKSksXHJcbiAgICAgICAgYWRkaXRpb25hbEl0ZW1SaWdodEFsaWduKCkpKTtcclxufVxyXG4vLyMgc291cmNlTWFwcGluZ1VSTD1TZWxlY3RDb250YWluZXIuanMubWFwIl19 */",
24507
+ map: "/*# sourceMappingURL=data:application/json;charset=utf-8;base64,eyJ2ZXJzaW9uIjozLCJzb3VyY2VzIjpbIlNlbGVjdENvbnRhaW5lci50c3giXSwibmFtZXMiOltdLCJtYXBwaW5ncyI6IkFBbUJ5QyIsImZpbGUiOiJTZWxlY3RDb250YWluZXIudHN4Iiwic291cmNlc0NvbnRlbnQiOlsiaW1wb3J0IFJlYWN0IGZyb20gJ3JlYWN0JztcclxuaW1wb3J0IHN0eWxlZCBmcm9tICdAZW1vdGlvbi9zdHlsZWQnO1xyXG5pbXBvcnQgeyBMYWJlbCwgTGFiZWxQb3NpdGlvbiB9IGZyb20gJy4uL0xhYmVsJztcclxuaW1wb3J0IHsgVmlzdWFsbHlIaWRkZW4gfSBmcm9tICcuLi9WaXN1YWxseUhpZGRlbic7XHJcbmltcG9ydCB7IElucHV0TWVzc2FnZSB9IGZyb20gJy4uL0lucHV0L0lucHV0TWVzc2FnZSc7XHJcbmltcG9ydCB7IFRoZW1lQ29udGV4dCB9IGZyb20gJy4uLy4uL3RoZW1lL1RoZW1lQ29udGV4dCc7XHJcbmV4cG9ydCBjb25zdCBTZWxlY3RDb250YWluZXJFbGVtZW50ID0gc3R5bGVkLmRpdiBgXG4gIGRpc3BsYXk6IGZsZXg7XG4gIGZsZXgtZGlyZWN0aW9uOiAke3Byb3BzID0+IHByb3BzLmxhYmVsUG9zaXRpb24gPT09IExhYmVsUG9zaXRpb24ubGVmdCB8fFxyXG4gICAgKHByb3BzLmlzTGFiZWxWaXN1YWxseUhpZGRlbiAmJiBMYWJlbFBvc2l0aW9uLnRvcClcclxuICAgID8gJ3JvdydcclxuICAgIDogJ2NvbHVtbid9O1xuICBwb3NpdGlvbjogcmVsYXRpdmU7XG4gIGxhYmVsIHtcbiAgICBmbGV4LWJhc2lzOiAke3Byb3BzID0+IHByb3BzLmxhYmVsV2lkdGggJiYgcHJvcHMubGFiZWxQb3NpdGlvbiA9PT0gTGFiZWxQb3NpdGlvbi5sZWZ0XHJcbiAgICA/IGAke3Byb3BzLmxhYmVsV2lkdGh9JWBcclxuICAgIDogJyd9O1xuICB9XG5gO1xyXG5jb25zdCBJbnB1dE1lc3NhZ2VDb250YWluZXIgPSBzdHlsZWQuZGl2IGBcbiAgZmxleC1ncm93OiAxO1xuICBwYWRkaW5nOiAwLjI1ZW07XG4gIG1hcmdpbjogLTAuMjVlbTtcbiAgbWluLXdpZHRoOiAwJTtcbiAgcG9zaXRpb246IHJlbGF0aXZlO1xuYDtcclxuY29uc3QgU3R5bGVkQWRkaXRpb25hbENvbnRlbnRXcmFwcGVyID0gc3R5bGVkLmRpdiBgXG4gIGFsaWduLWl0ZW1zOiBjZW50ZXI7XG4gIGRpc3BsYXk6IGZsZXg7XG4gIGZsZXg6IDE7XG4gIGp1c3RpZnktY29udGVudDogc3BhY2UtYmV0d2VlbjtcbiAgbGFiZWwge1xuICAgIG1hcmdpbjogJHtwcm9wcyA9PiBwcm9wcy5sYWJlbFBvc2l0aW9uID09PSBMYWJlbFBvc2l0aW9uLmxlZnRcclxuICAgID8gYDAgJHtwcm9wcy50aGVtZS5zcGFjZVNjYWxlLnNwYWNpbmcwM30gMCAwYFxyXG4gICAgOiAnJ307XG4gIH1cbiAgYnV0dG9uIHtcbiAgICBib3R0b206ICR7cHJvcHMgPT4gcHJvcHMubGFiZWxQb3NpdGlvbiAhPT0gTGFiZWxQb3NpdGlvbi5sZWZ0ID8gYDZweGAgOiAnJ307XG4gIH1cbmA7XHJcbmNvbnN0IFN0eWxlZEFkZGl0aW9uYWxDb250ZW50ID0gc3R5bGVkLmRpdiBgXG4gIGRpc3BsYXk6IGZsZXg7XG4gIGFsaWduLWl0ZW1zOiBjZW50ZXI7XG4gIGJ1dHRvbiB7XG4gICAgbWFyZ2luOiAke3Byb3BzID0+IHByb3BzLmxhYmVsUG9zaXRpb24gPT09IExhYmVsUG9zaXRpb24ubGVmdFxyXG4gICAgPyBgMCAwIDAgJHtwcm9wcy50aGVtZS5zcGFjZVNjYWxlLnNwYWNpbmcwM31gXHJcbiAgICA6ICcnfTtcbiAgfVxuYDtcclxuY29uc3QgRmllbGRDb250YWluZXIgPSBzdHlsZWQuZGl2IGBcbiAgZmxleDogMSAxIGF1dG87XG4gIG1pbi13aWR0aDogMCU7XG5gO1xyXG5leHBvcnQgZnVuY3Rpb24gU2VsZWN0Q29udGFpbmVyKHByb3BzKSB7XHJcbiAgICBjb25zdCB7IGFkZGl0aW9uYWxDb250ZW50LCBjaGlsZHJlbiwgZGVzY3JpcHRpb25JZCwgZXJyb3JNZXNzYWdlLCBnZXRMYWJlbFByb3BzLCBoZWxwZXJNZXNzYWdlLCBpc0ludmVyc2UsIGlzTGFiZWxWaXN1YWxseUhpZGRlbiwgbGFiZWxQb3NpdGlvbiwgbGFiZWxTdHlsZSwgbGFiZWxUZXh0LCBsYWJlbFdpZHRoLCBtZXNzYWdlU3R5bGUsIH0gPSBwcm9wcztcclxuICAgIGNvbnN0IGhhc0Vycm9yID0gISFlcnJvck1lc3NhZ2U7XHJcbiAgICBjb25zdCB0aGVtZSA9IFJlYWN0LnVzZUNvbnRleHQoVGhlbWVDb250ZXh0KTtcclxuICAgIC8vIElmIHRoZSBsYWJlbFBvc2l0aW9uIGlzIHNldCB0byAndG9wJyAoZGVmYXVsdCkgdGhlbiBhIDxkaXY+IHdyYXBzIHRoZSBMYWJlbCBhbmQgYWRkaXRpb25hbCBjb250ZW50IGZvciBwcm9wZXIgc3R5bGluZyBhbGlnbm1lbnQuXHJcbiAgICBmdW5jdGlvbiBBZGRpdGlvbmFsQ29udGVudFdyYXBwZXIocHJvcHMpIHtcclxuICAgICAgICBpZiAobGFiZWxQb3NpdGlvbiAhPT0gTGFiZWxQb3NpdGlvbi5sZWZ0ICYmXHJcbiAgICAgICAgICAgICFpc0xhYmVsVmlzdWFsbHlIaWRkZW4gJiZcclxuICAgICAgICAgICAgYWRkaXRpb25hbENvbnRlbnQpIHtcclxuICAgICAgICAgICAgcmV0dXJuIChSZWFjdC5jcmVhdGVFbGVtZW50KFN0eWxlZEFkZGl0aW9uYWxDb250ZW50V3JhcHBlciwgeyBsYWJlbFBvc2l0aW9uOiBsYWJlbFBvc2l0aW9uLCB0aGVtZTogdGhlbWUgfSxcclxuICAgICAgICAgICAgICAgIHByb3BzLmNoaWxkcmVuLFxyXG4gICAgICAgICAgICAgICAgYWRkaXRpb25hbENvbnRlbnQpKTtcclxuICAgICAgICB9XHJcbiAgICAgICAgcmV0dXJuIHByb3BzLmNoaWxkcmVuO1xyXG4gICAgfVxyXG4gICAgLy8gSWYgdGhlIGxhYmVsUG9zaXRpb24gaXMgc2V0IHRvIExhYmVsUG9zaXRpb24ubGVmdCB0aGVuIHRoZSBsYWJlbCwgc2VsZWN0LCBhbmQgYWRkaXRpb25hbCBjb250ZW50IGRpc3BsYXkgaW5saW5lLlxyXG4gICAgZnVuY3Rpb24gYWRkaXRpb25hbEl0ZW1SaWdodEFsaWduKCkge1xyXG4gICAgICAgIGlmICgobGFiZWxQb3NpdGlvbiA9PT0gTGFiZWxQb3NpdGlvbi5sZWZ0ICYmIGFkZGl0aW9uYWxDb250ZW50KSB8fFxyXG4gICAgICAgICAgICAobGFiZWxQb3NpdGlvbiAmJiBpc0xhYmVsVmlzdWFsbHlIaWRkZW4gJiYgYWRkaXRpb25hbENvbnRlbnQpKSB7XHJcbiAgICAgICAgICAgIHJldHVybiAoUmVhY3QuY3JlYXRlRWxlbWVudChTdHlsZWRBZGRpdGlvbmFsQ29udGVudCwgeyBsYWJlbFBvc2l0aW9uOiBsYWJlbFBvc2l0aW9uLCB0aGVtZTogdGhlbWUgfSwgYWRkaXRpb25hbENvbnRlbnQpKTtcclxuICAgICAgICB9XHJcbiAgICB9XHJcbiAgICByZXR1cm4gKFJlYWN0LmNyZWF0ZUVsZW1lbnQoU2VsZWN0Q29udGFpbmVyRWxlbWVudCwgeyBpc0xhYmVsVmlzdWFsbHlIaWRkZW46IGlzTGFiZWxWaXN1YWxseUhpZGRlbiwgbGFiZWxQb3NpdGlvbjogbGFiZWxQb3NpdGlvbiwgbGFiZWxXaWR0aDogbGFiZWxXaWR0aCwgXCJkYXRhLXRlc3RpZFwiOiBcInNlbGVjdENvbnRhaW5lckVsZW1lbnRcIiB9LFxyXG4gICAgICAgIFJlYWN0LmNyZWF0ZUVsZW1lbnQoQWRkaXRpb25hbENvbnRlbnRXcmFwcGVyLCB7IGxhYmVsUG9zaXRpb246IGxhYmVsUG9zaXRpb24gfSxcclxuICAgICAgICAgICAgUmVhY3QuY3JlYXRlRWxlbWVudChMYWJlbCwgT2JqZWN0LmFzc2lnbih7fSwgZ2V0TGFiZWxQcm9wcygpLCB7IGlzSW52ZXJzZTogaXNJbnZlcnNlLCBsYWJlbFBvc2l0aW9uOiBsYWJlbFBvc2l0aW9uLCBzdHlsZTogbGFiZWxTdHlsZSB9KSwgaXNMYWJlbFZpc3VhbGx5SGlkZGVuID8gKFJlYWN0LmNyZWF0ZUVsZW1lbnQoVmlzdWFsbHlIaWRkZW4sIG51bGwsIGxhYmVsVGV4dCkpIDogKGxhYmVsVGV4dCkpKSxcclxuICAgICAgICBSZWFjdC5jcmVhdGVFbGVtZW50KEZpZWxkQ29udGFpbmVyLCBudWxsLFxyXG4gICAgICAgICAgICBSZWFjdC5jcmVhdGVFbGVtZW50KElucHV0TWVzc2FnZUNvbnRhaW5lciwgbnVsbCwgY2hpbGRyZW4pLFxyXG4gICAgICAgICAgICAhKGxhYmVsUG9zaXRpb24gPT09IExhYmVsUG9zaXRpb24ubGVmdCAmJlxyXG4gICAgICAgICAgICAgICAgIShlcnJvck1lc3NhZ2UgfHwgaGVscGVyTWVzc2FnZSkpICYmXHJcbiAgICAgICAgICAgICAgICAoZXJyb3JNZXNzYWdlIHx8IGhlbHBlck1lc3NhZ2UpICYmIChSZWFjdC5jcmVhdGVFbGVtZW50KElucHV0TWVzc2FnZSwgeyBpZDogZGVzY3JpcHRpb25JZCwgaXNJbnZlcnNlOiBpc0ludmVyc2UsIGhhc0Vycm9yOiBoYXNFcnJvciwgc3R5bGU6IG1lc3NhZ2VTdHlsZSB9LCAoZXJyb3JNZXNzYWdlIHx8IGhlbHBlck1lc3NhZ2UpICYmIChSZWFjdC5jcmVhdGVFbGVtZW50KFJlYWN0LkZyYWdtZW50LCBudWxsLCBlcnJvck1lc3NhZ2UgPyBlcnJvck1lc3NhZ2UgOiBoZWxwZXJNZXNzYWdlKSkpKSksXHJcbiAgICAgICAgYWRkaXRpb25hbEl0ZW1SaWdodEFsaWduKCkpKTtcclxufVxyXG4vLyMgc291cmNlTWFwcGluZ1VSTD1TZWxlY3RDb250YWluZXIuanMubWFwIl19 */",
24504
24508
  toString: _EMOTION_STRINGIFIED_CSS_ERROR__$w
24505
24509
  });
24506
24510
  var StyledAdditionalContentWrapper$1 = /*#__PURE__*/_styled("div", {
@@ -24510,23 +24514,23 @@ var StyledAdditionalContentWrapper$1 = /*#__PURE__*/_styled("div", {
24510
24514
  return props.labelPosition === LabelPosition.left ? "0 " + props.theme.spaceScale.spacing03 + " 0 0" : '';
24511
24515
  }, ";}button{bottom:", function (props) {
24512
24516
  return props.labelPosition !== LabelPosition.left ? "6px" : '';
24513
- }, ";}" + (process.env.NODE_ENV === "production" ? "" : "/*# sourceMappingURL=data:application/json;charset=utf-8;base64,eyJ2ZXJzaW9uIjozLCJzb3VyY2VzIjpbIlNlbGVjdENvbnRhaW5lci50c3giXSwibmFtZXMiOltdLCJtYXBwaW5ncyI6IkFBMEJrRCIsImZpbGUiOiJTZWxlY3RDb250YWluZXIudHN4Iiwic291cmNlc0NvbnRlbnQiOlsiaW1wb3J0IFJlYWN0IGZyb20gJ3JlYWN0JztcclxuaW1wb3J0IHN0eWxlZCBmcm9tICdAZW1vdGlvbi9zdHlsZWQnO1xyXG5pbXBvcnQgeyBMYWJlbCwgTGFiZWxQb3NpdGlvbiB9IGZyb20gJy4uL0xhYmVsJztcclxuaW1wb3J0IHsgVmlzdWFsbHlIaWRkZW4gfSBmcm9tICcuLi9WaXN1YWxseUhpZGRlbic7XHJcbmltcG9ydCB7IElucHV0TWVzc2FnZSB9IGZyb20gJy4uL0lucHV0L0lucHV0TWVzc2FnZSc7XHJcbmltcG9ydCB7IFRoZW1lQ29udGV4dCB9IGZyb20gJy4uLy4uL3RoZW1lL1RoZW1lQ29udGV4dCc7XHJcbmV4cG9ydCBjb25zdCBTZWxlY3RDb250YWluZXJFbGVtZW50ID0gc3R5bGVkLmRpdiBgXG4gIGRpc3BsYXk6IGZsZXg7XG4gIGZsZXgtZGlyZWN0aW9uOiAke3Byb3BzID0+IHByb3BzLmxhYmVsUG9zaXRpb24gPT09IExhYmVsUG9zaXRpb24ubGVmdCB8fFxyXG4gICAgKHByb3BzLmlzTGFiZWxWaXN1YWxseUhpZGRlbiAmJiBMYWJlbFBvc2l0aW9uLnRvcClcclxuICAgID8gJ3JvdydcclxuICAgIDogJ2NvbHVtbid9O1xuICBwb3NpdGlvbjogcmVsYXRpdmU7XG4gIGxhYmVsIHtcbiAgICBmbGV4LWJhc2lzOiAke3Byb3BzID0+IHByb3BzLmxhYmVsV2lkdGggJiYgcHJvcHMubGFiZWxQb3NpdGlvbiA9PT0gTGFiZWxQb3NpdGlvbi5sZWZ0XHJcbiAgICA/IGAke3Byb3BzLmxhYmVsV2lkdGh9JWBcclxuICAgIDogJyd9O1xuICB9XG5gO1xyXG5jb25zdCBJbnB1dE1lc3NhZ2VDb250YWluZXIgPSBzdHlsZWQuZGl2IGBcbiAgZmxleC1ncm93OiAxO1xuICBwYWRkaW5nOiAwLjI1ZW07XG4gIG1hcmdpbjogLTAuMjVlbTtcbiAgbWluLXdpZHRoOiAwJTtcbiAgcG9zaXRpb246IHJlbGF0aXZlO1xuYDtcclxuY29uc3QgU3R5bGVkQWRkaXRpb25hbENvbnRlbnRXcmFwcGVyID0gc3R5bGVkLmRpdiBgXG4gIGFsaWduLWl0ZW1zOiBjZW50ZXI7XG4gIGRpc3BsYXk6IGZsZXg7XG4gIGZsZXg6IDE7XG4gIGp1c3RpZnktY29udGVudDogc3BhY2UtYmV0d2VlbjtcbiAgbGFiZWwge1xuICAgIG1hcmdpbjogJHtwcm9wcyA9PiBwcm9wcy5sYWJlbFBvc2l0aW9uID09PSBMYWJlbFBvc2l0aW9uLmxlZnRcclxuICAgID8gYDAgJHtwcm9wcy50aGVtZS5zcGFjZVNjYWxlLnNwYWNpbmcwM30gMCAwYFxyXG4gICAgOiAnJ307XG4gIH1cbiAgYnV0dG9uIHtcbiAgICBib3R0b206ICR7cHJvcHMgPT4gcHJvcHMubGFiZWxQb3NpdGlvbiAhPT0gTGFiZWxQb3NpdGlvbi5sZWZ0ID8gYDZweGAgOiAnJ307XG4gIH1cbmA7XHJcbmNvbnN0IFN0eWxlZEFkZGl0aW9uYWxDb250ZW50ID0gc3R5bGVkLmRpdiBgXG4gIGRpc3BsYXk6IGZsZXg7XG4gIGFsaWduLWl0ZW1zOiBjZW50ZXI7XG4gIGJ1dHRvbiB7XG4gICAgbWFyZ2luOiAke3Byb3BzID0+IHByb3BzLmxhYmVsUG9zaXRpb24gPT09IExhYmVsUG9zaXRpb24ubGVmdFxyXG4gICAgPyBgMCAwIDAgJHtwcm9wcy50aGVtZS5zcGFjZVNjYWxlLnNwYWNpbmcwM31gXHJcbiAgICA6ICcnfTtcbiAgfVxuYDtcclxuY29uc3QgRm9ybUZpZWxkID0gc3R5bGVkLmZvcm0gYFxuICBmbGV4OiAxIDEgYXV0bztcbiAgbWluLXdpZHRoOiAwJTtcbmA7XHJcbmV4cG9ydCBmdW5jdGlvbiBTZWxlY3RDb250YWluZXIocHJvcHMpIHtcclxuICAgIGNvbnN0IHsgYWRkaXRpb25hbENvbnRlbnQsIGNoaWxkcmVuLCBkZXNjcmlwdGlvbklkLCBlcnJvck1lc3NhZ2UsIGdldExhYmVsUHJvcHMsIGhlbHBlck1lc3NhZ2UsIGlzSW52ZXJzZSwgaXNMYWJlbFZpc3VhbGx5SGlkZGVuLCBsYWJlbFBvc2l0aW9uLCBsYWJlbFN0eWxlLCBsYWJlbFRleHQsIGxhYmVsV2lkdGgsIG1lc3NhZ2VTdHlsZSwgfSA9IHByb3BzO1xyXG4gICAgY29uc3QgaGFzRXJyb3IgPSAhIWVycm9yTWVzc2FnZTtcclxuICAgIGNvbnN0IHRoZW1lID0gUmVhY3QudXNlQ29udGV4dChUaGVtZUNvbnRleHQpO1xyXG4gICAgLy8gSWYgdGhlIGxhYmVsUG9zaXRpb24gaXMgc2V0IHRvICd0b3AnIChkZWZhdWx0KSB0aGVuIGEgPGRpdj4gd3JhcHMgdGhlIExhYmVsIGFuZCBhZGRpdGlvbmFsIGNvbnRlbnQgZm9yIHByb3BlciBzdHlsaW5nIGFsaWdubWVudC5cclxuICAgIGZ1bmN0aW9uIEFkZGl0aW9uYWxDb250ZW50V3JhcHBlcihwcm9wcykge1xyXG4gICAgICAgIGlmIChsYWJlbFBvc2l0aW9uICE9PSBMYWJlbFBvc2l0aW9uLmxlZnQgJiZcclxuICAgICAgICAgICAgIWlzTGFiZWxWaXN1YWxseUhpZGRlbiAmJlxyXG4gICAgICAgICAgICBhZGRpdGlvbmFsQ29udGVudCkge1xyXG4gICAgICAgICAgICByZXR1cm4gKFJlYWN0LmNyZWF0ZUVsZW1lbnQoU3R5bGVkQWRkaXRpb25hbENvbnRlbnRXcmFwcGVyLCB7IGxhYmVsUG9zaXRpb246IGxhYmVsUG9zaXRpb24sIHRoZW1lOiB0aGVtZSB9LFxyXG4gICAgICAgICAgICAgICAgcHJvcHMuY2hpbGRyZW4sXHJcbiAgICAgICAgICAgICAgICBhZGRpdGlvbmFsQ29udGVudCkpO1xyXG4gICAgICAgIH1cclxuICAgICAgICByZXR1cm4gcHJvcHMuY2hpbGRyZW47XHJcbiAgICB9XHJcbiAgICAvLyBJZiB0aGUgbGFiZWxQb3NpdGlvbiBpcyBzZXQgdG8gTGFiZWxQb3NpdGlvbi5sZWZ0IHRoZW4gdGhlIGxhYmVsLCBzZWxlY3QsIGFuZCBhZGRpdGlvbmFsIGNvbnRlbnQgZGlzcGxheSBpbmxpbmUuXHJcbiAgICBmdW5jdGlvbiBhZGRpdGlvbmFsSXRlbVJpZ2h0QWxpZ24oKSB7XHJcbiAgICAgICAgaWYgKChsYWJlbFBvc2l0aW9uID09PSBMYWJlbFBvc2l0aW9uLmxlZnQgJiYgYWRkaXRpb25hbENvbnRlbnQpIHx8XHJcbiAgICAgICAgICAgIChsYWJlbFBvc2l0aW9uICYmIGlzTGFiZWxWaXN1YWxseUhpZGRlbiAmJiBhZGRpdGlvbmFsQ29udGVudCkpIHtcclxuICAgICAgICAgICAgcmV0dXJuIChSZWFjdC5jcmVhdGVFbGVtZW50KFN0eWxlZEFkZGl0aW9uYWxDb250ZW50LCB7IGxhYmVsUG9zaXRpb246IGxhYmVsUG9zaXRpb24sIHRoZW1lOiB0aGVtZSB9LCBhZGRpdGlvbmFsQ29udGVudCkpO1xyXG4gICAgICAgIH1cclxuICAgIH1cclxuICAgIHJldHVybiAoUmVhY3QuY3JlYXRlRWxlbWVudChTZWxlY3RDb250YWluZXJFbGVtZW50LCB7IGlzTGFiZWxWaXN1YWxseUhpZGRlbjogaXNMYWJlbFZpc3VhbGx5SGlkZGVuLCBsYWJlbFBvc2l0aW9uOiBsYWJlbFBvc2l0aW9uLCBsYWJlbFdpZHRoOiBsYWJlbFdpZHRoLCBcImRhdGEtdGVzdGlkXCI6IFwic2VsZWN0Q29udGFpbmVyRWxlbWVudFwiIH0sXHJcbiAgICAgICAgUmVhY3QuY3JlYXRlRWxlbWVudChBZGRpdGlvbmFsQ29udGVudFdyYXBwZXIsIHsgbGFiZWxQb3NpdGlvbjogbGFiZWxQb3NpdGlvbiB9LFxyXG4gICAgICAgICAgICBSZWFjdC5jcmVhdGVFbGVtZW50KExhYmVsLCBPYmplY3QuYXNzaWduKHt9LCBnZXRMYWJlbFByb3BzKCksIHsgaXNJbnZlcnNlOiBpc0ludmVyc2UsIGxhYmVsUG9zaXRpb246IGxhYmVsUG9zaXRpb24sIHN0eWxlOiBsYWJlbFN0eWxlIH0pLCBpc0xhYmVsVmlzdWFsbHlIaWRkZW4gPyAoUmVhY3QuY3JlYXRlRWxlbWVudChWaXN1YWxseUhpZGRlbiwgbnVsbCwgbGFiZWxUZXh0KSkgOiAobGFiZWxUZXh0KSkpLFxyXG4gICAgICAgIFJlYWN0LmNyZWF0ZUVsZW1lbnQoRm9ybUZpZWxkLCBudWxsLFxyXG4gICAgICAgICAgICBSZWFjdC5jcmVhdGVFbGVtZW50KElucHV0TWVzc2FnZUNvbnRhaW5lciwgbnVsbCwgY2hpbGRyZW4pLFxyXG4gICAgICAgICAgICAhKGxhYmVsUG9zaXRpb24gPT09IExhYmVsUG9zaXRpb24ubGVmdCAmJlxyXG4gICAgICAgICAgICAgICAgIShlcnJvck1lc3NhZ2UgfHwgaGVscGVyTWVzc2FnZSkpICYmXHJcbiAgICAgICAgICAgICAgICAoZXJyb3JNZXNzYWdlIHx8IGhlbHBlck1lc3NhZ2UpICYmIChSZWFjdC5jcmVhdGVFbGVtZW50KElucHV0TWVzc2FnZSwgeyBpZDogZGVzY3JpcHRpb25JZCwgaXNJbnZlcnNlOiBpc0ludmVyc2UsIGhhc0Vycm9yOiBoYXNFcnJvciwgc3R5bGU6IG1lc3NhZ2VTdHlsZSB9LCAoZXJyb3JNZXNzYWdlIHx8IGhlbHBlck1lc3NhZ2UpICYmIChSZWFjdC5jcmVhdGVFbGVtZW50KFJlYWN0LkZyYWdtZW50LCBudWxsLCBlcnJvck1lc3NhZ2UgPyBlcnJvck1lc3NhZ2UgOiBoZWxwZXJNZXNzYWdlKSkpKSksXHJcbiAgICAgICAgYWRkaXRpb25hbEl0ZW1SaWdodEFsaWduKCkpKTtcclxufVxyXG4vLyMgc291cmNlTWFwcGluZ1VSTD1TZWxlY3RDb250YWluZXIuanMubWFwIl19 */"));
24517
+ }, ";}" + (process.env.NODE_ENV === "production" ? "" : "/*# sourceMappingURL=data:application/json;charset=utf-8;base64,eyJ2ZXJzaW9uIjozLCJzb3VyY2VzIjpbIlNlbGVjdENvbnRhaW5lci50c3giXSwibmFtZXMiOltdLCJtYXBwaW5ncyI6IkFBMEJrRCIsImZpbGUiOiJTZWxlY3RDb250YWluZXIudHN4Iiwic291cmNlc0NvbnRlbnQiOlsiaW1wb3J0IFJlYWN0IGZyb20gJ3JlYWN0JztcclxuaW1wb3J0IHN0eWxlZCBmcm9tICdAZW1vdGlvbi9zdHlsZWQnO1xyXG5pbXBvcnQgeyBMYWJlbCwgTGFiZWxQb3NpdGlvbiB9IGZyb20gJy4uL0xhYmVsJztcclxuaW1wb3J0IHsgVmlzdWFsbHlIaWRkZW4gfSBmcm9tICcuLi9WaXN1YWxseUhpZGRlbic7XHJcbmltcG9ydCB7IElucHV0TWVzc2FnZSB9IGZyb20gJy4uL0lucHV0L0lucHV0TWVzc2FnZSc7XHJcbmltcG9ydCB7IFRoZW1lQ29udGV4dCB9IGZyb20gJy4uLy4uL3RoZW1lL1RoZW1lQ29udGV4dCc7XHJcbmV4cG9ydCBjb25zdCBTZWxlY3RDb250YWluZXJFbGVtZW50ID0gc3R5bGVkLmRpdiBgXG4gIGRpc3BsYXk6IGZsZXg7XG4gIGZsZXgtZGlyZWN0aW9uOiAke3Byb3BzID0+IHByb3BzLmxhYmVsUG9zaXRpb24gPT09IExhYmVsUG9zaXRpb24ubGVmdCB8fFxyXG4gICAgKHByb3BzLmlzTGFiZWxWaXN1YWxseUhpZGRlbiAmJiBMYWJlbFBvc2l0aW9uLnRvcClcclxuICAgID8gJ3JvdydcclxuICAgIDogJ2NvbHVtbid9O1xuICBwb3NpdGlvbjogcmVsYXRpdmU7XG4gIGxhYmVsIHtcbiAgICBmbGV4LWJhc2lzOiAke3Byb3BzID0+IHByb3BzLmxhYmVsV2lkdGggJiYgcHJvcHMubGFiZWxQb3NpdGlvbiA9PT0gTGFiZWxQb3NpdGlvbi5sZWZ0XHJcbiAgICA/IGAke3Byb3BzLmxhYmVsV2lkdGh9JWBcclxuICAgIDogJyd9O1xuICB9XG5gO1xyXG5jb25zdCBJbnB1dE1lc3NhZ2VDb250YWluZXIgPSBzdHlsZWQuZGl2IGBcbiAgZmxleC1ncm93OiAxO1xuICBwYWRkaW5nOiAwLjI1ZW07XG4gIG1hcmdpbjogLTAuMjVlbTtcbiAgbWluLXdpZHRoOiAwJTtcbiAgcG9zaXRpb246IHJlbGF0aXZlO1xuYDtcclxuY29uc3QgU3R5bGVkQWRkaXRpb25hbENvbnRlbnRXcmFwcGVyID0gc3R5bGVkLmRpdiBgXG4gIGFsaWduLWl0ZW1zOiBjZW50ZXI7XG4gIGRpc3BsYXk6IGZsZXg7XG4gIGZsZXg6IDE7XG4gIGp1c3RpZnktY29udGVudDogc3BhY2UtYmV0d2VlbjtcbiAgbGFiZWwge1xuICAgIG1hcmdpbjogJHtwcm9wcyA9PiBwcm9wcy5sYWJlbFBvc2l0aW9uID09PSBMYWJlbFBvc2l0aW9uLmxlZnRcclxuICAgID8gYDAgJHtwcm9wcy50aGVtZS5zcGFjZVNjYWxlLnNwYWNpbmcwM30gMCAwYFxyXG4gICAgOiAnJ307XG4gIH1cbiAgYnV0dG9uIHtcbiAgICBib3R0b206ICR7cHJvcHMgPT4gcHJvcHMubGFiZWxQb3NpdGlvbiAhPT0gTGFiZWxQb3NpdGlvbi5sZWZ0ID8gYDZweGAgOiAnJ307XG4gIH1cbmA7XHJcbmNvbnN0IFN0eWxlZEFkZGl0aW9uYWxDb250ZW50ID0gc3R5bGVkLmRpdiBgXG4gIGRpc3BsYXk6IGZsZXg7XG4gIGFsaWduLWl0ZW1zOiBjZW50ZXI7XG4gIGJ1dHRvbiB7XG4gICAgbWFyZ2luOiAke3Byb3BzID0+IHByb3BzLmxhYmVsUG9zaXRpb24gPT09IExhYmVsUG9zaXRpb24ubGVmdFxyXG4gICAgPyBgMCAwIDAgJHtwcm9wcy50aGVtZS5zcGFjZVNjYWxlLnNwYWNpbmcwM31gXHJcbiAgICA6ICcnfTtcbiAgfVxuYDtcclxuY29uc3QgRmllbGRDb250YWluZXIgPSBzdHlsZWQuZGl2IGBcbiAgZmxleDogMSAxIGF1dG87XG4gIG1pbi13aWR0aDogMCU7XG5gO1xyXG5leHBvcnQgZnVuY3Rpb24gU2VsZWN0Q29udGFpbmVyKHByb3BzKSB7XHJcbiAgICBjb25zdCB7IGFkZGl0aW9uYWxDb250ZW50LCBjaGlsZHJlbiwgZGVzY3JpcHRpb25JZCwgZXJyb3JNZXNzYWdlLCBnZXRMYWJlbFByb3BzLCBoZWxwZXJNZXNzYWdlLCBpc0ludmVyc2UsIGlzTGFiZWxWaXN1YWxseUhpZGRlbiwgbGFiZWxQb3NpdGlvbiwgbGFiZWxTdHlsZSwgbGFiZWxUZXh0LCBsYWJlbFdpZHRoLCBtZXNzYWdlU3R5bGUsIH0gPSBwcm9wcztcclxuICAgIGNvbnN0IGhhc0Vycm9yID0gISFlcnJvck1lc3NhZ2U7XHJcbiAgICBjb25zdCB0aGVtZSA9IFJlYWN0LnVzZUNvbnRleHQoVGhlbWVDb250ZXh0KTtcclxuICAgIC8vIElmIHRoZSBsYWJlbFBvc2l0aW9uIGlzIHNldCB0byAndG9wJyAoZGVmYXVsdCkgdGhlbiBhIDxkaXY+IHdyYXBzIHRoZSBMYWJlbCBhbmQgYWRkaXRpb25hbCBjb250ZW50IGZvciBwcm9wZXIgc3R5bGluZyBhbGlnbm1lbnQuXHJcbiAgICBmdW5jdGlvbiBBZGRpdGlvbmFsQ29udGVudFdyYXBwZXIocHJvcHMpIHtcclxuICAgICAgICBpZiAobGFiZWxQb3NpdGlvbiAhPT0gTGFiZWxQb3NpdGlvbi5sZWZ0ICYmXHJcbiAgICAgICAgICAgICFpc0xhYmVsVmlzdWFsbHlIaWRkZW4gJiZcclxuICAgICAgICAgICAgYWRkaXRpb25hbENvbnRlbnQpIHtcclxuICAgICAgICAgICAgcmV0dXJuIChSZWFjdC5jcmVhdGVFbGVtZW50KFN0eWxlZEFkZGl0aW9uYWxDb250ZW50V3JhcHBlciwgeyBsYWJlbFBvc2l0aW9uOiBsYWJlbFBvc2l0aW9uLCB0aGVtZTogdGhlbWUgfSxcclxuICAgICAgICAgICAgICAgIHByb3BzLmNoaWxkcmVuLFxyXG4gICAgICAgICAgICAgICAgYWRkaXRpb25hbENvbnRlbnQpKTtcclxuICAgICAgICB9XHJcbiAgICAgICAgcmV0dXJuIHByb3BzLmNoaWxkcmVuO1xyXG4gICAgfVxyXG4gICAgLy8gSWYgdGhlIGxhYmVsUG9zaXRpb24gaXMgc2V0IHRvIExhYmVsUG9zaXRpb24ubGVmdCB0aGVuIHRoZSBsYWJlbCwgc2VsZWN0LCBhbmQgYWRkaXRpb25hbCBjb250ZW50IGRpc3BsYXkgaW5saW5lLlxyXG4gICAgZnVuY3Rpb24gYWRkaXRpb25hbEl0ZW1SaWdodEFsaWduKCkge1xyXG4gICAgICAgIGlmICgobGFiZWxQb3NpdGlvbiA9PT0gTGFiZWxQb3NpdGlvbi5sZWZ0ICYmIGFkZGl0aW9uYWxDb250ZW50KSB8fFxyXG4gICAgICAgICAgICAobGFiZWxQb3NpdGlvbiAmJiBpc0xhYmVsVmlzdWFsbHlIaWRkZW4gJiYgYWRkaXRpb25hbENvbnRlbnQpKSB7XHJcbiAgICAgICAgICAgIHJldHVybiAoUmVhY3QuY3JlYXRlRWxlbWVudChTdHlsZWRBZGRpdGlvbmFsQ29udGVudCwgeyBsYWJlbFBvc2l0aW9uOiBsYWJlbFBvc2l0aW9uLCB0aGVtZTogdGhlbWUgfSwgYWRkaXRpb25hbENvbnRlbnQpKTtcclxuICAgICAgICB9XHJcbiAgICB9XHJcbiAgICByZXR1cm4gKFJlYWN0LmNyZWF0ZUVsZW1lbnQoU2VsZWN0Q29udGFpbmVyRWxlbWVudCwgeyBpc0xhYmVsVmlzdWFsbHlIaWRkZW46IGlzTGFiZWxWaXN1YWxseUhpZGRlbiwgbGFiZWxQb3NpdGlvbjogbGFiZWxQb3NpdGlvbiwgbGFiZWxXaWR0aDogbGFiZWxXaWR0aCwgXCJkYXRhLXRlc3RpZFwiOiBcInNlbGVjdENvbnRhaW5lckVsZW1lbnRcIiB9LFxyXG4gICAgICAgIFJlYWN0LmNyZWF0ZUVsZW1lbnQoQWRkaXRpb25hbENvbnRlbnRXcmFwcGVyLCB7IGxhYmVsUG9zaXRpb246IGxhYmVsUG9zaXRpb24gfSxcclxuICAgICAgICAgICAgUmVhY3QuY3JlYXRlRWxlbWVudChMYWJlbCwgT2JqZWN0LmFzc2lnbih7fSwgZ2V0TGFiZWxQcm9wcygpLCB7IGlzSW52ZXJzZTogaXNJbnZlcnNlLCBsYWJlbFBvc2l0aW9uOiBsYWJlbFBvc2l0aW9uLCBzdHlsZTogbGFiZWxTdHlsZSB9KSwgaXNMYWJlbFZpc3VhbGx5SGlkZGVuID8gKFJlYWN0LmNyZWF0ZUVsZW1lbnQoVmlzdWFsbHlIaWRkZW4sIG51bGwsIGxhYmVsVGV4dCkpIDogKGxhYmVsVGV4dCkpKSxcclxuICAgICAgICBSZWFjdC5jcmVhdGVFbGVtZW50KEZpZWxkQ29udGFpbmVyLCBudWxsLFxyXG4gICAgICAgICAgICBSZWFjdC5jcmVhdGVFbGVtZW50KElucHV0TWVzc2FnZUNvbnRhaW5lciwgbnVsbCwgY2hpbGRyZW4pLFxyXG4gICAgICAgICAgICAhKGxhYmVsUG9zaXRpb24gPT09IExhYmVsUG9zaXRpb24ubGVmdCAmJlxyXG4gICAgICAgICAgICAgICAgIShlcnJvck1lc3NhZ2UgfHwgaGVscGVyTWVzc2FnZSkpICYmXHJcbiAgICAgICAgICAgICAgICAoZXJyb3JNZXNzYWdlIHx8IGhlbHBlck1lc3NhZ2UpICYmIChSZWFjdC5jcmVhdGVFbGVtZW50KElucHV0TWVzc2FnZSwgeyBpZDogZGVzY3JpcHRpb25JZCwgaXNJbnZlcnNlOiBpc0ludmVyc2UsIGhhc0Vycm9yOiBoYXNFcnJvciwgc3R5bGU6IG1lc3NhZ2VTdHlsZSB9LCAoZXJyb3JNZXNzYWdlIHx8IGhlbHBlck1lc3NhZ2UpICYmIChSZWFjdC5jcmVhdGVFbGVtZW50KFJlYWN0LkZyYWdtZW50LCBudWxsLCBlcnJvck1lc3NhZ2UgPyBlcnJvck1lc3NhZ2UgOiBoZWxwZXJNZXNzYWdlKSkpKSksXHJcbiAgICAgICAgYWRkaXRpb25hbEl0ZW1SaWdodEFsaWduKCkpKTtcclxufVxyXG4vLyMgc291cmNlTWFwcGluZ1VSTD1TZWxlY3RDb250YWluZXIuanMubWFwIl19 */"));
24514
24518
  var StyledAdditionalContent = /*#__PURE__*/_styled("div", {
24515
24519
  target: "eh2jlnx1",
24516
24520
  label: "StyledAdditionalContent"
24517
24521
  })("display:flex;align-items:center;button{margin:", function (props) {
24518
24522
  return props.labelPosition === LabelPosition.left ? "0 0 0 " + props.theme.spaceScale.spacing03 : '';
24519
- }, ";}" + (process.env.NODE_ENV === "production" ? "" : "/*# sourceMappingURL=data:application/json;charset=utf-8;base64,eyJ2ZXJzaW9uIjozLCJzb3VyY2VzIjpbIlNlbGVjdENvbnRhaW5lci50c3giXSwibmFtZXMiOltdLCJtYXBwaW5ncyI6IkFBd0MyQyIsImZpbGUiOiJTZWxlY3RDb250YWluZXIudHN4Iiwic291cmNlc0NvbnRlbnQiOlsiaW1wb3J0IFJlYWN0IGZyb20gJ3JlYWN0JztcclxuaW1wb3J0IHN0eWxlZCBmcm9tICdAZW1vdGlvbi9zdHlsZWQnO1xyXG5pbXBvcnQgeyBMYWJlbCwgTGFiZWxQb3NpdGlvbiB9IGZyb20gJy4uL0xhYmVsJztcclxuaW1wb3J0IHsgVmlzdWFsbHlIaWRkZW4gfSBmcm9tICcuLi9WaXN1YWxseUhpZGRlbic7XHJcbmltcG9ydCB7IElucHV0TWVzc2FnZSB9IGZyb20gJy4uL0lucHV0L0lucHV0TWVzc2FnZSc7XHJcbmltcG9ydCB7IFRoZW1lQ29udGV4dCB9IGZyb20gJy4uLy4uL3RoZW1lL1RoZW1lQ29udGV4dCc7XHJcbmV4cG9ydCBjb25zdCBTZWxlY3RDb250YWluZXJFbGVtZW50ID0gc3R5bGVkLmRpdiBgXG4gIGRpc3BsYXk6IGZsZXg7XG4gIGZsZXgtZGlyZWN0aW9uOiAke3Byb3BzID0+IHByb3BzLmxhYmVsUG9zaXRpb24gPT09IExhYmVsUG9zaXRpb24ubGVmdCB8fFxyXG4gICAgKHByb3BzLmlzTGFiZWxWaXN1YWxseUhpZGRlbiAmJiBMYWJlbFBvc2l0aW9uLnRvcClcclxuICAgID8gJ3JvdydcclxuICAgIDogJ2NvbHVtbid9O1xuICBwb3NpdGlvbjogcmVsYXRpdmU7XG4gIGxhYmVsIHtcbiAgICBmbGV4LWJhc2lzOiAke3Byb3BzID0+IHByb3BzLmxhYmVsV2lkdGggJiYgcHJvcHMubGFiZWxQb3NpdGlvbiA9PT0gTGFiZWxQb3NpdGlvbi5sZWZ0XHJcbiAgICA/IGAke3Byb3BzLmxhYmVsV2lkdGh9JWBcclxuICAgIDogJyd9O1xuICB9XG5gO1xyXG5jb25zdCBJbnB1dE1lc3NhZ2VDb250YWluZXIgPSBzdHlsZWQuZGl2IGBcbiAgZmxleC1ncm93OiAxO1xuICBwYWRkaW5nOiAwLjI1ZW07XG4gIG1hcmdpbjogLTAuMjVlbTtcbiAgbWluLXdpZHRoOiAwJTtcbiAgcG9zaXRpb246IHJlbGF0aXZlO1xuYDtcclxuY29uc3QgU3R5bGVkQWRkaXRpb25hbENvbnRlbnRXcmFwcGVyID0gc3R5bGVkLmRpdiBgXG4gIGFsaWduLWl0ZW1zOiBjZW50ZXI7XG4gIGRpc3BsYXk6IGZsZXg7XG4gIGZsZXg6IDE7XG4gIGp1c3RpZnktY29udGVudDogc3BhY2UtYmV0d2VlbjtcbiAgbGFiZWwge1xuICAgIG1hcmdpbjogJHtwcm9wcyA9PiBwcm9wcy5sYWJlbFBvc2l0aW9uID09PSBMYWJlbFBvc2l0aW9uLmxlZnRcclxuICAgID8gYDAgJHtwcm9wcy50aGVtZS5zcGFjZVNjYWxlLnNwYWNpbmcwM30gMCAwYFxyXG4gICAgOiAnJ307XG4gIH1cbiAgYnV0dG9uIHtcbiAgICBib3R0b206ICR7cHJvcHMgPT4gcHJvcHMubGFiZWxQb3NpdGlvbiAhPT0gTGFiZWxQb3NpdGlvbi5sZWZ0ID8gYDZweGAgOiAnJ307XG4gIH1cbmA7XHJcbmNvbnN0IFN0eWxlZEFkZGl0aW9uYWxDb250ZW50ID0gc3R5bGVkLmRpdiBgXG4gIGRpc3BsYXk6IGZsZXg7XG4gIGFsaWduLWl0ZW1zOiBjZW50ZXI7XG4gIGJ1dHRvbiB7XG4gICAgbWFyZ2luOiAke3Byb3BzID0+IHByb3BzLmxhYmVsUG9zaXRpb24gPT09IExhYmVsUG9zaXRpb24ubGVmdFxyXG4gICAgPyBgMCAwIDAgJHtwcm9wcy50aGVtZS5zcGFjZVNjYWxlLnNwYWNpbmcwM31gXHJcbiAgICA6ICcnfTtcbiAgfVxuYDtcclxuY29uc3QgRm9ybUZpZWxkID0gc3R5bGVkLmZvcm0gYFxuICBmbGV4OiAxIDEgYXV0bztcbiAgbWluLXdpZHRoOiAwJTtcbmA7XHJcbmV4cG9ydCBmdW5jdGlvbiBTZWxlY3RDb250YWluZXIocHJvcHMpIHtcclxuICAgIGNvbnN0IHsgYWRkaXRpb25hbENvbnRlbnQsIGNoaWxkcmVuLCBkZXNjcmlwdGlvbklkLCBlcnJvck1lc3NhZ2UsIGdldExhYmVsUHJvcHMsIGhlbHBlck1lc3NhZ2UsIGlzSW52ZXJzZSwgaXNMYWJlbFZpc3VhbGx5SGlkZGVuLCBsYWJlbFBvc2l0aW9uLCBsYWJlbFN0eWxlLCBsYWJlbFRleHQsIGxhYmVsV2lkdGgsIG1lc3NhZ2VTdHlsZSwgfSA9IHByb3BzO1xyXG4gICAgY29uc3QgaGFzRXJyb3IgPSAhIWVycm9yTWVzc2FnZTtcclxuICAgIGNvbnN0IHRoZW1lID0gUmVhY3QudXNlQ29udGV4dChUaGVtZUNvbnRleHQpO1xyXG4gICAgLy8gSWYgdGhlIGxhYmVsUG9zaXRpb24gaXMgc2V0IHRvICd0b3AnIChkZWZhdWx0KSB0aGVuIGEgPGRpdj4gd3JhcHMgdGhlIExhYmVsIGFuZCBhZGRpdGlvbmFsIGNvbnRlbnQgZm9yIHByb3BlciBzdHlsaW5nIGFsaWdubWVudC5cclxuICAgIGZ1bmN0aW9uIEFkZGl0aW9uYWxDb250ZW50V3JhcHBlcihwcm9wcykge1xyXG4gICAgICAgIGlmIChsYWJlbFBvc2l0aW9uICE9PSBMYWJlbFBvc2l0aW9uLmxlZnQgJiZcclxuICAgICAgICAgICAgIWlzTGFiZWxWaXN1YWxseUhpZGRlbiAmJlxyXG4gICAgICAgICAgICBhZGRpdGlvbmFsQ29udGVudCkge1xyXG4gICAgICAgICAgICByZXR1cm4gKFJlYWN0LmNyZWF0ZUVsZW1lbnQoU3R5bGVkQWRkaXRpb25hbENvbnRlbnRXcmFwcGVyLCB7IGxhYmVsUG9zaXRpb246IGxhYmVsUG9zaXRpb24sIHRoZW1lOiB0aGVtZSB9LFxyXG4gICAgICAgICAgICAgICAgcHJvcHMuY2hpbGRyZW4sXHJcbiAgICAgICAgICAgICAgICBhZGRpdGlvbmFsQ29udGVudCkpO1xyXG4gICAgICAgIH1cclxuICAgICAgICByZXR1cm4gcHJvcHMuY2hpbGRyZW47XHJcbiAgICB9XHJcbiAgICAvLyBJZiB0aGUgbGFiZWxQb3NpdGlvbiBpcyBzZXQgdG8gTGFiZWxQb3NpdGlvbi5sZWZ0IHRoZW4gdGhlIGxhYmVsLCBzZWxlY3QsIGFuZCBhZGRpdGlvbmFsIGNvbnRlbnQgZGlzcGxheSBpbmxpbmUuXHJcbiAgICBmdW5jdGlvbiBhZGRpdGlvbmFsSXRlbVJpZ2h0QWxpZ24oKSB7XHJcbiAgICAgICAgaWYgKChsYWJlbFBvc2l0aW9uID09PSBMYWJlbFBvc2l0aW9uLmxlZnQgJiYgYWRkaXRpb25hbENvbnRlbnQpIHx8XHJcbiAgICAgICAgICAgIChsYWJlbFBvc2l0aW9uICYmIGlzTGFiZWxWaXN1YWxseUhpZGRlbiAmJiBhZGRpdGlvbmFsQ29udGVudCkpIHtcclxuICAgICAgICAgICAgcmV0dXJuIChSZWFjdC5jcmVhdGVFbGVtZW50KFN0eWxlZEFkZGl0aW9uYWxDb250ZW50LCB7IGxhYmVsUG9zaXRpb246IGxhYmVsUG9zaXRpb24sIHRoZW1lOiB0aGVtZSB9LCBhZGRpdGlvbmFsQ29udGVudCkpO1xyXG4gICAgICAgIH1cclxuICAgIH1cclxuICAgIHJldHVybiAoUmVhY3QuY3JlYXRlRWxlbWVudChTZWxlY3RDb250YWluZXJFbGVtZW50LCB7IGlzTGFiZWxWaXN1YWxseUhpZGRlbjogaXNMYWJlbFZpc3VhbGx5SGlkZGVuLCBsYWJlbFBvc2l0aW9uOiBsYWJlbFBvc2l0aW9uLCBsYWJlbFdpZHRoOiBsYWJlbFdpZHRoLCBcImRhdGEtdGVzdGlkXCI6IFwic2VsZWN0Q29udGFpbmVyRWxlbWVudFwiIH0sXHJcbiAgICAgICAgUmVhY3QuY3JlYXRlRWxlbWVudChBZGRpdGlvbmFsQ29udGVudFdyYXBwZXIsIHsgbGFiZWxQb3NpdGlvbjogbGFiZWxQb3NpdGlvbiB9LFxyXG4gICAgICAgICAgICBSZWFjdC5jcmVhdGVFbGVtZW50KExhYmVsLCBPYmplY3QuYXNzaWduKHt9LCBnZXRMYWJlbFByb3BzKCksIHsgaXNJbnZlcnNlOiBpc0ludmVyc2UsIGxhYmVsUG9zaXRpb246IGxhYmVsUG9zaXRpb24sIHN0eWxlOiBsYWJlbFN0eWxlIH0pLCBpc0xhYmVsVmlzdWFsbHlIaWRkZW4gPyAoUmVhY3QuY3JlYXRlRWxlbWVudChWaXN1YWxseUhpZGRlbiwgbnVsbCwgbGFiZWxUZXh0KSkgOiAobGFiZWxUZXh0KSkpLFxyXG4gICAgICAgIFJlYWN0LmNyZWF0ZUVsZW1lbnQoRm9ybUZpZWxkLCBudWxsLFxyXG4gICAgICAgICAgICBSZWFjdC5jcmVhdGVFbGVtZW50KElucHV0TWVzc2FnZUNvbnRhaW5lciwgbnVsbCwgY2hpbGRyZW4pLFxyXG4gICAgICAgICAgICAhKGxhYmVsUG9zaXRpb24gPT09IExhYmVsUG9zaXRpb24ubGVmdCAmJlxyXG4gICAgICAgICAgICAgICAgIShlcnJvck1lc3NhZ2UgfHwgaGVscGVyTWVzc2FnZSkpICYmXHJcbiAgICAgICAgICAgICAgICAoZXJyb3JNZXNzYWdlIHx8IGhlbHBlck1lc3NhZ2UpICYmIChSZWFjdC5jcmVhdGVFbGVtZW50KElucHV0TWVzc2FnZSwgeyBpZDogZGVzY3JpcHRpb25JZCwgaXNJbnZlcnNlOiBpc0ludmVyc2UsIGhhc0Vycm9yOiBoYXNFcnJvciwgc3R5bGU6IG1lc3NhZ2VTdHlsZSB9LCAoZXJyb3JNZXNzYWdlIHx8IGhlbHBlck1lc3NhZ2UpICYmIChSZWFjdC5jcmVhdGVFbGVtZW50KFJlYWN0LkZyYWdtZW50LCBudWxsLCBlcnJvck1lc3NhZ2UgPyBlcnJvck1lc3NhZ2UgOiBoZWxwZXJNZXNzYWdlKSkpKSksXHJcbiAgICAgICAgYWRkaXRpb25hbEl0ZW1SaWdodEFsaWduKCkpKTtcclxufVxyXG4vLyMgc291cmNlTWFwcGluZ1VSTD1TZWxlY3RDb250YWluZXIuanMubWFwIl19 */"));
24520
- var FormField = /*#__PURE__*/_styled("form", {
24523
+ }, ";}" + (process.env.NODE_ENV === "production" ? "" : "/*# sourceMappingURL=data:application/json;charset=utf-8;base64,eyJ2ZXJzaW9uIjozLCJzb3VyY2VzIjpbIlNlbGVjdENvbnRhaW5lci50c3giXSwibmFtZXMiOltdLCJtYXBwaW5ncyI6IkFBd0MyQyIsImZpbGUiOiJTZWxlY3RDb250YWluZXIudHN4Iiwic291cmNlc0NvbnRlbnQiOlsiaW1wb3J0IFJlYWN0IGZyb20gJ3JlYWN0JztcclxuaW1wb3J0IHN0eWxlZCBmcm9tICdAZW1vdGlvbi9zdHlsZWQnO1xyXG5pbXBvcnQgeyBMYWJlbCwgTGFiZWxQb3NpdGlvbiB9IGZyb20gJy4uL0xhYmVsJztcclxuaW1wb3J0IHsgVmlzdWFsbHlIaWRkZW4gfSBmcm9tICcuLi9WaXN1YWxseUhpZGRlbic7XHJcbmltcG9ydCB7IElucHV0TWVzc2FnZSB9IGZyb20gJy4uL0lucHV0L0lucHV0TWVzc2FnZSc7XHJcbmltcG9ydCB7IFRoZW1lQ29udGV4dCB9IGZyb20gJy4uLy4uL3RoZW1lL1RoZW1lQ29udGV4dCc7XHJcbmV4cG9ydCBjb25zdCBTZWxlY3RDb250YWluZXJFbGVtZW50ID0gc3R5bGVkLmRpdiBgXG4gIGRpc3BsYXk6IGZsZXg7XG4gIGZsZXgtZGlyZWN0aW9uOiAke3Byb3BzID0+IHByb3BzLmxhYmVsUG9zaXRpb24gPT09IExhYmVsUG9zaXRpb24ubGVmdCB8fFxyXG4gICAgKHByb3BzLmlzTGFiZWxWaXN1YWxseUhpZGRlbiAmJiBMYWJlbFBvc2l0aW9uLnRvcClcclxuICAgID8gJ3JvdydcclxuICAgIDogJ2NvbHVtbid9O1xuICBwb3NpdGlvbjogcmVsYXRpdmU7XG4gIGxhYmVsIHtcbiAgICBmbGV4LWJhc2lzOiAke3Byb3BzID0+IHByb3BzLmxhYmVsV2lkdGggJiYgcHJvcHMubGFiZWxQb3NpdGlvbiA9PT0gTGFiZWxQb3NpdGlvbi5sZWZ0XHJcbiAgICA/IGAke3Byb3BzLmxhYmVsV2lkdGh9JWBcclxuICAgIDogJyd9O1xuICB9XG5gO1xyXG5jb25zdCBJbnB1dE1lc3NhZ2VDb250YWluZXIgPSBzdHlsZWQuZGl2IGBcbiAgZmxleC1ncm93OiAxO1xuICBwYWRkaW5nOiAwLjI1ZW07XG4gIG1hcmdpbjogLTAuMjVlbTtcbiAgbWluLXdpZHRoOiAwJTtcbiAgcG9zaXRpb246IHJlbGF0aXZlO1xuYDtcclxuY29uc3QgU3R5bGVkQWRkaXRpb25hbENvbnRlbnRXcmFwcGVyID0gc3R5bGVkLmRpdiBgXG4gIGFsaWduLWl0ZW1zOiBjZW50ZXI7XG4gIGRpc3BsYXk6IGZsZXg7XG4gIGZsZXg6IDE7XG4gIGp1c3RpZnktY29udGVudDogc3BhY2UtYmV0d2VlbjtcbiAgbGFiZWwge1xuICAgIG1hcmdpbjogJHtwcm9wcyA9PiBwcm9wcy5sYWJlbFBvc2l0aW9uID09PSBMYWJlbFBvc2l0aW9uLmxlZnRcclxuICAgID8gYDAgJHtwcm9wcy50aGVtZS5zcGFjZVNjYWxlLnNwYWNpbmcwM30gMCAwYFxyXG4gICAgOiAnJ307XG4gIH1cbiAgYnV0dG9uIHtcbiAgICBib3R0b206ICR7cHJvcHMgPT4gcHJvcHMubGFiZWxQb3NpdGlvbiAhPT0gTGFiZWxQb3NpdGlvbi5sZWZ0ID8gYDZweGAgOiAnJ307XG4gIH1cbmA7XHJcbmNvbnN0IFN0eWxlZEFkZGl0aW9uYWxDb250ZW50ID0gc3R5bGVkLmRpdiBgXG4gIGRpc3BsYXk6IGZsZXg7XG4gIGFsaWduLWl0ZW1zOiBjZW50ZXI7XG4gIGJ1dHRvbiB7XG4gICAgbWFyZ2luOiAke3Byb3BzID0+IHByb3BzLmxhYmVsUG9zaXRpb24gPT09IExhYmVsUG9zaXRpb24ubGVmdFxyXG4gICAgPyBgMCAwIDAgJHtwcm9wcy50aGVtZS5zcGFjZVNjYWxlLnNwYWNpbmcwM31gXHJcbiAgICA6ICcnfTtcbiAgfVxuYDtcclxuY29uc3QgRmllbGRDb250YWluZXIgPSBzdHlsZWQuZGl2IGBcbiAgZmxleDogMSAxIGF1dG87XG4gIG1pbi13aWR0aDogMCU7XG5gO1xyXG5leHBvcnQgZnVuY3Rpb24gU2VsZWN0Q29udGFpbmVyKHByb3BzKSB7XHJcbiAgICBjb25zdCB7IGFkZGl0aW9uYWxDb250ZW50LCBjaGlsZHJlbiwgZGVzY3JpcHRpb25JZCwgZXJyb3JNZXNzYWdlLCBnZXRMYWJlbFByb3BzLCBoZWxwZXJNZXNzYWdlLCBpc0ludmVyc2UsIGlzTGFiZWxWaXN1YWxseUhpZGRlbiwgbGFiZWxQb3NpdGlvbiwgbGFiZWxTdHlsZSwgbGFiZWxUZXh0LCBsYWJlbFdpZHRoLCBtZXNzYWdlU3R5bGUsIH0gPSBwcm9wcztcclxuICAgIGNvbnN0IGhhc0Vycm9yID0gISFlcnJvck1lc3NhZ2U7XHJcbiAgICBjb25zdCB0aGVtZSA9IFJlYWN0LnVzZUNvbnRleHQoVGhlbWVDb250ZXh0KTtcclxuICAgIC8vIElmIHRoZSBsYWJlbFBvc2l0aW9uIGlzIHNldCB0byAndG9wJyAoZGVmYXVsdCkgdGhlbiBhIDxkaXY+IHdyYXBzIHRoZSBMYWJlbCBhbmQgYWRkaXRpb25hbCBjb250ZW50IGZvciBwcm9wZXIgc3R5bGluZyBhbGlnbm1lbnQuXHJcbiAgICBmdW5jdGlvbiBBZGRpdGlvbmFsQ29udGVudFdyYXBwZXIocHJvcHMpIHtcclxuICAgICAgICBpZiAobGFiZWxQb3NpdGlvbiAhPT0gTGFiZWxQb3NpdGlvbi5sZWZ0ICYmXHJcbiAgICAgICAgICAgICFpc0xhYmVsVmlzdWFsbHlIaWRkZW4gJiZcclxuICAgICAgICAgICAgYWRkaXRpb25hbENvbnRlbnQpIHtcclxuICAgICAgICAgICAgcmV0dXJuIChSZWFjdC5jcmVhdGVFbGVtZW50KFN0eWxlZEFkZGl0aW9uYWxDb250ZW50V3JhcHBlciwgeyBsYWJlbFBvc2l0aW9uOiBsYWJlbFBvc2l0aW9uLCB0aGVtZTogdGhlbWUgfSxcclxuICAgICAgICAgICAgICAgIHByb3BzLmNoaWxkcmVuLFxyXG4gICAgICAgICAgICAgICAgYWRkaXRpb25hbENvbnRlbnQpKTtcclxuICAgICAgICB9XHJcbiAgICAgICAgcmV0dXJuIHByb3BzLmNoaWxkcmVuO1xyXG4gICAgfVxyXG4gICAgLy8gSWYgdGhlIGxhYmVsUG9zaXRpb24gaXMgc2V0IHRvIExhYmVsUG9zaXRpb24ubGVmdCB0aGVuIHRoZSBsYWJlbCwgc2VsZWN0LCBhbmQgYWRkaXRpb25hbCBjb250ZW50IGRpc3BsYXkgaW5saW5lLlxyXG4gICAgZnVuY3Rpb24gYWRkaXRpb25hbEl0ZW1SaWdodEFsaWduKCkge1xyXG4gICAgICAgIGlmICgobGFiZWxQb3NpdGlvbiA9PT0gTGFiZWxQb3NpdGlvbi5sZWZ0ICYmIGFkZGl0aW9uYWxDb250ZW50KSB8fFxyXG4gICAgICAgICAgICAobGFiZWxQb3NpdGlvbiAmJiBpc0xhYmVsVmlzdWFsbHlIaWRkZW4gJiYgYWRkaXRpb25hbENvbnRlbnQpKSB7XHJcbiAgICAgICAgICAgIHJldHVybiAoUmVhY3QuY3JlYXRlRWxlbWVudChTdHlsZWRBZGRpdGlvbmFsQ29udGVudCwgeyBsYWJlbFBvc2l0aW9uOiBsYWJlbFBvc2l0aW9uLCB0aGVtZTogdGhlbWUgfSwgYWRkaXRpb25hbENvbnRlbnQpKTtcclxuICAgICAgICB9XHJcbiAgICB9XHJcbiAgICByZXR1cm4gKFJlYWN0LmNyZWF0ZUVsZW1lbnQoU2VsZWN0Q29udGFpbmVyRWxlbWVudCwgeyBpc0xhYmVsVmlzdWFsbHlIaWRkZW46IGlzTGFiZWxWaXN1YWxseUhpZGRlbiwgbGFiZWxQb3NpdGlvbjogbGFiZWxQb3NpdGlvbiwgbGFiZWxXaWR0aDogbGFiZWxXaWR0aCwgXCJkYXRhLXRlc3RpZFwiOiBcInNlbGVjdENvbnRhaW5lckVsZW1lbnRcIiB9LFxyXG4gICAgICAgIFJlYWN0LmNyZWF0ZUVsZW1lbnQoQWRkaXRpb25hbENvbnRlbnRXcmFwcGVyLCB7IGxhYmVsUG9zaXRpb246IGxhYmVsUG9zaXRpb24gfSxcclxuICAgICAgICAgICAgUmVhY3QuY3JlYXRlRWxlbWVudChMYWJlbCwgT2JqZWN0LmFzc2lnbih7fSwgZ2V0TGFiZWxQcm9wcygpLCB7IGlzSW52ZXJzZTogaXNJbnZlcnNlLCBsYWJlbFBvc2l0aW9uOiBsYWJlbFBvc2l0aW9uLCBzdHlsZTogbGFiZWxTdHlsZSB9KSwgaXNMYWJlbFZpc3VhbGx5SGlkZGVuID8gKFJlYWN0LmNyZWF0ZUVsZW1lbnQoVmlzdWFsbHlIaWRkZW4sIG51bGwsIGxhYmVsVGV4dCkpIDogKGxhYmVsVGV4dCkpKSxcclxuICAgICAgICBSZWFjdC5jcmVhdGVFbGVtZW50KEZpZWxkQ29udGFpbmVyLCBudWxsLFxyXG4gICAgICAgICAgICBSZWFjdC5jcmVhdGVFbGVtZW50KElucHV0TWVzc2FnZUNvbnRhaW5lciwgbnVsbCwgY2hpbGRyZW4pLFxyXG4gICAgICAgICAgICAhKGxhYmVsUG9zaXRpb24gPT09IExhYmVsUG9zaXRpb24ubGVmdCAmJlxyXG4gICAgICAgICAgICAgICAgIShlcnJvck1lc3NhZ2UgfHwgaGVscGVyTWVzc2FnZSkpICYmXHJcbiAgICAgICAgICAgICAgICAoZXJyb3JNZXNzYWdlIHx8IGhlbHBlck1lc3NhZ2UpICYmIChSZWFjdC5jcmVhdGVFbGVtZW50KElucHV0TWVzc2FnZSwgeyBpZDogZGVzY3JpcHRpb25JZCwgaXNJbnZlcnNlOiBpc0ludmVyc2UsIGhhc0Vycm9yOiBoYXNFcnJvciwgc3R5bGU6IG1lc3NhZ2VTdHlsZSB9LCAoZXJyb3JNZXNzYWdlIHx8IGhlbHBlck1lc3NhZ2UpICYmIChSZWFjdC5jcmVhdGVFbGVtZW50KFJlYWN0LkZyYWdtZW50LCBudWxsLCBlcnJvck1lc3NhZ2UgPyBlcnJvck1lc3NhZ2UgOiBoZWxwZXJNZXNzYWdlKSkpKSksXHJcbiAgICAgICAgYWRkaXRpb25hbEl0ZW1SaWdodEFsaWduKCkpKTtcclxufVxyXG4vLyMgc291cmNlTWFwcGluZ1VSTD1TZWxlY3RDb250YWluZXIuanMubWFwIl19 */"));
24524
+ var FieldContainer = /*#__PURE__*/_styled("div", {
24521
24525
  target: "eh2jlnx0",
24522
- label: "FormField"
24526
+ label: "FieldContainer"
24523
24527
  })(process.env.NODE_ENV === "production" ? {
24524
24528
  name: "4n9v3b",
24525
24529
  styles: "flex:1 1 auto;min-width:0%"
24526
24530
  } : {
24527
24531
  name: "4n9v3b",
24528
24532
  styles: "flex:1 1 auto;min-width:0%",
24529
- map: "/*# sourceMappingURL=data:application/json;charset=utf-8;base64,eyJ2ZXJzaW9uIjozLCJzb3VyY2VzIjpbIlNlbGVjdENvbnRhaW5lci50c3giXSwibmFtZXMiOltdLCJtYXBwaW5ncyI6IkFBaUQ4QiIsImZpbGUiOiJTZWxlY3RDb250YWluZXIudHN4Iiwic291cmNlc0NvbnRlbnQiOlsiaW1wb3J0IFJlYWN0IGZyb20gJ3JlYWN0JztcclxuaW1wb3J0IHN0eWxlZCBmcm9tICdAZW1vdGlvbi9zdHlsZWQnO1xyXG5pbXBvcnQgeyBMYWJlbCwgTGFiZWxQb3NpdGlvbiB9IGZyb20gJy4uL0xhYmVsJztcclxuaW1wb3J0IHsgVmlzdWFsbHlIaWRkZW4gfSBmcm9tICcuLi9WaXN1YWxseUhpZGRlbic7XHJcbmltcG9ydCB7IElucHV0TWVzc2FnZSB9IGZyb20gJy4uL0lucHV0L0lucHV0TWVzc2FnZSc7XHJcbmltcG9ydCB7IFRoZW1lQ29udGV4dCB9IGZyb20gJy4uLy4uL3RoZW1lL1RoZW1lQ29udGV4dCc7XHJcbmV4cG9ydCBjb25zdCBTZWxlY3RDb250YWluZXJFbGVtZW50ID0gc3R5bGVkLmRpdiBgXG4gIGRpc3BsYXk6IGZsZXg7XG4gIGZsZXgtZGlyZWN0aW9uOiAke3Byb3BzID0+IHByb3BzLmxhYmVsUG9zaXRpb24gPT09IExhYmVsUG9zaXRpb24ubGVmdCB8fFxyXG4gICAgKHByb3BzLmlzTGFiZWxWaXN1YWxseUhpZGRlbiAmJiBMYWJlbFBvc2l0aW9uLnRvcClcclxuICAgID8gJ3JvdydcclxuICAgIDogJ2NvbHVtbid9O1xuICBwb3NpdGlvbjogcmVsYXRpdmU7XG4gIGxhYmVsIHtcbiAgICBmbGV4LWJhc2lzOiAke3Byb3BzID0+IHByb3BzLmxhYmVsV2lkdGggJiYgcHJvcHMubGFiZWxQb3NpdGlvbiA9PT0gTGFiZWxQb3NpdGlvbi5sZWZ0XHJcbiAgICA/IGAke3Byb3BzLmxhYmVsV2lkdGh9JWBcclxuICAgIDogJyd9O1xuICB9XG5gO1xyXG5jb25zdCBJbnB1dE1lc3NhZ2VDb250YWluZXIgPSBzdHlsZWQuZGl2IGBcbiAgZmxleC1ncm93OiAxO1xuICBwYWRkaW5nOiAwLjI1ZW07XG4gIG1hcmdpbjogLTAuMjVlbTtcbiAgbWluLXdpZHRoOiAwJTtcbiAgcG9zaXRpb246IHJlbGF0aXZlO1xuYDtcclxuY29uc3QgU3R5bGVkQWRkaXRpb25hbENvbnRlbnRXcmFwcGVyID0gc3R5bGVkLmRpdiBgXG4gIGFsaWduLWl0ZW1zOiBjZW50ZXI7XG4gIGRpc3BsYXk6IGZsZXg7XG4gIGZsZXg6IDE7XG4gIGp1c3RpZnktY29udGVudDogc3BhY2UtYmV0d2VlbjtcbiAgbGFiZWwge1xuICAgIG1hcmdpbjogJHtwcm9wcyA9PiBwcm9wcy5sYWJlbFBvc2l0aW9uID09PSBMYWJlbFBvc2l0aW9uLmxlZnRcclxuICAgID8gYDAgJHtwcm9wcy50aGVtZS5zcGFjZVNjYWxlLnNwYWNpbmcwM30gMCAwYFxyXG4gICAgOiAnJ307XG4gIH1cbiAgYnV0dG9uIHtcbiAgICBib3R0b206ICR7cHJvcHMgPT4gcHJvcHMubGFiZWxQb3NpdGlvbiAhPT0gTGFiZWxQb3NpdGlvbi5sZWZ0ID8gYDZweGAgOiAnJ307XG4gIH1cbmA7XHJcbmNvbnN0IFN0eWxlZEFkZGl0aW9uYWxDb250ZW50ID0gc3R5bGVkLmRpdiBgXG4gIGRpc3BsYXk6IGZsZXg7XG4gIGFsaWduLWl0ZW1zOiBjZW50ZXI7XG4gIGJ1dHRvbiB7XG4gICAgbWFyZ2luOiAke3Byb3BzID0+IHByb3BzLmxhYmVsUG9zaXRpb24gPT09IExhYmVsUG9zaXRpb24ubGVmdFxyXG4gICAgPyBgMCAwIDAgJHtwcm9wcy50aGVtZS5zcGFjZVNjYWxlLnNwYWNpbmcwM31gXHJcbiAgICA6ICcnfTtcbiAgfVxuYDtcclxuY29uc3QgRm9ybUZpZWxkID0gc3R5bGVkLmZvcm0gYFxuICBmbGV4OiAxIDEgYXV0bztcbiAgbWluLXdpZHRoOiAwJTtcbmA7XHJcbmV4cG9ydCBmdW5jdGlvbiBTZWxlY3RDb250YWluZXIocHJvcHMpIHtcclxuICAgIGNvbnN0IHsgYWRkaXRpb25hbENvbnRlbnQsIGNoaWxkcmVuLCBkZXNjcmlwdGlvbklkLCBlcnJvck1lc3NhZ2UsIGdldExhYmVsUHJvcHMsIGhlbHBlck1lc3NhZ2UsIGlzSW52ZXJzZSwgaXNMYWJlbFZpc3VhbGx5SGlkZGVuLCBsYWJlbFBvc2l0aW9uLCBsYWJlbFN0eWxlLCBsYWJlbFRleHQsIGxhYmVsV2lkdGgsIG1lc3NhZ2VTdHlsZSwgfSA9IHByb3BzO1xyXG4gICAgY29uc3QgaGFzRXJyb3IgPSAhIWVycm9yTWVzc2FnZTtcclxuICAgIGNvbnN0IHRoZW1lID0gUmVhY3QudXNlQ29udGV4dChUaGVtZUNvbnRleHQpO1xyXG4gICAgLy8gSWYgdGhlIGxhYmVsUG9zaXRpb24gaXMgc2V0IHRvICd0b3AnIChkZWZhdWx0KSB0aGVuIGEgPGRpdj4gd3JhcHMgdGhlIExhYmVsIGFuZCBhZGRpdGlvbmFsIGNvbnRlbnQgZm9yIHByb3BlciBzdHlsaW5nIGFsaWdubWVudC5cclxuICAgIGZ1bmN0aW9uIEFkZGl0aW9uYWxDb250ZW50V3JhcHBlcihwcm9wcykge1xyXG4gICAgICAgIGlmIChsYWJlbFBvc2l0aW9uICE9PSBMYWJlbFBvc2l0aW9uLmxlZnQgJiZcclxuICAgICAgICAgICAgIWlzTGFiZWxWaXN1YWxseUhpZGRlbiAmJlxyXG4gICAgICAgICAgICBhZGRpdGlvbmFsQ29udGVudCkge1xyXG4gICAgICAgICAgICByZXR1cm4gKFJlYWN0LmNyZWF0ZUVsZW1lbnQoU3R5bGVkQWRkaXRpb25hbENvbnRlbnRXcmFwcGVyLCB7IGxhYmVsUG9zaXRpb246IGxhYmVsUG9zaXRpb24sIHRoZW1lOiB0aGVtZSB9LFxyXG4gICAgICAgICAgICAgICAgcHJvcHMuY2hpbGRyZW4sXHJcbiAgICAgICAgICAgICAgICBhZGRpdGlvbmFsQ29udGVudCkpO1xyXG4gICAgICAgIH1cclxuICAgICAgICByZXR1cm4gcHJvcHMuY2hpbGRyZW47XHJcbiAgICB9XHJcbiAgICAvLyBJZiB0aGUgbGFiZWxQb3NpdGlvbiBpcyBzZXQgdG8gTGFiZWxQb3NpdGlvbi5sZWZ0IHRoZW4gdGhlIGxhYmVsLCBzZWxlY3QsIGFuZCBhZGRpdGlvbmFsIGNvbnRlbnQgZGlzcGxheSBpbmxpbmUuXHJcbiAgICBmdW5jdGlvbiBhZGRpdGlvbmFsSXRlbVJpZ2h0QWxpZ24oKSB7XHJcbiAgICAgICAgaWYgKChsYWJlbFBvc2l0aW9uID09PSBMYWJlbFBvc2l0aW9uLmxlZnQgJiYgYWRkaXRpb25hbENvbnRlbnQpIHx8XHJcbiAgICAgICAgICAgIChsYWJlbFBvc2l0aW9uICYmIGlzTGFiZWxWaXN1YWxseUhpZGRlbiAmJiBhZGRpdGlvbmFsQ29udGVudCkpIHtcclxuICAgICAgICAgICAgcmV0dXJuIChSZWFjdC5jcmVhdGVFbGVtZW50KFN0eWxlZEFkZGl0aW9uYWxDb250ZW50LCB7IGxhYmVsUG9zaXRpb246IGxhYmVsUG9zaXRpb24sIHRoZW1lOiB0aGVtZSB9LCBhZGRpdGlvbmFsQ29udGVudCkpO1xyXG4gICAgICAgIH1cclxuICAgIH1cclxuICAgIHJldHVybiAoUmVhY3QuY3JlYXRlRWxlbWVudChTZWxlY3RDb250YWluZXJFbGVtZW50LCB7IGlzTGFiZWxWaXN1YWxseUhpZGRlbjogaXNMYWJlbFZpc3VhbGx5SGlkZGVuLCBsYWJlbFBvc2l0aW9uOiBsYWJlbFBvc2l0aW9uLCBsYWJlbFdpZHRoOiBsYWJlbFdpZHRoLCBcImRhdGEtdGVzdGlkXCI6IFwic2VsZWN0Q29udGFpbmVyRWxlbWVudFwiIH0sXHJcbiAgICAgICAgUmVhY3QuY3JlYXRlRWxlbWVudChBZGRpdGlvbmFsQ29udGVudFdyYXBwZXIsIHsgbGFiZWxQb3NpdGlvbjogbGFiZWxQb3NpdGlvbiB9LFxyXG4gICAgICAgICAgICBSZWFjdC5jcmVhdGVFbGVtZW50KExhYmVsLCBPYmplY3QuYXNzaWduKHt9LCBnZXRMYWJlbFByb3BzKCksIHsgaXNJbnZlcnNlOiBpc0ludmVyc2UsIGxhYmVsUG9zaXRpb246IGxhYmVsUG9zaXRpb24sIHN0eWxlOiBsYWJlbFN0eWxlIH0pLCBpc0xhYmVsVmlzdWFsbHlIaWRkZW4gPyAoUmVhY3QuY3JlYXRlRWxlbWVudChWaXN1YWxseUhpZGRlbiwgbnVsbCwgbGFiZWxUZXh0KSkgOiAobGFiZWxUZXh0KSkpLFxyXG4gICAgICAgIFJlYWN0LmNyZWF0ZUVsZW1lbnQoRm9ybUZpZWxkLCBudWxsLFxyXG4gICAgICAgICAgICBSZWFjdC5jcmVhdGVFbGVtZW50KElucHV0TWVzc2FnZUNvbnRhaW5lciwgbnVsbCwgY2hpbGRyZW4pLFxyXG4gICAgICAgICAgICAhKGxhYmVsUG9zaXRpb24gPT09IExhYmVsUG9zaXRpb24ubGVmdCAmJlxyXG4gICAgICAgICAgICAgICAgIShlcnJvck1lc3NhZ2UgfHwgaGVscGVyTWVzc2FnZSkpICYmXHJcbiAgICAgICAgICAgICAgICAoZXJyb3JNZXNzYWdlIHx8IGhlbHBlck1lc3NhZ2UpICYmIChSZWFjdC5jcmVhdGVFbGVtZW50KElucHV0TWVzc2FnZSwgeyBpZDogZGVzY3JpcHRpb25JZCwgaXNJbnZlcnNlOiBpc0ludmVyc2UsIGhhc0Vycm9yOiBoYXNFcnJvciwgc3R5bGU6IG1lc3NhZ2VTdHlsZSB9LCAoZXJyb3JNZXNzYWdlIHx8IGhlbHBlck1lc3NhZ2UpICYmIChSZWFjdC5jcmVhdGVFbGVtZW50KFJlYWN0LkZyYWdtZW50LCBudWxsLCBlcnJvck1lc3NhZ2UgPyBlcnJvck1lc3NhZ2UgOiBoZWxwZXJNZXNzYWdlKSkpKSksXHJcbiAgICAgICAgYWRkaXRpb25hbEl0ZW1SaWdodEFsaWduKCkpKTtcclxufVxyXG4vLyMgc291cmNlTWFwcGluZ1VSTD1TZWxlY3RDb250YWluZXIuanMubWFwIl19 */",
24533
+ map: "/*# sourceMappingURL=data:application/json;charset=utf-8;base64,eyJ2ZXJzaW9uIjozLCJzb3VyY2VzIjpbIlNlbGVjdENvbnRhaW5lci50c3giXSwibmFtZXMiOltdLCJtYXBwaW5ncyI6IkFBaURrQyIsImZpbGUiOiJTZWxlY3RDb250YWluZXIudHN4Iiwic291cmNlc0NvbnRlbnQiOlsiaW1wb3J0IFJlYWN0IGZyb20gJ3JlYWN0JztcclxuaW1wb3J0IHN0eWxlZCBmcm9tICdAZW1vdGlvbi9zdHlsZWQnO1xyXG5pbXBvcnQgeyBMYWJlbCwgTGFiZWxQb3NpdGlvbiB9IGZyb20gJy4uL0xhYmVsJztcclxuaW1wb3J0IHsgVmlzdWFsbHlIaWRkZW4gfSBmcm9tICcuLi9WaXN1YWxseUhpZGRlbic7XHJcbmltcG9ydCB7IElucHV0TWVzc2FnZSB9IGZyb20gJy4uL0lucHV0L0lucHV0TWVzc2FnZSc7XHJcbmltcG9ydCB7IFRoZW1lQ29udGV4dCB9IGZyb20gJy4uLy4uL3RoZW1lL1RoZW1lQ29udGV4dCc7XHJcbmV4cG9ydCBjb25zdCBTZWxlY3RDb250YWluZXJFbGVtZW50ID0gc3R5bGVkLmRpdiBgXG4gIGRpc3BsYXk6IGZsZXg7XG4gIGZsZXgtZGlyZWN0aW9uOiAke3Byb3BzID0+IHByb3BzLmxhYmVsUG9zaXRpb24gPT09IExhYmVsUG9zaXRpb24ubGVmdCB8fFxyXG4gICAgKHByb3BzLmlzTGFiZWxWaXN1YWxseUhpZGRlbiAmJiBMYWJlbFBvc2l0aW9uLnRvcClcclxuICAgID8gJ3JvdydcclxuICAgIDogJ2NvbHVtbid9O1xuICBwb3NpdGlvbjogcmVsYXRpdmU7XG4gIGxhYmVsIHtcbiAgICBmbGV4LWJhc2lzOiAke3Byb3BzID0+IHByb3BzLmxhYmVsV2lkdGggJiYgcHJvcHMubGFiZWxQb3NpdGlvbiA9PT0gTGFiZWxQb3NpdGlvbi5sZWZ0XHJcbiAgICA/IGAke3Byb3BzLmxhYmVsV2lkdGh9JWBcclxuICAgIDogJyd9O1xuICB9XG5gO1xyXG5jb25zdCBJbnB1dE1lc3NhZ2VDb250YWluZXIgPSBzdHlsZWQuZGl2IGBcbiAgZmxleC1ncm93OiAxO1xuICBwYWRkaW5nOiAwLjI1ZW07XG4gIG1hcmdpbjogLTAuMjVlbTtcbiAgbWluLXdpZHRoOiAwJTtcbiAgcG9zaXRpb246IHJlbGF0aXZlO1xuYDtcclxuY29uc3QgU3R5bGVkQWRkaXRpb25hbENvbnRlbnRXcmFwcGVyID0gc3R5bGVkLmRpdiBgXG4gIGFsaWduLWl0ZW1zOiBjZW50ZXI7XG4gIGRpc3BsYXk6IGZsZXg7XG4gIGZsZXg6IDE7XG4gIGp1c3RpZnktY29udGVudDogc3BhY2UtYmV0d2VlbjtcbiAgbGFiZWwge1xuICAgIG1hcmdpbjogJHtwcm9wcyA9PiBwcm9wcy5sYWJlbFBvc2l0aW9uID09PSBMYWJlbFBvc2l0aW9uLmxlZnRcclxuICAgID8gYDAgJHtwcm9wcy50aGVtZS5zcGFjZVNjYWxlLnNwYWNpbmcwM30gMCAwYFxyXG4gICAgOiAnJ307XG4gIH1cbiAgYnV0dG9uIHtcbiAgICBib3R0b206ICR7cHJvcHMgPT4gcHJvcHMubGFiZWxQb3NpdGlvbiAhPT0gTGFiZWxQb3NpdGlvbi5sZWZ0ID8gYDZweGAgOiAnJ307XG4gIH1cbmA7XHJcbmNvbnN0IFN0eWxlZEFkZGl0aW9uYWxDb250ZW50ID0gc3R5bGVkLmRpdiBgXG4gIGRpc3BsYXk6IGZsZXg7XG4gIGFsaWduLWl0ZW1zOiBjZW50ZXI7XG4gIGJ1dHRvbiB7XG4gICAgbWFyZ2luOiAke3Byb3BzID0+IHByb3BzLmxhYmVsUG9zaXRpb24gPT09IExhYmVsUG9zaXRpb24ubGVmdFxyXG4gICAgPyBgMCAwIDAgJHtwcm9wcy50aGVtZS5zcGFjZVNjYWxlLnNwYWNpbmcwM31gXHJcbiAgICA6ICcnfTtcbiAgfVxuYDtcclxuY29uc3QgRmllbGRDb250YWluZXIgPSBzdHlsZWQuZGl2IGBcbiAgZmxleDogMSAxIGF1dG87XG4gIG1pbi13aWR0aDogMCU7XG5gO1xyXG5leHBvcnQgZnVuY3Rpb24gU2VsZWN0Q29udGFpbmVyKHByb3BzKSB7XHJcbiAgICBjb25zdCB7IGFkZGl0aW9uYWxDb250ZW50LCBjaGlsZHJlbiwgZGVzY3JpcHRpb25JZCwgZXJyb3JNZXNzYWdlLCBnZXRMYWJlbFByb3BzLCBoZWxwZXJNZXNzYWdlLCBpc0ludmVyc2UsIGlzTGFiZWxWaXN1YWxseUhpZGRlbiwgbGFiZWxQb3NpdGlvbiwgbGFiZWxTdHlsZSwgbGFiZWxUZXh0LCBsYWJlbFdpZHRoLCBtZXNzYWdlU3R5bGUsIH0gPSBwcm9wcztcclxuICAgIGNvbnN0IGhhc0Vycm9yID0gISFlcnJvck1lc3NhZ2U7XHJcbiAgICBjb25zdCB0aGVtZSA9IFJlYWN0LnVzZUNvbnRleHQoVGhlbWVDb250ZXh0KTtcclxuICAgIC8vIElmIHRoZSBsYWJlbFBvc2l0aW9uIGlzIHNldCB0byAndG9wJyAoZGVmYXVsdCkgdGhlbiBhIDxkaXY+IHdyYXBzIHRoZSBMYWJlbCBhbmQgYWRkaXRpb25hbCBjb250ZW50IGZvciBwcm9wZXIgc3R5bGluZyBhbGlnbm1lbnQuXHJcbiAgICBmdW5jdGlvbiBBZGRpdGlvbmFsQ29udGVudFdyYXBwZXIocHJvcHMpIHtcclxuICAgICAgICBpZiAobGFiZWxQb3NpdGlvbiAhPT0gTGFiZWxQb3NpdGlvbi5sZWZ0ICYmXHJcbiAgICAgICAgICAgICFpc0xhYmVsVmlzdWFsbHlIaWRkZW4gJiZcclxuICAgICAgICAgICAgYWRkaXRpb25hbENvbnRlbnQpIHtcclxuICAgICAgICAgICAgcmV0dXJuIChSZWFjdC5jcmVhdGVFbGVtZW50KFN0eWxlZEFkZGl0aW9uYWxDb250ZW50V3JhcHBlciwgeyBsYWJlbFBvc2l0aW9uOiBsYWJlbFBvc2l0aW9uLCB0aGVtZTogdGhlbWUgfSxcclxuICAgICAgICAgICAgICAgIHByb3BzLmNoaWxkcmVuLFxyXG4gICAgICAgICAgICAgICAgYWRkaXRpb25hbENvbnRlbnQpKTtcclxuICAgICAgICB9XHJcbiAgICAgICAgcmV0dXJuIHByb3BzLmNoaWxkcmVuO1xyXG4gICAgfVxyXG4gICAgLy8gSWYgdGhlIGxhYmVsUG9zaXRpb24gaXMgc2V0IHRvIExhYmVsUG9zaXRpb24ubGVmdCB0aGVuIHRoZSBsYWJlbCwgc2VsZWN0LCBhbmQgYWRkaXRpb25hbCBjb250ZW50IGRpc3BsYXkgaW5saW5lLlxyXG4gICAgZnVuY3Rpb24gYWRkaXRpb25hbEl0ZW1SaWdodEFsaWduKCkge1xyXG4gICAgICAgIGlmICgobGFiZWxQb3NpdGlvbiA9PT0gTGFiZWxQb3NpdGlvbi5sZWZ0ICYmIGFkZGl0aW9uYWxDb250ZW50KSB8fFxyXG4gICAgICAgICAgICAobGFiZWxQb3NpdGlvbiAmJiBpc0xhYmVsVmlzdWFsbHlIaWRkZW4gJiYgYWRkaXRpb25hbENvbnRlbnQpKSB7XHJcbiAgICAgICAgICAgIHJldHVybiAoUmVhY3QuY3JlYXRlRWxlbWVudChTdHlsZWRBZGRpdGlvbmFsQ29udGVudCwgeyBsYWJlbFBvc2l0aW9uOiBsYWJlbFBvc2l0aW9uLCB0aGVtZTogdGhlbWUgfSwgYWRkaXRpb25hbENvbnRlbnQpKTtcclxuICAgICAgICB9XHJcbiAgICB9XHJcbiAgICByZXR1cm4gKFJlYWN0LmNyZWF0ZUVsZW1lbnQoU2VsZWN0Q29udGFpbmVyRWxlbWVudCwgeyBpc0xhYmVsVmlzdWFsbHlIaWRkZW46IGlzTGFiZWxWaXN1YWxseUhpZGRlbiwgbGFiZWxQb3NpdGlvbjogbGFiZWxQb3NpdGlvbiwgbGFiZWxXaWR0aDogbGFiZWxXaWR0aCwgXCJkYXRhLXRlc3RpZFwiOiBcInNlbGVjdENvbnRhaW5lckVsZW1lbnRcIiB9LFxyXG4gICAgICAgIFJlYWN0LmNyZWF0ZUVsZW1lbnQoQWRkaXRpb25hbENvbnRlbnRXcmFwcGVyLCB7IGxhYmVsUG9zaXRpb246IGxhYmVsUG9zaXRpb24gfSxcclxuICAgICAgICAgICAgUmVhY3QuY3JlYXRlRWxlbWVudChMYWJlbCwgT2JqZWN0LmFzc2lnbih7fSwgZ2V0TGFiZWxQcm9wcygpLCB7IGlzSW52ZXJzZTogaXNJbnZlcnNlLCBsYWJlbFBvc2l0aW9uOiBsYWJlbFBvc2l0aW9uLCBzdHlsZTogbGFiZWxTdHlsZSB9KSwgaXNMYWJlbFZpc3VhbGx5SGlkZGVuID8gKFJlYWN0LmNyZWF0ZUVsZW1lbnQoVmlzdWFsbHlIaWRkZW4sIG51bGwsIGxhYmVsVGV4dCkpIDogKGxhYmVsVGV4dCkpKSxcclxuICAgICAgICBSZWFjdC5jcmVhdGVFbGVtZW50KEZpZWxkQ29udGFpbmVyLCBudWxsLFxyXG4gICAgICAgICAgICBSZWFjdC5jcmVhdGVFbGVtZW50KElucHV0TWVzc2FnZUNvbnRhaW5lciwgbnVsbCwgY2hpbGRyZW4pLFxyXG4gICAgICAgICAgICAhKGxhYmVsUG9zaXRpb24gPT09IExhYmVsUG9zaXRpb24ubGVmdCAmJlxyXG4gICAgICAgICAgICAgICAgIShlcnJvck1lc3NhZ2UgfHwgaGVscGVyTWVzc2FnZSkpICYmXHJcbiAgICAgICAgICAgICAgICAoZXJyb3JNZXNzYWdlIHx8IGhlbHBlck1lc3NhZ2UpICYmIChSZWFjdC5jcmVhdGVFbGVtZW50KElucHV0TWVzc2FnZSwgeyBpZDogZGVzY3JpcHRpb25JZCwgaXNJbnZlcnNlOiBpc0ludmVyc2UsIGhhc0Vycm9yOiBoYXNFcnJvciwgc3R5bGU6IG1lc3NhZ2VTdHlsZSB9LCAoZXJyb3JNZXNzYWdlIHx8IGhlbHBlck1lc3NhZ2UpICYmIChSZWFjdC5jcmVhdGVFbGVtZW50KFJlYWN0LkZyYWdtZW50LCBudWxsLCBlcnJvck1lc3NhZ2UgPyBlcnJvck1lc3NhZ2UgOiBoZWxwZXJNZXNzYWdlKSkpKSksXHJcbiAgICAgICAgYWRkaXRpb25hbEl0ZW1SaWdodEFsaWduKCkpKTtcclxufVxyXG4vLyMgc291cmNlTWFwcGluZ1VSTD1TZWxlY3RDb250YWluZXIuanMubWFwIl19 */",
24530
24534
  toString: _EMOTION_STRINGIFIED_CSS_ERROR__$w
24531
24535
  });
24532
24536
  function SelectContainer$1(props) {
@@ -24575,7 +24579,7 @@ function SelectContainer$1(props) {
24575
24579
  isInverse: isInverse,
24576
24580
  labelPosition: labelPosition,
24577
24581
  style: labelStyle
24578
- }), isLabelVisuallyHidden ? React__default.createElement(VisuallyHidden, null, labelText) : labelText)), React__default.createElement(FormField, null, React__default.createElement(InputMessageContainer, null, children), !(labelPosition === LabelPosition.left && !(errorMessage || helperMessage)) && (errorMessage || helperMessage) && React__default.createElement(InputMessage, {
24582
+ }), isLabelVisuallyHidden ? React__default.createElement(VisuallyHidden, null, labelText) : labelText)), React__default.createElement(FieldContainer, null, React__default.createElement(InputMessageContainer, null, children), !(labelPosition === LabelPosition.left && !(errorMessage || helperMessage)) && (errorMessage || helperMessage) && React__default.createElement(InputMessage, {
24579
24583
  id: descriptionId,
24580
24584
  isInverse: isInverse,
24581
24585
  hasError: hasError,