react-magma-dom 5.1.0-rc.19 → 5.1.0-rc.20

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.
@@ -22,6 +22,10 @@ export interface BannerProps extends AlertProps {
22
22
  * @default false
23
23
  */
24
24
  isDismissible?: boolean;
25
+ /**
26
+ * Reference to the dismiss button element
27
+ */
28
+ dismissibleButtonRef?: React.Ref<HTMLButtonElement>;
25
29
  isInverse?: boolean;
26
30
  }
27
31
  export declare const Banner: React.ForwardRefExoticComponent<BannerProps & React.RefAttributes<HTMLDivElement>>;
package/dist/esm/index.js CHANGED
@@ -4246,7 +4246,7 @@ var Badge = /*#__PURE__*/forwardRef(function (props, ref) {
4246
4246
  }), children);
4247
4247
  });
4248
4248
 
4249
- var _excluded$c = ["actionButtonText", "actionButtonOnClick", "additionalContent", "children", "closeAriaLabel", "isDismissible", "onDismiss", "testId", "variant"];
4249
+ var _excluded$c = ["actionButtonText", "actionButtonOnClick", "additionalContent", "children", "closeAriaLabel", "isDismissible", "onDismiss", "testId", "variant", "dismissibleButtonRef"];
4250
4250
  function _EMOTION_STRINGIFIED_CSS_ERROR__$6() { return "You have tried to stringify object returned from `css` function. It isn't supposed to be used directly (e.g. as value of the `className` prop), but rather handed to emotion so it can handle it (e.g. as value of `css` prop)."; }
4251
4251
  var StyledBanner = /*#__PURE__*/_styled("div", {
4252
4252
  target: "e1b9nb1m4",
@@ -4269,7 +4269,7 @@ var StyledBanner = /*#__PURE__*/_styled("div", {
4269
4269
  return props.theme.typeScale.size02.letterSpacing;
4270
4270
  }, ";line-height:", function (props) {
4271
4271
  return props.theme.typeScale.size02.lineHeight;
4272
- }, ";}" + (process.env.NODE_ENV === "production" ? "" : "/*# sourceMappingURL=data:application/json;charset=utf-8;base64,{"version":3,"sources":["index.tsx"],"names":[],"mappings":"AAUgC","file":"index.tsx","sourcesContent":["import * as React from 'react';\r\nimport isPropValid from '@emotion/is-prop-valid';\r\nimport styled from '@emotion/styled';\r\nimport { CloseIcon } from 'react-magma-icons';\r\nimport { I18nContext } from '../../i18n';\r\nimport { useIsInverse } from '../../inverse';\r\nimport { ThemeContext } from '../../theme/ThemeContext';\r\nimport { AdditionalContentWrapper, AlertVariant, buildAlertBackground, buildAlertBorder, buildAlertColor, buildLinkColor, buildLinkHoverColor, VARIANT_ICON, } from '../AlertBase';\r\nimport { Button, ButtonSize, ButtonVariant, ButtonColor } from '../Button';\r\nimport { IconButton } from '../IconButton';\r\nconst StyledBanner = styled.div `\n  align-items: stretch;\n  background: ${props => buildAlertBackground(props)};\n  color: ${props => buildAlertColor(props)};\n  display: flex;\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  position: relative;\n  text-align: left;\n\n  @media (max-width: ${props => props.theme.breakpoints.small}px) {\n    text-align: left;\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`;\r\nconst BannerContents = styled.div `\n  align-items: center;\n  border-bottom: 1px solid ${props => buildAlertBorder(props)};\n  display: flex;\n  flex-grow: 1;\n  justify-content: flex-start;\n  padding: ${props => props.additionalContent && props.isDismissible\r\n    ? `${props.theme.spaceScale.spacing04} 0 ${props.theme.spaceScale.spacing04} ${props.theme.spaceScale.spacing04}`\r\n    : props.theme.spaceScale.spacing04};\n\n  @media (max-width: ${props => props.theme.breakpoints.small}px) {\n    justify-content: flex-start;\n  }\n\n  a {\n    color: ${props => buildLinkColor(props)};\n    font-weight: 400;\n    font-family: ${props => props.theme.bodyFont};\n    text-decoration: underline;\n    &:not([disabled]) {\n      &:focus,\n      &:hover {\n        color: ${props => buildLinkHoverColor(props)};\n      }\n    }\n  }\n`;\r\nconst ButtonWrapper = styled.span `\n  align-items: center;\n  display: flex;\n  flex-shrink: 0;\n`;\r\nconst allowedProps = ['icon', 'isInverse', 'theme', 'variant'];\r\nconst shouldForwardProp = prop => {\r\n    return isPropValid(prop) || allowedProps.includes(prop);\r\n};\r\nfunction buildDismissButtonColor(props) {\r\n    if (props.isInverse) {\r\n        return props.theme.colors.neutral100;\r\n    }\r\n    switch (props.alertVariant) {\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\nconst DismissButton = styled(IconButton, { shouldForwardProp }) `\n  align-self: stretch;\n  border-radius: 0;\n  color: ${props => buildDismissButtonColor(props)};\n  height: auto;\n  padding: 0 ${props => props.theme.spaceScale.spacing05};\n  width: auto;\n  border-bottom: 1px solid\n    ${props => buildAlertBorder({\r\n    variant: props.alertVariant,\r\n    theme: props.theme,\r\n    isInverse: props.isInverse,\r\n})};\n\n  &:not(:disabled) {\n    &:hover {\n      background: none;\n      color: ${props => buildDismissButtonColor(props)};\n    }\n    &:focus {\n      background: none;\n      color: ${props => buildDismissButtonColor(props)};\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    &:active {\n      background: none;\n      color: ${props => buildDismissButtonColor(props)};\n    }\n  }\n`;\r\nconst IconWrapper = styled.span `\n  display: inline-flex;\n  padding-right: ${props => props.theme.spaceScale.spacing03};\n\n  @media (max-width: ${props => props.theme.breakpoints.small}px) {\n    svg {\n      width: 20px;\n    }\n  }\n`;\r\nfunction renderIcon(variant = 'info', theme) {\r\n    const Icon = VARIANT_ICON[variant];\r\n    return (React.createElement(IconWrapper, { theme: theme },\r\n        React.createElement(Icon, { size: theme.iconSizes.medium })));\r\n}\r\nfunction getButtonColor(variant) {\r\n    switch (variant) {\r\n        case 'danger':\r\n            return ButtonColor.danger;\r\n        default:\r\n            return ButtonColor.primary;\r\n    }\r\n}\r\nexport const Banner = React.forwardRef((props, ref) => {\r\n    const { actionButtonText, actionButtonOnClick, additionalContent, children, closeAriaLabel, isDismissible, onDismiss, testId, variant = AlertVariant.info, ...other } = props;\r\n    const theme = React.useContext(ThemeContext);\r\n    const i18n = React.useContext(I18nContext);\r\n    const isInverse = useIsInverse(props.isInverse);\r\n    return (React.createElement(StyledBanner, Object.assign({}, other, { \"data-testid\": testId, ref: ref, theme: theme, variant: variant }),\r\n        React.createElement(BannerContents, { additionalContent: additionalContent, isDismissible: isDismissible, theme: theme, variant: variant, isInverse: isInverse },\r\n            renderIcon(variant, theme),\r\n            React.createElement(\"span\", null, children),\r\n            actionButtonText && actionButtonOnClick && (React.createElement(Button, { color: getButtonColor(variant), isInverse: isInverse, onClick: actionButtonOnClick, style: { margin: `0 0 0 ${theme.spaceScale.spacing08}` }, size: ButtonSize.small }, actionButtonText)),\r\n            additionalContent && (React.createElement(AdditionalContentWrapper, { theme: theme }, additionalContent))),\r\n        isDismissible && (React.createElement(ButtonWrapper, { color: variant },\r\n            React.createElement(DismissButton, { alertVariant: variant, \"aria-label\": closeAriaLabel ? closeAriaLabel : i18n.alert.dismissAriaLabel, icon: React.createElement(CloseIcon, { size: theme.iconSizes.small }), isInverse: isInverse, onClick: onDismiss, theme: theme, variant: ButtonVariant.link })))));\r\n});\r\n//# sourceMappingURL=index.js.map"]} */"));
4272
+ }, ";}" + (process.env.NODE_ENV === "production" ? "" : "/*# sourceMappingURL=data:application/json;charset=utf-8;base64,{"version":3,"sources":["index.tsx"],"names":[],"mappings":"AAUgC","file":"index.tsx","sourcesContent":["import * as React from 'react';\r\nimport isPropValid from '@emotion/is-prop-valid';\r\nimport styled from '@emotion/styled';\r\nimport { CloseIcon } from 'react-magma-icons';\r\nimport { I18nContext } from '../../i18n';\r\nimport { useIsInverse } from '../../inverse';\r\nimport { ThemeContext } from '../../theme/ThemeContext';\r\nimport { AdditionalContentWrapper, AlertVariant, buildAlertBackground, buildAlertBorder, buildAlertColor, buildLinkColor, buildLinkHoverColor, VARIANT_ICON, } from '../AlertBase';\r\nimport { Button, ButtonSize, ButtonVariant, ButtonColor } from '../Button';\r\nimport { IconButton } from '../IconButton';\r\nconst StyledBanner = styled.div `\n  align-items: stretch;\n  background: ${props => buildAlertBackground(props)};\n  color: ${props => buildAlertColor(props)};\n  display: flex;\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  position: relative;\n  text-align: left;\n\n  @media (max-width: ${props => props.theme.breakpoints.small}px) {\n    text-align: left;\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`;\r\nconst BannerContents = styled.div `\n  align-items: center;\n  border-bottom: 1px solid ${props => buildAlertBorder(props)};\n  display: flex;\n  flex-grow: 1;\n  justify-content: flex-start;\n  padding: ${props => props.additionalContent && props.isDismissible\r\n    ? `${props.theme.spaceScale.spacing04} 0 ${props.theme.spaceScale.spacing04} ${props.theme.spaceScale.spacing04}`\r\n    : props.theme.spaceScale.spacing04};\n\n  @media (max-width: ${props => props.theme.breakpoints.small}px) {\n    justify-content: flex-start;\n  }\n\n  a {\n    color: ${props => buildLinkColor(props)};\n    font-weight: 400;\n    font-family: ${props => props.theme.bodyFont};\n    text-decoration: underline;\n    &:not([disabled]) {\n      &:focus,\n      &:hover {\n        color: ${props => buildLinkHoverColor(props)};\n      }\n    }\n  }\n`;\r\nconst ButtonWrapper = styled.span `\n  align-items: center;\n  display: flex;\n  flex-shrink: 0;\n`;\r\nconst allowedProps = ['icon', 'isInverse', 'theme', 'variant'];\r\nconst shouldForwardProp = prop => {\r\n    return isPropValid(prop) || allowedProps.includes(prop);\r\n};\r\nfunction buildDismissButtonColor(props) {\r\n    if (props.isInverse) {\r\n        return props.theme.colors.neutral100;\r\n    }\r\n    switch (props.alertVariant) {\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\nconst DismissButton = styled(IconButton, { shouldForwardProp }) `\n  align-self: stretch;\n  border-radius: 0;\n  color: ${props => buildDismissButtonColor(props)};\n  height: auto;\n  padding: 0 ${props => props.theme.spaceScale.spacing05};\n  width: auto;\n  border-bottom: 1px solid\n    ${props => buildAlertBorder({\r\n    variant: props.alertVariant,\r\n    theme: props.theme,\r\n    isInverse: props.isInverse,\r\n})};\n\n  &:not(:disabled) {\n    &:hover {\n      background: none;\n      color: ${props => buildDismissButtonColor(props)};\n    }\n    &:focus {\n      background: none;\n      color: ${props => buildDismissButtonColor(props)};\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    &:active {\n      background: none;\n      color: ${props => buildDismissButtonColor(props)};\n    }\n  }\n`;\r\nconst IconWrapper = styled.span `\n  display: inline-flex;\n  padding-right: ${props => props.theme.spaceScale.spacing03};\n\n  @media (max-width: ${props => props.theme.breakpoints.small}px) {\n    svg {\n      width: 20px;\n    }\n  }\n`;\r\nfunction renderIcon(variant = 'info', theme) {\r\n    const Icon = VARIANT_ICON[variant];\r\n    return (React.createElement(IconWrapper, { theme: theme },\r\n        React.createElement(Icon, { size: theme.iconSizes.medium })));\r\n}\r\nfunction getButtonColor(variant) {\r\n    switch (variant) {\r\n        case 'danger':\r\n            return ButtonColor.danger;\r\n        default:\r\n            return ButtonColor.primary;\r\n    }\r\n}\r\nexport const Banner = React.forwardRef((props, ref) => {\r\n    const { actionButtonText, actionButtonOnClick, additionalContent, children, closeAriaLabel, isDismissible, onDismiss, testId, variant = AlertVariant.info, dismissibleButtonRef, ...other } = props;\r\n    const theme = React.useContext(ThemeContext);\r\n    const i18n = React.useContext(I18nContext);\r\n    const isInverse = useIsInverse(props.isInverse);\r\n    return (React.createElement(StyledBanner, Object.assign({}, other, { \"data-testid\": testId, ref: ref, theme: theme, variant: variant }),\r\n        React.createElement(BannerContents, { additionalContent: additionalContent, isDismissible: isDismissible, theme: theme, variant: variant, isInverse: isInverse },\r\n            renderIcon(variant, theme),\r\n            React.createElement(\"span\", null, children),\r\n            actionButtonText && actionButtonOnClick && (React.createElement(Button, { color: getButtonColor(variant), isInverse: isInverse, onClick: actionButtonOnClick, style: { margin: `0 0 0 ${theme.spaceScale.spacing08}` }, size: ButtonSize.small }, actionButtonText)),\r\n            additionalContent && (React.createElement(AdditionalContentWrapper, { theme: theme }, additionalContent))),\r\n        isDismissible && (React.createElement(ButtonWrapper, { color: variant },\r\n            React.createElement(DismissButton, { alertVariant: variant, \"aria-label\": closeAriaLabel ? closeAriaLabel : i18n.alert.dismissAriaLabel, icon: React.createElement(CloseIcon, { size: theme.iconSizes.small }), isInverse: isInverse, onClick: onDismiss, theme: theme, variant: ButtonVariant.link, ref: dismissibleButtonRef })))));\r\n});\r\n//# sourceMappingURL=index.js.map"]} */"));
4273
4273
  var BannerContents = /*#__PURE__*/_styled("div", {
4274
4274
  target: "e1b9nb1m3",
4275
4275
  label: "BannerContents"
@@ -4285,7 +4285,7 @@ var BannerContents = /*#__PURE__*/_styled("div", {
4285
4285
  return props.theme.bodyFont;
4286
4286
  }, ";text-decoration:underline;&:not([disabled]){&:focus,&:hover{color:", function (props) {
4287
4287
  return buildLinkHoverColor(props);
4288
- }, ";}}}" + (process.env.NODE_ENV === "production" ? "" : "/*# sourceMappingURL=data:application/json;charset=utf-8;base64,{"version":3,"sources":["index.tsx"],"names":[],"mappings":"AA4BkC","file":"index.tsx","sourcesContent":["import * as React from 'react';\r\nimport isPropValid from '@emotion/is-prop-valid';\r\nimport styled from '@emotion/styled';\r\nimport { CloseIcon } from 'react-magma-icons';\r\nimport { I18nContext } from '../../i18n';\r\nimport { useIsInverse } from '../../inverse';\r\nimport { ThemeContext } from '../../theme/ThemeContext';\r\nimport { AdditionalContentWrapper, AlertVariant, buildAlertBackground, buildAlertBorder, buildAlertColor, buildLinkColor, buildLinkHoverColor, VARIANT_ICON, } from '../AlertBase';\r\nimport { Button, ButtonSize, ButtonVariant, ButtonColor } from '../Button';\r\nimport { IconButton } from '../IconButton';\r\nconst StyledBanner = styled.div `\n  align-items: stretch;\n  background: ${props => buildAlertBackground(props)};\n  color: ${props => buildAlertColor(props)};\n  display: flex;\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  position: relative;\n  text-align: left;\n\n  @media (max-width: ${props => props.theme.breakpoints.small}px) {\n    text-align: left;\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`;\r\nconst BannerContents = styled.div `\n  align-items: center;\n  border-bottom: 1px solid ${props => buildAlertBorder(props)};\n  display: flex;\n  flex-grow: 1;\n  justify-content: flex-start;\n  padding: ${props => props.additionalContent && props.isDismissible\r\n    ? `${props.theme.spaceScale.spacing04} 0 ${props.theme.spaceScale.spacing04} ${props.theme.spaceScale.spacing04}`\r\n    : props.theme.spaceScale.spacing04};\n\n  @media (max-width: ${props => props.theme.breakpoints.small}px) {\n    justify-content: flex-start;\n  }\n\n  a {\n    color: ${props => buildLinkColor(props)};\n    font-weight: 400;\n    font-family: ${props => props.theme.bodyFont};\n    text-decoration: underline;\n    &:not([disabled]) {\n      &:focus,\n      &:hover {\n        color: ${props => buildLinkHoverColor(props)};\n      }\n    }\n  }\n`;\r\nconst ButtonWrapper = styled.span `\n  align-items: center;\n  display: flex;\n  flex-shrink: 0;\n`;\r\nconst allowedProps = ['icon', 'isInverse', 'theme', 'variant'];\r\nconst shouldForwardProp = prop => {\r\n    return isPropValid(prop) || allowedProps.includes(prop);\r\n};\r\nfunction buildDismissButtonColor(props) {\r\n    if (props.isInverse) {\r\n        return props.theme.colors.neutral100;\r\n    }\r\n    switch (props.alertVariant) {\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\nconst DismissButton = styled(IconButton, { shouldForwardProp }) `\n  align-self: stretch;\n  border-radius: 0;\n  color: ${props => buildDismissButtonColor(props)};\n  height: auto;\n  padding: 0 ${props => props.theme.spaceScale.spacing05};\n  width: auto;\n  border-bottom: 1px solid\n    ${props => buildAlertBorder({\r\n    variant: props.alertVariant,\r\n    theme: props.theme,\r\n    isInverse: props.isInverse,\r\n})};\n\n  &:not(:disabled) {\n    &:hover {\n      background: none;\n      color: ${props => buildDismissButtonColor(props)};\n    }\n    &:focus {\n      background: none;\n      color: ${props => buildDismissButtonColor(props)};\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    &:active {\n      background: none;\n      color: ${props => buildDismissButtonColor(props)};\n    }\n  }\n`;\r\nconst IconWrapper = styled.span `\n  display: inline-flex;\n  padding-right: ${props => props.theme.spaceScale.spacing03};\n\n  @media (max-width: ${props => props.theme.breakpoints.small}px) {\n    svg {\n      width: 20px;\n    }\n  }\n`;\r\nfunction renderIcon(variant = 'info', theme) {\r\n    const Icon = VARIANT_ICON[variant];\r\n    return (React.createElement(IconWrapper, { theme: theme },\r\n        React.createElement(Icon, { size: theme.iconSizes.medium })));\r\n}\r\nfunction getButtonColor(variant) {\r\n    switch (variant) {\r\n        case 'danger':\r\n            return ButtonColor.danger;\r\n        default:\r\n            return ButtonColor.primary;\r\n    }\r\n}\r\nexport const Banner = React.forwardRef((props, ref) => {\r\n    const { actionButtonText, actionButtonOnClick, additionalContent, children, closeAriaLabel, isDismissible, onDismiss, testId, variant = AlertVariant.info, ...other } = props;\r\n    const theme = React.useContext(ThemeContext);\r\n    const i18n = React.useContext(I18nContext);\r\n    const isInverse = useIsInverse(props.isInverse);\r\n    return (React.createElement(StyledBanner, Object.assign({}, other, { \"data-testid\": testId, ref: ref, theme: theme, variant: variant }),\r\n        React.createElement(BannerContents, { additionalContent: additionalContent, isDismissible: isDismissible, theme: theme, variant: variant, isInverse: isInverse },\r\n            renderIcon(variant, theme),\r\n            React.createElement(\"span\", null, children),\r\n            actionButtonText && actionButtonOnClick && (React.createElement(Button, { color: getButtonColor(variant), isInverse: isInverse, onClick: actionButtonOnClick, style: { margin: `0 0 0 ${theme.spaceScale.spacing08}` }, size: ButtonSize.small }, actionButtonText)),\r\n            additionalContent && (React.createElement(AdditionalContentWrapper, { theme: theme }, additionalContent))),\r\n        isDismissible && (React.createElement(ButtonWrapper, { color: variant },\r\n            React.createElement(DismissButton, { alertVariant: variant, \"aria-label\": closeAriaLabel ? closeAriaLabel : i18n.alert.dismissAriaLabel, icon: React.createElement(CloseIcon, { size: theme.iconSizes.small }), isInverse: isInverse, onClick: onDismiss, theme: theme, variant: ButtonVariant.link })))));\r\n});\r\n//# sourceMappingURL=index.js.map"]} */"));
4288
+ }, ";}}}" + (process.env.NODE_ENV === "production" ? "" : "/*# sourceMappingURL=data:application/json;charset=utf-8;base64,{"version":3,"sources":["index.tsx"],"names":[],"mappings":"AA4BkC","file":"index.tsx","sourcesContent":["import * as React from 'react';\r\nimport isPropValid from '@emotion/is-prop-valid';\r\nimport styled from '@emotion/styled';\r\nimport { CloseIcon } from 'react-magma-icons';\r\nimport { I18nContext } from '../../i18n';\r\nimport { useIsInverse } from '../../inverse';\r\nimport { ThemeContext } from '../../theme/ThemeContext';\r\nimport { AdditionalContentWrapper, AlertVariant, buildAlertBackground, buildAlertBorder, buildAlertColor, buildLinkColor, buildLinkHoverColor, VARIANT_ICON, } from '../AlertBase';\r\nimport { Button, ButtonSize, ButtonVariant, ButtonColor } from '../Button';\r\nimport { IconButton } from '../IconButton';\r\nconst StyledBanner = styled.div `\n  align-items: stretch;\n  background: ${props => buildAlertBackground(props)};\n  color: ${props => buildAlertColor(props)};\n  display: flex;\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  position: relative;\n  text-align: left;\n\n  @media (max-width: ${props => props.theme.breakpoints.small}px) {\n    text-align: left;\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`;\r\nconst BannerContents = styled.div `\n  align-items: center;\n  border-bottom: 1px solid ${props => buildAlertBorder(props)};\n  display: flex;\n  flex-grow: 1;\n  justify-content: flex-start;\n  padding: ${props => props.additionalContent && props.isDismissible\r\n    ? `${props.theme.spaceScale.spacing04} 0 ${props.theme.spaceScale.spacing04} ${props.theme.spaceScale.spacing04}`\r\n    : props.theme.spaceScale.spacing04};\n\n  @media (max-width: ${props => props.theme.breakpoints.small}px) {\n    justify-content: flex-start;\n  }\n\n  a {\n    color: ${props => buildLinkColor(props)};\n    font-weight: 400;\n    font-family: ${props => props.theme.bodyFont};\n    text-decoration: underline;\n    &:not([disabled]) {\n      &:focus,\n      &:hover {\n        color: ${props => buildLinkHoverColor(props)};\n      }\n    }\n  }\n`;\r\nconst ButtonWrapper = styled.span `\n  align-items: center;\n  display: flex;\n  flex-shrink: 0;\n`;\r\nconst allowedProps = ['icon', 'isInverse', 'theme', 'variant'];\r\nconst shouldForwardProp = prop => {\r\n    return isPropValid(prop) || allowedProps.includes(prop);\r\n};\r\nfunction buildDismissButtonColor(props) {\r\n    if (props.isInverse) {\r\n        return props.theme.colors.neutral100;\r\n    }\r\n    switch (props.alertVariant) {\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\nconst DismissButton = styled(IconButton, { shouldForwardProp }) `\n  align-self: stretch;\n  border-radius: 0;\n  color: ${props => buildDismissButtonColor(props)};\n  height: auto;\n  padding: 0 ${props => props.theme.spaceScale.spacing05};\n  width: auto;\n  border-bottom: 1px solid\n    ${props => buildAlertBorder({\r\n    variant: props.alertVariant,\r\n    theme: props.theme,\r\n    isInverse: props.isInverse,\r\n})};\n\n  &:not(:disabled) {\n    &:hover {\n      background: none;\n      color: ${props => buildDismissButtonColor(props)};\n    }\n    &:focus {\n      background: none;\n      color: ${props => buildDismissButtonColor(props)};\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    &:active {\n      background: none;\n      color: ${props => buildDismissButtonColor(props)};\n    }\n  }\n`;\r\nconst IconWrapper = styled.span `\n  display: inline-flex;\n  padding-right: ${props => props.theme.spaceScale.spacing03};\n\n  @media (max-width: ${props => props.theme.breakpoints.small}px) {\n    svg {\n      width: 20px;\n    }\n  }\n`;\r\nfunction renderIcon(variant = 'info', theme) {\r\n    const Icon = VARIANT_ICON[variant];\r\n    return (React.createElement(IconWrapper, { theme: theme },\r\n        React.createElement(Icon, { size: theme.iconSizes.medium })));\r\n}\r\nfunction getButtonColor(variant) {\r\n    switch (variant) {\r\n        case 'danger':\r\n            return ButtonColor.danger;\r\n        default:\r\n            return ButtonColor.primary;\r\n    }\r\n}\r\nexport const Banner = React.forwardRef((props, ref) => {\r\n    const { actionButtonText, actionButtonOnClick, additionalContent, children, closeAriaLabel, isDismissible, onDismiss, testId, variant = AlertVariant.info, dismissibleButtonRef, ...other } = props;\r\n    const theme = React.useContext(ThemeContext);\r\n    const i18n = React.useContext(I18nContext);\r\n    const isInverse = useIsInverse(props.isInverse);\r\n    return (React.createElement(StyledBanner, Object.assign({}, other, { \"data-testid\": testId, ref: ref, theme: theme, variant: variant }),\r\n        React.createElement(BannerContents, { additionalContent: additionalContent, isDismissible: isDismissible, theme: theme, variant: variant, isInverse: isInverse },\r\n            renderIcon(variant, theme),\r\n            React.createElement(\"span\", null, children),\r\n            actionButtonText && actionButtonOnClick && (React.createElement(Button, { color: getButtonColor(variant), isInverse: isInverse, onClick: actionButtonOnClick, style: { margin: `0 0 0 ${theme.spaceScale.spacing08}` }, size: ButtonSize.small }, actionButtonText)),\r\n            additionalContent && (React.createElement(AdditionalContentWrapper, { theme: theme }, additionalContent))),\r\n        isDismissible && (React.createElement(ButtonWrapper, { color: variant },\r\n            React.createElement(DismissButton, { alertVariant: variant, \"aria-label\": closeAriaLabel ? closeAriaLabel : i18n.alert.dismissAriaLabel, icon: React.createElement(CloseIcon, { size: theme.iconSizes.small }), isInverse: isInverse, onClick: onDismiss, theme: theme, variant: ButtonVariant.link, ref: dismissibleButtonRef })))));\r\n});\r\n//# sourceMappingURL=index.js.map"]} */"));
4289
4289
  var ButtonWrapper = /*#__PURE__*/_styled("span", {
4290
4290
  target: "e1b9nb1m2",
4291
4291
  label: "ButtonWrapper"
@@ -4294,7 +4294,7 @@ var ButtonWrapper = /*#__PURE__*/_styled("span", {
4294
4294
  styles: "align-items:center;display:flex;flex-shrink:0"
4295
4295
  } : {
4296
4296
  name: "1uow4sb",
4297
- styles: "align-items:center;display:flex;flex-shrink:0/*# sourceMappingURL=data:application/json;charset=utf-8;base64,{"version":3,"sources":["index.tsx"],"names":[],"mappings":"AAuDkC","file":"index.tsx","sourcesContent":["import * as React from 'react';\r\nimport isPropValid from '@emotion/is-prop-valid';\r\nimport styled from '@emotion/styled';\r\nimport { CloseIcon } from 'react-magma-icons';\r\nimport { I18nContext } from '../../i18n';\r\nimport { useIsInverse } from '../../inverse';\r\nimport { ThemeContext } from '../../theme/ThemeContext';\r\nimport { AdditionalContentWrapper, AlertVariant, buildAlertBackground, buildAlertBorder, buildAlertColor, buildLinkColor, buildLinkHoverColor, VARIANT_ICON, } from '../AlertBase';\r\nimport { Button, ButtonSize, ButtonVariant, ButtonColor } from '../Button';\r\nimport { IconButton } from '../IconButton';\r\nconst StyledBanner = styled.div `\n  align-items: stretch;\n  background: ${props => buildAlertBackground(props)};\n  color: ${props => buildAlertColor(props)};\n  display: flex;\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  position: relative;\n  text-align: left;\n\n  @media (max-width: ${props => props.theme.breakpoints.small}px) {\n    text-align: left;\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`;\r\nconst BannerContents = styled.div `\n  align-items: center;\n  border-bottom: 1px solid ${props => buildAlertBorder(props)};\n  display: flex;\n  flex-grow: 1;\n  justify-content: flex-start;\n  padding: ${props => props.additionalContent && props.isDismissible\r\n    ? `${props.theme.spaceScale.spacing04} 0 ${props.theme.spaceScale.spacing04} ${props.theme.spaceScale.spacing04}`\r\n    : props.theme.spaceScale.spacing04};\n\n  @media (max-width: ${props => props.theme.breakpoints.small}px) {\n    justify-content: flex-start;\n  }\n\n  a {\n    color: ${props => buildLinkColor(props)};\n    font-weight: 400;\n    font-family: ${props => props.theme.bodyFont};\n    text-decoration: underline;\n    &:not([disabled]) {\n      &:focus,\n      &:hover {\n        color: ${props => buildLinkHoverColor(props)};\n      }\n    }\n  }\n`;\r\nconst ButtonWrapper = styled.span `\n  align-items: center;\n  display: flex;\n  flex-shrink: 0;\n`;\r\nconst allowedProps = ['icon', 'isInverse', 'theme', 'variant'];\r\nconst shouldForwardProp = prop => {\r\n    return isPropValid(prop) || allowedProps.includes(prop);\r\n};\r\nfunction buildDismissButtonColor(props) {\r\n    if (props.isInverse) {\r\n        return props.theme.colors.neutral100;\r\n    }\r\n    switch (props.alertVariant) {\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\nconst DismissButton = styled(IconButton, { shouldForwardProp }) `\n  align-self: stretch;\n  border-radius: 0;\n  color: ${props => buildDismissButtonColor(props)};\n  height: auto;\n  padding: 0 ${props => props.theme.spaceScale.spacing05};\n  width: auto;\n  border-bottom: 1px solid\n    ${props => buildAlertBorder({\r\n    variant: props.alertVariant,\r\n    theme: props.theme,\r\n    isInverse: props.isInverse,\r\n})};\n\n  &:not(:disabled) {\n    &:hover {\n      background: none;\n      color: ${props => buildDismissButtonColor(props)};\n    }\n    &:focus {\n      background: none;\n      color: ${props => buildDismissButtonColor(props)};\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    &:active {\n      background: none;\n      color: ${props => buildDismissButtonColor(props)};\n    }\n  }\n`;\r\nconst IconWrapper = styled.span `\n  display: inline-flex;\n  padding-right: ${props => props.theme.spaceScale.spacing03};\n\n  @media (max-width: ${props => props.theme.breakpoints.small}px) {\n    svg {\n      width: 20px;\n    }\n  }\n`;\r\nfunction renderIcon(variant = 'info', theme) {\r\n    const Icon = VARIANT_ICON[variant];\r\n    return (React.createElement(IconWrapper, { theme: theme },\r\n        React.createElement(Icon, { size: theme.iconSizes.medium })));\r\n}\r\nfunction getButtonColor(variant) {\r\n    switch (variant) {\r\n        case 'danger':\r\n            return ButtonColor.danger;\r\n        default:\r\n            return ButtonColor.primary;\r\n    }\r\n}\r\nexport const Banner = React.forwardRef((props, ref) => {\r\n    const { actionButtonText, actionButtonOnClick, additionalContent, children, closeAriaLabel, isDismissible, onDismiss, testId, variant = AlertVariant.info, ...other } = props;\r\n    const theme = React.useContext(ThemeContext);\r\n    const i18n = React.useContext(I18nContext);\r\n    const isInverse = useIsInverse(props.isInverse);\r\n    return (React.createElement(StyledBanner, Object.assign({}, other, { \"data-testid\": testId, ref: ref, theme: theme, variant: variant }),\r\n        React.createElement(BannerContents, { additionalContent: additionalContent, isDismissible: isDismissible, theme: theme, variant: variant, isInverse: isInverse },\r\n            renderIcon(variant, theme),\r\n            React.createElement(\"span\", null, children),\r\n            actionButtonText && actionButtonOnClick && (React.createElement(Button, { color: getButtonColor(variant), isInverse: isInverse, onClick: actionButtonOnClick, style: { margin: `0 0 0 ${theme.spaceScale.spacing08}` }, size: ButtonSize.small }, actionButtonText)),\r\n            additionalContent && (React.createElement(AdditionalContentWrapper, { theme: theme }, additionalContent))),\r\n        isDismissible && (React.createElement(ButtonWrapper, { color: variant },\r\n            React.createElement(DismissButton, { alertVariant: variant, \"aria-label\": closeAriaLabel ? closeAriaLabel : i18n.alert.dismissAriaLabel, icon: React.createElement(CloseIcon, { size: theme.iconSizes.small }), isInverse: isInverse, onClick: onDismiss, theme: theme, variant: ButtonVariant.link })))));\r\n});\r\n//# sourceMappingURL=index.js.map"]} */",
4297
+ styles: "align-items:center;display:flex;flex-shrink:0/*# sourceMappingURL=data:application/json;charset=utf-8;base64,{"version":3,"sources":["index.tsx"],"names":[],"mappings":"AAuDkC","file":"index.tsx","sourcesContent":["import * as React from 'react';\r\nimport isPropValid from '@emotion/is-prop-valid';\r\nimport styled from '@emotion/styled';\r\nimport { CloseIcon } from 'react-magma-icons';\r\nimport { I18nContext } from '../../i18n';\r\nimport { useIsInverse } from '../../inverse';\r\nimport { ThemeContext } from '../../theme/ThemeContext';\r\nimport { AdditionalContentWrapper, AlertVariant, buildAlertBackground, buildAlertBorder, buildAlertColor, buildLinkColor, buildLinkHoverColor, VARIANT_ICON, } from '../AlertBase';\r\nimport { Button, ButtonSize, ButtonVariant, ButtonColor } from '../Button';\r\nimport { IconButton } from '../IconButton';\r\nconst StyledBanner = styled.div `\n  align-items: stretch;\n  background: ${props => buildAlertBackground(props)};\n  color: ${props => buildAlertColor(props)};\n  display: flex;\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  position: relative;\n  text-align: left;\n\n  @media (max-width: ${props => props.theme.breakpoints.small}px) {\n    text-align: left;\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`;\r\nconst BannerContents = styled.div `\n  align-items: center;\n  border-bottom: 1px solid ${props => buildAlertBorder(props)};\n  display: flex;\n  flex-grow: 1;\n  justify-content: flex-start;\n  padding: ${props => props.additionalContent && props.isDismissible\r\n    ? `${props.theme.spaceScale.spacing04} 0 ${props.theme.spaceScale.spacing04} ${props.theme.spaceScale.spacing04}`\r\n    : props.theme.spaceScale.spacing04};\n\n  @media (max-width: ${props => props.theme.breakpoints.small}px) {\n    justify-content: flex-start;\n  }\n\n  a {\n    color: ${props => buildLinkColor(props)};\n    font-weight: 400;\n    font-family: ${props => props.theme.bodyFont};\n    text-decoration: underline;\n    &:not([disabled]) {\n      &:focus,\n      &:hover {\n        color: ${props => buildLinkHoverColor(props)};\n      }\n    }\n  }\n`;\r\nconst ButtonWrapper = styled.span `\n  align-items: center;\n  display: flex;\n  flex-shrink: 0;\n`;\r\nconst allowedProps = ['icon', 'isInverse', 'theme', 'variant'];\r\nconst shouldForwardProp = prop => {\r\n    return isPropValid(prop) || allowedProps.includes(prop);\r\n};\r\nfunction buildDismissButtonColor(props) {\r\n    if (props.isInverse) {\r\n        return props.theme.colors.neutral100;\r\n    }\r\n    switch (props.alertVariant) {\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\nconst DismissButton = styled(IconButton, { shouldForwardProp }) `\n  align-self: stretch;\n  border-radius: 0;\n  color: ${props => buildDismissButtonColor(props)};\n  height: auto;\n  padding: 0 ${props => props.theme.spaceScale.spacing05};\n  width: auto;\n  border-bottom: 1px solid\n    ${props => buildAlertBorder({\r\n    variant: props.alertVariant,\r\n    theme: props.theme,\r\n    isInverse: props.isInverse,\r\n})};\n\n  &:not(:disabled) {\n    &:hover {\n      background: none;\n      color: ${props => buildDismissButtonColor(props)};\n    }\n    &:focus {\n      background: none;\n      color: ${props => buildDismissButtonColor(props)};\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    &:active {\n      background: none;\n      color: ${props => buildDismissButtonColor(props)};\n    }\n  }\n`;\r\nconst IconWrapper = styled.span `\n  display: inline-flex;\n  padding-right: ${props => props.theme.spaceScale.spacing03};\n\n  @media (max-width: ${props => props.theme.breakpoints.small}px) {\n    svg {\n      width: 20px;\n    }\n  }\n`;\r\nfunction renderIcon(variant = 'info', theme) {\r\n    const Icon = VARIANT_ICON[variant];\r\n    return (React.createElement(IconWrapper, { theme: theme },\r\n        React.createElement(Icon, { size: theme.iconSizes.medium })));\r\n}\r\nfunction getButtonColor(variant) {\r\n    switch (variant) {\r\n        case 'danger':\r\n            return ButtonColor.danger;\r\n        default:\r\n            return ButtonColor.primary;\r\n    }\r\n}\r\nexport const Banner = React.forwardRef((props, ref) => {\r\n    const { actionButtonText, actionButtonOnClick, additionalContent, children, closeAriaLabel, isDismissible, onDismiss, testId, variant = AlertVariant.info, dismissibleButtonRef, ...other } = props;\r\n    const theme = React.useContext(ThemeContext);\r\n    const i18n = React.useContext(I18nContext);\r\n    const isInverse = useIsInverse(props.isInverse);\r\n    return (React.createElement(StyledBanner, Object.assign({}, other, { \"data-testid\": testId, ref: ref, theme: theme, variant: variant }),\r\n        React.createElement(BannerContents, { additionalContent: additionalContent, isDismissible: isDismissible, theme: theme, variant: variant, isInverse: isInverse },\r\n            renderIcon(variant, theme),\r\n            React.createElement(\"span\", null, children),\r\n            actionButtonText && actionButtonOnClick && (React.createElement(Button, { color: getButtonColor(variant), isInverse: isInverse, onClick: actionButtonOnClick, style: { margin: `0 0 0 ${theme.spaceScale.spacing08}` }, size: ButtonSize.small }, actionButtonText)),\r\n            additionalContent && (React.createElement(AdditionalContentWrapper, { theme: theme }, additionalContent))),\r\n        isDismissible && (React.createElement(ButtonWrapper, { color: variant },\r\n            React.createElement(DismissButton, { alertVariant: variant, \"aria-label\": closeAriaLabel ? closeAriaLabel : i18n.alert.dismissAriaLabel, icon: React.createElement(CloseIcon, { size: theme.iconSizes.small }), isInverse: isInverse, onClick: onDismiss, theme: theme, variant: ButtonVariant.link, ref: dismissibleButtonRef })))));\r\n});\r\n//# sourceMappingURL=index.js.map"]} */",
4298
4298
  toString: _EMOTION_STRINGIFIED_CSS_ERROR__$6
4299
4299
  });
4300
4300
  var allowedProps = ['icon', 'isInverse', 'theme', 'variant'];
@@ -4338,7 +4338,7 @@ var DismissButton$1 = /*#__PURE__*/_styled(IconButton, {
4338
4338
  return props.isInverse ? props.theme.colors.focusInverse : props.theme.colors.focus;
4339
4339
  }, ";outline-offset:0!important;}&:active{background:none;color:", function (props) {
4340
4340
  return buildDismissButtonColor(props);
4341
- }, ";}}" + (process.env.NODE_ENV === "production" ? "" : "/*# sourceMappingURL=data:application/json;charset=utf-8;base64,{"version":3,"sources":["index.tsx"],"names":[],"mappings":"AA+EgE","file":"index.tsx","sourcesContent":["import * as React from 'react';\r\nimport isPropValid from '@emotion/is-prop-valid';\r\nimport styled from '@emotion/styled';\r\nimport { CloseIcon } from 'react-magma-icons';\r\nimport { I18nContext } from '../../i18n';\r\nimport { useIsInverse } from '../../inverse';\r\nimport { ThemeContext } from '../../theme/ThemeContext';\r\nimport { AdditionalContentWrapper, AlertVariant, buildAlertBackground, buildAlertBorder, buildAlertColor, buildLinkColor, buildLinkHoverColor, VARIANT_ICON, } from '../AlertBase';\r\nimport { Button, ButtonSize, ButtonVariant, ButtonColor } from '../Button';\r\nimport { IconButton } from '../IconButton';\r\nconst StyledBanner = styled.div `\n  align-items: stretch;\n  background: ${props => buildAlertBackground(props)};\n  color: ${props => buildAlertColor(props)};\n  display: flex;\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  position: relative;\n  text-align: left;\n\n  @media (max-width: ${props => props.theme.breakpoints.small}px) {\n    text-align: left;\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`;\r\nconst BannerContents = styled.div `\n  align-items: center;\n  border-bottom: 1px solid ${props => buildAlertBorder(props)};\n  display: flex;\n  flex-grow: 1;\n  justify-content: flex-start;\n  padding: ${props => props.additionalContent && props.isDismissible\r\n    ? `${props.theme.spaceScale.spacing04} 0 ${props.theme.spaceScale.spacing04} ${props.theme.spaceScale.spacing04}`\r\n    : props.theme.spaceScale.spacing04};\n\n  @media (max-width: ${props => props.theme.breakpoints.small}px) {\n    justify-content: flex-start;\n  }\n\n  a {\n    color: ${props => buildLinkColor(props)};\n    font-weight: 400;\n    font-family: ${props => props.theme.bodyFont};\n    text-decoration: underline;\n    &:not([disabled]) {\n      &:focus,\n      &:hover {\n        color: ${props => buildLinkHoverColor(props)};\n      }\n    }\n  }\n`;\r\nconst ButtonWrapper = styled.span `\n  align-items: center;\n  display: flex;\n  flex-shrink: 0;\n`;\r\nconst allowedProps = ['icon', 'isInverse', 'theme', 'variant'];\r\nconst shouldForwardProp = prop => {\r\n    return isPropValid(prop) || allowedProps.includes(prop);\r\n};\r\nfunction buildDismissButtonColor(props) {\r\n    if (props.isInverse) {\r\n        return props.theme.colors.neutral100;\r\n    }\r\n    switch (props.alertVariant) {\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\nconst DismissButton = styled(IconButton, { shouldForwardProp }) `\n  align-self: stretch;\n  border-radius: 0;\n  color: ${props => buildDismissButtonColor(props)};\n  height: auto;\n  padding: 0 ${props => props.theme.spaceScale.spacing05};\n  width: auto;\n  border-bottom: 1px solid\n    ${props => buildAlertBorder({\r\n    variant: props.alertVariant,\r\n    theme: props.theme,\r\n    isInverse: props.isInverse,\r\n})};\n\n  &:not(:disabled) {\n    &:hover {\n      background: none;\n      color: ${props => buildDismissButtonColor(props)};\n    }\n    &:focus {\n      background: none;\n      color: ${props => buildDismissButtonColor(props)};\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    &:active {\n      background: none;\n      color: ${props => buildDismissButtonColor(props)};\n    }\n  }\n`;\r\nconst IconWrapper = styled.span `\n  display: inline-flex;\n  padding-right: ${props => props.theme.spaceScale.spacing03};\n\n  @media (max-width: ${props => props.theme.breakpoints.small}px) {\n    svg {\n      width: 20px;\n    }\n  }\n`;\r\nfunction renderIcon(variant = 'info', theme) {\r\n    const Icon = VARIANT_ICON[variant];\r\n    return (React.createElement(IconWrapper, { theme: theme },\r\n        React.createElement(Icon, { size: theme.iconSizes.medium })));\r\n}\r\nfunction getButtonColor(variant) {\r\n    switch (variant) {\r\n        case 'danger':\r\n            return ButtonColor.danger;\r\n        default:\r\n            return ButtonColor.primary;\r\n    }\r\n}\r\nexport const Banner = React.forwardRef((props, ref) => {\r\n    const { actionButtonText, actionButtonOnClick, additionalContent, children, closeAriaLabel, isDismissible, onDismiss, testId, variant = AlertVariant.info, ...other } = props;\r\n    const theme = React.useContext(ThemeContext);\r\n    const i18n = React.useContext(I18nContext);\r\n    const isInverse = useIsInverse(props.isInverse);\r\n    return (React.createElement(StyledBanner, Object.assign({}, other, { \"data-testid\": testId, ref: ref, theme: theme, variant: variant }),\r\n        React.createElement(BannerContents, { additionalContent: additionalContent, isDismissible: isDismissible, theme: theme, variant: variant, isInverse: isInverse },\r\n            renderIcon(variant, theme),\r\n            React.createElement(\"span\", null, children),\r\n            actionButtonText && actionButtonOnClick && (React.createElement(Button, { color: getButtonColor(variant), isInverse: isInverse, onClick: actionButtonOnClick, style: { margin: `0 0 0 ${theme.spaceScale.spacing08}` }, size: ButtonSize.small }, actionButtonText)),\r\n            additionalContent && (React.createElement(AdditionalContentWrapper, { theme: theme }, additionalContent))),\r\n        isDismissible && (React.createElement(ButtonWrapper, { color: variant },\r\n            React.createElement(DismissButton, { alertVariant: variant, \"aria-label\": closeAriaLabel ? closeAriaLabel : i18n.alert.dismissAriaLabel, icon: React.createElement(CloseIcon, { size: theme.iconSizes.small }), isInverse: isInverse, onClick: onDismiss, theme: theme, variant: ButtonVariant.link })))));\r\n});\r\n//# sourceMappingURL=index.js.map"]} */"));
4341
+ }, ";}}" + (process.env.NODE_ENV === "production" ? "" : "/*# sourceMappingURL=data:application/json;charset=utf-8;base64,{"version":3,"sources":["index.tsx"],"names":[],"mappings":"AA+EgE","file":"index.tsx","sourcesContent":["import * as React from 'react';\r\nimport isPropValid from '@emotion/is-prop-valid';\r\nimport styled from '@emotion/styled';\r\nimport { CloseIcon } from 'react-magma-icons';\r\nimport { I18nContext } from '../../i18n';\r\nimport { useIsInverse } from '../../inverse';\r\nimport { ThemeContext } from '../../theme/ThemeContext';\r\nimport { AdditionalContentWrapper, AlertVariant, buildAlertBackground, buildAlertBorder, buildAlertColor, buildLinkColor, buildLinkHoverColor, VARIANT_ICON, } from '../AlertBase';\r\nimport { Button, ButtonSize, ButtonVariant, ButtonColor } from '../Button';\r\nimport { IconButton } from '../IconButton';\r\nconst StyledBanner = styled.div `\n  align-items: stretch;\n  background: ${props => buildAlertBackground(props)};\n  color: ${props => buildAlertColor(props)};\n  display: flex;\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  position: relative;\n  text-align: left;\n\n  @media (max-width: ${props => props.theme.breakpoints.small}px) {\n    text-align: left;\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`;\r\nconst BannerContents = styled.div `\n  align-items: center;\n  border-bottom: 1px solid ${props => buildAlertBorder(props)};\n  display: flex;\n  flex-grow: 1;\n  justify-content: flex-start;\n  padding: ${props => props.additionalContent && props.isDismissible\r\n    ? `${props.theme.spaceScale.spacing04} 0 ${props.theme.spaceScale.spacing04} ${props.theme.spaceScale.spacing04}`\r\n    : props.theme.spaceScale.spacing04};\n\n  @media (max-width: ${props => props.theme.breakpoints.small}px) {\n    justify-content: flex-start;\n  }\n\n  a {\n    color: ${props => buildLinkColor(props)};\n    font-weight: 400;\n    font-family: ${props => props.theme.bodyFont};\n    text-decoration: underline;\n    &:not([disabled]) {\n      &:focus,\n      &:hover {\n        color: ${props => buildLinkHoverColor(props)};\n      }\n    }\n  }\n`;\r\nconst ButtonWrapper = styled.span `\n  align-items: center;\n  display: flex;\n  flex-shrink: 0;\n`;\r\nconst allowedProps = ['icon', 'isInverse', 'theme', 'variant'];\r\nconst shouldForwardProp = prop => {\r\n    return isPropValid(prop) || allowedProps.includes(prop);\r\n};\r\nfunction buildDismissButtonColor(props) {\r\n    if (props.isInverse) {\r\n        return props.theme.colors.neutral100;\r\n    }\r\n    switch (props.alertVariant) {\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\nconst DismissButton = styled(IconButton, { shouldForwardProp }) `\n  align-self: stretch;\n  border-radius: 0;\n  color: ${props => buildDismissButtonColor(props)};\n  height: auto;\n  padding: 0 ${props => props.theme.spaceScale.spacing05};\n  width: auto;\n  border-bottom: 1px solid\n    ${props => buildAlertBorder({\r\n    variant: props.alertVariant,\r\n    theme: props.theme,\r\n    isInverse: props.isInverse,\r\n})};\n\n  &:not(:disabled) {\n    &:hover {\n      background: none;\n      color: ${props => buildDismissButtonColor(props)};\n    }\n    &:focus {\n      background: none;\n      color: ${props => buildDismissButtonColor(props)};\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    &:active {\n      background: none;\n      color: ${props => buildDismissButtonColor(props)};\n    }\n  }\n`;\r\nconst IconWrapper = styled.span `\n  display: inline-flex;\n  padding-right: ${props => props.theme.spaceScale.spacing03};\n\n  @media (max-width: ${props => props.theme.breakpoints.small}px) {\n    svg {\n      width: 20px;\n    }\n  }\n`;\r\nfunction renderIcon(variant = 'info', theme) {\r\n    const Icon = VARIANT_ICON[variant];\r\n    return (React.createElement(IconWrapper, { theme: theme },\r\n        React.createElement(Icon, { size: theme.iconSizes.medium })));\r\n}\r\nfunction getButtonColor(variant) {\r\n    switch (variant) {\r\n        case 'danger':\r\n            return ButtonColor.danger;\r\n        default:\r\n            return ButtonColor.primary;\r\n    }\r\n}\r\nexport const Banner = React.forwardRef((props, ref) => {\r\n    const { actionButtonText, actionButtonOnClick, additionalContent, children, closeAriaLabel, isDismissible, onDismiss, testId, variant = AlertVariant.info, dismissibleButtonRef, ...other } = props;\r\n    const theme = React.useContext(ThemeContext);\r\n    const i18n = React.useContext(I18nContext);\r\n    const isInverse = useIsInverse(props.isInverse);\r\n    return (React.createElement(StyledBanner, Object.assign({}, other, { \"data-testid\": testId, ref: ref, theme: theme, variant: variant }),\r\n        React.createElement(BannerContents, { additionalContent: additionalContent, isDismissible: isDismissible, theme: theme, variant: variant, isInverse: isInverse },\r\n            renderIcon(variant, theme),\r\n            React.createElement(\"span\", null, children),\r\n            actionButtonText && actionButtonOnClick && (React.createElement(Button, { color: getButtonColor(variant), isInverse: isInverse, onClick: actionButtonOnClick, style: { margin: `0 0 0 ${theme.spaceScale.spacing08}` }, size: ButtonSize.small }, actionButtonText)),\r\n            additionalContent && (React.createElement(AdditionalContentWrapper, { theme: theme }, additionalContent))),\r\n        isDismissible && (React.createElement(ButtonWrapper, { color: variant },\r\n            React.createElement(DismissButton, { alertVariant: variant, \"aria-label\": closeAriaLabel ? closeAriaLabel : i18n.alert.dismissAriaLabel, icon: React.createElement(CloseIcon, { size: theme.iconSizes.small }), isInverse: isInverse, onClick: onDismiss, theme: theme, variant: ButtonVariant.link, ref: dismissibleButtonRef })))));\r\n});\r\n//# sourceMappingURL=index.js.map"]} */"));
4342
4342
  var IconWrapper$1 = /*#__PURE__*/_styled("span", {
4343
4343
  target: "e1b9nb1m0",
4344
4344
  label: "IconWrapper"
@@ -4346,7 +4346,7 @@ var IconWrapper$1 = /*#__PURE__*/_styled("span", {
4346
4346
  return props.theme.spaceScale.spacing03;
4347
4347
  }, ";@media (max-width: ", function (props) {
4348
4348
  return props.theme.breakpoints.small;
4349
- }, "px){svg{width:20px;}}" + (process.env.NODE_ENV === "production" ? "" : "/*# sourceMappingURL=data:application/json;charset=utf-8;base64,{"version":3,"sources":["index.tsx"],"names":[],"mappings":"AAiHgC","file":"index.tsx","sourcesContent":["import * as React from 'react';\r\nimport isPropValid from '@emotion/is-prop-valid';\r\nimport styled from '@emotion/styled';\r\nimport { CloseIcon } from 'react-magma-icons';\r\nimport { I18nContext } from '../../i18n';\r\nimport { useIsInverse } from '../../inverse';\r\nimport { ThemeContext } from '../../theme/ThemeContext';\r\nimport { AdditionalContentWrapper, AlertVariant, buildAlertBackground, buildAlertBorder, buildAlertColor, buildLinkColor, buildLinkHoverColor, VARIANT_ICON, } from '../AlertBase';\r\nimport { Button, ButtonSize, ButtonVariant, ButtonColor } from '../Button';\r\nimport { IconButton } from '../IconButton';\r\nconst StyledBanner = styled.div `\n  align-items: stretch;\n  background: ${props => buildAlertBackground(props)};\n  color: ${props => buildAlertColor(props)};\n  display: flex;\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  position: relative;\n  text-align: left;\n\n  @media (max-width: ${props => props.theme.breakpoints.small}px) {\n    text-align: left;\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`;\r\nconst BannerContents = styled.div `\n  align-items: center;\n  border-bottom: 1px solid ${props => buildAlertBorder(props)};\n  display: flex;\n  flex-grow: 1;\n  justify-content: flex-start;\n  padding: ${props => props.additionalContent && props.isDismissible\r\n    ? `${props.theme.spaceScale.spacing04} 0 ${props.theme.spaceScale.spacing04} ${props.theme.spaceScale.spacing04}`\r\n    : props.theme.spaceScale.spacing04};\n\n  @media (max-width: ${props => props.theme.breakpoints.small}px) {\n    justify-content: flex-start;\n  }\n\n  a {\n    color: ${props => buildLinkColor(props)};\n    font-weight: 400;\n    font-family: ${props => props.theme.bodyFont};\n    text-decoration: underline;\n    &:not([disabled]) {\n      &:focus,\n      &:hover {\n        color: ${props => buildLinkHoverColor(props)};\n      }\n    }\n  }\n`;\r\nconst ButtonWrapper = styled.span `\n  align-items: center;\n  display: flex;\n  flex-shrink: 0;\n`;\r\nconst allowedProps = ['icon', 'isInverse', 'theme', 'variant'];\r\nconst shouldForwardProp = prop => {\r\n    return isPropValid(prop) || allowedProps.includes(prop);\r\n};\r\nfunction buildDismissButtonColor(props) {\r\n    if (props.isInverse) {\r\n        return props.theme.colors.neutral100;\r\n    }\r\n    switch (props.alertVariant) {\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\nconst DismissButton = styled(IconButton, { shouldForwardProp }) `\n  align-self: stretch;\n  border-radius: 0;\n  color: ${props => buildDismissButtonColor(props)};\n  height: auto;\n  padding: 0 ${props => props.theme.spaceScale.spacing05};\n  width: auto;\n  border-bottom: 1px solid\n    ${props => buildAlertBorder({\r\n    variant: props.alertVariant,\r\n    theme: props.theme,\r\n    isInverse: props.isInverse,\r\n})};\n\n  &:not(:disabled) {\n    &:hover {\n      background: none;\n      color: ${props => buildDismissButtonColor(props)};\n    }\n    &:focus {\n      background: none;\n      color: ${props => buildDismissButtonColor(props)};\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    &:active {\n      background: none;\n      color: ${props => buildDismissButtonColor(props)};\n    }\n  }\n`;\r\nconst IconWrapper = styled.span `\n  display: inline-flex;\n  padding-right: ${props => props.theme.spaceScale.spacing03};\n\n  @media (max-width: ${props => props.theme.breakpoints.small}px) {\n    svg {\n      width: 20px;\n    }\n  }\n`;\r\nfunction renderIcon(variant = 'info', theme) {\r\n    const Icon = VARIANT_ICON[variant];\r\n    return (React.createElement(IconWrapper, { theme: theme },\r\n        React.createElement(Icon, { size: theme.iconSizes.medium })));\r\n}\r\nfunction getButtonColor(variant) {\r\n    switch (variant) {\r\n        case 'danger':\r\n            return ButtonColor.danger;\r\n        default:\r\n            return ButtonColor.primary;\r\n    }\r\n}\r\nexport const Banner = React.forwardRef((props, ref) => {\r\n    const { actionButtonText, actionButtonOnClick, additionalContent, children, closeAriaLabel, isDismissible, onDismiss, testId, variant = AlertVariant.info, ...other } = props;\r\n    const theme = React.useContext(ThemeContext);\r\n    const i18n = React.useContext(I18nContext);\r\n    const isInverse = useIsInverse(props.isInverse);\r\n    return (React.createElement(StyledBanner, Object.assign({}, other, { \"data-testid\": testId, ref: ref, theme: theme, variant: variant }),\r\n        React.createElement(BannerContents, { additionalContent: additionalContent, isDismissible: isDismissible, theme: theme, variant: variant, isInverse: isInverse },\r\n            renderIcon(variant, theme),\r\n            React.createElement(\"span\", null, children),\r\n            actionButtonText && actionButtonOnClick && (React.createElement(Button, { color: getButtonColor(variant), isInverse: isInverse, onClick: actionButtonOnClick, style: { margin: `0 0 0 ${theme.spaceScale.spacing08}` }, size: ButtonSize.small }, actionButtonText)),\r\n            additionalContent && (React.createElement(AdditionalContentWrapper, { theme: theme }, additionalContent))),\r\n        isDismissible && (React.createElement(ButtonWrapper, { color: variant },\r\n            React.createElement(DismissButton, { alertVariant: variant, \"aria-label\": closeAriaLabel ? closeAriaLabel : i18n.alert.dismissAriaLabel, icon: React.createElement(CloseIcon, { size: theme.iconSizes.small }), isInverse: isInverse, onClick: onDismiss, theme: theme, variant: ButtonVariant.link })))));\r\n});\r\n//# sourceMappingURL=index.js.map"]} */"));
4349
+ }, "px){svg{width:20px;}}" + (process.env.NODE_ENV === "production" ? "" : "/*# sourceMappingURL=data:application/json;charset=utf-8;base64,{"version":3,"sources":["index.tsx"],"names":[],"mappings":"AAiHgC","file":"index.tsx","sourcesContent":["import * as React from 'react';\r\nimport isPropValid from '@emotion/is-prop-valid';\r\nimport styled from '@emotion/styled';\r\nimport { CloseIcon } from 'react-magma-icons';\r\nimport { I18nContext } from '../../i18n';\r\nimport { useIsInverse } from '../../inverse';\r\nimport { ThemeContext } from '../../theme/ThemeContext';\r\nimport { AdditionalContentWrapper, AlertVariant, buildAlertBackground, buildAlertBorder, buildAlertColor, buildLinkColor, buildLinkHoverColor, VARIANT_ICON, } from '../AlertBase';\r\nimport { Button, ButtonSize, ButtonVariant, ButtonColor } from '../Button';\r\nimport { IconButton } from '../IconButton';\r\nconst StyledBanner = styled.div `\n  align-items: stretch;\n  background: ${props => buildAlertBackground(props)};\n  color: ${props => buildAlertColor(props)};\n  display: flex;\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  position: relative;\n  text-align: left;\n\n  @media (max-width: ${props => props.theme.breakpoints.small}px) {\n    text-align: left;\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`;\r\nconst BannerContents = styled.div `\n  align-items: center;\n  border-bottom: 1px solid ${props => buildAlertBorder(props)};\n  display: flex;\n  flex-grow: 1;\n  justify-content: flex-start;\n  padding: ${props => props.additionalContent && props.isDismissible\r\n    ? `${props.theme.spaceScale.spacing04} 0 ${props.theme.spaceScale.spacing04} ${props.theme.spaceScale.spacing04}`\r\n    : props.theme.spaceScale.spacing04};\n\n  @media (max-width: ${props => props.theme.breakpoints.small}px) {\n    justify-content: flex-start;\n  }\n\n  a {\n    color: ${props => buildLinkColor(props)};\n    font-weight: 400;\n    font-family: ${props => props.theme.bodyFont};\n    text-decoration: underline;\n    &:not([disabled]) {\n      &:focus,\n      &:hover {\n        color: ${props => buildLinkHoverColor(props)};\n      }\n    }\n  }\n`;\r\nconst ButtonWrapper = styled.span `\n  align-items: center;\n  display: flex;\n  flex-shrink: 0;\n`;\r\nconst allowedProps = ['icon', 'isInverse', 'theme', 'variant'];\r\nconst shouldForwardProp = prop => {\r\n    return isPropValid(prop) || allowedProps.includes(prop);\r\n};\r\nfunction buildDismissButtonColor(props) {\r\n    if (props.isInverse) {\r\n        return props.theme.colors.neutral100;\r\n    }\r\n    switch (props.alertVariant) {\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\nconst DismissButton = styled(IconButton, { shouldForwardProp }) `\n  align-self: stretch;\n  border-radius: 0;\n  color: ${props => buildDismissButtonColor(props)};\n  height: auto;\n  padding: 0 ${props => props.theme.spaceScale.spacing05};\n  width: auto;\n  border-bottom: 1px solid\n    ${props => buildAlertBorder({\r\n    variant: props.alertVariant,\r\n    theme: props.theme,\r\n    isInverse: props.isInverse,\r\n})};\n\n  &:not(:disabled) {\n    &:hover {\n      background: none;\n      color: ${props => buildDismissButtonColor(props)};\n    }\n    &:focus {\n      background: none;\n      color: ${props => buildDismissButtonColor(props)};\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    &:active {\n      background: none;\n      color: ${props => buildDismissButtonColor(props)};\n    }\n  }\n`;\r\nconst IconWrapper = styled.span `\n  display: inline-flex;\n  padding-right: ${props => props.theme.spaceScale.spacing03};\n\n  @media (max-width: ${props => props.theme.breakpoints.small}px) {\n    svg {\n      width: 20px;\n    }\n  }\n`;\r\nfunction renderIcon(variant = 'info', theme) {\r\n    const Icon = VARIANT_ICON[variant];\r\n    return (React.createElement(IconWrapper, { theme: theme },\r\n        React.createElement(Icon, { size: theme.iconSizes.medium })));\r\n}\r\nfunction getButtonColor(variant) {\r\n    switch (variant) {\r\n        case 'danger':\r\n            return ButtonColor.danger;\r\n        default:\r\n            return ButtonColor.primary;\r\n    }\r\n}\r\nexport const Banner = React.forwardRef((props, ref) => {\r\n    const { actionButtonText, actionButtonOnClick, additionalContent, children, closeAriaLabel, isDismissible, onDismiss, testId, variant = AlertVariant.info, dismissibleButtonRef, ...other } = props;\r\n    const theme = React.useContext(ThemeContext);\r\n    const i18n = React.useContext(I18nContext);\r\n    const isInverse = useIsInverse(props.isInverse);\r\n    return (React.createElement(StyledBanner, Object.assign({}, other, { \"data-testid\": testId, ref: ref, theme: theme, variant: variant }),\r\n        React.createElement(BannerContents, { additionalContent: additionalContent, isDismissible: isDismissible, theme: theme, variant: variant, isInverse: isInverse },\r\n            renderIcon(variant, theme),\r\n            React.createElement(\"span\", null, children),\r\n            actionButtonText && actionButtonOnClick && (React.createElement(Button, { color: getButtonColor(variant), isInverse: isInverse, onClick: actionButtonOnClick, style: { margin: `0 0 0 ${theme.spaceScale.spacing08}` }, size: ButtonSize.small }, actionButtonText)),\r\n            additionalContent && (React.createElement(AdditionalContentWrapper, { theme: theme }, additionalContent))),\r\n        isDismissible && (React.createElement(ButtonWrapper, { color: variant },\r\n            React.createElement(DismissButton, { alertVariant: variant, \"aria-label\": closeAriaLabel ? closeAriaLabel : i18n.alert.dismissAriaLabel, icon: React.createElement(CloseIcon, { size: theme.iconSizes.small }), isInverse: isInverse, onClick: onDismiss, theme: theme, variant: ButtonVariant.link, ref: dismissibleButtonRef })))));\r\n});\r\n//# sourceMappingURL=index.js.map"]} */"));
4350
4350
  function renderIcon$1(variant, theme) {
4351
4351
  if (variant === void 0) {
4352
4352
  variant = 'info';
@@ -4377,6 +4377,7 @@ var Banner = /*#__PURE__*/forwardRef(function (props, ref) {
4377
4377
  testId = props.testId,
4378
4378
  _props$variant = props.variant,
4379
4379
  variant = _props$variant === void 0 ? AlertVariant.info : _props$variant,
4380
+ dismissibleButtonRef = props.dismissibleButtonRef,
4380
4381
  other = _objectWithoutPropertiesLoose(props, _excluded$c);
4381
4382
  var theme = useContext(ThemeContext);
4382
4383
  var i18n = useContext(I18nContext);
@@ -4413,7 +4414,8 @@ var Banner = /*#__PURE__*/forwardRef(function (props, ref) {
4413
4414
  isInverse: isInverse,
4414
4415
  onClick: onDismiss,
4415
4416
  theme: theme,
4416
- variant: ButtonVariant.link
4417
+ variant: ButtonVariant.link,
4418
+ ref: dismissibleButtonRef
4417
4419
  }))));
4418
4420
  });
4419
4421