react-magma-dom 4.11.0-next.23 → 4.11.0-next.25

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
@@ -633,6 +633,15 @@ var mergeRefs = function mergeRefs() {
633
633
  });
634
634
  };
635
635
  };
636
+ function isElementInteractive(element) {
637
+ if (!element || !(element instanceof HTMLElement)) return false;
638
+ var tag = element.tagName.toLowerCase();
639
+ if (['button', 'input', 'select', 'textarea', 'a'].includes(tag) || element.hasAttribute('tabindex') && element.tabIndex >= 0) {
640
+ if (tag === 'a' && !element.href) return false;
641
+ return !element.hasAttribute('disabled');
642
+ }
643
+ return false;
644
+ }
636
645
 
637
646
  function _extends$1() {
638
647
  return _extends$1 = Object.assign ? Object.assign.bind() : function (n) {
@@ -4458,7 +4467,7 @@ var Badge = /*#__PURE__*/forwardRef(function (props, ref) {
4458
4467
  }), children);
4459
4468
  });
4460
4469
 
4461
- var _excluded$c = ["actionButtonText", "actionButtonOnClick", "additionalContent", "children", "closeAriaLabel", "isDismissible", "onDismiss", "testId", "variant"];
4470
+ var _excluded$c = ["actionButtonText", "actionButtonOnClick", "additionalContent", "children", "closeAriaLabel", "isDismissible", "onDismiss", "testId", "variant", "dismissibleButtonRef"];
4462
4471
  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)."; }
4463
4472
  var StyledBanner = /*#__PURE__*/_styled("div", {
4464
4473
  target: "e1b9nb1m4",
@@ -4481,7 +4490,7 @@ var StyledBanner = /*#__PURE__*/_styled("div", {
4481
4490
  return props.theme.typeScale.size02.letterSpacing;
4482
4491
  }, ";line-height:", function (props) {
4483
4492
  return props.theme.typeScale.size02.lineHeight;
4484
- }, ";}" + (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"]} */"));
4493
+ }, ";}" + (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"]} */"));
4485
4494
  var BannerContents = /*#__PURE__*/_styled("div", {
4486
4495
  target: "e1b9nb1m3",
4487
4496
  label: "BannerContents"
@@ -4497,7 +4506,7 @@ var BannerContents = /*#__PURE__*/_styled("div", {
4497
4506
  return props.theme.bodyFont;
4498
4507
  }, ";text-decoration:underline;&:not([disabled]){&:focus,&:hover{color:", function (props) {
4499
4508
  return buildLinkHoverColor(props);
4500
- }, ";}}}" + (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"]} */"));
4509
+ }, ";}}}" + (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"]} */"));
4501
4510
  var ButtonWrapper = /*#__PURE__*/_styled("span", {
4502
4511
  target: "e1b9nb1m2",
4503
4512
  label: "ButtonWrapper"
@@ -4506,7 +4515,7 @@ var ButtonWrapper = /*#__PURE__*/_styled("span", {
4506
4515
  styles: "align-items:center;display:flex;flex-shrink:0"
4507
4516
  } : {
4508
4517
  name: "1uow4sb",
4509
- 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"]} */",
4518
+ 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"]} */",
4510
4519
  toString: _EMOTION_STRINGIFIED_CSS_ERROR__$6
4511
4520
  });
4512
4521
  var allowedProps = ['icon', 'isInverse', 'theme', 'variant'];
@@ -4550,7 +4559,7 @@ var DismissButton$1 = /*#__PURE__*/_styled(IconButton, {
4550
4559
  return props.isInverse ? props.theme.colors.focusInverse : props.theme.colors.focus;
4551
4560
  }, ";outline-offset:0!important;}&:active{background:none;color:", function (props) {
4552
4561
  return buildDismissButtonColor(props);
4553
- }, ";}}" + (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"]} */"));
4562
+ }, ";}}" + (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"]} */"));
4554
4563
  var IconWrapper$1 = /*#__PURE__*/_styled("span", {
4555
4564
  target: "e1b9nb1m0",
4556
4565
  label: "IconWrapper"
@@ -4558,7 +4567,7 @@ var IconWrapper$1 = /*#__PURE__*/_styled("span", {
4558
4567
  return props.theme.spaceScale.spacing03;
4559
4568
  }, ";@media (max-width: ", function (props) {
4560
4569
  return props.theme.breakpoints.small;
4561
- }, "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"]} */"));
4570
+ }, "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"]} */"));
4562
4571
  function renderIcon$1(variant, theme) {
4563
4572
  if (variant === void 0) {
4564
4573
  variant = 'info';
@@ -4589,6 +4598,7 @@ var Banner = /*#__PURE__*/forwardRef(function (props, ref) {
4589
4598
  testId = props.testId,
4590
4599
  _props$variant = props.variant,
4591
4600
  variant = _props$variant === void 0 ? AlertVariant.info : _props$variant,
4601
+ dismissibleButtonRef = props.dismissibleButtonRef,
4592
4602
  other = _objectWithoutPropertiesLoose(props, _excluded$c);
4593
4603
  var theme = useContext(ThemeContext);
4594
4604
  var i18n = useContext(I18nContext);
@@ -4625,7 +4635,8 @@ var Banner = /*#__PURE__*/forwardRef(function (props, ref) {
4625
4635
  isInverse: isInverse,
4626
4636
  onClick: onDismiss,
4627
4637
  theme: theme,
4628
- variant: ButtonVariant.link
4638
+ variant: ButtonVariant.link,
4639
+ ref: dismissibleButtonRef
4629
4640
  })));
4630
4641
  });
4631
4642
 
@@ -8728,7 +8739,7 @@ var StyledContainer$2 = /*#__PURE__*/_styled("div", {
8728
8739
  styles: "display:inline-block"
8729
8740
  } : {
8730
8741
  name: "1r5gb7q",
8731
- styles: "display:inline-block/*# sourceMappingURL=data:application/json;charset=utf-8;base64,{"version":3,"sources":["Popover.tsx"],"names":[],"mappings":"AAiBmC","file":"Popover.tsx","sourcesContent":["import React from 'react';\r\nimport styled from '@emotion/styled';\r\nimport { offset, flip, autoUpdate, arrow, shift, useFloating, } from '@floating-ui/react';\r\nimport { useIsInverse } from '../../inverse';\r\nimport { resolveProps, useForkedRef, useGenerateId } from '../../utils';\r\nimport { ButtonGroupContext } from '../ButtonGroup';\r\nexport var PopoverPosition;\r\n(function (PopoverPosition) {\r\n    PopoverPosition[\"bottom\"] = \"bottom\";\r\n    PopoverPosition[\"top\"] = \"top\";\r\n})(PopoverPosition || (PopoverPosition = {}));\r\nexport var PopoverAlignment;\r\n(function (PopoverAlignment) {\r\n    PopoverAlignment[\"center\"] = \"center\";\r\n    PopoverAlignment[\"start\"] = \"start\";\r\n    PopoverAlignment[\"end\"] = \"end\";\r\n})(PopoverAlignment || (PopoverAlignment = {}));\r\nconst StyledContainer = styled.div `\n  display: inline-block;\n`;\r\nexport const PopoverContext = React.createContext({\r\n    isOpen: false,\r\n    setIsOpen: () => false,\r\n});\r\nexport function hasActiveElementsChecker(ref) {\r\n    return (Array.from(ref.current?.querySelectorAll('button, [href], input, select, textarea, [tabindex]:not([tabindex=\"-1\"]), video') || []).filter((element) => {\r\n        const style = window.getComputedStyle(element);\r\n        return (element instanceof HTMLElement &&\r\n            style.display !== 'none' &&\r\n            style.visibility !== 'hidden' &&\r\n            !element.hasAttribute('disabled'));\r\n    }).length > 0);\r\n}\r\nexport function isElementInteractive(element) {\r\n    if (!element || !(element instanceof HTMLElement))\r\n        return false;\r\n    const tag = element.tagName.toLowerCase();\r\n    if (['button', 'input', 'select', 'textarea', 'a'].includes(tag) ||\r\n        element.hasAttribute('tabindex')) {\r\n        if (tag === 'a' && !element.href)\r\n            return false;\r\n        return !element.hasAttribute('disabled');\r\n    }\r\n    return false;\r\n}\r\nexport const Popover = React.forwardRef((props, forwardedRef) => {\r\n    const [isOpen, setIsOpen] = React.useState(false);\r\n    const contextProps = React.useContext(ButtonGroupContext);\r\n    const resolvedProps = resolveProps(contextProps, props);\r\n    const ownRef = React.useRef();\r\n    const toggleRef = React.useRef();\r\n    const contentRef = React.useRef(null);\r\n    const popoverContentId = React.useRef('');\r\n    const popoverTriggerId = React.useRef('');\r\n    const arrowRef = React.useRef(null);\r\n    const hasActiveElements = React.useMemo(() => hasActiveElementsChecker(contentRef), [contentRef, contentRef.current]);\r\n    const { onClose, onOpen, position = PopoverPosition.bottom, children, testId, maxHeight, width, hoverable, isDisabled, hasPointer = true, openByDefault, id: defaultId, apiRef, focusTrap, alignment = PopoverAlignment.center, ...other } = props;\r\n    React.useEffect(() => {\r\n        if (apiRef) {\r\n            apiRef.current = {\r\n                closePopoverManually(event) {\r\n                    closePopover(event);\r\n                },\r\n                openPopoverManually(event) {\r\n                    openPopover();\r\n                },\r\n            };\r\n        }\r\n        if (openByDefault) {\r\n            openPopover();\r\n        }\r\n    }, []);\r\n    React.useEffect(() => {\r\n        const handleEsc = event => {\r\n            if (event.key === 'Escape' && isOpen) {\r\n                closePopover(event);\r\n            }\r\n        };\r\n        window.addEventListener('keydown', handleEsc);\r\n        return () => {\r\n            window.removeEventListener('keydown', handleEsc);\r\n        };\r\n    }, [isOpen]);\r\n    const popoverId = useGenerateId(defaultId);\r\n    popoverTriggerId.current = `${popoverId}_trigger`;\r\n    popoverContentId.current = `${popoverId}_content`;\r\n    const ref = useForkedRef(forwardedRef, ownRef);\r\n    const isInverse = useIsInverse(resolvedProps.isInverse);\r\n    const handleMouseOver = () => {\r\n        if (hoverable && !isDisabled && !hasActiveElements) {\r\n            setIsOpen(true);\r\n        }\r\n    };\r\n    const handleMouseLeave = () => {\r\n        if (hoverable && !isDisabled && !hasActiveElements) {\r\n            setIsOpen(false);\r\n        }\r\n    };\r\n    function openPopover() {\r\n        setIsOpen(true);\r\n        if (!hoverable) {\r\n            toggleRef.current.focus();\r\n        }\r\n        onOpen && typeof onOpen === 'function' && onOpen();\r\n    }\r\n    function closePopover(event) {\r\n        setIsOpen(false);\r\n        if (event && event.type === 'blur') {\r\n            const relatedTarget = event.relatedTarget;\r\n            if (!isElementInteractive(relatedTarget) && !hoverable) {\r\n                toggleRef.current?.focus();\r\n            }\r\n        }\r\n        onClose && typeof onClose === 'function' && onClose(event);\r\n    }\r\n    function handleKeyDown(event) {\r\n        if (event.key === 'Escape') {\r\n            if (isOpen) {\r\n                event.stopPropagation();\r\n            }\r\n            closePopover(event);\r\n            toggleRef.current?.focus();\r\n        }\r\n    }\r\n    function handlePopoverBlur(event) {\r\n        const { currentTarget, relatedTarget } = event;\r\n        const isInMenu = relatedTarget && currentTarget.contains(relatedTarget);\r\n        if (!isInMenu && isOpen) {\r\n            closePopover(event);\r\n        }\r\n    }\r\n    const placement = React.useMemo(() => {\r\n        return alignment === PopoverAlignment.center\r\n            ? position\r\n            : `${position}-${alignment}`;\r\n    }, [position, alignment]);\r\n    const { refs, floatingStyles, context, elements, update } = useFloating({\r\n        //flip() - Changes the placement of the floating element to keep it in view.\r\n        //offset() - Translates the floating element along the specified axes. (Space between the Trigger and the Content).\r\n        //shift() - Shifts the floating element along the specified axes to keep it in view within the clipping context or viewport.\r\n        //arrow() - Positions an arrow element pointing at the reference element, ensuring proper alignment.\r\n        middleware: [\r\n            flip(),\r\n            shift({ padding: 12 }),\r\n            offset(hasPointer ? 12 : 4),\r\n            arrow({ element: arrowRef }),\r\n        ],\r\n        placement: placement,\r\n        whileElementsMounted: autoUpdate,\r\n    });\r\n    React.useEffect(() => {\r\n        const referenceElement = elements.reference;\r\n        const floatingElement = elements.floating;\r\n        if (isOpen && referenceElement && floatingElement) {\r\n            return autoUpdate(referenceElement, floatingElement, update);\r\n        }\r\n    }, [isOpen, elements, update]);\r\n    const maxHeightString = typeof maxHeight === 'number' ? `${maxHeight}px` : maxHeight;\r\n    const widthString = width === 'target'\r\n        ? `${refs.reference.current?.getBoundingClientRect().width}px`\r\n        : typeof width === 'number'\r\n            ? `${width}px`\r\n            : width;\r\n    const onFocus = () => {\r\n        if (hoverable && !isDisabled && !hasActiveElements) {\r\n            openPopover();\r\n        }\r\n    };\r\n    return (React.createElement(PopoverContext.Provider, { value: {\r\n            floatingStyles,\r\n            position: placement,\r\n            closePopover,\r\n            popoverTriggerId,\r\n            popoverContentId,\r\n            openPopover,\r\n            isInverse,\r\n            isOpen,\r\n            maxHeight: maxHeightString,\r\n            width: widthString,\r\n            contentRef,\r\n            setIsOpen,\r\n            setFloating: refs.setFloating,\r\n            setReference: refs.setReference,\r\n            arrowRef,\r\n            arrowContext: context,\r\n            toggleRef,\r\n            isDisabled,\r\n            hoverable,\r\n            hasPointer,\r\n            focusTrap,\r\n            hasActiveElements,\r\n        } },\r\n        React.createElement(StyledContainer, Object.assign({}, other, { onKeyDown: handleKeyDown, onBlur: handlePopoverBlur, ref: ref, \"data-testid\": testId, onMouseOver: handleMouseOver, onMouseLeave: handleMouseLeave, id: popoverId, onFocus: onFocus }), children)));\r\n});\r\n//# sourceMappingURL=Popover.js.map"]} */",
8742
+ styles: "display:inline-block/*# sourceMappingURL=data:application/json;charset=utf-8;base64,{"version":3,"sources":["Popover.tsx"],"names":[],"mappings":"AAiBmC","file":"Popover.tsx","sourcesContent":["import React from 'react';\r\nimport styled from '@emotion/styled';\r\nimport { offset, flip, autoUpdate, arrow, shift, useFloating, } from '@floating-ui/react';\r\nimport { useIsInverse } from '../../inverse';\r\nimport { isElementInteractive, resolveProps, useForkedRef, useGenerateId, } from '../../utils';\r\nimport { ButtonGroupContext } from '../ButtonGroup';\r\nexport var PopoverPosition;\r\n(function (PopoverPosition) {\r\n    PopoverPosition[\"bottom\"] = \"bottom\";\r\n    PopoverPosition[\"top\"] = \"top\";\r\n})(PopoverPosition || (PopoverPosition = {}));\r\nexport var PopoverAlignment;\r\n(function (PopoverAlignment) {\r\n    PopoverAlignment[\"center\"] = \"center\";\r\n    PopoverAlignment[\"start\"] = \"start\";\r\n    PopoverAlignment[\"end\"] = \"end\";\r\n})(PopoverAlignment || (PopoverAlignment = {}));\r\nconst StyledContainer = styled.div `\n  display: inline-block;\n`;\r\nexport const PopoverContext = React.createContext({\r\n    isOpen: false,\r\n    setIsOpen: () => false,\r\n});\r\nexport function hasActiveElementsChecker(ref) {\r\n    return (Array.from(ref.current?.querySelectorAll('button, [href], input, select, textarea, [tabindex]:not([tabindex=\"-1\"]), video') || []).filter((element) => {\r\n        const style = window.getComputedStyle(element);\r\n        return (element instanceof HTMLElement &&\r\n            style.display !== 'none' &&\r\n            style.visibility !== 'hidden' &&\r\n            !element.hasAttribute('disabled'));\r\n    }).length > 0);\r\n}\r\nexport const Popover = React.forwardRef((props, forwardedRef) => {\r\n    const [isOpen, setIsOpen] = React.useState(false);\r\n    const contextProps = React.useContext(ButtonGroupContext);\r\n    const resolvedProps = resolveProps(contextProps, props);\r\n    const ownRef = React.useRef();\r\n    const toggleRef = React.useRef();\r\n    const contentRef = React.useRef(null);\r\n    const popoverContentId = React.useRef('');\r\n    const popoverTriggerId = React.useRef('');\r\n    const arrowRef = React.useRef(null);\r\n    const hasActiveElements = React.useMemo(() => hasActiveElementsChecker(contentRef), [contentRef, contentRef.current]);\r\n    const { onClose, onOpen, position = PopoverPosition.bottom, children, testId, maxHeight, width, hoverable, isDisabled, hasPointer = true, openByDefault, id: defaultId, apiRef, focusTrap, alignment = PopoverAlignment.center, ...other } = props;\r\n    React.useEffect(() => {\r\n        if (apiRef) {\r\n            apiRef.current = {\r\n                closePopoverManually(event) {\r\n                    closePopover(event);\r\n                },\r\n                openPopoverManually(event) {\r\n                    openPopover();\r\n                },\r\n            };\r\n        }\r\n        if (openByDefault) {\r\n            openPopover();\r\n        }\r\n    }, []);\r\n    React.useEffect(() => {\r\n        const handleEsc = event => {\r\n            if (event.key === 'Escape' && isOpen) {\r\n                closePopover(event);\r\n            }\r\n        };\r\n        window.addEventListener('keydown', handleEsc);\r\n        return () => {\r\n            window.removeEventListener('keydown', handleEsc);\r\n        };\r\n    }, [isOpen]);\r\n    const popoverId = useGenerateId(defaultId);\r\n    popoverTriggerId.current = `${popoverId}_trigger`;\r\n    popoverContentId.current = `${popoverId}_content`;\r\n    const ref = useForkedRef(forwardedRef, ownRef);\r\n    const isInverse = useIsInverse(resolvedProps.isInverse);\r\n    const handleMouseOver = () => {\r\n        if (hoverable && !isDisabled && !hasActiveElements) {\r\n            setIsOpen(true);\r\n        }\r\n    };\r\n    const handleMouseLeave = () => {\r\n        if (hoverable && !isDisabled && !hasActiveElements) {\r\n            setIsOpen(false);\r\n        }\r\n    };\r\n    function openPopover() {\r\n        setIsOpen(true);\r\n        if (!hoverable) {\r\n            toggleRef.current.focus();\r\n        }\r\n        onOpen && typeof onOpen === 'function' && onOpen();\r\n    }\r\n    function closePopover(event) {\r\n        setIsOpen(false);\r\n        if (event && event.type === 'blur') {\r\n            const relatedTarget = event.relatedTarget;\r\n            if (!isElementInteractive(relatedTarget) && !hoverable) {\r\n                toggleRef.current?.focus();\r\n            }\r\n        }\r\n        onClose && typeof onClose === 'function' && onClose(event);\r\n    }\r\n    function handleKeyDown(event) {\r\n        if (event.key === 'Escape') {\r\n            if (isOpen) {\r\n                event.stopPropagation();\r\n            }\r\n            closePopover(event);\r\n            toggleRef.current?.focus();\r\n        }\r\n    }\r\n    function handlePopoverBlur(event) {\r\n        const { currentTarget, relatedTarget } = event;\r\n        const isInMenu = relatedTarget && currentTarget.contains(relatedTarget);\r\n        if (!isInMenu && isOpen) {\r\n            closePopover(event);\r\n        }\r\n    }\r\n    const placement = React.useMemo(() => {\r\n        return alignment === PopoverAlignment.center\r\n            ? position\r\n            : `${position}-${alignment}`;\r\n    }, [position, alignment]);\r\n    const { refs, floatingStyles, context, elements, update } = useFloating({\r\n        //flip() - Changes the placement of the floating element to keep it in view.\r\n        //offset() - Translates the floating element along the specified axes. (Space between the Trigger and the Content).\r\n        //shift() - Shifts the floating element along the specified axes to keep it in view within the clipping context or viewport.\r\n        //arrow() - Positions an arrow element pointing at the reference element, ensuring proper alignment.\r\n        middleware: [\r\n            flip(),\r\n            shift({ padding: 12 }),\r\n            offset(hasPointer ? 12 : 4),\r\n            arrow({ element: arrowRef }),\r\n        ],\r\n        placement: placement,\r\n        whileElementsMounted: autoUpdate,\r\n    });\r\n    React.useEffect(() => {\r\n        const referenceElement = elements.reference;\r\n        const floatingElement = elements.floating;\r\n        if (isOpen && referenceElement && floatingElement) {\r\n            return autoUpdate(referenceElement, floatingElement, update);\r\n        }\r\n    }, [isOpen, elements, update]);\r\n    const maxHeightString = typeof maxHeight === 'number' ? `${maxHeight}px` : maxHeight;\r\n    const widthString = width === 'target'\r\n        ? `${refs.reference.current?.getBoundingClientRect().width}px`\r\n        : typeof width === 'number'\r\n            ? `${width}px`\r\n            : width;\r\n    const onFocus = () => {\r\n        if (hoverable && !isDisabled && !hasActiveElements) {\r\n            openPopover();\r\n        }\r\n    };\r\n    return (React.createElement(PopoverContext.Provider, { value: {\r\n            floatingStyles,\r\n            position: placement,\r\n            closePopover,\r\n            popoverTriggerId,\r\n            popoverContentId,\r\n            openPopover,\r\n            isInverse,\r\n            isOpen,\r\n            maxHeight: maxHeightString,\r\n            width: widthString,\r\n            contentRef,\r\n            setIsOpen,\r\n            setFloating: refs.setFloating,\r\n            setReference: refs.setReference,\r\n            arrowRef,\r\n            arrowContext: context,\r\n            toggleRef,\r\n            isDisabled,\r\n            hoverable,\r\n            hasPointer,\r\n            focusTrap,\r\n            hasActiveElements,\r\n        } },\r\n        React.createElement(StyledContainer, Object.assign({}, other, { onKeyDown: handleKeyDown, onBlur: handlePopoverBlur, ref: ref, \"data-testid\": testId, onMouseOver: handleMouseOver, onMouseLeave: handleMouseLeave, id: popoverId, onFocus: onFocus }), children)));\r\n});\r\n//# sourceMappingURL=Popover.js.map"]} */",
8732
8743
  toString: _EMOTION_STRINGIFIED_CSS_ERROR__$b
8733
8744
  });
8734
8745
  var PopoverContext = /*#__PURE__*/React__default.createContext({
@@ -8744,15 +8755,6 @@ function hasActiveElementsChecker(ref) {
8744
8755
  return element instanceof HTMLElement && style.display !== 'none' && style.visibility !== 'hidden' && !element.hasAttribute('disabled');
8745
8756
  }).length > 0;
8746
8757
  }
8747
- function isElementInteractive(element) {
8748
- if (!element || !(element instanceof HTMLElement)) return false;
8749
- var tag = element.tagName.toLowerCase();
8750
- if (['button', 'input', 'select', 'textarea', 'a'].includes(tag) || element.hasAttribute('tabindex')) {
8751
- if (tag === 'a' && !element.href) return false;
8752
- return !element.hasAttribute('disabled');
8753
- }
8754
- return false;
8755
- }
8756
8758
  var Popover = /*#__PURE__*/React__default.forwardRef(function (props, forwardedRef) {
8757
8759
  var _refs$reference$curre;
8758
8760
  var _React$useState = React__default.useState(false),
@@ -14058,7 +14060,7 @@ var Container$2 = /*#__PURE__*/_styled("div", {
14058
14060
  styles: "display:inline-block;position:relative"
14059
14061
  } : {
14060
14062
  name: "11ffxfj",
14061
- styles: "display:inline-block;position:relative/*# sourceMappingURL=data:application/json;charset=utf-8;base64,{"version":3,"sources":["Dropdown.tsx"],"names":[],"mappings":"AAoB6B","file":"Dropdown.tsx","sourcesContent":["import * as React from 'react';\r\nimport { useState } from 'react';\r\nimport styled from '@emotion/styled';\r\nimport { autoUpdate, flip, offset, useFloating, } from '@floating-ui/react-dom';\r\nimport { useDescendants } from '../../hooks/useDescendants';\r\nimport { useIsInverse } from '../../inverse';\r\nimport { resolveProps, useForkedRef, useGenerateId } from '../../utils';\r\nimport { ButtonGroupContext } from '../ButtonGroup';\r\nexport var DropdownDropDirection;\r\n(function (DropdownDropDirection) {\r\n    DropdownDropDirection[\"down\"] = \"down\";\r\n    DropdownDropDirection[\"left\"] = \"left\";\r\n    DropdownDropDirection[\"right\"] = \"right\";\r\n    DropdownDropDirection[\"up\"] = \"up\";\r\n})(DropdownDropDirection || (DropdownDropDirection = {}));\r\nexport var DropdownAlignment;\r\n(function (DropdownAlignment) {\r\n    DropdownAlignment[\"start\"] = \"start\";\r\n    DropdownAlignment[\"end\"] = \"end\";\r\n})(DropdownAlignment || (DropdownAlignment = {}));\r\nconst Container = styled.div `\n  display: inline-block;\n  position: relative;\n`;\r\nexport const DropdownContext = React.createContext({\r\n    isOpen: false,\r\n    registerDropdownMenuItem: (elements, element) => { },\r\n    setIsOpen: () => false,\r\n});\r\nexport const useDropdownContext = () => React.useContext(DropdownContext);\r\nexport const Dropdown = React.forwardRef((props, forwardedRef) => {\r\n    const contextProps = React.useContext(ButtonGroupContext);\r\n    const resolvedProps = resolveProps(contextProps, props);\r\n    const { activeIndex, alignment, children, dropDirection, maxHeight, onClose, onOpen, testId, width, ...other } = resolvedProps;\r\n    const [isOpen, setIsOpen] = React.useState(false);\r\n    const [activeItemIndex, setActiveItemIndex] = React.useState(activeIndex || -1);\r\n    const ownRef = React.useRef();\r\n    const toggleRef = React.useRef(null);\r\n    const menuRef = React.useRef([]);\r\n    const dropdownButtonId = React.useRef('');\r\n    const ref = useForkedRef(forwardedRef, ownRef);\r\n    const [itemRefArray, registerDropdownMenuItem] = useDescendants();\r\n    React.useEffect(() => {\r\n        if (activeIndex >= 0) {\r\n            setActiveItemIndex(activeIndex);\r\n        }\r\n    }, [activeIndex]);\r\n    function openDropdown() {\r\n        const [filteredItems] = getFilteredItem();\r\n        setIsOpen(true);\r\n        if (filteredItems.length > 0) {\r\n            setTimeout(() => {\r\n                filteredItems[0]?.current?.focus();\r\n            }, 0);\r\n        }\r\n        else {\r\n            setTimeout(() => {\r\n                menuRef.current.focus();\r\n            }, 0);\r\n        }\r\n        onOpen && typeof onOpen === 'function' && onOpen();\r\n    }\r\n    function closeDropdown(event) {\r\n        setIsOpen(false);\r\n        toggleRef.current?.focus();\r\n        onClose && typeof onClose === 'function' && onClose(event);\r\n    }\r\n    function getFilteredItem() {\r\n        const filteredItems = itemRefArray.current.filter(itemRef => itemRef.current);\r\n        const filteredItemIndex = filteredItems\r\n            .map(filteredItem => filteredItem.current)\r\n            .indexOf(document.activeElement);\r\n        return [filteredItems, filteredItemIndex];\r\n    }\r\n    function handleKeyDown(event) {\r\n        if (event.key === 'Escape') {\r\n            event.nativeEvent.stopImmediatePropagation();\r\n            closeDropdown(event);\r\n        }\r\n        if (event.key === 'ArrowDown') {\r\n            const [filteredItems, filteredItemIndex] = getFilteredItem();\r\n            if (filteredItems.length === 0) {\r\n                return;\r\n            }\r\n            event.preventDefault();\r\n            if (filteredItemIndex === -1 ||\r\n                filteredItemIndex === filteredItems.length - 1) {\r\n                filteredItems[0].current.focus();\r\n            }\r\n            else {\r\n                filteredItems[filteredItemIndex + 1].current.focus();\r\n            }\r\n        }\r\n        if (event.key === 'ArrowUp') {\r\n            const [filteredItems, filteredItemIndex] = getFilteredItem();\r\n            if (filteredItems.length === 0) {\r\n                return;\r\n            }\r\n            event.preventDefault();\r\n            if (filteredItemIndex === -1 || filteredItemIndex === 0) {\r\n                filteredItems[filteredItems.length - 1].current.focus();\r\n            }\r\n            else {\r\n                filteredItems[filteredItemIndex - 1].current.focus();\r\n            }\r\n        }\r\n    }\r\n    function handleDropdownBlur(event) {\r\n        const { currentTarget, relatedTarget } = event;\r\n        const isInMenu = relatedTarget && currentTarget.contains(relatedTarget);\r\n        if (!isInMenu && isOpen) {\r\n            closeDropdown(event);\r\n        }\r\n    }\r\n    const maxHeightString = typeof maxHeight === 'number' ? `${maxHeight}px` : maxHeight;\r\n    const widthString = typeof width === 'number' ? `${width}px` : width;\r\n    const isInverse = useIsInverse(resolvedProps.isInverse);\r\n    const [placement, setPlacement] = useState('bottom-start');\r\n    dropdownButtonId.current = useGenerateId();\r\n    const changePlacement = (dropDirection = DropdownDropDirection.down, alignment = DropdownAlignment.start) => {\r\n        const placementMap = new Map([\r\n            ['up-start', 'top-start'],\r\n            ['up-end', 'top-end'],\r\n            ['right-start', 'right-start'],\r\n            ['right-end', 'right-end'],\r\n            ['down-end', 'bottom-end'],\r\n            ['left-start', 'left-start'],\r\n            ['left-end', 'left-end'],\r\n        ]);\r\n        // dropDirection & alignment are deprecated.\r\n        // this fallback can be removed when the props are deleted.\r\n        const contentPosition = `${dropDirection}-${alignment}`;\r\n        setPlacement(placementMap.get(contentPosition) ?? 'bottom-start');\r\n    };\r\n    const { refs, floatingStyles, elements, update } = useFloating({\r\n        middleware: [flip(), offset(2)],\r\n        placement: placement,\r\n        whileElementsMounted: autoUpdate,\r\n    });\r\n    React.useEffect(() => {\r\n        changePlacement(dropDirection, alignment);\r\n    }, [dropDirection, alignment]);\r\n    // Need cleanup state to avoid memory leaks\r\n    React.useEffect(() => {\r\n        const referenceDropdownButton = elements.reference;\r\n        const floatingDropdownContent = elements.floating;\r\n        if (isOpen && referenceDropdownButton && floatingDropdownContent) {\r\n            return autoUpdate(referenceDropdownButton, floatingDropdownContent, update);\r\n        }\r\n    }, [isOpen, elements, update]);\r\n    const contextValue = React.useMemo(() => ({\r\n        activeItemIndex,\r\n        alignment,\r\n        closeDropdown,\r\n        dropdownButtonId,\r\n        dropDirection,\r\n        floatingStyles,\r\n        handleDropdownBlur,\r\n        itemRefArray,\r\n        isFixedWidth: !!width,\r\n        isOpen,\r\n        isInverse,\r\n        maxHeight: maxHeightString,\r\n        menuRef,\r\n        openDropdown,\r\n        registerDropdownMenuItem,\r\n        setActiveItemIndex,\r\n        setIsOpen,\r\n        setReference: refs.setReference,\r\n        setFloating: refs.setFloating,\r\n        toggleRef,\r\n        width: widthString,\r\n    }), [\r\n        activeItemIndex,\r\n        alignment,\r\n        closeDropdown,\r\n        dropdownButtonId,\r\n        dropDirection,\r\n        floatingStyles,\r\n        handleDropdownBlur,\r\n        itemRefArray,\r\n        width,\r\n        isOpen,\r\n        isInverse,\r\n        maxHeightString,\r\n        menuRef,\r\n        openDropdown,\r\n        registerDropdownMenuItem,\r\n        setActiveItemIndex,\r\n        setIsOpen,\r\n        refs.setReference,\r\n        refs.setFloating,\r\n        toggleRef,\r\n        widthString,\r\n    ]);\r\n    return (React.createElement(DropdownContext.Provider, { value: contextValue },\r\n        React.createElement(Container, Object.assign({}, other, { ref: ref, \"data-testid\": testId, onKeyDown: isOpen ? handleKeyDown : null, onBlur: handleDropdownBlur }), children)));\r\n});\r\n//# sourceMappingURL=Dropdown.js.map"]} */",
14063
+ styles: "display:inline-block;position:relative/*# sourceMappingURL=data:application/json;charset=utf-8;base64,{"version":3,"sources":["Dropdown.tsx"],"names":[],"mappings":"AAoB6B","file":"Dropdown.tsx","sourcesContent":["import * as React from 'react';\r\nimport { useState } from 'react';\r\nimport styled from '@emotion/styled';\r\nimport { autoUpdate, flip, offset, useFloating, } from '@floating-ui/react-dom';\r\nimport { useDescendants } from '../../hooks/useDescendants';\r\nimport { useIsInverse } from '../../inverse';\r\nimport { isElementInteractive, resolveProps, useForkedRef, useGenerateId, } from '../../utils';\r\nimport { ButtonGroupContext } from '../ButtonGroup';\r\nexport var DropdownDropDirection;\r\n(function (DropdownDropDirection) {\r\n    DropdownDropDirection[\"down\"] = \"down\";\r\n    DropdownDropDirection[\"left\"] = \"left\";\r\n    DropdownDropDirection[\"right\"] = \"right\";\r\n    DropdownDropDirection[\"up\"] = \"up\";\r\n})(DropdownDropDirection || (DropdownDropDirection = {}));\r\nexport var DropdownAlignment;\r\n(function (DropdownAlignment) {\r\n    DropdownAlignment[\"start\"] = \"start\";\r\n    DropdownAlignment[\"end\"] = \"end\";\r\n})(DropdownAlignment || (DropdownAlignment = {}));\r\nconst Container = styled.div `\n  display: inline-block;\n  position: relative;\n`;\r\nexport const DropdownContext = React.createContext({\r\n    isOpen: false,\r\n    registerDropdownMenuItem: (elements, element) => { },\r\n    setIsOpen: () => false,\r\n});\r\nexport const useDropdownContext = () => React.useContext(DropdownContext);\r\nexport const Dropdown = React.forwardRef((props, forwardedRef) => {\r\n    const contextProps = React.useContext(ButtonGroupContext);\r\n    const resolvedProps = resolveProps(contextProps, props);\r\n    const { activeIndex, alignment, children, dropDirection, maxHeight, onClose, onOpen, testId, width, ...other } = resolvedProps;\r\n    const [isOpen, setIsOpen] = React.useState(false);\r\n    const [activeItemIndex, setActiveItemIndex] = React.useState(activeIndex || -1);\r\n    const ownRef = React.useRef();\r\n    const toggleRef = React.useRef(null);\r\n    const menuRef = React.useRef([]);\r\n    const dropdownButtonId = React.useRef('');\r\n    const ref = useForkedRef(forwardedRef, ownRef);\r\n    const [itemRefArray, registerDropdownMenuItem] = useDescendants();\r\n    React.useEffect(() => {\r\n        if (activeIndex >= 0) {\r\n            setActiveItemIndex(activeIndex);\r\n        }\r\n    }, [activeIndex]);\r\n    function openDropdown() {\r\n        const [filteredItems] = getFilteredItem();\r\n        setIsOpen(true);\r\n        if (filteredItems.length > 0) {\r\n            setTimeout(() => {\r\n                filteredItems[0]?.current?.focus();\r\n            }, 0);\r\n        }\r\n        else {\r\n            setTimeout(() => {\r\n                menuRef.current.focus();\r\n            }, 0);\r\n        }\r\n        onOpen && typeof onOpen === 'function' && onOpen();\r\n    }\r\n    function closeDropdown(event) {\r\n        setIsOpen(false);\r\n        if (event && event.type === 'blur') {\r\n            const relatedTarget = event.relatedTarget;\r\n            if (!isElementInteractive(relatedTarget)) {\r\n                toggleRef.current?.focus();\r\n            }\r\n        }\r\n        onClose && typeof onClose === 'function' && onClose(event);\r\n    }\r\n    function getFilteredItem() {\r\n        const filteredItems = itemRefArray.current.filter(itemRef => itemRef.current);\r\n        const filteredItemIndex = filteredItems\r\n            .map(filteredItem => filteredItem.current)\r\n            .indexOf(document.activeElement);\r\n        return [filteredItems, filteredItemIndex];\r\n    }\r\n    function handleKeyDown(event) {\r\n        if (event.key === 'Escape') {\r\n            event.nativeEvent.stopImmediatePropagation();\r\n            closeDropdown(event);\r\n        }\r\n        if (event.key === 'ArrowDown') {\r\n            const [filteredItems, filteredItemIndex] = getFilteredItem();\r\n            if (filteredItems.length === 0) {\r\n                return;\r\n            }\r\n            event.preventDefault();\r\n            if (filteredItemIndex === -1 ||\r\n                filteredItemIndex === filteredItems.length - 1) {\r\n                filteredItems[0].current.focus();\r\n            }\r\n            else {\r\n                filteredItems[filteredItemIndex + 1].current.focus();\r\n            }\r\n        }\r\n        if (event.key === 'ArrowUp') {\r\n            const [filteredItems, filteredItemIndex] = getFilteredItem();\r\n            if (filteredItems.length === 0) {\r\n                return;\r\n            }\r\n            event.preventDefault();\r\n            if (filteredItemIndex === -1 || filteredItemIndex === 0) {\r\n                filteredItems[filteredItems.length - 1].current.focus();\r\n            }\r\n            else {\r\n                filteredItems[filteredItemIndex - 1].current.focus();\r\n            }\r\n        }\r\n    }\r\n    function handleDropdownBlur(event) {\r\n        const { currentTarget, relatedTarget } = event;\r\n        const isInMenu = relatedTarget && currentTarget.contains(relatedTarget);\r\n        if (!isInMenu && isOpen) {\r\n            closeDropdown(event);\r\n        }\r\n    }\r\n    const maxHeightString = typeof maxHeight === 'number' ? `${maxHeight}px` : maxHeight;\r\n    const widthString = typeof width === 'number' ? `${width}px` : width;\r\n    const isInverse = useIsInverse(resolvedProps.isInverse);\r\n    const [placement, setPlacement] = useState('bottom-start');\r\n    dropdownButtonId.current = useGenerateId();\r\n    const changePlacement = (dropDirection = DropdownDropDirection.down, alignment = DropdownAlignment.start) => {\r\n        const placementMap = new Map([\r\n            ['up-start', 'top-start'],\r\n            ['up-end', 'top-end'],\r\n            ['right-start', 'right-start'],\r\n            ['right-end', 'right-end'],\r\n            ['down-end', 'bottom-end'],\r\n            ['left-start', 'left-start'],\r\n            ['left-end', 'left-end'],\r\n        ]);\r\n        // dropDirection & alignment are deprecated.\r\n        // this fallback can be removed when the props are deleted.\r\n        const contentPosition = `${dropDirection}-${alignment}`;\r\n        setPlacement(placementMap.get(contentPosition) ?? 'bottom-start');\r\n    };\r\n    const { refs, floatingStyles, elements, update } = useFloating({\r\n        middleware: [flip(), offset(2)],\r\n        placement: placement,\r\n        whileElementsMounted: autoUpdate,\r\n    });\r\n    React.useEffect(() => {\r\n        changePlacement(dropDirection, alignment);\r\n    }, [dropDirection, alignment]);\r\n    // Need cleanup state to avoid memory leaks\r\n    React.useEffect(() => {\r\n        const referenceDropdownButton = elements.reference;\r\n        const floatingDropdownContent = elements.floating;\r\n        if (isOpen && referenceDropdownButton && floatingDropdownContent) {\r\n            return autoUpdate(referenceDropdownButton, floatingDropdownContent, update);\r\n        }\r\n    }, [isOpen, elements, update]);\r\n    const contextValue = React.useMemo(() => ({\r\n        activeItemIndex,\r\n        alignment,\r\n        closeDropdown,\r\n        dropdownButtonId,\r\n        dropDirection,\r\n        floatingStyles,\r\n        handleDropdownBlur,\r\n        itemRefArray,\r\n        isFixedWidth: !!width,\r\n        isOpen,\r\n        isInverse,\r\n        maxHeight: maxHeightString,\r\n        menuRef,\r\n        openDropdown,\r\n        registerDropdownMenuItem,\r\n        setActiveItemIndex,\r\n        setIsOpen,\r\n        setReference: refs.setReference,\r\n        setFloating: refs.setFloating,\r\n        toggleRef,\r\n        width: widthString,\r\n    }), [\r\n        activeItemIndex,\r\n        alignment,\r\n        closeDropdown,\r\n        dropdownButtonId,\r\n        dropDirection,\r\n        floatingStyles,\r\n        handleDropdownBlur,\r\n        itemRefArray,\r\n        width,\r\n        isOpen,\r\n        isInverse,\r\n        maxHeightString,\r\n        menuRef,\r\n        openDropdown,\r\n        registerDropdownMenuItem,\r\n        setActiveItemIndex,\r\n        setIsOpen,\r\n        refs.setReference,\r\n        refs.setFloating,\r\n        toggleRef,\r\n        widthString,\r\n    ]);\r\n    return (React.createElement(DropdownContext.Provider, { value: contextValue },\r\n        React.createElement(Container, Object.assign({}, other, { ref: ref, \"data-testid\": testId, onKeyDown: isOpen ? handleKeyDown : null, onBlur: handleDropdownBlur }), children)));\r\n});\r\n//# sourceMappingURL=Dropdown.js.map"]} */",
14062
14064
  toString: _EMOTION_STRINGIFIED_CSS_ERROR__$o
14063
14065
  });
14064
14066
  var DropdownContext = /*#__PURE__*/createContext({
@@ -14117,9 +14119,14 @@ var Dropdown = /*#__PURE__*/forwardRef(function (props, forwardedRef) {
14117
14119
  onOpen && typeof onOpen === 'function' && onOpen();
14118
14120
  }
14119
14121
  function closeDropdown(event) {
14120
- var _toggleRef$current;
14121
14122
  setIsOpen(false);
14122
- (_toggleRef$current = toggleRef.current) == null || _toggleRef$current.focus();
14123
+ if (event && event.type === 'blur') {
14124
+ var relatedTarget = event.relatedTarget;
14125
+ if (!isElementInteractive(relatedTarget)) {
14126
+ var _toggleRef$current;
14127
+ (_toggleRef$current = toggleRef.current) == null || _toggleRef$current.focus();
14128
+ }
14129
+ }
14123
14130
  onClose && typeof onClose === 'function' && onClose(event);
14124
14131
  }
14125
14132
  function getFilteredItem() {
@@ -20796,7 +20803,7 @@ function buildLabelPadding(props) {
20796
20803
  }
20797
20804
  }
20798
20805
  var TagStyling = function TagStyling(props) {
20799
- return /*#__PURE__*/css("border:", props.theme.tag.border, ";border-radius:", props.theme.spaceScale.spacing05, ";background:", buildButtonBackground$1(props), ";color:", buildButtonTextColor(props), ";box-shadow:", buildBoxShadow$1(props), ";font-family:", props.theme.bodyFont, ";display:", props.theme.tag.display, ";align-items:", props.theme.tag.alignItems, ";justify-content:", props.theme.tag.justifyContent, ";font-size:", props.size === 'small' ? "" + props.theme.typeScale.size01.fontSize : "" + props.theme.typeScale.size02.fontSize, ";font-weight:", props.size === 'small' ? "500" : "inherit", ";letter-spacing:", props.size === 'small' ? "" + props.theme.typeScale.size01.letterSpacing : "" + props.theme.typeScale.size02.letterSpacing, ";min-width:", props.size === 'small' ? props.theme.spaceScale.spacing10 : props.theme.spaceScale.spacing12, ";padding:", buildTagPadding(props), ";svg:first-of-type{opacity:", props.disabled ? buildSvgOpacity(props) : 'inherit', ";height:", props.size === 'small' ? props.theme.iconSizes.xSmall + "px" : props.theme.iconSizes.small + "px", ";width:", props.size === 'small' ? props.theme.iconSizes.xSmall + "px" : props.theme.iconSizes.small + "px", ";}svg:last-child{opacity:", buildSvgOpacity(props), ";width:", props.size === 'small' ? props.theme.iconSizes.xSmall + "px" : props.theme.iconSizes.small + "px", ";};label:TagStyling;" + (process.env.NODE_ENV === "production" ? "" : "/*# sourceMappingURL=data:application/json;charset=utf-8;base64,{"version":3,"sources":["Tag.tsx"],"names":[],"mappings":"AAsLgC","file":"Tag.tsx","sourcesContent":["import * as React from 'react';\r\nimport { css } from '@emotion/react';\r\nimport styled from '@emotion/styled';\r\nimport { transparentize } from 'polished';\r\nimport { CancelIcon } from 'react-magma-icons';\r\nimport { I18nContext } from '../../i18n';\r\nimport { useIsInverse } from '../../inverse';\r\nimport { ThemeContext } from '../../theme/ThemeContext';\r\nimport { getNodeText } from '../../utils';\r\nexport var TagColor;\r\n(function (TagColor) {\r\n    TagColor[\"default\"] = \"default\";\r\n    TagColor[\"primary\"] = \"primary\";\r\n    TagColor[\"lowContrast\"] = \"lowContrast\";\r\n    TagColor[\"highContrast\"] = \"highContrast\";\r\n})(TagColor || (TagColor = {}));\r\nexport var TagSize;\r\n(function (TagSize) {\r\n    TagSize[\"medium\"] = \"medium\";\r\n    TagSize[\"small\"] = \"small\";\r\n})(TagSize || (TagSize = {}));\r\nfunction buildBoxShadow(props) {\r\n    if (props.color === 'lowContrast') {\r\n        if (props.isInverse) {\r\n            if (props.disabled) {\r\n                return `0 0 0 1px ${transparentize(0.8, props.theme.colors.neutral100)}`;\r\n            }\r\n            return `0 0 0 1px ${transparentize(0.5, props.theme.colors.neutral100)}`;\r\n        }\r\n        if (props.disabled) {\r\n            return `0 0 0 1px ${props.theme.colors.neutral300}`;\r\n        }\r\n        return `inset 0 0 0  1px ${props.theme.colors.neutral400}`;\r\n    }\r\n}\r\nfunction buildButtonBackground(props) {\r\n    if (props.isInverse) {\r\n        if (props.disabled) {\r\n            // Disabled inverse state background colors\r\n            switch (props.color) {\r\n                case 'primary' || 'highContrast':\r\n                    return transparentize(0.7, props.theme.colors.neutral100);\r\n                case 'lowContrast':\r\n                    return `none`;\r\n                default:\r\n                    return transparentize(0.7, props.theme.colors.neutral100);\r\n            }\r\n        }\r\n        // Inverse background colors\r\n        switch (props.color) {\r\n            case 'primary':\r\n                return props.theme.colors.tertiary500;\r\n            case 'lowContrast':\r\n                return `none;`;\r\n            case 'highContrast':\r\n                return props.theme.colors.neutral100;\r\n            default:\r\n                return props.theme.colors.neutral500;\r\n        }\r\n    }\r\n    else if (props.disabled && !props.isInverse) {\r\n        // Disabled state background colors\r\n        switch (props.color) {\r\n            case 'primary' || 'highContrast':\r\n                return transparentize(0.4, props.theme.colors.neutral300);\r\n            case 'lowContrast':\r\n                return props.theme.colors.neutral100;\r\n            default:\r\n                return transparentize(0.4, props.theme.colors.neutral300);\r\n        }\r\n    }\r\n    // Default state background colors\r\n    switch (props.color) {\r\n        case 'primary':\r\n            return props.theme.colors.primary;\r\n        case 'lowContrast':\r\n            return props.theme.colors.neutral100;\r\n        case 'highContrast':\r\n            return props.theme.colors.neutral700;\r\n        default:\r\n            return props.theme.colors.neutral300;\r\n    }\r\n}\r\nfunction buildButtonTextColor(props) {\r\n    if (props.isInverse) {\r\n        if (props.disabled) {\r\n            // Disabled inverse state text colors\r\n            switch (props.color) {\r\n                case 'primary' || 'highContrast':\r\n                    return transparentize(0.6, props.theme.colors.neutral100);\r\n                case 'lowContrast':\r\n                    return transparentize(0.7, props.theme.colors.neutral100);\r\n                default:\r\n                    return transparentize(0.6, props.theme.colors.neutral100);\r\n            }\r\n        }\r\n        // Inverse text colors\r\n        switch (props.color) {\r\n            case 'primary':\r\n                return props.theme.colors.primary600;\r\n            case 'lowContrast':\r\n                return props.theme.colors.tertiary500;\r\n            case 'highContrast':\r\n                return props.theme.colors.neutral700;\r\n            default:\r\n                return props.theme.colors.neutral100;\r\n        }\r\n    }\r\n    else if (props.disabled && !props.isInverse) {\r\n        // Disabled state text colors\r\n        return transparentize(0.4, props.theme.colors.neutral500);\r\n    }\r\n    // Default state text colors\r\n    switch (props.color) {\r\n        case 'primary':\r\n            return props.theme.colors.neutral100;\r\n        case 'highContrast':\r\n            return props.theme.colors.neutral100;\r\n        case 'lowContrast':\r\n            return props.theme.colors.neutral700;\r\n        default:\r\n            return props.theme.colors.neutral700;\r\n    }\r\n}\r\nfunction buildSvgOpacity(props) {\r\n    if (props.isInverse) {\r\n        if (props.color === 'lowContrast' && props.disabled) {\r\n            return '30%';\r\n        }\r\n        if (props.onClick || props.onDelete) {\r\n            if (props.disabled) {\r\n                return '40%';\r\n            }\r\n            return '75%';\r\n        }\r\n    }\r\n    if (props.onClick || props.onDelete) {\r\n        if (props.disabled) {\r\n            return '60%';\r\n        }\r\n        return '75%';\r\n    }\r\n    if (props.color === 'lowContrast' && props.disabled) {\r\n        return '30%';\r\n    }\r\n    else if (props.disabled) {\r\n        return '40%';\r\n    }\r\n    return '1';\r\n}\r\nfunction buildTagPadding(props) {\r\n    if (props.icon) {\r\n        switch (props.size) {\r\n            case 'small':\r\n                return `0 ${props.theme.spaceScale.spacing02}`;\r\n            default:\r\n                return `${props.theme.spaceScale.spacing02} 6px`;\r\n        }\r\n    }\r\n    switch (props.size) {\r\n        case 'small':\r\n            return `0 ${props.theme.spaceScale.spacing02}`;\r\n        default:\r\n            return `${props.theme.spaceScale.spacing02} 6px`;\r\n    }\r\n}\r\nfunction buildLabelPadding(props) {\r\n    if (props.icon) {\r\n        switch (props.size) {\r\n            case 'small':\r\n                return `0 ${props.theme.spaceScale.spacing02}`;\r\n            default:\r\n                return `0 ${props.theme.spaceScale.spacing03}`;\r\n        }\r\n    }\r\n    switch (props.size) {\r\n        case 'small':\r\n            return `0 ${props.theme.spaceScale.spacing02}`;\r\n        default:\r\n            return `0 ${props.theme.spaceScale.spacing03}`;\r\n    }\r\n}\r\nconst TagStyling = props => css `\n  border: ${props.theme.tag.border};\n  border-radius: ${props.theme.spaceScale.spacing05};\n  background: ${buildButtonBackground(props)};\n  color: ${buildButtonTextColor(props)};\n  box-shadow: ${buildBoxShadow(props)};\n  font-family: ${props.theme.bodyFont};\n  display: ${props.theme.tag.display};\n  align-items: ${props.theme.tag.alignItems};\n  justify-content: ${props.theme.tag.justifyContent};\n  font-size: ${props.size === 'small'\r\n    ? `${props.theme.typeScale.size01.fontSize}`\r\n    : `${props.theme.typeScale.size02.fontSize}`};\n  font-weight: ${props.size === 'small' ? `500` : `inherit`};\n  letter-spacing: ${props.size === 'small'\r\n    ? `${props.theme.typeScale.size01.letterSpacing}`\r\n    : `${props.theme.typeScale.size02.letterSpacing}`};\n  min-width: ${props.size === 'small'\r\n    ? props.theme.spaceScale.spacing10\r\n    : props.theme.spaceScale.spacing12};\n  padding: ${buildTagPadding(props)};\n  svg:first-of-type {\n    opacity: ${props.disabled ? buildSvgOpacity(props) : 'inherit'};\n    height: ${props.size === 'small'\r\n    ? `${props.theme.iconSizes.xSmall}px`\r\n    : `${props.theme.iconSizes.small}px`};\n    width: ${props.size === 'small'\r\n    ? `${props.theme.iconSizes.xSmall}px`\r\n    : `${props.theme.iconSizes.small}px`};\n  }\n  svg:last-child {\n    opacity: ${buildSvgOpacity(props)};\n    width: ${props.size === 'small'\r\n    ? `${props.theme.iconSizes.xSmall}px`\r\n    : `${props.theme.iconSizes.small}px`};\n  }\n`;\r\nconst StyledButton = styled.button `\n  ${TagStyling};\n  cursor: ${props => (props.disabled ? 'not-allowed' : 'pointer')};\n  &:focus {\n    outline-offset: 2px;\n    outline: 2px solid\n      ${props => props.isInverse\r\n    ? props.theme.colors.focusInverse\r\n    : props.theme.colors.focus};\n  }\n`;\r\nconst StyledSpan = styled.span `\n  ${TagStyling};\n  cursor: ${props => (props.disabled ? 'not-allowed' : 'inherit')};\n`;\r\nconst LabelWrap = styled.span `\n  padding: ${buildLabelPadding};\n`;\r\nfunction getStyledTag(isClickable) {\r\n    return isClickable ? StyledButton : StyledSpan;\r\n}\r\nexport const Tag = React.forwardRef((props, ref) => {\r\n    const { children, color, labelText = children, onClick, onDelete, isInverse: isInverseProp, size = TagSize.medium, testId, ...rest } = props;\r\n    const theme = React.useContext(ThemeContext);\r\n    const isInverse = useIsInverse(isInverseProp);\r\n    const i18n = React.useContext(I18nContext);\r\n    const deleteAriaLabel = i18n.tag.deleteAriaLabel.replace(/\\{labelText\\}/g, getNodeText(labelText));\r\n    const { icon } = props;\r\n    const StyledTag = getStyledTag(Boolean(onClick || onDelete));\r\n    function handleClick() {\r\n        if (onClick && typeof onClick === 'function') {\r\n            onClick();\r\n        }\r\n        else if (onDelete && typeof onDelete === 'function') {\r\n            onDelete();\r\n        }\r\n    }\r\n    return (React.createElement(StyledTag, Object.assign({ color: color, icon: icon, onClick: handleClick, isInverse: isInverse, ref: ref, \"data-testid\": props.testId, size: size, theme: theme }, rest),\r\n        icon,\r\n        React.createElement(LabelWrap, Object.assign({ size: size }, rest, { theme: theme }), children),\r\n        onDelete && (React.createElement(CancelIcon, { \"aria-label\": deleteAriaLabel, size: theme.iconSizes.small }))));\r\n});\r\n//# sourceMappingURL=Tag.js.map"]} */"));
20806
+ return /*#__PURE__*/css("border:", props.theme.tag.border, ";border-radius:", props.theme.spaceScale.spacing05, ";background:", buildButtonBackground$1(props), ";color:", buildButtonTextColor(props), ";box-shadow:", buildBoxShadow$1(props), ";font-family:", props.theme.bodyFont, ";display:", props.theme.tag.display, ";align-items:", props.theme.tag.alignItems, ";justify-content:", props.theme.tag.justifyContent, ";font-size:", props.size === 'small' ? "" + props.theme.typeScale.size01.fontSize : "" + props.theme.typeScale.size02.fontSize, ";font-weight:", props.size === 'small' ? "500" : "inherit", ";letter-spacing:", props.size === 'small' ? "" + props.theme.typeScale.size01.letterSpacing : "" + props.theme.typeScale.size02.letterSpacing, ";min-width:", props.size === 'small' ? props.theme.spaceScale.spacing10 : props.theme.spaceScale.spacing12, ";padding:", buildTagPadding(props), ";svg:first-of-type{opacity:", props.disabled ? buildSvgOpacity(props) : 'inherit', ";height:", props.size === 'small' ? props.theme.iconSizes.xSmall + "px" : props.theme.iconSizes.small + "px", ";width:", props.size === 'small' ? props.theme.iconSizes.xSmall + "px" : props.theme.iconSizes.small + "px", ";}svg:last-child{opacity:", buildSvgOpacity(props), ";width:", props.size === 'small' ? props.theme.iconSizes.xSmall + "px" : props.theme.iconSizes.small + "px", ";};label:TagStyling;" + (process.env.NODE_ENV === "production" ? "" : "/*# sourceMappingURL=data:application/json;charset=utf-8;base64,{"version":3,"sources":["Tag.tsx"],"names":[],"mappings":"AAsLgC","file":"Tag.tsx","sourcesContent":["import * as React from 'react';\r\nimport { css } from '@emotion/react';\r\nimport styled from '@emotion/styled';\r\nimport { transparentize } from 'polished';\r\nimport { CancelIcon } from 'react-magma-icons';\r\nimport { I18nContext } from '../../i18n';\r\nimport { useIsInverse } from '../../inverse';\r\nimport { ThemeContext } from '../../theme/ThemeContext';\r\nimport { getNodeText } from '../../utils';\r\nexport var TagColor;\r\n(function (TagColor) {\r\n    TagColor[\"default\"] = \"default\";\r\n    TagColor[\"primary\"] = \"primary\";\r\n    TagColor[\"lowContrast\"] = \"lowContrast\";\r\n    TagColor[\"highContrast\"] = \"highContrast\";\r\n})(TagColor || (TagColor = {}));\r\nexport var TagSize;\r\n(function (TagSize) {\r\n    TagSize[\"medium\"] = \"medium\";\r\n    TagSize[\"small\"] = \"small\";\r\n})(TagSize || (TagSize = {}));\r\nfunction buildBoxShadow(props) {\r\n    if (props.color === 'lowContrast') {\r\n        if (props.isInverse) {\r\n            if (props.disabled) {\r\n                return `0 0 0 1px ${transparentize(0.8, props.theme.colors.neutral100)}`;\r\n            }\r\n            return `0 0 0 1px ${transparentize(0.5, props.theme.colors.neutral100)}`;\r\n        }\r\n        if (props.disabled) {\r\n            return `0 0 0 1px ${props.theme.colors.neutral300}`;\r\n        }\r\n        return `inset 0 0 0  1px ${props.theme.colors.neutral400}`;\r\n    }\r\n}\r\nfunction buildButtonBackground(props) {\r\n    if (props.isInverse) {\r\n        if (props.disabled) {\r\n            // Disabled inverse state background colors\r\n            switch (props.color) {\r\n                case 'primary' || 'highContrast':\r\n                    return transparentize(0.7, props.theme.colors.neutral100);\r\n                case 'lowContrast':\r\n                    return `none`;\r\n                default:\r\n                    return transparentize(0.7, props.theme.colors.neutral100);\r\n            }\r\n        }\r\n        // Inverse background colors\r\n        switch (props.color) {\r\n            case 'primary':\r\n                return props.theme.colors.tertiary500;\r\n            case 'lowContrast':\r\n                return `none;`;\r\n            case 'highContrast':\r\n                return props.theme.colors.neutral100;\r\n            default:\r\n                return props.theme.colors.neutral500;\r\n        }\r\n    }\r\n    else if (props.disabled && !props.isInverse) {\r\n        // Disabled state background colors\r\n        switch (props.color) {\r\n            case 'primary' || 'highContrast':\r\n                return transparentize(0.4, props.theme.colors.neutral300);\r\n            case 'lowContrast':\r\n                return props.theme.colors.neutral100;\r\n            default:\r\n                return transparentize(0.4, props.theme.colors.neutral300);\r\n        }\r\n    }\r\n    // Default state background colors\r\n    switch (props.color) {\r\n        case 'primary':\r\n            return props.theme.colors.primary;\r\n        case 'lowContrast':\r\n            return props.theme.colors.neutral100;\r\n        case 'highContrast':\r\n            return props.theme.colors.neutral700;\r\n        default:\r\n            return props.theme.colors.neutral300;\r\n    }\r\n}\r\nfunction buildButtonTextColor(props) {\r\n    if (props.isInverse) {\r\n        if (props.disabled) {\r\n            // Disabled inverse state text colors\r\n            switch (props.color) {\r\n                case 'primary' || 'highContrast':\r\n                    return transparentize(0.6, props.theme.colors.neutral100);\r\n                case 'lowContrast':\r\n                    return transparentize(0.7, props.theme.colors.neutral100);\r\n                default:\r\n                    return transparentize(0.6, props.theme.colors.neutral100);\r\n            }\r\n        }\r\n        // Inverse text colors\r\n        switch (props.color) {\r\n            case 'primary':\r\n                return props.theme.colors.primary600;\r\n            case 'lowContrast':\r\n                return props.theme.colors.tertiary500;\r\n            case 'highContrast':\r\n                return props.theme.colors.neutral700;\r\n            default:\r\n                return props.theme.colors.neutral100;\r\n        }\r\n    }\r\n    else if (props.disabled && !props.isInverse) {\r\n        // Disabled state text colors\r\n        return transparentize(0.4, props.theme.colors.neutral500);\r\n    }\r\n    // Default state text colors\r\n    switch (props.color) {\r\n        case 'primary':\r\n            return props.theme.colors.neutral100;\r\n        case 'highContrast':\r\n            return props.theme.colors.neutral100;\r\n        case 'lowContrast':\r\n            return props.theme.colors.neutral700;\r\n        default:\r\n            return props.theme.colors.neutral700;\r\n    }\r\n}\r\nfunction buildSvgOpacity(props) {\r\n    if (props.isInverse) {\r\n        if (props.color === 'lowContrast' && props.disabled) {\r\n            return '30%';\r\n        }\r\n        if (props.onClick || props.onDelete) {\r\n            if (props.disabled) {\r\n                return '40%';\r\n            }\r\n            return '75%';\r\n        }\r\n    }\r\n    if (props.onClick || props.onDelete) {\r\n        if (props.disabled) {\r\n            return '60%';\r\n        }\r\n        return '75%';\r\n    }\r\n    if (props.color === 'lowContrast' && props.disabled) {\r\n        return '30%';\r\n    }\r\n    else if (props.disabled) {\r\n        return '40%';\r\n    }\r\n    return '1';\r\n}\r\nfunction buildTagPadding(props) {\r\n    if (props.icon) {\r\n        switch (props.size) {\r\n            case 'small':\r\n                return `0 ${props.theme.spaceScale.spacing02}`;\r\n            default:\r\n                return `${props.theme.spaceScale.spacing02} 6px`;\r\n        }\r\n    }\r\n    switch (props.size) {\r\n        case 'small':\r\n            return `0 ${props.theme.spaceScale.spacing02}`;\r\n        default:\r\n            return `${props.theme.spaceScale.spacing02} 6px`;\r\n    }\r\n}\r\nfunction buildLabelPadding(props) {\r\n    if (props.icon) {\r\n        switch (props.size) {\r\n            case 'small':\r\n                return `0 ${props.theme.spaceScale.spacing02}`;\r\n            default:\r\n                return `0 ${props.theme.spaceScale.spacing03}`;\r\n        }\r\n    }\r\n    switch (props.size) {\r\n        case 'small':\r\n            return `0 ${props.theme.spaceScale.spacing02}`;\r\n        default:\r\n            return `0 ${props.theme.spaceScale.spacing03}`;\r\n    }\r\n}\r\nconst TagStyling = props => css `\n  border: ${props.theme.tag.border};\n  border-radius: ${props.theme.spaceScale.spacing05};\n  background: ${buildButtonBackground(props)};\n  color: ${buildButtonTextColor(props)};\n  box-shadow: ${buildBoxShadow(props)};\n  font-family: ${props.theme.bodyFont};\n  display: ${props.theme.tag.display};\n  align-items: ${props.theme.tag.alignItems};\n  justify-content: ${props.theme.tag.justifyContent};\n  font-size: ${props.size === 'small'\r\n    ? `${props.theme.typeScale.size01.fontSize}`\r\n    : `${props.theme.typeScale.size02.fontSize}`};\n  font-weight: ${props.size === 'small' ? `500` : `inherit`};\n  letter-spacing: ${props.size === 'small'\r\n    ? `${props.theme.typeScale.size01.letterSpacing}`\r\n    : `${props.theme.typeScale.size02.letterSpacing}`};\n  min-width: ${props.size === 'small'\r\n    ? props.theme.spaceScale.spacing10\r\n    : props.theme.spaceScale.spacing12};\n  padding: ${buildTagPadding(props)};\n  svg:first-of-type {\n    opacity: ${props.disabled ? buildSvgOpacity(props) : 'inherit'};\n    height: ${props.size === 'small'\r\n    ? `${props.theme.iconSizes.xSmall}px`\r\n    : `${props.theme.iconSizes.small}px`};\n    width: ${props.size === 'small'\r\n    ? `${props.theme.iconSizes.xSmall}px`\r\n    : `${props.theme.iconSizes.small}px`};\n  }\n  svg:last-child {\n    opacity: ${buildSvgOpacity(props)};\n    width: ${props.size === 'small'\r\n    ? `${props.theme.iconSizes.xSmall}px`\r\n    : `${props.theme.iconSizes.small}px`};\n  }\n`;\r\nconst StyledButton = styled.button `\n  ${TagStyling};\n  cursor: ${props => (props.disabled ? 'not-allowed' : 'pointer')};\n  &:focus {\n    outline-offset: 2px;\n    outline: 2px solid\n      ${props => props.isInverse\r\n    ? props.theme.colors.focusInverse\r\n    : props.theme.colors.focus};\n  }\n`;\r\nconst StyledSpan = styled.span `\n  ${TagStyling};\n  cursor: ${props => (props.disabled ? 'not-allowed' : 'inherit')};\n`;\r\nconst LabelWrap = styled.span `\n  padding: ${buildLabelPadding};\n`;\r\nfunction getStyledTag(isClickable) {\r\n    return isClickable ? StyledButton : StyledSpan;\r\n}\r\nexport const Tag = React.forwardRef((props, ref) => {\r\n    const { children, color, labelText = children, onClick, onDelete, isInverse: isInverseProp, size = TagSize.medium, testId, ...rest } = props;\r\n    const theme = React.useContext(ThemeContext);\r\n    const isInverse = useIsInverse(isInverseProp);\r\n    const i18n = React.useContext(I18nContext);\r\n    const nodeLabel = getNodeText(labelText);\r\n    const deleteAriaLabel = i18n.tag.deleteAriaLabel.replace(/\\{labelText\\}/g, nodeLabel);\r\n    const { icon } = props;\r\n    const StyledTag = getStyledTag(Boolean(onClick || onDelete));\r\n    function handleClick() {\r\n        if (onClick && typeof onClick === 'function') {\r\n            onClick();\r\n        }\r\n        else if (onDelete && typeof onDelete === 'function') {\r\n            onDelete();\r\n        }\r\n    }\r\n    return (React.createElement(StyledTag, Object.assign({ \"aria-label\": onDelete ? deleteAriaLabel : nodeLabel, color: color, icon: icon, onClick: handleClick, isInverse: isInverse, ref: ref, \"data-testid\": props.testId, size: size, theme: theme }, rest),\r\n        icon,\r\n        React.createElement(LabelWrap, Object.assign({ size: size, theme: theme }, rest), children),\r\n        onDelete && React.createElement(CancelIcon, { size: theme.iconSizes.small })));\r\n});\r\n//# sourceMappingURL=Tag.js.map"]} */"));
20800
20807
  };
20801
20808
  var StyledButton$5 = /*#__PURE__*/_styled("button", {
20802
20809
  target: "e10ye2342",
@@ -20805,17 +20812,17 @@ var StyledButton$5 = /*#__PURE__*/_styled("button", {
20805
20812
  return props.disabled ? 'not-allowed' : 'pointer';
20806
20813
  }, ";&:focus{outline-offset:2px;outline:2px solid ", function (props) {
20807
20814
  return props.isInverse ? props.theme.colors.focusInverse : props.theme.colors.focus;
20808
- }, ";}" + (process.env.NODE_ENV === "production" ? "" : "/*# sourceMappingURL=data:application/json;charset=utf-8;base64,{"version":3,"sources":["Tag.tsx"],"names":[],"mappings":"AA2NmC","file":"Tag.tsx","sourcesContent":["import * as React from 'react';\r\nimport { css } from '@emotion/react';\r\nimport styled from '@emotion/styled';\r\nimport { transparentize } from 'polished';\r\nimport { CancelIcon } from 'react-magma-icons';\r\nimport { I18nContext } from '../../i18n';\r\nimport { useIsInverse } from '../../inverse';\r\nimport { ThemeContext } from '../../theme/ThemeContext';\r\nimport { getNodeText } from '../../utils';\r\nexport var TagColor;\r\n(function (TagColor) {\r\n    TagColor[\"default\"] = \"default\";\r\n    TagColor[\"primary\"] = \"primary\";\r\n    TagColor[\"lowContrast\"] = \"lowContrast\";\r\n    TagColor[\"highContrast\"] = \"highContrast\";\r\n})(TagColor || (TagColor = {}));\r\nexport var TagSize;\r\n(function (TagSize) {\r\n    TagSize[\"medium\"] = \"medium\";\r\n    TagSize[\"small\"] = \"small\";\r\n})(TagSize || (TagSize = {}));\r\nfunction buildBoxShadow(props) {\r\n    if (props.color === 'lowContrast') {\r\n        if (props.isInverse) {\r\n            if (props.disabled) {\r\n                return `0 0 0 1px ${transparentize(0.8, props.theme.colors.neutral100)}`;\r\n            }\r\n            return `0 0 0 1px ${transparentize(0.5, props.theme.colors.neutral100)}`;\r\n        }\r\n        if (props.disabled) {\r\n            return `0 0 0 1px ${props.theme.colors.neutral300}`;\r\n        }\r\n        return `inset 0 0 0  1px ${props.theme.colors.neutral400}`;\r\n    }\r\n}\r\nfunction buildButtonBackground(props) {\r\n    if (props.isInverse) {\r\n        if (props.disabled) {\r\n            // Disabled inverse state background colors\r\n            switch (props.color) {\r\n                case 'primary' || 'highContrast':\r\n                    return transparentize(0.7, props.theme.colors.neutral100);\r\n                case 'lowContrast':\r\n                    return `none`;\r\n                default:\r\n                    return transparentize(0.7, props.theme.colors.neutral100);\r\n            }\r\n        }\r\n        // Inverse background colors\r\n        switch (props.color) {\r\n            case 'primary':\r\n                return props.theme.colors.tertiary500;\r\n            case 'lowContrast':\r\n                return `none;`;\r\n            case 'highContrast':\r\n                return props.theme.colors.neutral100;\r\n            default:\r\n                return props.theme.colors.neutral500;\r\n        }\r\n    }\r\n    else if (props.disabled && !props.isInverse) {\r\n        // Disabled state background colors\r\n        switch (props.color) {\r\n            case 'primary' || 'highContrast':\r\n                return transparentize(0.4, props.theme.colors.neutral300);\r\n            case 'lowContrast':\r\n                return props.theme.colors.neutral100;\r\n            default:\r\n                return transparentize(0.4, props.theme.colors.neutral300);\r\n        }\r\n    }\r\n    // Default state background colors\r\n    switch (props.color) {\r\n        case 'primary':\r\n            return props.theme.colors.primary;\r\n        case 'lowContrast':\r\n            return props.theme.colors.neutral100;\r\n        case 'highContrast':\r\n            return props.theme.colors.neutral700;\r\n        default:\r\n            return props.theme.colors.neutral300;\r\n    }\r\n}\r\nfunction buildButtonTextColor(props) {\r\n    if (props.isInverse) {\r\n        if (props.disabled) {\r\n            // Disabled inverse state text colors\r\n            switch (props.color) {\r\n                case 'primary' || 'highContrast':\r\n                    return transparentize(0.6, props.theme.colors.neutral100);\r\n                case 'lowContrast':\r\n                    return transparentize(0.7, props.theme.colors.neutral100);\r\n                default:\r\n                    return transparentize(0.6, props.theme.colors.neutral100);\r\n            }\r\n        }\r\n        // Inverse text colors\r\n        switch (props.color) {\r\n            case 'primary':\r\n                return props.theme.colors.primary600;\r\n            case 'lowContrast':\r\n                return props.theme.colors.tertiary500;\r\n            case 'highContrast':\r\n                return props.theme.colors.neutral700;\r\n            default:\r\n                return props.theme.colors.neutral100;\r\n        }\r\n    }\r\n    else if (props.disabled && !props.isInverse) {\r\n        // Disabled state text colors\r\n        return transparentize(0.4, props.theme.colors.neutral500);\r\n    }\r\n    // Default state text colors\r\n    switch (props.color) {\r\n        case 'primary':\r\n            return props.theme.colors.neutral100;\r\n        case 'highContrast':\r\n            return props.theme.colors.neutral100;\r\n        case 'lowContrast':\r\n            return props.theme.colors.neutral700;\r\n        default:\r\n            return props.theme.colors.neutral700;\r\n    }\r\n}\r\nfunction buildSvgOpacity(props) {\r\n    if (props.isInverse) {\r\n        if (props.color === 'lowContrast' && props.disabled) {\r\n            return '30%';\r\n        }\r\n        if (props.onClick || props.onDelete) {\r\n            if (props.disabled) {\r\n                return '40%';\r\n            }\r\n            return '75%';\r\n        }\r\n    }\r\n    if (props.onClick || props.onDelete) {\r\n        if (props.disabled) {\r\n            return '60%';\r\n        }\r\n        return '75%';\r\n    }\r\n    if (props.color === 'lowContrast' && props.disabled) {\r\n        return '30%';\r\n    }\r\n    else if (props.disabled) {\r\n        return '40%';\r\n    }\r\n    return '1';\r\n}\r\nfunction buildTagPadding(props) {\r\n    if (props.icon) {\r\n        switch (props.size) {\r\n            case 'small':\r\n                return `0 ${props.theme.spaceScale.spacing02}`;\r\n            default:\r\n                return `${props.theme.spaceScale.spacing02} 6px`;\r\n        }\r\n    }\r\n    switch (props.size) {\r\n        case 'small':\r\n            return `0 ${props.theme.spaceScale.spacing02}`;\r\n        default:\r\n            return `${props.theme.spaceScale.spacing02} 6px`;\r\n    }\r\n}\r\nfunction buildLabelPadding(props) {\r\n    if (props.icon) {\r\n        switch (props.size) {\r\n            case 'small':\r\n                return `0 ${props.theme.spaceScale.spacing02}`;\r\n            default:\r\n                return `0 ${props.theme.spaceScale.spacing03}`;\r\n        }\r\n    }\r\n    switch (props.size) {\r\n        case 'small':\r\n            return `0 ${props.theme.spaceScale.spacing02}`;\r\n        default:\r\n            return `0 ${props.theme.spaceScale.spacing03}`;\r\n    }\r\n}\r\nconst TagStyling = props => css `\n  border: ${props.theme.tag.border};\n  border-radius: ${props.theme.spaceScale.spacing05};\n  background: ${buildButtonBackground(props)};\n  color: ${buildButtonTextColor(props)};\n  box-shadow: ${buildBoxShadow(props)};\n  font-family: ${props.theme.bodyFont};\n  display: ${props.theme.tag.display};\n  align-items: ${props.theme.tag.alignItems};\n  justify-content: ${props.theme.tag.justifyContent};\n  font-size: ${props.size === 'small'\r\n    ? `${props.theme.typeScale.size01.fontSize}`\r\n    : `${props.theme.typeScale.size02.fontSize}`};\n  font-weight: ${props.size === 'small' ? `500` : `inherit`};\n  letter-spacing: ${props.size === 'small'\r\n    ? `${props.theme.typeScale.size01.letterSpacing}`\r\n    : `${props.theme.typeScale.size02.letterSpacing}`};\n  min-width: ${props.size === 'small'\r\n    ? props.theme.spaceScale.spacing10\r\n    : props.theme.spaceScale.spacing12};\n  padding: ${buildTagPadding(props)};\n  svg:first-of-type {\n    opacity: ${props.disabled ? buildSvgOpacity(props) : 'inherit'};\n    height: ${props.size === 'small'\r\n    ? `${props.theme.iconSizes.xSmall}px`\r\n    : `${props.theme.iconSizes.small}px`};\n    width: ${props.size === 'small'\r\n    ? `${props.theme.iconSizes.xSmall}px`\r\n    : `${props.theme.iconSizes.small}px`};\n  }\n  svg:last-child {\n    opacity: ${buildSvgOpacity(props)};\n    width: ${props.size === 'small'\r\n    ? `${props.theme.iconSizes.xSmall}px`\r\n    : `${props.theme.iconSizes.small}px`};\n  }\n`;\r\nconst StyledButton = styled.button `\n  ${TagStyling};\n  cursor: ${props => (props.disabled ? 'not-allowed' : 'pointer')};\n  &:focus {\n    outline-offset: 2px;\n    outline: 2px solid\n      ${props => props.isInverse\r\n    ? props.theme.colors.focusInverse\r\n    : props.theme.colors.focus};\n  }\n`;\r\nconst StyledSpan = styled.span `\n  ${TagStyling};\n  cursor: ${props => (props.disabled ? 'not-allowed' : 'inherit')};\n`;\r\nconst LabelWrap = styled.span `\n  padding: ${buildLabelPadding};\n`;\r\nfunction getStyledTag(isClickable) {\r\n    return isClickable ? StyledButton : StyledSpan;\r\n}\r\nexport const Tag = React.forwardRef((props, ref) => {\r\n    const { children, color, labelText = children, onClick, onDelete, isInverse: isInverseProp, size = TagSize.medium, testId, ...rest } = props;\r\n    const theme = React.useContext(ThemeContext);\r\n    const isInverse = useIsInverse(isInverseProp);\r\n    const i18n = React.useContext(I18nContext);\r\n    const deleteAriaLabel = i18n.tag.deleteAriaLabel.replace(/\\{labelText\\}/g, getNodeText(labelText));\r\n    const { icon } = props;\r\n    const StyledTag = getStyledTag(Boolean(onClick || onDelete));\r\n    function handleClick() {\r\n        if (onClick && typeof onClick === 'function') {\r\n            onClick();\r\n        }\r\n        else if (onDelete && typeof onDelete === 'function') {\r\n            onDelete();\r\n        }\r\n    }\r\n    return (React.createElement(StyledTag, Object.assign({ color: color, icon: icon, onClick: handleClick, isInverse: isInverse, ref: ref, \"data-testid\": props.testId, size: size, theme: theme }, rest),\r\n        icon,\r\n        React.createElement(LabelWrap, Object.assign({ size: size }, rest, { theme: theme }), children),\r\n        onDelete && (React.createElement(CancelIcon, { \"aria-label\": deleteAriaLabel, size: theme.iconSizes.small }))));\r\n});\r\n//# sourceMappingURL=Tag.js.map"]} */"));
20815
+ }, ";}" + (process.env.NODE_ENV === "production" ? "" : "/*# sourceMappingURL=data:application/json;charset=utf-8;base64,{"version":3,"sources":["Tag.tsx"],"names":[],"mappings":"AA2NmC","file":"Tag.tsx","sourcesContent":["import * as React from 'react';\r\nimport { css } from '@emotion/react';\r\nimport styled from '@emotion/styled';\r\nimport { transparentize } from 'polished';\r\nimport { CancelIcon } from 'react-magma-icons';\r\nimport { I18nContext } from '../../i18n';\r\nimport { useIsInverse } from '../../inverse';\r\nimport { ThemeContext } from '../../theme/ThemeContext';\r\nimport { getNodeText } from '../../utils';\r\nexport var TagColor;\r\n(function (TagColor) {\r\n    TagColor[\"default\"] = \"default\";\r\n    TagColor[\"primary\"] = \"primary\";\r\n    TagColor[\"lowContrast\"] = \"lowContrast\";\r\n    TagColor[\"highContrast\"] = \"highContrast\";\r\n})(TagColor || (TagColor = {}));\r\nexport var TagSize;\r\n(function (TagSize) {\r\n    TagSize[\"medium\"] = \"medium\";\r\n    TagSize[\"small\"] = \"small\";\r\n})(TagSize || (TagSize = {}));\r\nfunction buildBoxShadow(props) {\r\n    if (props.color === 'lowContrast') {\r\n        if (props.isInverse) {\r\n            if (props.disabled) {\r\n                return `0 0 0 1px ${transparentize(0.8, props.theme.colors.neutral100)}`;\r\n            }\r\n            return `0 0 0 1px ${transparentize(0.5, props.theme.colors.neutral100)}`;\r\n        }\r\n        if (props.disabled) {\r\n            return `0 0 0 1px ${props.theme.colors.neutral300}`;\r\n        }\r\n        return `inset 0 0 0  1px ${props.theme.colors.neutral400}`;\r\n    }\r\n}\r\nfunction buildButtonBackground(props) {\r\n    if (props.isInverse) {\r\n        if (props.disabled) {\r\n            // Disabled inverse state background colors\r\n            switch (props.color) {\r\n                case 'primary' || 'highContrast':\r\n                    return transparentize(0.7, props.theme.colors.neutral100);\r\n                case 'lowContrast':\r\n                    return `none`;\r\n                default:\r\n                    return transparentize(0.7, props.theme.colors.neutral100);\r\n            }\r\n        }\r\n        // Inverse background colors\r\n        switch (props.color) {\r\n            case 'primary':\r\n                return props.theme.colors.tertiary500;\r\n            case 'lowContrast':\r\n                return `none;`;\r\n            case 'highContrast':\r\n                return props.theme.colors.neutral100;\r\n            default:\r\n                return props.theme.colors.neutral500;\r\n        }\r\n    }\r\n    else if (props.disabled && !props.isInverse) {\r\n        // Disabled state background colors\r\n        switch (props.color) {\r\n            case 'primary' || 'highContrast':\r\n                return transparentize(0.4, props.theme.colors.neutral300);\r\n            case 'lowContrast':\r\n                return props.theme.colors.neutral100;\r\n            default:\r\n                return transparentize(0.4, props.theme.colors.neutral300);\r\n        }\r\n    }\r\n    // Default state background colors\r\n    switch (props.color) {\r\n        case 'primary':\r\n            return props.theme.colors.primary;\r\n        case 'lowContrast':\r\n            return props.theme.colors.neutral100;\r\n        case 'highContrast':\r\n            return props.theme.colors.neutral700;\r\n        default:\r\n            return props.theme.colors.neutral300;\r\n    }\r\n}\r\nfunction buildButtonTextColor(props) {\r\n    if (props.isInverse) {\r\n        if (props.disabled) {\r\n            // Disabled inverse state text colors\r\n            switch (props.color) {\r\n                case 'primary' || 'highContrast':\r\n                    return transparentize(0.6, props.theme.colors.neutral100);\r\n                case 'lowContrast':\r\n                    return transparentize(0.7, props.theme.colors.neutral100);\r\n                default:\r\n                    return transparentize(0.6, props.theme.colors.neutral100);\r\n            }\r\n        }\r\n        // Inverse text colors\r\n        switch (props.color) {\r\n            case 'primary':\r\n                return props.theme.colors.primary600;\r\n            case 'lowContrast':\r\n                return props.theme.colors.tertiary500;\r\n            case 'highContrast':\r\n                return props.theme.colors.neutral700;\r\n            default:\r\n                return props.theme.colors.neutral100;\r\n        }\r\n    }\r\n    else if (props.disabled && !props.isInverse) {\r\n        // Disabled state text colors\r\n        return transparentize(0.4, props.theme.colors.neutral500);\r\n    }\r\n    // Default state text colors\r\n    switch (props.color) {\r\n        case 'primary':\r\n            return props.theme.colors.neutral100;\r\n        case 'highContrast':\r\n            return props.theme.colors.neutral100;\r\n        case 'lowContrast':\r\n            return props.theme.colors.neutral700;\r\n        default:\r\n            return props.theme.colors.neutral700;\r\n    }\r\n}\r\nfunction buildSvgOpacity(props) {\r\n    if (props.isInverse) {\r\n        if (props.color === 'lowContrast' && props.disabled) {\r\n            return '30%';\r\n        }\r\n        if (props.onClick || props.onDelete) {\r\n            if (props.disabled) {\r\n                return '40%';\r\n            }\r\n            return '75%';\r\n        }\r\n    }\r\n    if (props.onClick || props.onDelete) {\r\n        if (props.disabled) {\r\n            return '60%';\r\n        }\r\n        return '75%';\r\n    }\r\n    if (props.color === 'lowContrast' && props.disabled) {\r\n        return '30%';\r\n    }\r\n    else if (props.disabled) {\r\n        return '40%';\r\n    }\r\n    return '1';\r\n}\r\nfunction buildTagPadding(props) {\r\n    if (props.icon) {\r\n        switch (props.size) {\r\n            case 'small':\r\n                return `0 ${props.theme.spaceScale.spacing02}`;\r\n            default:\r\n                return `${props.theme.spaceScale.spacing02} 6px`;\r\n        }\r\n    }\r\n    switch (props.size) {\r\n        case 'small':\r\n            return `0 ${props.theme.spaceScale.spacing02}`;\r\n        default:\r\n            return `${props.theme.spaceScale.spacing02} 6px`;\r\n    }\r\n}\r\nfunction buildLabelPadding(props) {\r\n    if (props.icon) {\r\n        switch (props.size) {\r\n            case 'small':\r\n                return `0 ${props.theme.spaceScale.spacing02}`;\r\n            default:\r\n                return `0 ${props.theme.spaceScale.spacing03}`;\r\n        }\r\n    }\r\n    switch (props.size) {\r\n        case 'small':\r\n            return `0 ${props.theme.spaceScale.spacing02}`;\r\n        default:\r\n            return `0 ${props.theme.spaceScale.spacing03}`;\r\n    }\r\n}\r\nconst TagStyling = props => css `\n  border: ${props.theme.tag.border};\n  border-radius: ${props.theme.spaceScale.spacing05};\n  background: ${buildButtonBackground(props)};\n  color: ${buildButtonTextColor(props)};\n  box-shadow: ${buildBoxShadow(props)};\n  font-family: ${props.theme.bodyFont};\n  display: ${props.theme.tag.display};\n  align-items: ${props.theme.tag.alignItems};\n  justify-content: ${props.theme.tag.justifyContent};\n  font-size: ${props.size === 'small'\r\n    ? `${props.theme.typeScale.size01.fontSize}`\r\n    : `${props.theme.typeScale.size02.fontSize}`};\n  font-weight: ${props.size === 'small' ? `500` : `inherit`};\n  letter-spacing: ${props.size === 'small'\r\n    ? `${props.theme.typeScale.size01.letterSpacing}`\r\n    : `${props.theme.typeScale.size02.letterSpacing}`};\n  min-width: ${props.size === 'small'\r\n    ? props.theme.spaceScale.spacing10\r\n    : props.theme.spaceScale.spacing12};\n  padding: ${buildTagPadding(props)};\n  svg:first-of-type {\n    opacity: ${props.disabled ? buildSvgOpacity(props) : 'inherit'};\n    height: ${props.size === 'small'\r\n    ? `${props.theme.iconSizes.xSmall}px`\r\n    : `${props.theme.iconSizes.small}px`};\n    width: ${props.size === 'small'\r\n    ? `${props.theme.iconSizes.xSmall}px`\r\n    : `${props.theme.iconSizes.small}px`};\n  }\n  svg:last-child {\n    opacity: ${buildSvgOpacity(props)};\n    width: ${props.size === 'small'\r\n    ? `${props.theme.iconSizes.xSmall}px`\r\n    : `${props.theme.iconSizes.small}px`};\n  }\n`;\r\nconst StyledButton = styled.button `\n  ${TagStyling};\n  cursor: ${props => (props.disabled ? 'not-allowed' : 'pointer')};\n  &:focus {\n    outline-offset: 2px;\n    outline: 2px solid\n      ${props => props.isInverse\r\n    ? props.theme.colors.focusInverse\r\n    : props.theme.colors.focus};\n  }\n`;\r\nconst StyledSpan = styled.span `\n  ${TagStyling};\n  cursor: ${props => (props.disabled ? 'not-allowed' : 'inherit')};\n`;\r\nconst LabelWrap = styled.span `\n  padding: ${buildLabelPadding};\n`;\r\nfunction getStyledTag(isClickable) {\r\n    return isClickable ? StyledButton : StyledSpan;\r\n}\r\nexport const Tag = React.forwardRef((props, ref) => {\r\n    const { children, color, labelText = children, onClick, onDelete, isInverse: isInverseProp, size = TagSize.medium, testId, ...rest } = props;\r\n    const theme = React.useContext(ThemeContext);\r\n    const isInverse = useIsInverse(isInverseProp);\r\n    const i18n = React.useContext(I18nContext);\r\n    const nodeLabel = getNodeText(labelText);\r\n    const deleteAriaLabel = i18n.tag.deleteAriaLabel.replace(/\\{labelText\\}/g, nodeLabel);\r\n    const { icon } = props;\r\n    const StyledTag = getStyledTag(Boolean(onClick || onDelete));\r\n    function handleClick() {\r\n        if (onClick && typeof onClick === 'function') {\r\n            onClick();\r\n        }\r\n        else if (onDelete && typeof onDelete === 'function') {\r\n            onDelete();\r\n        }\r\n    }\r\n    return (React.createElement(StyledTag, Object.assign({ \"aria-label\": onDelete ? deleteAriaLabel : nodeLabel, color: color, icon: icon, onClick: handleClick, isInverse: isInverse, ref: ref, \"data-testid\": props.testId, size: size, theme: theme }, rest),\r\n        icon,\r\n        React.createElement(LabelWrap, Object.assign({ size: size, theme: theme }, rest), children),\r\n        onDelete && React.createElement(CancelIcon, { size: theme.iconSizes.small })));\r\n});\r\n//# sourceMappingURL=Tag.js.map"]} */"));
20809
20816
  var StyledSpan$3 = /*#__PURE__*/_styled("span", {
20810
20817
  target: "e10ye2341",
20811
20818
  label: "StyledSpan"
20812
20819
  })(TagStyling, ";cursor:", function (props) {
20813
20820
  return props.disabled ? 'not-allowed' : 'inherit';
20814
- }, ";" + (process.env.NODE_ENV === "production" ? "" : "/*# sourceMappingURL=data:application/json;charset=utf-8;base64,{"version":3,"sources":["Tag.tsx"],"names":[],"mappings":"AAsO+B","file":"Tag.tsx","sourcesContent":["import * as React from 'react';\r\nimport { css } from '@emotion/react';\r\nimport styled from '@emotion/styled';\r\nimport { transparentize } from 'polished';\r\nimport { CancelIcon } from 'react-magma-icons';\r\nimport { I18nContext } from '../../i18n';\r\nimport { useIsInverse } from '../../inverse';\r\nimport { ThemeContext } from '../../theme/ThemeContext';\r\nimport { getNodeText } from '../../utils';\r\nexport var TagColor;\r\n(function (TagColor) {\r\n    TagColor[\"default\"] = \"default\";\r\n    TagColor[\"primary\"] = \"primary\";\r\n    TagColor[\"lowContrast\"] = \"lowContrast\";\r\n    TagColor[\"highContrast\"] = \"highContrast\";\r\n})(TagColor || (TagColor = {}));\r\nexport var TagSize;\r\n(function (TagSize) {\r\n    TagSize[\"medium\"] = \"medium\";\r\n    TagSize[\"small\"] = \"small\";\r\n})(TagSize || (TagSize = {}));\r\nfunction buildBoxShadow(props) {\r\n    if (props.color === 'lowContrast') {\r\n        if (props.isInverse) {\r\n            if (props.disabled) {\r\n                return `0 0 0 1px ${transparentize(0.8, props.theme.colors.neutral100)}`;\r\n            }\r\n            return `0 0 0 1px ${transparentize(0.5, props.theme.colors.neutral100)}`;\r\n        }\r\n        if (props.disabled) {\r\n            return `0 0 0 1px ${props.theme.colors.neutral300}`;\r\n        }\r\n        return `inset 0 0 0  1px ${props.theme.colors.neutral400}`;\r\n    }\r\n}\r\nfunction buildButtonBackground(props) {\r\n    if (props.isInverse) {\r\n        if (props.disabled) {\r\n            // Disabled inverse state background colors\r\n            switch (props.color) {\r\n                case 'primary' || 'highContrast':\r\n                    return transparentize(0.7, props.theme.colors.neutral100);\r\n                case 'lowContrast':\r\n                    return `none`;\r\n                default:\r\n                    return transparentize(0.7, props.theme.colors.neutral100);\r\n            }\r\n        }\r\n        // Inverse background colors\r\n        switch (props.color) {\r\n            case 'primary':\r\n                return props.theme.colors.tertiary500;\r\n            case 'lowContrast':\r\n                return `none;`;\r\n            case 'highContrast':\r\n                return props.theme.colors.neutral100;\r\n            default:\r\n                return props.theme.colors.neutral500;\r\n        }\r\n    }\r\n    else if (props.disabled && !props.isInverse) {\r\n        // Disabled state background colors\r\n        switch (props.color) {\r\n            case 'primary' || 'highContrast':\r\n                return transparentize(0.4, props.theme.colors.neutral300);\r\n            case 'lowContrast':\r\n                return props.theme.colors.neutral100;\r\n            default:\r\n                return transparentize(0.4, props.theme.colors.neutral300);\r\n        }\r\n    }\r\n    // Default state background colors\r\n    switch (props.color) {\r\n        case 'primary':\r\n            return props.theme.colors.primary;\r\n        case 'lowContrast':\r\n            return props.theme.colors.neutral100;\r\n        case 'highContrast':\r\n            return props.theme.colors.neutral700;\r\n        default:\r\n            return props.theme.colors.neutral300;\r\n    }\r\n}\r\nfunction buildButtonTextColor(props) {\r\n    if (props.isInverse) {\r\n        if (props.disabled) {\r\n            // Disabled inverse state text colors\r\n            switch (props.color) {\r\n                case 'primary' || 'highContrast':\r\n                    return transparentize(0.6, props.theme.colors.neutral100);\r\n                case 'lowContrast':\r\n                    return transparentize(0.7, props.theme.colors.neutral100);\r\n                default:\r\n                    return transparentize(0.6, props.theme.colors.neutral100);\r\n            }\r\n        }\r\n        // Inverse text colors\r\n        switch (props.color) {\r\n            case 'primary':\r\n                return props.theme.colors.primary600;\r\n            case 'lowContrast':\r\n                return props.theme.colors.tertiary500;\r\n            case 'highContrast':\r\n                return props.theme.colors.neutral700;\r\n            default:\r\n                return props.theme.colors.neutral100;\r\n        }\r\n    }\r\n    else if (props.disabled && !props.isInverse) {\r\n        // Disabled state text colors\r\n        return transparentize(0.4, props.theme.colors.neutral500);\r\n    }\r\n    // Default state text colors\r\n    switch (props.color) {\r\n        case 'primary':\r\n            return props.theme.colors.neutral100;\r\n        case 'highContrast':\r\n            return props.theme.colors.neutral100;\r\n        case 'lowContrast':\r\n            return props.theme.colors.neutral700;\r\n        default:\r\n            return props.theme.colors.neutral700;\r\n    }\r\n}\r\nfunction buildSvgOpacity(props) {\r\n    if (props.isInverse) {\r\n        if (props.color === 'lowContrast' && props.disabled) {\r\n            return '30%';\r\n        }\r\n        if (props.onClick || props.onDelete) {\r\n            if (props.disabled) {\r\n                return '40%';\r\n            }\r\n            return '75%';\r\n        }\r\n    }\r\n    if (props.onClick || props.onDelete) {\r\n        if (props.disabled) {\r\n            return '60%';\r\n        }\r\n        return '75%';\r\n    }\r\n    if (props.color === 'lowContrast' && props.disabled) {\r\n        return '30%';\r\n    }\r\n    else if (props.disabled) {\r\n        return '40%';\r\n    }\r\n    return '1';\r\n}\r\nfunction buildTagPadding(props) {\r\n    if (props.icon) {\r\n        switch (props.size) {\r\n            case 'small':\r\n                return `0 ${props.theme.spaceScale.spacing02}`;\r\n            default:\r\n                return `${props.theme.spaceScale.spacing02} 6px`;\r\n        }\r\n    }\r\n    switch (props.size) {\r\n        case 'small':\r\n            return `0 ${props.theme.spaceScale.spacing02}`;\r\n        default:\r\n            return `${props.theme.spaceScale.spacing02} 6px`;\r\n    }\r\n}\r\nfunction buildLabelPadding(props) {\r\n    if (props.icon) {\r\n        switch (props.size) {\r\n            case 'small':\r\n                return `0 ${props.theme.spaceScale.spacing02}`;\r\n            default:\r\n                return `0 ${props.theme.spaceScale.spacing03}`;\r\n        }\r\n    }\r\n    switch (props.size) {\r\n        case 'small':\r\n            return `0 ${props.theme.spaceScale.spacing02}`;\r\n        default:\r\n            return `0 ${props.theme.spaceScale.spacing03}`;\r\n    }\r\n}\r\nconst TagStyling = props => css `\n  border: ${props.theme.tag.border};\n  border-radius: ${props.theme.spaceScale.spacing05};\n  background: ${buildButtonBackground(props)};\n  color: ${buildButtonTextColor(props)};\n  box-shadow: ${buildBoxShadow(props)};\n  font-family: ${props.theme.bodyFont};\n  display: ${props.theme.tag.display};\n  align-items: ${props.theme.tag.alignItems};\n  justify-content: ${props.theme.tag.justifyContent};\n  font-size: ${props.size === 'small'\r\n    ? `${props.theme.typeScale.size01.fontSize}`\r\n    : `${props.theme.typeScale.size02.fontSize}`};\n  font-weight: ${props.size === 'small' ? `500` : `inherit`};\n  letter-spacing: ${props.size === 'small'\r\n    ? `${props.theme.typeScale.size01.letterSpacing}`\r\n    : `${props.theme.typeScale.size02.letterSpacing}`};\n  min-width: ${props.size === 'small'\r\n    ? props.theme.spaceScale.spacing10\r\n    : props.theme.spaceScale.spacing12};\n  padding: ${buildTagPadding(props)};\n  svg:first-of-type {\n    opacity: ${props.disabled ? buildSvgOpacity(props) : 'inherit'};\n    height: ${props.size === 'small'\r\n    ? `${props.theme.iconSizes.xSmall}px`\r\n    : `${props.theme.iconSizes.small}px`};\n    width: ${props.size === 'small'\r\n    ? `${props.theme.iconSizes.xSmall}px`\r\n    : `${props.theme.iconSizes.small}px`};\n  }\n  svg:last-child {\n    opacity: ${buildSvgOpacity(props)};\n    width: ${props.size === 'small'\r\n    ? `${props.theme.iconSizes.xSmall}px`\r\n    : `${props.theme.iconSizes.small}px`};\n  }\n`;\r\nconst StyledButton = styled.button `\n  ${TagStyling};\n  cursor: ${props => (props.disabled ? 'not-allowed' : 'pointer')};\n  &:focus {\n    outline-offset: 2px;\n    outline: 2px solid\n      ${props => props.isInverse\r\n    ? props.theme.colors.focusInverse\r\n    : props.theme.colors.focus};\n  }\n`;\r\nconst StyledSpan = styled.span `\n  ${TagStyling};\n  cursor: ${props => (props.disabled ? 'not-allowed' : 'inherit')};\n`;\r\nconst LabelWrap = styled.span `\n  padding: ${buildLabelPadding};\n`;\r\nfunction getStyledTag(isClickable) {\r\n    return isClickable ? StyledButton : StyledSpan;\r\n}\r\nexport const Tag = React.forwardRef((props, ref) => {\r\n    const { children, color, labelText = children, onClick, onDelete, isInverse: isInverseProp, size = TagSize.medium, testId, ...rest } = props;\r\n    const theme = React.useContext(ThemeContext);\r\n    const isInverse = useIsInverse(isInverseProp);\r\n    const i18n = React.useContext(I18nContext);\r\n    const deleteAriaLabel = i18n.tag.deleteAriaLabel.replace(/\\{labelText\\}/g, getNodeText(labelText));\r\n    const { icon } = props;\r\n    const StyledTag = getStyledTag(Boolean(onClick || onDelete));\r\n    function handleClick() {\r\n        if (onClick && typeof onClick === 'function') {\r\n            onClick();\r\n        }\r\n        else if (onDelete && typeof onDelete === 'function') {\r\n            onDelete();\r\n        }\r\n    }\r\n    return (React.createElement(StyledTag, Object.assign({ color: color, icon: icon, onClick: handleClick, isInverse: isInverse, ref: ref, \"data-testid\": props.testId, size: size, theme: theme }, rest),\r\n        icon,\r\n        React.createElement(LabelWrap, Object.assign({ size: size }, rest, { theme: theme }), children),\r\n        onDelete && (React.createElement(CancelIcon, { \"aria-label\": deleteAriaLabel, size: theme.iconSizes.small }))));\r\n});\r\n//# sourceMappingURL=Tag.js.map"]} */"));
20821
+ }, ";" + (process.env.NODE_ENV === "production" ? "" : "/*# sourceMappingURL=data:application/json;charset=utf-8;base64,{"version":3,"sources":["Tag.tsx"],"names":[],"mappings":"AAsO+B","file":"Tag.tsx","sourcesContent":["import * as React from 'react';\r\nimport { css } from '@emotion/react';\r\nimport styled from '@emotion/styled';\r\nimport { transparentize } from 'polished';\r\nimport { CancelIcon } from 'react-magma-icons';\r\nimport { I18nContext } from '../../i18n';\r\nimport { useIsInverse } from '../../inverse';\r\nimport { ThemeContext } from '../../theme/ThemeContext';\r\nimport { getNodeText } from '../../utils';\r\nexport var TagColor;\r\n(function (TagColor) {\r\n    TagColor[\"default\"] = \"default\";\r\n    TagColor[\"primary\"] = \"primary\";\r\n    TagColor[\"lowContrast\"] = \"lowContrast\";\r\n    TagColor[\"highContrast\"] = \"highContrast\";\r\n})(TagColor || (TagColor = {}));\r\nexport var TagSize;\r\n(function (TagSize) {\r\n    TagSize[\"medium\"] = \"medium\";\r\n    TagSize[\"small\"] = \"small\";\r\n})(TagSize || (TagSize = {}));\r\nfunction buildBoxShadow(props) {\r\n    if (props.color === 'lowContrast') {\r\n        if (props.isInverse) {\r\n            if (props.disabled) {\r\n                return `0 0 0 1px ${transparentize(0.8, props.theme.colors.neutral100)}`;\r\n            }\r\n            return `0 0 0 1px ${transparentize(0.5, props.theme.colors.neutral100)}`;\r\n        }\r\n        if (props.disabled) {\r\n            return `0 0 0 1px ${props.theme.colors.neutral300}`;\r\n        }\r\n        return `inset 0 0 0  1px ${props.theme.colors.neutral400}`;\r\n    }\r\n}\r\nfunction buildButtonBackground(props) {\r\n    if (props.isInverse) {\r\n        if (props.disabled) {\r\n            // Disabled inverse state background colors\r\n            switch (props.color) {\r\n                case 'primary' || 'highContrast':\r\n                    return transparentize(0.7, props.theme.colors.neutral100);\r\n                case 'lowContrast':\r\n                    return `none`;\r\n                default:\r\n                    return transparentize(0.7, props.theme.colors.neutral100);\r\n            }\r\n        }\r\n        // Inverse background colors\r\n        switch (props.color) {\r\n            case 'primary':\r\n                return props.theme.colors.tertiary500;\r\n            case 'lowContrast':\r\n                return `none;`;\r\n            case 'highContrast':\r\n                return props.theme.colors.neutral100;\r\n            default:\r\n                return props.theme.colors.neutral500;\r\n        }\r\n    }\r\n    else if (props.disabled && !props.isInverse) {\r\n        // Disabled state background colors\r\n        switch (props.color) {\r\n            case 'primary' || 'highContrast':\r\n                return transparentize(0.4, props.theme.colors.neutral300);\r\n            case 'lowContrast':\r\n                return props.theme.colors.neutral100;\r\n            default:\r\n                return transparentize(0.4, props.theme.colors.neutral300);\r\n        }\r\n    }\r\n    // Default state background colors\r\n    switch (props.color) {\r\n        case 'primary':\r\n            return props.theme.colors.primary;\r\n        case 'lowContrast':\r\n            return props.theme.colors.neutral100;\r\n        case 'highContrast':\r\n            return props.theme.colors.neutral700;\r\n        default:\r\n            return props.theme.colors.neutral300;\r\n    }\r\n}\r\nfunction buildButtonTextColor(props) {\r\n    if (props.isInverse) {\r\n        if (props.disabled) {\r\n            // Disabled inverse state text colors\r\n            switch (props.color) {\r\n                case 'primary' || 'highContrast':\r\n                    return transparentize(0.6, props.theme.colors.neutral100);\r\n                case 'lowContrast':\r\n                    return transparentize(0.7, props.theme.colors.neutral100);\r\n                default:\r\n                    return transparentize(0.6, props.theme.colors.neutral100);\r\n            }\r\n        }\r\n        // Inverse text colors\r\n        switch (props.color) {\r\n            case 'primary':\r\n                return props.theme.colors.primary600;\r\n            case 'lowContrast':\r\n                return props.theme.colors.tertiary500;\r\n            case 'highContrast':\r\n                return props.theme.colors.neutral700;\r\n            default:\r\n                return props.theme.colors.neutral100;\r\n        }\r\n    }\r\n    else if (props.disabled && !props.isInverse) {\r\n        // Disabled state text colors\r\n        return transparentize(0.4, props.theme.colors.neutral500);\r\n    }\r\n    // Default state text colors\r\n    switch (props.color) {\r\n        case 'primary':\r\n            return props.theme.colors.neutral100;\r\n        case 'highContrast':\r\n            return props.theme.colors.neutral100;\r\n        case 'lowContrast':\r\n            return props.theme.colors.neutral700;\r\n        default:\r\n            return props.theme.colors.neutral700;\r\n    }\r\n}\r\nfunction buildSvgOpacity(props) {\r\n    if (props.isInverse) {\r\n        if (props.color === 'lowContrast' && props.disabled) {\r\n            return '30%';\r\n        }\r\n        if (props.onClick || props.onDelete) {\r\n            if (props.disabled) {\r\n                return '40%';\r\n            }\r\n            return '75%';\r\n        }\r\n    }\r\n    if (props.onClick || props.onDelete) {\r\n        if (props.disabled) {\r\n            return '60%';\r\n        }\r\n        return '75%';\r\n    }\r\n    if (props.color === 'lowContrast' && props.disabled) {\r\n        return '30%';\r\n    }\r\n    else if (props.disabled) {\r\n        return '40%';\r\n    }\r\n    return '1';\r\n}\r\nfunction buildTagPadding(props) {\r\n    if (props.icon) {\r\n        switch (props.size) {\r\n            case 'small':\r\n                return `0 ${props.theme.spaceScale.spacing02}`;\r\n            default:\r\n                return `${props.theme.spaceScale.spacing02} 6px`;\r\n        }\r\n    }\r\n    switch (props.size) {\r\n        case 'small':\r\n            return `0 ${props.theme.spaceScale.spacing02}`;\r\n        default:\r\n            return `${props.theme.spaceScale.spacing02} 6px`;\r\n    }\r\n}\r\nfunction buildLabelPadding(props) {\r\n    if (props.icon) {\r\n        switch (props.size) {\r\n            case 'small':\r\n                return `0 ${props.theme.spaceScale.spacing02}`;\r\n            default:\r\n                return `0 ${props.theme.spaceScale.spacing03}`;\r\n        }\r\n    }\r\n    switch (props.size) {\r\n        case 'small':\r\n            return `0 ${props.theme.spaceScale.spacing02}`;\r\n        default:\r\n            return `0 ${props.theme.spaceScale.spacing03}`;\r\n    }\r\n}\r\nconst TagStyling = props => css `\n  border: ${props.theme.tag.border};\n  border-radius: ${props.theme.spaceScale.spacing05};\n  background: ${buildButtonBackground(props)};\n  color: ${buildButtonTextColor(props)};\n  box-shadow: ${buildBoxShadow(props)};\n  font-family: ${props.theme.bodyFont};\n  display: ${props.theme.tag.display};\n  align-items: ${props.theme.tag.alignItems};\n  justify-content: ${props.theme.tag.justifyContent};\n  font-size: ${props.size === 'small'\r\n    ? `${props.theme.typeScale.size01.fontSize}`\r\n    : `${props.theme.typeScale.size02.fontSize}`};\n  font-weight: ${props.size === 'small' ? `500` : `inherit`};\n  letter-spacing: ${props.size === 'small'\r\n    ? `${props.theme.typeScale.size01.letterSpacing}`\r\n    : `${props.theme.typeScale.size02.letterSpacing}`};\n  min-width: ${props.size === 'small'\r\n    ? props.theme.spaceScale.spacing10\r\n    : props.theme.spaceScale.spacing12};\n  padding: ${buildTagPadding(props)};\n  svg:first-of-type {\n    opacity: ${props.disabled ? buildSvgOpacity(props) : 'inherit'};\n    height: ${props.size === 'small'\r\n    ? `${props.theme.iconSizes.xSmall}px`\r\n    : `${props.theme.iconSizes.small}px`};\n    width: ${props.size === 'small'\r\n    ? `${props.theme.iconSizes.xSmall}px`\r\n    : `${props.theme.iconSizes.small}px`};\n  }\n  svg:last-child {\n    opacity: ${buildSvgOpacity(props)};\n    width: ${props.size === 'small'\r\n    ? `${props.theme.iconSizes.xSmall}px`\r\n    : `${props.theme.iconSizes.small}px`};\n  }\n`;\r\nconst StyledButton = styled.button `\n  ${TagStyling};\n  cursor: ${props => (props.disabled ? 'not-allowed' : 'pointer')};\n  &:focus {\n    outline-offset: 2px;\n    outline: 2px solid\n      ${props => props.isInverse\r\n    ? props.theme.colors.focusInverse\r\n    : props.theme.colors.focus};\n  }\n`;\r\nconst StyledSpan = styled.span `\n  ${TagStyling};\n  cursor: ${props => (props.disabled ? 'not-allowed' : 'inherit')};\n`;\r\nconst LabelWrap = styled.span `\n  padding: ${buildLabelPadding};\n`;\r\nfunction getStyledTag(isClickable) {\r\n    return isClickable ? StyledButton : StyledSpan;\r\n}\r\nexport const Tag = React.forwardRef((props, ref) => {\r\n    const { children, color, labelText = children, onClick, onDelete, isInverse: isInverseProp, size = TagSize.medium, testId, ...rest } = props;\r\n    const theme = React.useContext(ThemeContext);\r\n    const isInverse = useIsInverse(isInverseProp);\r\n    const i18n = React.useContext(I18nContext);\r\n    const nodeLabel = getNodeText(labelText);\r\n    const deleteAriaLabel = i18n.tag.deleteAriaLabel.replace(/\\{labelText\\}/g, nodeLabel);\r\n    const { icon } = props;\r\n    const StyledTag = getStyledTag(Boolean(onClick || onDelete));\r\n    function handleClick() {\r\n        if (onClick && typeof onClick === 'function') {\r\n            onClick();\r\n        }\r\n        else if (onDelete && typeof onDelete === 'function') {\r\n            onDelete();\r\n        }\r\n    }\r\n    return (React.createElement(StyledTag, Object.assign({ \"aria-label\": onDelete ? deleteAriaLabel : nodeLabel, color: color, icon: icon, onClick: handleClick, isInverse: isInverse, ref: ref, \"data-testid\": props.testId, size: size, theme: theme }, rest),\r\n        icon,\r\n        React.createElement(LabelWrap, Object.assign({ size: size, theme: theme }, rest), children),\r\n        onDelete && React.createElement(CancelIcon, { size: theme.iconSizes.small })));\r\n});\r\n//# sourceMappingURL=Tag.js.map"]} */"));
20815
20822
  var LabelWrap = /*#__PURE__*/_styled("span", {
20816
20823
  target: "e10ye2340",
20817
20824
  label: "LabelWrap"
20818
- })("padding:", buildLabelPadding, ";" + (process.env.NODE_ENV === "production" ? "" : "/*# sourceMappingURL=data:application/json;charset=utf-8;base64,{"version":3,"sources":["Tag.tsx"],"names":[],"mappings":"AA0O8B","file":"Tag.tsx","sourcesContent":["import * as React from 'react';\r\nimport { css } from '@emotion/react';\r\nimport styled from '@emotion/styled';\r\nimport { transparentize } from 'polished';\r\nimport { CancelIcon } from 'react-magma-icons';\r\nimport { I18nContext } from '../../i18n';\r\nimport { useIsInverse } from '../../inverse';\r\nimport { ThemeContext } from '../../theme/ThemeContext';\r\nimport { getNodeText } from '../../utils';\r\nexport var TagColor;\r\n(function (TagColor) {\r\n    TagColor[\"default\"] = \"default\";\r\n    TagColor[\"primary\"] = \"primary\";\r\n    TagColor[\"lowContrast\"] = \"lowContrast\";\r\n    TagColor[\"highContrast\"] = \"highContrast\";\r\n})(TagColor || (TagColor = {}));\r\nexport var TagSize;\r\n(function (TagSize) {\r\n    TagSize[\"medium\"] = \"medium\";\r\n    TagSize[\"small\"] = \"small\";\r\n})(TagSize || (TagSize = {}));\r\nfunction buildBoxShadow(props) {\r\n    if (props.color === 'lowContrast') {\r\n        if (props.isInverse) {\r\n            if (props.disabled) {\r\n                return `0 0 0 1px ${transparentize(0.8, props.theme.colors.neutral100)}`;\r\n            }\r\n            return `0 0 0 1px ${transparentize(0.5, props.theme.colors.neutral100)}`;\r\n        }\r\n        if (props.disabled) {\r\n            return `0 0 0 1px ${props.theme.colors.neutral300}`;\r\n        }\r\n        return `inset 0 0 0  1px ${props.theme.colors.neutral400}`;\r\n    }\r\n}\r\nfunction buildButtonBackground(props) {\r\n    if (props.isInverse) {\r\n        if (props.disabled) {\r\n            // Disabled inverse state background colors\r\n            switch (props.color) {\r\n                case 'primary' || 'highContrast':\r\n                    return transparentize(0.7, props.theme.colors.neutral100);\r\n                case 'lowContrast':\r\n                    return `none`;\r\n                default:\r\n                    return transparentize(0.7, props.theme.colors.neutral100);\r\n            }\r\n        }\r\n        // Inverse background colors\r\n        switch (props.color) {\r\n            case 'primary':\r\n                return props.theme.colors.tertiary500;\r\n            case 'lowContrast':\r\n                return `none;`;\r\n            case 'highContrast':\r\n                return props.theme.colors.neutral100;\r\n            default:\r\n                return props.theme.colors.neutral500;\r\n        }\r\n    }\r\n    else if (props.disabled && !props.isInverse) {\r\n        // Disabled state background colors\r\n        switch (props.color) {\r\n            case 'primary' || 'highContrast':\r\n                return transparentize(0.4, props.theme.colors.neutral300);\r\n            case 'lowContrast':\r\n                return props.theme.colors.neutral100;\r\n            default:\r\n                return transparentize(0.4, props.theme.colors.neutral300);\r\n        }\r\n    }\r\n    // Default state background colors\r\n    switch (props.color) {\r\n        case 'primary':\r\n            return props.theme.colors.primary;\r\n        case 'lowContrast':\r\n            return props.theme.colors.neutral100;\r\n        case 'highContrast':\r\n            return props.theme.colors.neutral700;\r\n        default:\r\n            return props.theme.colors.neutral300;\r\n    }\r\n}\r\nfunction buildButtonTextColor(props) {\r\n    if (props.isInverse) {\r\n        if (props.disabled) {\r\n            // Disabled inverse state text colors\r\n            switch (props.color) {\r\n                case 'primary' || 'highContrast':\r\n                    return transparentize(0.6, props.theme.colors.neutral100);\r\n                case 'lowContrast':\r\n                    return transparentize(0.7, props.theme.colors.neutral100);\r\n                default:\r\n                    return transparentize(0.6, props.theme.colors.neutral100);\r\n            }\r\n        }\r\n        // Inverse text colors\r\n        switch (props.color) {\r\n            case 'primary':\r\n                return props.theme.colors.primary600;\r\n            case 'lowContrast':\r\n                return props.theme.colors.tertiary500;\r\n            case 'highContrast':\r\n                return props.theme.colors.neutral700;\r\n            default:\r\n                return props.theme.colors.neutral100;\r\n        }\r\n    }\r\n    else if (props.disabled && !props.isInverse) {\r\n        // Disabled state text colors\r\n        return transparentize(0.4, props.theme.colors.neutral500);\r\n    }\r\n    // Default state text colors\r\n    switch (props.color) {\r\n        case 'primary':\r\n            return props.theme.colors.neutral100;\r\n        case 'highContrast':\r\n            return props.theme.colors.neutral100;\r\n        case 'lowContrast':\r\n            return props.theme.colors.neutral700;\r\n        default:\r\n            return props.theme.colors.neutral700;\r\n    }\r\n}\r\nfunction buildSvgOpacity(props) {\r\n    if (props.isInverse) {\r\n        if (props.color === 'lowContrast' && props.disabled) {\r\n            return '30%';\r\n        }\r\n        if (props.onClick || props.onDelete) {\r\n            if (props.disabled) {\r\n                return '40%';\r\n            }\r\n            return '75%';\r\n        }\r\n    }\r\n    if (props.onClick || props.onDelete) {\r\n        if (props.disabled) {\r\n            return '60%';\r\n        }\r\n        return '75%';\r\n    }\r\n    if (props.color === 'lowContrast' && props.disabled) {\r\n        return '30%';\r\n    }\r\n    else if (props.disabled) {\r\n        return '40%';\r\n    }\r\n    return '1';\r\n}\r\nfunction buildTagPadding(props) {\r\n    if (props.icon) {\r\n        switch (props.size) {\r\n            case 'small':\r\n                return `0 ${props.theme.spaceScale.spacing02}`;\r\n            default:\r\n                return `${props.theme.spaceScale.spacing02} 6px`;\r\n        }\r\n    }\r\n    switch (props.size) {\r\n        case 'small':\r\n            return `0 ${props.theme.spaceScale.spacing02}`;\r\n        default:\r\n            return `${props.theme.spaceScale.spacing02} 6px`;\r\n    }\r\n}\r\nfunction buildLabelPadding(props) {\r\n    if (props.icon) {\r\n        switch (props.size) {\r\n            case 'small':\r\n                return `0 ${props.theme.spaceScale.spacing02}`;\r\n            default:\r\n                return `0 ${props.theme.spaceScale.spacing03}`;\r\n        }\r\n    }\r\n    switch (props.size) {\r\n        case 'small':\r\n            return `0 ${props.theme.spaceScale.spacing02}`;\r\n        default:\r\n            return `0 ${props.theme.spaceScale.spacing03}`;\r\n    }\r\n}\r\nconst TagStyling = props => css `\n  border: ${props.theme.tag.border};\n  border-radius: ${props.theme.spaceScale.spacing05};\n  background: ${buildButtonBackground(props)};\n  color: ${buildButtonTextColor(props)};\n  box-shadow: ${buildBoxShadow(props)};\n  font-family: ${props.theme.bodyFont};\n  display: ${props.theme.tag.display};\n  align-items: ${props.theme.tag.alignItems};\n  justify-content: ${props.theme.tag.justifyContent};\n  font-size: ${props.size === 'small'\r\n    ? `${props.theme.typeScale.size01.fontSize}`\r\n    : `${props.theme.typeScale.size02.fontSize}`};\n  font-weight: ${props.size === 'small' ? `500` : `inherit`};\n  letter-spacing: ${props.size === 'small'\r\n    ? `${props.theme.typeScale.size01.letterSpacing}`\r\n    : `${props.theme.typeScale.size02.letterSpacing}`};\n  min-width: ${props.size === 'small'\r\n    ? props.theme.spaceScale.spacing10\r\n    : props.theme.spaceScale.spacing12};\n  padding: ${buildTagPadding(props)};\n  svg:first-of-type {\n    opacity: ${props.disabled ? buildSvgOpacity(props) : 'inherit'};\n    height: ${props.size === 'small'\r\n    ? `${props.theme.iconSizes.xSmall}px`\r\n    : `${props.theme.iconSizes.small}px`};\n    width: ${props.size === 'small'\r\n    ? `${props.theme.iconSizes.xSmall}px`\r\n    : `${props.theme.iconSizes.small}px`};\n  }\n  svg:last-child {\n    opacity: ${buildSvgOpacity(props)};\n    width: ${props.size === 'small'\r\n    ? `${props.theme.iconSizes.xSmall}px`\r\n    : `${props.theme.iconSizes.small}px`};\n  }\n`;\r\nconst StyledButton = styled.button `\n  ${TagStyling};\n  cursor: ${props => (props.disabled ? 'not-allowed' : 'pointer')};\n  &:focus {\n    outline-offset: 2px;\n    outline: 2px solid\n      ${props => props.isInverse\r\n    ? props.theme.colors.focusInverse\r\n    : props.theme.colors.focus};\n  }\n`;\r\nconst StyledSpan = styled.span `\n  ${TagStyling};\n  cursor: ${props => (props.disabled ? 'not-allowed' : 'inherit')};\n`;\r\nconst LabelWrap = styled.span `\n  padding: ${buildLabelPadding};\n`;\r\nfunction getStyledTag(isClickable) {\r\n    return isClickable ? StyledButton : StyledSpan;\r\n}\r\nexport const Tag = React.forwardRef((props, ref) => {\r\n    const { children, color, labelText = children, onClick, onDelete, isInverse: isInverseProp, size = TagSize.medium, testId, ...rest } = props;\r\n    const theme = React.useContext(ThemeContext);\r\n    const isInverse = useIsInverse(isInverseProp);\r\n    const i18n = React.useContext(I18nContext);\r\n    const deleteAriaLabel = i18n.tag.deleteAriaLabel.replace(/\\{labelText\\}/g, getNodeText(labelText));\r\n    const { icon } = props;\r\n    const StyledTag = getStyledTag(Boolean(onClick || onDelete));\r\n    function handleClick() {\r\n        if (onClick && typeof onClick === 'function') {\r\n            onClick();\r\n        }\r\n        else if (onDelete && typeof onDelete === 'function') {\r\n            onDelete();\r\n        }\r\n    }\r\n    return (React.createElement(StyledTag, Object.assign({ color: color, icon: icon, onClick: handleClick, isInverse: isInverse, ref: ref, \"data-testid\": props.testId, size: size, theme: theme }, rest),\r\n        icon,\r\n        React.createElement(LabelWrap, Object.assign({ size: size }, rest, { theme: theme }), children),\r\n        onDelete && (React.createElement(CancelIcon, { \"aria-label\": deleteAriaLabel, size: theme.iconSizes.small }))));\r\n});\r\n//# sourceMappingURL=Tag.js.map"]} */"));
20825
+ })("padding:", buildLabelPadding, ";" + (process.env.NODE_ENV === "production" ? "" : "/*# sourceMappingURL=data:application/json;charset=utf-8;base64,{"version":3,"sources":["Tag.tsx"],"names":[],"mappings":"AA0O8B","file":"Tag.tsx","sourcesContent":["import * as React from 'react';\r\nimport { css } from '@emotion/react';\r\nimport styled from '@emotion/styled';\r\nimport { transparentize } from 'polished';\r\nimport { CancelIcon } from 'react-magma-icons';\r\nimport { I18nContext } from '../../i18n';\r\nimport { useIsInverse } from '../../inverse';\r\nimport { ThemeContext } from '../../theme/ThemeContext';\r\nimport { getNodeText } from '../../utils';\r\nexport var TagColor;\r\n(function (TagColor) {\r\n    TagColor[\"default\"] = \"default\";\r\n    TagColor[\"primary\"] = \"primary\";\r\n    TagColor[\"lowContrast\"] = \"lowContrast\";\r\n    TagColor[\"highContrast\"] = \"highContrast\";\r\n})(TagColor || (TagColor = {}));\r\nexport var TagSize;\r\n(function (TagSize) {\r\n    TagSize[\"medium\"] = \"medium\";\r\n    TagSize[\"small\"] = \"small\";\r\n})(TagSize || (TagSize = {}));\r\nfunction buildBoxShadow(props) {\r\n    if (props.color === 'lowContrast') {\r\n        if (props.isInverse) {\r\n            if (props.disabled) {\r\n                return `0 0 0 1px ${transparentize(0.8, props.theme.colors.neutral100)}`;\r\n            }\r\n            return `0 0 0 1px ${transparentize(0.5, props.theme.colors.neutral100)}`;\r\n        }\r\n        if (props.disabled) {\r\n            return `0 0 0 1px ${props.theme.colors.neutral300}`;\r\n        }\r\n        return `inset 0 0 0  1px ${props.theme.colors.neutral400}`;\r\n    }\r\n}\r\nfunction buildButtonBackground(props) {\r\n    if (props.isInverse) {\r\n        if (props.disabled) {\r\n            // Disabled inverse state background colors\r\n            switch (props.color) {\r\n                case 'primary' || 'highContrast':\r\n                    return transparentize(0.7, props.theme.colors.neutral100);\r\n                case 'lowContrast':\r\n                    return `none`;\r\n                default:\r\n                    return transparentize(0.7, props.theme.colors.neutral100);\r\n            }\r\n        }\r\n        // Inverse background colors\r\n        switch (props.color) {\r\n            case 'primary':\r\n                return props.theme.colors.tertiary500;\r\n            case 'lowContrast':\r\n                return `none;`;\r\n            case 'highContrast':\r\n                return props.theme.colors.neutral100;\r\n            default:\r\n                return props.theme.colors.neutral500;\r\n        }\r\n    }\r\n    else if (props.disabled && !props.isInverse) {\r\n        // Disabled state background colors\r\n        switch (props.color) {\r\n            case 'primary' || 'highContrast':\r\n                return transparentize(0.4, props.theme.colors.neutral300);\r\n            case 'lowContrast':\r\n                return props.theme.colors.neutral100;\r\n            default:\r\n                return transparentize(0.4, props.theme.colors.neutral300);\r\n        }\r\n    }\r\n    // Default state background colors\r\n    switch (props.color) {\r\n        case 'primary':\r\n            return props.theme.colors.primary;\r\n        case 'lowContrast':\r\n            return props.theme.colors.neutral100;\r\n        case 'highContrast':\r\n            return props.theme.colors.neutral700;\r\n        default:\r\n            return props.theme.colors.neutral300;\r\n    }\r\n}\r\nfunction buildButtonTextColor(props) {\r\n    if (props.isInverse) {\r\n        if (props.disabled) {\r\n            // Disabled inverse state text colors\r\n            switch (props.color) {\r\n                case 'primary' || 'highContrast':\r\n                    return transparentize(0.6, props.theme.colors.neutral100);\r\n                case 'lowContrast':\r\n                    return transparentize(0.7, props.theme.colors.neutral100);\r\n                default:\r\n                    return transparentize(0.6, props.theme.colors.neutral100);\r\n            }\r\n        }\r\n        // Inverse text colors\r\n        switch (props.color) {\r\n            case 'primary':\r\n                return props.theme.colors.primary600;\r\n            case 'lowContrast':\r\n                return props.theme.colors.tertiary500;\r\n            case 'highContrast':\r\n                return props.theme.colors.neutral700;\r\n            default:\r\n                return props.theme.colors.neutral100;\r\n        }\r\n    }\r\n    else if (props.disabled && !props.isInverse) {\r\n        // Disabled state text colors\r\n        return transparentize(0.4, props.theme.colors.neutral500);\r\n    }\r\n    // Default state text colors\r\n    switch (props.color) {\r\n        case 'primary':\r\n            return props.theme.colors.neutral100;\r\n        case 'highContrast':\r\n            return props.theme.colors.neutral100;\r\n        case 'lowContrast':\r\n            return props.theme.colors.neutral700;\r\n        default:\r\n            return props.theme.colors.neutral700;\r\n    }\r\n}\r\nfunction buildSvgOpacity(props) {\r\n    if (props.isInverse) {\r\n        if (props.color === 'lowContrast' && props.disabled) {\r\n            return '30%';\r\n        }\r\n        if (props.onClick || props.onDelete) {\r\n            if (props.disabled) {\r\n                return '40%';\r\n            }\r\n            return '75%';\r\n        }\r\n    }\r\n    if (props.onClick || props.onDelete) {\r\n        if (props.disabled) {\r\n            return '60%';\r\n        }\r\n        return '75%';\r\n    }\r\n    if (props.color === 'lowContrast' && props.disabled) {\r\n        return '30%';\r\n    }\r\n    else if (props.disabled) {\r\n        return '40%';\r\n    }\r\n    return '1';\r\n}\r\nfunction buildTagPadding(props) {\r\n    if (props.icon) {\r\n        switch (props.size) {\r\n            case 'small':\r\n                return `0 ${props.theme.spaceScale.spacing02}`;\r\n            default:\r\n                return `${props.theme.spaceScale.spacing02} 6px`;\r\n        }\r\n    }\r\n    switch (props.size) {\r\n        case 'small':\r\n            return `0 ${props.theme.spaceScale.spacing02}`;\r\n        default:\r\n            return `${props.theme.spaceScale.spacing02} 6px`;\r\n    }\r\n}\r\nfunction buildLabelPadding(props) {\r\n    if (props.icon) {\r\n        switch (props.size) {\r\n            case 'small':\r\n                return `0 ${props.theme.spaceScale.spacing02}`;\r\n            default:\r\n                return `0 ${props.theme.spaceScale.spacing03}`;\r\n        }\r\n    }\r\n    switch (props.size) {\r\n        case 'small':\r\n            return `0 ${props.theme.spaceScale.spacing02}`;\r\n        default:\r\n            return `0 ${props.theme.spaceScale.spacing03}`;\r\n    }\r\n}\r\nconst TagStyling = props => css `\n  border: ${props.theme.tag.border};\n  border-radius: ${props.theme.spaceScale.spacing05};\n  background: ${buildButtonBackground(props)};\n  color: ${buildButtonTextColor(props)};\n  box-shadow: ${buildBoxShadow(props)};\n  font-family: ${props.theme.bodyFont};\n  display: ${props.theme.tag.display};\n  align-items: ${props.theme.tag.alignItems};\n  justify-content: ${props.theme.tag.justifyContent};\n  font-size: ${props.size === 'small'\r\n    ? `${props.theme.typeScale.size01.fontSize}`\r\n    : `${props.theme.typeScale.size02.fontSize}`};\n  font-weight: ${props.size === 'small' ? `500` : `inherit`};\n  letter-spacing: ${props.size === 'small'\r\n    ? `${props.theme.typeScale.size01.letterSpacing}`\r\n    : `${props.theme.typeScale.size02.letterSpacing}`};\n  min-width: ${props.size === 'small'\r\n    ? props.theme.spaceScale.spacing10\r\n    : props.theme.spaceScale.spacing12};\n  padding: ${buildTagPadding(props)};\n  svg:first-of-type {\n    opacity: ${props.disabled ? buildSvgOpacity(props) : 'inherit'};\n    height: ${props.size === 'small'\r\n    ? `${props.theme.iconSizes.xSmall}px`\r\n    : `${props.theme.iconSizes.small}px`};\n    width: ${props.size === 'small'\r\n    ? `${props.theme.iconSizes.xSmall}px`\r\n    : `${props.theme.iconSizes.small}px`};\n  }\n  svg:last-child {\n    opacity: ${buildSvgOpacity(props)};\n    width: ${props.size === 'small'\r\n    ? `${props.theme.iconSizes.xSmall}px`\r\n    : `${props.theme.iconSizes.small}px`};\n  }\n`;\r\nconst StyledButton = styled.button `\n  ${TagStyling};\n  cursor: ${props => (props.disabled ? 'not-allowed' : 'pointer')};\n  &:focus {\n    outline-offset: 2px;\n    outline: 2px solid\n      ${props => props.isInverse\r\n    ? props.theme.colors.focusInverse\r\n    : props.theme.colors.focus};\n  }\n`;\r\nconst StyledSpan = styled.span `\n  ${TagStyling};\n  cursor: ${props => (props.disabled ? 'not-allowed' : 'inherit')};\n`;\r\nconst LabelWrap = styled.span `\n  padding: ${buildLabelPadding};\n`;\r\nfunction getStyledTag(isClickable) {\r\n    return isClickable ? StyledButton : StyledSpan;\r\n}\r\nexport const Tag = React.forwardRef((props, ref) => {\r\n    const { children, color, labelText = children, onClick, onDelete, isInverse: isInverseProp, size = TagSize.medium, testId, ...rest } = props;\r\n    const theme = React.useContext(ThemeContext);\r\n    const isInverse = useIsInverse(isInverseProp);\r\n    const i18n = React.useContext(I18nContext);\r\n    const nodeLabel = getNodeText(labelText);\r\n    const deleteAriaLabel = i18n.tag.deleteAriaLabel.replace(/\\{labelText\\}/g, nodeLabel);\r\n    const { icon } = props;\r\n    const StyledTag = getStyledTag(Boolean(onClick || onDelete));\r\n    function handleClick() {\r\n        if (onClick && typeof onClick === 'function') {\r\n            onClick();\r\n        }\r\n        else if (onDelete && typeof onDelete === 'function') {\r\n            onDelete();\r\n        }\r\n    }\r\n    return (React.createElement(StyledTag, Object.assign({ \"aria-label\": onDelete ? deleteAriaLabel : nodeLabel, color: color, icon: icon, onClick: handleClick, isInverse: isInverse, ref: ref, \"data-testid\": props.testId, size: size, theme: theme }, rest),\r\n        icon,\r\n        React.createElement(LabelWrap, Object.assign({ size: size, theme: theme }, rest), children),\r\n        onDelete && React.createElement(CancelIcon, { size: theme.iconSizes.small })));\r\n});\r\n//# sourceMappingURL=Tag.js.map"]} */"));
20819
20826
  function getStyledTag(isClickable) {
20820
20827
  return isClickable ? StyledButton$5 : StyledSpan$3;
20821
20828
  }
@@ -20833,7 +20840,8 @@ var Tag = /*#__PURE__*/forwardRef(function (props, ref) {
20833
20840
  var theme = useContext(ThemeContext);
20834
20841
  var isInverse = useIsInverse(isInverseProp);
20835
20842
  var i18n = useContext(I18nContext);
20836
- var deleteAriaLabel = i18n.tag.deleteAriaLabel.replace(/\{labelText\}/g, getNodeText(labelText));
20843
+ var nodeLabel = getNodeText(labelText);
20844
+ var deleteAriaLabel = i18n.tag.deleteAriaLabel.replace(/\{labelText\}/g, nodeLabel);
20837
20845
  var icon = props.icon;
20838
20846
  var StyledTag = getStyledTag(Boolean(onClick || onDelete));
20839
20847
  function handleClick() {
@@ -20844,6 +20852,7 @@ var Tag = /*#__PURE__*/forwardRef(function (props, ref) {
20844
20852
  }
20845
20853
  }
20846
20854
  return createElement(StyledTag, Object.assign({
20855
+ "aria-label": onDelete ? deleteAriaLabel : nodeLabel,
20847
20856
  color: color,
20848
20857
  icon: icon,
20849
20858
  onClick: handleClick,
@@ -20853,11 +20862,9 @@ var Tag = /*#__PURE__*/forwardRef(function (props, ref) {
20853
20862
  size: size,
20854
20863
  theme: theme
20855
20864
  }, rest), icon, createElement(LabelWrap, Object.assign({
20856
- size: size
20857
- }, rest, {
20865
+ size: size,
20858
20866
  theme: theme
20859
- }), children), onDelete && createElement(CancelIcon, {
20860
- "aria-label": deleteAriaLabel,
20867
+ }, rest), children), onDelete && createElement(CancelIcon, {
20861
20868
  size: theme.iconSizes.small
20862
20869
  }));
20863
20870
  });