react-magma-dom 5.1.0-rc.19 → 5.1.0-rc.21
This diff represents the content of publicly available package versions that have been released to one of the supported registries. The information contained in this diff is provided for informational purposes only and reflects changes between package versions as they appear in their respective public registries.
- package/dist/components/Banner/index.d.ts +4 -0
- package/dist/components/Popover/Popover.d.ts +0 -1
- package/dist/esm/index.js +27 -20
- package/dist/esm/index.js.map +1 -1
- package/dist/react-magma-dom.cjs.development.js +27 -20
- package/dist/react-magma-dom.cjs.development.js.map +1 -1
- package/dist/react-magma-dom.cjs.production.min.js +1 -1
- package/dist/react-magma-dom.cjs.production.min.js.map +1 -1
- package/dist/utils/index.d.ts +1 -0
- package/package.json +1 -1
|
@@ -22,6 +22,10 @@ export interface BannerProps extends AlertProps {
|
|
|
22
22
|
* @default false
|
|
23
23
|
*/
|
|
24
24
|
isDismissible?: boolean;
|
|
25
|
+
/**
|
|
26
|
+
* Reference to the dismiss button element
|
|
27
|
+
*/
|
|
28
|
+
dismissibleButtonRef?: React.Ref<HTMLButtonElement>;
|
|
25
29
|
isInverse?: boolean;
|
|
26
30
|
}
|
|
27
31
|
export declare const Banner: React.ForwardRefExoticComponent<BannerProps & React.RefAttributes<HTMLDivElement>>;
|
|
@@ -112,5 +112,4 @@ export interface PopoverContextInterface {
|
|
|
112
112
|
}
|
|
113
113
|
export declare const PopoverContext: React.Context<PopoverContextInterface>;
|
|
114
114
|
export declare function hasActiveElementsChecker(ref: any): boolean;
|
|
115
|
-
export declare function isElementInteractive(element: EventTarget | null): boolean;
|
|
116
115
|
export declare const Popover: React.ForwardRefExoticComponent<PopoverProps & React.RefAttributes<HTMLDivElement>>;
|
package/dist/esm/index.js
CHANGED
|
@@ -472,6 +472,15 @@ var mergeRefs = function mergeRefs() {
|
|
|
472
472
|
});
|
|
473
473
|
};
|
|
474
474
|
};
|
|
475
|
+
function isElementInteractive(element) {
|
|
476
|
+
if (!element || !(element instanceof HTMLElement)) return false;
|
|
477
|
+
var tag = element.tagName.toLowerCase();
|
|
478
|
+
if (['button', 'input', 'select', 'textarea', 'a'].includes(tag) || element.hasAttribute('tabindex') && element.tabIndex >= 0) {
|
|
479
|
+
if (tag === 'a' && !element.href) return false;
|
|
480
|
+
return !element.hasAttribute('disabled');
|
|
481
|
+
}
|
|
482
|
+
return false;
|
|
483
|
+
}
|
|
475
484
|
|
|
476
485
|
function _extends$1() {
|
|
477
486
|
return _extends$1 = Object.assign ? Object.assign.bind() : function (n) {
|
|
@@ -4246,7 +4255,7 @@ var Badge = /*#__PURE__*/forwardRef(function (props, ref) {
|
|
|
4246
4255
|
}), children);
|
|
4247
4256
|
});
|
|
4248
4257
|
|
|
4249
|
-
var _excluded$c = ["actionButtonText", "actionButtonOnClick", "additionalContent", "children", "closeAriaLabel", "isDismissible", "onDismiss", "testId", "variant"];
|
|
4258
|
+
var _excluded$c = ["actionButtonText", "actionButtonOnClick", "additionalContent", "children", "closeAriaLabel", "isDismissible", "onDismiss", "testId", "variant", "dismissibleButtonRef"];
|
|
4250
4259
|
function _EMOTION_STRINGIFIED_CSS_ERROR__$6() { return "You have tried to stringify object returned from `css` function. It isn't supposed to be used directly (e.g. as value of the `className` prop), but rather handed to emotion so it can handle it (e.g. as value of `css` prop)."; }
|
|
4251
4260
|
var StyledBanner = /*#__PURE__*/_styled("div", {
|
|
4252
4261
|
target: "e1b9nb1m4",
|
|
@@ -4269,7 +4278,7 @@ var StyledBanner = /*#__PURE__*/_styled("div", {
|
|
|
4269
4278
|
return props.theme.typeScale.size02.letterSpacing;
|
|
4270
4279
|
}, ";line-height:", function (props) {
|
|
4271
4280
|
return props.theme.typeScale.size02.lineHeight;
|
|
4272
|
-
}, ";}" + (process.env.NODE_ENV === "production" ? "" : "/*# sourceMappingURL=data:application/json;charset=utf-8;base64,eyJ2ZXJzaW9uIjozLCJzb3VyY2VzIjpbImluZGV4LnRzeCJdLCJuYW1lcyI6W10sIm1hcHBpbmdzIjoiQUFVZ0MiLCJmaWxlIjoiaW5kZXgudHN4Iiwic291cmNlc0NvbnRlbnQiOlsiaW1wb3J0ICogYXMgUmVhY3QgZnJvbSAncmVhY3QnO1xyXG5pbXBvcnQgaXNQcm9wVmFsaWQgZnJvbSAnQGVtb3Rpb24vaXMtcHJvcC12YWxpZCc7XHJcbmltcG9ydCBzdHlsZWQgZnJvbSAnQGVtb3Rpb24vc3R5bGVkJztcclxuaW1wb3J0IHsgQ2xvc2VJY29uIH0gZnJvbSAncmVhY3QtbWFnbWEtaWNvbnMnO1xyXG5pbXBvcnQgeyBJMThuQ29udGV4dCB9IGZyb20gJy4uLy4uL2kxOG4nO1xyXG5pbXBvcnQgeyB1c2VJc0ludmVyc2UgfSBmcm9tICcuLi8uLi9pbnZlcnNlJztcclxuaW1wb3J0IHsgVGhlbWVDb250ZXh0IH0gZnJvbSAnLi4vLi4vdGhlbWUvVGhlbWVDb250ZXh0JztcclxuaW1wb3J0IHsgQWRkaXRpb25hbENvbnRlbnRXcmFwcGVyLCBBbGVydFZhcmlhbnQsIGJ1aWxkQWxlcnRCYWNrZ3JvdW5kLCBidWlsZEFsZXJ0Qm9yZGVyLCBidWlsZEFsZXJ0Q29sb3IsIGJ1aWxkTGlua0NvbG9yLCBidWlsZExpbmtIb3ZlckNvbG9yLCBWQVJJQU5UX0lDT04sIH0gZnJvbSAnLi4vQWxlcnRCYXNlJztcclxuaW1wb3J0IHsgQnV0dG9uLCBCdXR0b25TaXplLCBCdXR0b25WYXJpYW50LCBCdXR0b25Db2xvciB9IGZyb20gJy4uL0J1dHRvbic7XHJcbmltcG9ydCB7IEljb25CdXR0b24gfSBmcm9tICcuLi9JY29uQnV0dG9uJztcclxuY29uc3QgU3R5bGVkQmFubmVyID0gc3R5bGVkLmRpdiBgXG4gIGFsaWduLWl0ZW1zOiBzdHJldGNoO1xuICBiYWNrZ3JvdW5kOiAke3Byb3BzID0+IGJ1aWxkQWxlcnRCYWNrZ3JvdW5kKHByb3BzKX07XG4gIGNvbG9yOiAke3Byb3BzID0+IGJ1aWxkQWxlcnRDb2xvcihwcm9wcyl9O1xuICBkaXNwbGF5OiBmbGV4O1xuICBmb250LXNpemU6ICR7cHJvcHMgPT4gcHJvcHMudGhlbWUudHlwZVNjYWxlLnNpemUwMy5mb250U2l6ZX07XG4gIGZvbnQtZmFtaWx5OiAke3Byb3BzID0+IHByb3BzLnRoZW1lLmJvZHlGb250fTtcbiAgbGluZS1oZWlnaHQ6ICR7cHJvcHMgPT4gcHJvcHMudGhlbWUudHlwZVNjYWxlLnNpemUwMy5saW5lSGVpZ2h0fTtcbiAgcG9zaXRpb246IHJlbGF0aXZlO1xuICB0ZXh0LWFsaWduOiBsZWZ0O1xuXG4gIEBtZWRpYSAobWF4LXdpZHRoOiAke3Byb3BzID0+IHByb3BzLnRoZW1lLmJyZWFrcG9pbnRzLnNtYWxsfXB4KSB7XG4gICAgdGV4dC1hbGlnbjogbGVmdDtcbiAgICBmb250LXNpemU6ICR7cHJvcHMgPT4gcHJvcHMudGhlbWUudHlwZVNjYWxlLnNpemUwMi5mb250U2l6ZX07XG4gICAgbGV0dGVyLXNwYWNpbmc6ICR7cHJvcHMgPT4gcHJvcHMudGhlbWUudHlwZVNjYWxlLnNpemUwMi5sZXR0ZXJTcGFjaW5nfTtcbiAgICBsaW5lLWhlaWdodDogJHtwcm9wcyA9PiBwcm9wcy50aGVtZS50eXBlU2NhbGUuc2l6ZTAyLmxpbmVIZWlnaHR9O1xuICB9XG5gO1xyXG5jb25zdCBCYW5uZXJDb250ZW50cyA9IHN0eWxlZC5kaXYgYFxuICBhbGlnbi1pdGVtczogY2VudGVyO1xuICBib3JkZXItYm90dG9tOiAxcHggc29saWQgJHtwcm9wcyA9PiBidWlsZEFsZXJ0Qm9yZGVyKHByb3BzKX07XG4gIGRpc3BsYXk6IGZsZXg7XG4gIGZsZXgtZ3JvdzogMTtcbiAganVzdGlmeS1jb250ZW50OiBmbGV4LXN0YXJ0O1xuICBwYWRkaW5nOiAke3Byb3BzID0+IHByb3BzLmFkZGl0aW9uYWxDb250ZW50ICYmIHByb3BzLmlzRGlzbWlzc2libGVcclxuICAgID8gYCR7cHJvcHMudGhlbWUuc3BhY2VTY2FsZS5zcGFjaW5nMDR9IDAgJHtwcm9wcy50aGVtZS5zcGFjZVNjYWxlLnNwYWNpbmcwNH0gJHtwcm9wcy50aGVtZS5zcGFjZVNjYWxlLnNwYWNpbmcwNH1gXHJcbiAgICA6IHByb3BzLnRoZW1lLnNwYWNlU2NhbGUuc3BhY2luZzA0fTtcblxuICBAbWVkaWEgKG1heC13aWR0aDogJHtwcm9wcyA9PiBwcm9wcy50aGVtZS5icmVha3BvaW50cy5zbWFsbH1weCkge1xuICAgIGp1c3RpZnktY29udGVudDogZmxleC1zdGFydDtcbiAgfVxuXG4gIGEge1xuICAgIGNvbG9yOiAke3Byb3BzID0+IGJ1aWxkTGlua0NvbG9yKHByb3BzKX07XG4gICAgZm9udC13ZWlnaHQ6IDQwMDtcbiAgICBmb250LWZhbWlseTogJHtwcm9wcyA9PiBwcm9wcy50aGVtZS5ib2R5Rm9udH07XG4gICAgdGV4dC1kZWNvcmF0aW9uOiB1bmRlcmxpbmU7XG4gICAgJjpub3QoW2Rpc2FibGVkXSkge1xuICAgICAgJjpmb2N1cyxcbiAgICAgICY6aG92ZXIge1xuICAgICAgICBjb2xvcjogJHtwcm9wcyA9PiBidWlsZExpbmtIb3ZlckNvbG9yKHByb3BzKX07XG4gICAgICB9XG4gICAgfVxuICB9XG5gO1xyXG5jb25zdCBCdXR0b25XcmFwcGVyID0gc3R5bGVkLnNwYW4gYFxuICBhbGlnbi1pdGVtczogY2VudGVyO1xuICBkaXNwbGF5OiBmbGV4O1xuICBmbGV4LXNocmluazogMDtcbmA7XHJcbmNvbnN0IGFsbG93ZWRQcm9wcyA9IFsnaWNvbicsICdpc0ludmVyc2UnLCAndGhlbWUnLCAndmFyaWFudCddO1xyXG5jb25zdCBzaG91bGRGb3J3YXJkUHJvcCA9IHByb3AgPT4ge1xyXG4gICAgcmV0dXJuIGlzUHJvcFZhbGlkKHByb3ApIHx8IGFsbG93ZWRQcm9wcy5pbmNsdWRlcyhwcm9wKTtcclxufTtcclxuZnVuY3Rpb24gYnVpbGREaXNtaXNzQnV0dG9uQ29sb3IocHJvcHMpIHtcclxuICAgIGlmIChwcm9wcy5pc0ludmVyc2UpIHtcclxuICAgICAgICByZXR1cm4gcHJvcHMudGhlbWUuY29sb3JzLm5ldXRyYWwxMDA7XHJcbiAgICB9XHJcbiAgICBzd2l0Y2ggKHByb3BzLmFsZXJ0VmFyaWFudCkge1xyXG4gICAgICAgIGNhc2UgJ3N1Y2Nlc3MnOlxyXG4gICAgICAgICAgICByZXR1cm4gcHJvcHMudGhlbWUuY29sb3JzLnN1Y2Nlc3M1MDA7XHJcbiAgICAgICAgY2FzZSAnd2FybmluZyc6XHJcbiAgICAgICAgICAgIHJldHVybiBwcm9wcy50aGVtZS5jb2xvcnMud2FybmluZzUwMDtcclxuICAgICAgICBjYXNlICdkYW5nZXInOlxyXG4gICAgICAgICAgICByZXR1cm4gcHJvcHMudGhlbWUuY29sb3JzLmRhbmdlcjUwMDtcclxuICAgICAgICBkZWZhdWx0OlxyXG4gICAgICAgICAgICByZXR1cm4gcHJvcHMudGhlbWUuY29sb3JzLmluZm81MDA7XHJcbiAgICB9XHJcbn1cclxuY29uc3QgRGlzbWlzc0J1dHRvbiA9IHN0eWxlZChJY29uQnV0dG9uLCB7IHNob3VsZEZvcndhcmRQcm9wIH0pIGBcbiAgYWxpZ24tc2VsZjogc3RyZXRjaDtcbiAgYm9yZGVyLXJhZGl1czogMDtcbiAgY29sb3I6ICR7cHJvcHMgPT4gYnVpbGREaXNtaXNzQnV0dG9uQ29sb3IocHJvcHMpfTtcbiAgaGVpZ2h0OiBhdXRvO1xuICBwYWRkaW5nOiAwICR7cHJvcHMgPT4gcHJvcHMudGhlbWUuc3BhY2VTY2FsZS5zcGFjaW5nMDV9O1xuICB3aWR0aDogYXV0bztcbiAgYm9yZGVyLWJvdHRvbTogMXB4IHNvbGlkXG4gICAgJHtwcm9wcyA9PiBidWlsZEFsZXJ0Qm9yZGVyKHtcclxuICAgIHZhcmlhbnQ6IHByb3BzLmFsZXJ0VmFyaWFudCxcclxuICAgIHRoZW1lOiBwcm9wcy50aGVtZSxcclxuICAgIGlzSW52ZXJzZTogcHJvcHMuaXNJbnZlcnNlLFxyXG59KX07XG5cbiAgJjpub3QoOmRpc2FibGVkKSB7XG4gICAgJjpob3ZlciB7XG4gICAgICBiYWNrZ3JvdW5kOiBub25lO1xuICAgICAgY29sb3I6ICR7cHJvcHMgPT4gYnVpbGREaXNtaXNzQnV0dG9uQ29sb3IocHJvcHMpfTtcbiAgICB9XG4gICAgJjpmb2N1cyB7XG4gICAgICBiYWNrZ3JvdW5kOiBub25lO1xuICAgICAgY29sb3I6ICR7cHJvcHMgPT4gYnVpbGREaXNtaXNzQnV0dG9uQ29sb3IocHJvcHMpfTtcbiAgICAgIG91dGxpbmU6IDJweCBzb2xpZFxuICAgICAgICAke3Byb3BzID0+
|
|
4281
|
+
}, ";}" + (process.env.NODE_ENV === "production" ? "" : "/*# sourceMappingURL=data:application/json;charset=utf-8;base64,{"version":3,"sources":["index.tsx"],"names":[],"mappings":"AAUgC","file":"index.tsx","sourcesContent":["import * as React from 'react';\r\nimport isPropValid from '@emotion/is-prop-valid';\r\nimport styled from '@emotion/styled';\r\nimport { CloseIcon } from 'react-magma-icons';\r\nimport { I18nContext } from '../../i18n';\r\nimport { useIsInverse } from '../../inverse';\r\nimport { ThemeContext } from '../../theme/ThemeContext';\r\nimport { AdditionalContentWrapper, AlertVariant, buildAlertBackground, buildAlertBorder, buildAlertColor, buildLinkColor, buildLinkHoverColor, VARIANT_ICON, } from '../AlertBase';\r\nimport { Button, ButtonSize, ButtonVariant, ButtonColor } from '../Button';\r\nimport { IconButton } from '../IconButton';\r\nconst StyledBanner = styled.div `\n  align-items: stretch;\n  background: ${props => buildAlertBackground(props)};\n  color: ${props => buildAlertColor(props)};\n  display: flex;\n  font-size: ${props => props.theme.typeScale.size03.fontSize};\n  font-family: ${props => props.theme.bodyFont};\n  line-height: ${props => props.theme.typeScale.size03.lineHeight};\n  position: relative;\n  text-align: left;\n\n  @media (max-width: ${props => props.theme.breakpoints.small}px) {\n    text-align: left;\n    font-size: ${props => props.theme.typeScale.size02.fontSize};\n    letter-spacing: ${props => props.theme.typeScale.size02.letterSpacing};\n    line-height: ${props => props.theme.typeScale.size02.lineHeight};\n  }\n`;\r\nconst BannerContents = styled.div `\n  align-items: center;\n  border-bottom: 1px solid ${props => buildAlertBorder(props)};\n  display: flex;\n  flex-grow: 1;\n  justify-content: flex-start;\n  padding: ${props => props.additionalContent && props.isDismissible\r\n    ? `${props.theme.spaceScale.spacing04} 0 ${props.theme.spaceScale.spacing04} ${props.theme.spaceScale.spacing04}`\r\n    : props.theme.spaceScale.spacing04};\n\n  @media (max-width: ${props => props.theme.breakpoints.small}px) {\n    justify-content: flex-start;\n  }\n\n  a {\n    color: ${props => buildLinkColor(props)};\n    font-weight: 400;\n    font-family: ${props => props.theme.bodyFont};\n    text-decoration: underline;\n    &:not([disabled]) {\n      &:focus,\n      &:hover {\n        color: ${props => buildLinkHoverColor(props)};\n      }\n    }\n  }\n`;\r\nconst ButtonWrapper = styled.span `\n  align-items: center;\n  display: flex;\n  flex-shrink: 0;\n`;\r\nconst allowedProps = ['icon', 'isInverse', 'theme', 'variant'];\r\nconst shouldForwardProp = prop => {\r\n    return isPropValid(prop) || allowedProps.includes(prop);\r\n};\r\nfunction buildDismissButtonColor(props) {\r\n    if (props.isInverse) {\r\n        return props.theme.colors.neutral100;\r\n    }\r\n    switch (props.alertVariant) {\r\n        case 'success':\r\n            return props.theme.colors.success500;\r\n        case 'warning':\r\n            return props.theme.colors.warning500;\r\n        case 'danger':\r\n            return props.theme.colors.danger500;\r\n        default:\r\n            return props.theme.colors.info500;\r\n    }\r\n}\r\nconst DismissButton = styled(IconButton, { shouldForwardProp }) `\n  align-self: stretch;\n  border-radius: 0;\n  color: ${props => buildDismissButtonColor(props)};\n  height: auto;\n  padding: 0 ${props => props.theme.spaceScale.spacing05};\n  width: auto;\n  border-bottom: 1px solid\n    ${props => buildAlertBorder({\r\n    variant: props.alertVariant,\r\n    theme: props.theme,\r\n    isInverse: props.isInverse,\r\n})};\n\n  &:not(:disabled) {\n    &:hover {\n      background: none;\n      color: ${props => buildDismissButtonColor(props)};\n    }\n    &:focus {\n      background: none;\n      color: ${props => buildDismissButtonColor(props)};\n      outline: 2px solid\n        ${props => props.isInverse\r\n    ? props.theme.colors.focusInverse\r\n    : props.theme.colors.focus};\n      outline-offset: 0 !important;\n    }\n    &:active {\n      background: none;\n      color: ${props => buildDismissButtonColor(props)};\n    }\n  }\n`;\r\nconst IconWrapper = styled.span `\n  display: inline-flex;\n  padding-right: ${props => props.theme.spaceScale.spacing03};\n\n  @media (max-width: ${props => props.theme.breakpoints.small}px) {\n    svg {\n      width: 20px;\n    }\n  }\n`;\r\nfunction renderIcon(variant = 'info', theme) {\r\n    const Icon = VARIANT_ICON[variant];\r\n    return (React.createElement(IconWrapper, { theme: theme },\r\n        React.createElement(Icon, { size: theme.iconSizes.medium })));\r\n}\r\nfunction getButtonColor(variant) {\r\n    switch (variant) {\r\n        case 'danger':\r\n            return ButtonColor.danger;\r\n        default:\r\n            return ButtonColor.primary;\r\n    }\r\n}\r\nexport const Banner = React.forwardRef((props, ref) => {\r\n    const { actionButtonText, actionButtonOnClick, additionalContent, children, closeAriaLabel, isDismissible, onDismiss, testId, variant = AlertVariant.info, dismissibleButtonRef, ...other } = props;\r\n    const theme = React.useContext(ThemeContext);\r\n    const i18n = React.useContext(I18nContext);\r\n    const isInverse = useIsInverse(props.isInverse);\r\n    return (React.createElement(StyledBanner, Object.assign({}, other, { \"data-testid\": testId, ref: ref, theme: theme, variant: variant }),\r\n        React.createElement(BannerContents, { additionalContent: additionalContent, isDismissible: isDismissible, theme: theme, variant: variant, isInverse: isInverse },\r\n            renderIcon(variant, theme),\r\n            React.createElement(\"span\", null, children),\r\n            actionButtonText && actionButtonOnClick && (React.createElement(Button, { color: getButtonColor(variant), isInverse: isInverse, onClick: actionButtonOnClick, style: { margin: `0 0 0 ${theme.spaceScale.spacing08}` }, size: ButtonSize.small }, actionButtonText)),\r\n            additionalContent && (React.createElement(AdditionalContentWrapper, { theme: theme }, additionalContent))),\r\n        isDismissible && (React.createElement(ButtonWrapper, { color: variant },\r\n            React.createElement(DismissButton, { alertVariant: variant, \"aria-label\": closeAriaLabel ? closeAriaLabel : i18n.alert.dismissAriaLabel, icon: React.createElement(CloseIcon, { size: theme.iconSizes.small }), isInverse: isInverse, onClick: onDismiss, theme: theme, variant: ButtonVariant.link, ref: dismissibleButtonRef })))));\r\n});\r\n//# sourceMappingURL=index.js.map"]} */"));
|
|
4273
4282
|
var BannerContents = /*#__PURE__*/_styled("div", {
|
|
4274
4283
|
target: "e1b9nb1m3",
|
|
4275
4284
|
label: "BannerContents"
|
|
@@ -4285,7 +4294,7 @@ var BannerContents = /*#__PURE__*/_styled("div", {
|
|
|
4285
4294
|
return props.theme.bodyFont;
|
|
4286
4295
|
}, ";text-decoration:underline;&:not([disabled]){&:focus,&:hover{color:", function (props) {
|
|
4287
4296
|
return buildLinkHoverColor(props);
|
|
4288
|
-
}, ";}}}" + (process.env.NODE_ENV === "production" ? "" : "/*# sourceMappingURL=data:application/json;charset=utf-8;base64,eyJ2ZXJzaW9uIjozLCJzb3VyY2VzIjpbImluZGV4LnRzeCJdLCJuYW1lcyI6W10sIm1hcHBpbmdzIjoiQUE0QmtDIiwiZmlsZSI6ImluZGV4LnRzeCIsInNvdXJjZXNDb250ZW50IjpbImltcG9ydCAqIGFzIFJlYWN0IGZyb20gJ3JlYWN0JztcclxuaW1wb3J0IGlzUHJvcFZhbGlkIGZyb20gJ0BlbW90aW9uL2lzLXByb3AtdmFsaWQnO1xyXG5pbXBvcnQgc3R5bGVkIGZyb20gJ0BlbW90aW9uL3N0eWxlZCc7XHJcbmltcG9ydCB7IENsb3NlSWNvbiB9IGZyb20gJ3JlYWN0LW1hZ21hLWljb25zJztcclxuaW1wb3J0IHsgSTE4bkNvbnRleHQgfSBmcm9tICcuLi8uLi9pMThuJztcclxuaW1wb3J0IHsgdXNlSXNJbnZlcnNlIH0gZnJvbSAnLi4vLi4vaW52ZXJzZSc7XHJcbmltcG9ydCB7IFRoZW1lQ29udGV4dCB9IGZyb20gJy4uLy4uL3RoZW1lL1RoZW1lQ29udGV4dCc7XHJcbmltcG9ydCB7IEFkZGl0aW9uYWxDb250ZW50V3JhcHBlciwgQWxlcnRWYXJpYW50LCBidWlsZEFsZXJ0QmFja2dyb3VuZCwgYnVpbGRBbGVydEJvcmRlciwgYnVpbGRBbGVydENvbG9yLCBidWlsZExpbmtDb2xvciwgYnVpbGRMaW5rSG92ZXJDb2xvciwgVkFSSUFOVF9JQ09OLCB9IGZyb20gJy4uL0FsZXJ0QmFzZSc7XHJcbmltcG9ydCB7IEJ1dHRvbiwgQnV0dG9uU2l6ZSwgQnV0dG9uVmFyaWFudCwgQnV0dG9uQ29sb3IgfSBmcm9tICcuLi9CdXR0b24nO1xyXG5pbXBvcnQgeyBJY29uQnV0dG9uIH0gZnJvbSAnLi4vSWNvbkJ1dHRvbic7XHJcbmNvbnN0IFN0eWxlZEJhbm5lciA9IHN0eWxlZC5kaXYgYFxuICBhbGlnbi1pdGVtczogc3RyZXRjaDtcbiAgYmFja2dyb3VuZDogJHtwcm9wcyA9PiBidWlsZEFsZXJ0QmFja2dyb3VuZChwcm9wcyl9O1xuICBjb2xvcjogJHtwcm9wcyA9PiBidWlsZEFsZXJ0Q29sb3IocHJvcHMpfTtcbiAgZGlzcGxheTogZmxleDtcbiAgZm9udC1zaXplOiAke3Byb3BzID0+IHByb3BzLnRoZW1lLnR5cGVTY2FsZS5zaXplMDMuZm9udFNpemV9O1xuICBmb250LWZhbWlseTogJHtwcm9wcyA9PiBwcm9wcy50aGVtZS5ib2R5Rm9udH07XG4gIGxpbmUtaGVpZ2h0OiAke3Byb3BzID0+IHByb3BzLnRoZW1lLnR5cGVTY2FsZS5zaXplMDMubGluZUhlaWdodH07XG4gIHBvc2l0aW9uOiByZWxhdGl2ZTtcbiAgdGV4dC1hbGlnbjogbGVmdDtcblxuICBAbWVkaWEgKG1heC13aWR0aDogJHtwcm9wcyA9PiBwcm9wcy50aGVtZS5icmVha3BvaW50cy5zbWFsbH1weCkge1xuICAgIHRleHQtYWxpZ246IGxlZnQ7XG4gICAgZm9udC1zaXplOiAke3Byb3BzID0+IHByb3BzLnRoZW1lLnR5cGVTY2FsZS5zaXplMDIuZm9udFNpemV9O1xuICAgIGxldHRlci1zcGFjaW5nOiAke3Byb3BzID0+IHByb3BzLnRoZW1lLnR5cGVTY2FsZS5zaXplMDIubGV0dGVyU3BhY2luZ307XG4gICAgbGluZS1oZWlnaHQ6ICR7cHJvcHMgPT4gcHJvcHMudGhlbWUudHlwZVNjYWxlLnNpemUwMi5saW5lSGVpZ2h0fTtcbiAgfVxuYDtcclxuY29uc3QgQmFubmVyQ29udGVudHMgPSBzdHlsZWQuZGl2IGBcbiAgYWxpZ24taXRlbXM6IGNlbnRlcjtcbiAgYm9yZGVyLWJvdHRvbTogMXB4IHNvbGlkICR7cHJvcHMgPT4gYnVpbGRBbGVydEJvcmRlcihwcm9wcyl9O1xuICBkaXNwbGF5OiBmbGV4O1xuICBmbGV4LWdyb3c6IDE7XG4gIGp1c3RpZnktY29udGVudDogZmxleC1zdGFydDtcbiAgcGFkZGluZzogJHtwcm9wcyA9PiBwcm9wcy5hZGRpdGlvbmFsQ29udGVudCAmJiBwcm9wcy5pc0Rpc21pc3NpYmxlXHJcbiAgICA/IGAke3Byb3BzLnRoZW1lLnNwYWNlU2NhbGUuc3BhY2luZzA0fSAwICR7cHJvcHMudGhlbWUuc3BhY2VTY2FsZS5zcGFjaW5nMDR9ICR7cHJvcHMudGhlbWUuc3BhY2VTY2FsZS5zcGFjaW5nMDR9YFxyXG4gICAgOiBwcm9wcy50aGVtZS5zcGFjZVNjYWxlLnNwYWNpbmcwNH07XG5cbiAgQG1lZGlhIChtYXgtd2lkdGg6ICR7cHJvcHMgPT4gcHJvcHMudGhlbWUuYnJlYWtwb2ludHMuc21hbGx9cHgpIHtcbiAgICBqdXN0aWZ5LWNvbnRlbnQ6IGZsZXgtc3RhcnQ7XG4gIH1cblxuICBhIHtcbiAgICBjb2xvcjogJHtwcm9wcyA9PiBidWlsZExpbmtDb2xvcihwcm9wcyl9O1xuICAgIGZvbnQtd2VpZ2h0OiA0MDA7XG4gICAgZm9udC1mYW1pbHk6ICR7cHJvcHMgPT4gcHJvcHMudGhlbWUuYm9keUZvbnR9O1xuICAgIHRleHQtZGVjb3JhdGlvbjogdW5kZXJsaW5lO1xuICAgICY6bm90KFtkaXNhYmxlZF0pIHtcbiAgICAgICY6Zm9jdXMsXG4gICAgICAmOmhvdmVyIHtcbiAgICAgICAgY29sb3I6ICR7cHJvcHMgPT4gYnVpbGRMaW5rSG92ZXJDb2xvcihwcm9wcyl9O1xuICAgICAgfVxuICAgIH1cbiAgfVxuYDtcclxuY29uc3QgQnV0dG9uV3JhcHBlciA9IHN0eWxlZC5zcGFuIGBcbiAgYWxpZ24taXRlbXM6IGNlbnRlcjtcbiAgZGlzcGxheTogZmxleDtcbiAgZmxleC1zaHJpbms6IDA7XG5gO1xyXG5jb25zdCBhbGxvd2VkUHJvcHMgPSBbJ2ljb24nLCAnaXNJbnZlcnNlJywgJ3RoZW1lJywgJ3ZhcmlhbnQnXTtcclxuY29uc3Qgc2hvdWxkRm9yd2FyZFByb3AgPSBwcm9wID0+IHtcclxuICAgIHJldHVybiBpc1Byb3BWYWxpZChwcm9wKSB8fCBhbGxvd2VkUHJvcHMuaW5jbHVkZXMocHJvcCk7XHJcbn07XHJcbmZ1bmN0aW9uIGJ1aWxkRGlzbWlzc0J1dHRvbkNvbG9yKHByb3BzKSB7XHJcbiAgICBpZiAocHJvcHMuaXNJbnZlcnNlKSB7XHJcbiAgICAgICAgcmV0dXJuIHByb3BzLnRoZW1lLmNvbG9ycy5uZXV0cmFsMTAwO1xyXG4gICAgfVxyXG4gICAgc3dpdGNoIChwcm9wcy5hbGVydFZhcmlhbnQpIHtcclxuICAgICAgICBjYXNlICdzdWNjZXNzJzpcclxuICAgICAgICAgICAgcmV0dXJuIHByb3BzLnRoZW1lLmNvbG9ycy5zdWNjZXNzNTAwO1xyXG4gICAgICAgIGNhc2UgJ3dhcm5pbmcnOlxyXG4gICAgICAgICAgICByZXR1cm4gcHJvcHMudGhlbWUuY29sb3JzLndhcm5pbmc1MDA7XHJcbiAgICAgICAgY2FzZSAnZGFuZ2VyJzpcclxuICAgICAgICAgICAgcmV0dXJuIHByb3BzLnRoZW1lLmNvbG9ycy5kYW5nZXI1MDA7XHJcbiAgICAgICAgZGVmYXVsdDpcclxuICAgICAgICAgICAgcmV0dXJuIHByb3BzLnRoZW1lLmNvbG9ycy5pbmZvNTAwO1xyXG4gICAgfVxyXG59XHJcbmNvbnN0IERpc21pc3NCdXR0b24gPSBzdHlsZWQoSWNvbkJ1dHRvbiwgeyBzaG91bGRGb3J3YXJkUHJvcCB9KSBgXG4gIGFsaWduLXNlbGY6IHN0cmV0Y2g7XG4gIGJvcmRlci1yYWRpdXM6IDA7XG4gIGNvbG9yOiAke3Byb3BzID0+IGJ1aWxkRGlzbWlzc0J1dHRvbkNvbG9yKHByb3BzKX07XG4gIGhlaWdodDogYXV0bztcbiAgcGFkZGluZzogMCAke3Byb3BzID0+IHByb3BzLnRoZW1lLnNwYWNlU2NhbGUuc3BhY2luZzA1fTtcbiAgd2lkdGg6IGF1dG87XG4gIGJvcmRlci1ib3R0b206IDFweCBzb2xpZFxuICAgICR7cHJvcHMgPT4gYnVpbGRBbGVydEJvcmRlcih7XHJcbiAgICB2YXJpYW50OiBwcm9wcy5hbGVydFZhcmlhbnQsXHJcbiAgICB0aGVtZTogcHJvcHMudGhlbWUsXHJcbiAgICBpc0ludmVyc2U6IHByb3BzLmlzSW52ZXJzZSxcclxufSl9O1xuXG4gICY6bm90KDpkaXNhYmxlZCkge1xuICAgICY6aG92ZXIge1xuICAgICAgYmFja2dyb3VuZDogbm9uZTtcbiAgICAgIGNvbG9yOiAke3Byb3BzID0+IGJ1aWxkRGlzbWlzc0J1dHRvbkNvbG9yKHByb3BzKX07XG4gICAgfVxuICAgICY6Zm9jdXMge1xuICAgICAgYmFja2dyb3VuZDogbm9uZTtcbiAgICAgIGNvbG9yOiAke3Byb3BzID0+IGJ1aWxkRGlzbWlzc0J1dHRvbkNvbG9yKHByb3BzKX07XG4gICAgICBvdXRsaW5lOiAycHggc29saWRcbiAgICAgICAgJHtwcm9wcyA9PiBwcm9wcy5pc0ludmVyc2VcclxuICAgID8gcHJvcHMudGhlbWUuY29sb3JzLmZvY3VzSW52ZXJzZVxyXG4gICAgOiBwcm9wcy50aGVtZS5jb2xvcnMuZm9jdXN9O1xuICAgICAgb3V0bGluZS1vZmZzZXQ6IDAgIWltcG9ydGFudDtcbiAgICB9XG4gICAgJjphY3RpdmUge1xuICAgICAgYmFja2dyb3VuZDogbm9uZTtcbiAgICAgIGNvbG9yOiAke3Byb3BzID0+IGJ1aWxkRGlzbWlzc0J1dHRvbkNvbG9yKHByb3BzKX07XG4gICAgfVxuICB9XG5gO1xyXG5jb25zdCBJY29uV3JhcHBlciA9IHN0eWxlZC5zcGFuIGBcbiAgZGlzcGxheTogaW5saW5lLWZsZXg7XG4gIHBhZGRpbmctcmlnaHQ6ICR7cHJvcHMgPT4gcHJvcHMudGhlbWUuc3BhY2VTY2FsZS5zcGFjaW5nMDN9O1xuXG4gIEBtZWRpYSAobWF4LXdpZHRoOiAke3Byb3BzID0+IHByb3BzLnRoZW1lLmJyZWFrcG9pbnRzLnNtYWxsfXB4KSB7XG4gICAgc3ZnIHtcbiAgICAgIHdpZHRoOiAyMHB4O1xuICAgIH1cbiAgfVxuYDtcclxuZnVuY3Rpb24gcmVuZGVySWNvbih2YXJpYW50ID0gJ2luZm8nLCB0aGVtZSkge1xyXG4gICAgY29uc3QgSWNvbiA9IFZBUklBTlRfSUNPTlt2YXJpYW50XTtcclxuICAgIHJldHVybiAoUmVhY3QuY3JlYXRlRWxlbWVudChJY29uV3JhcHBlciwgeyB0aGVtZTogdGhlbWUgfSxcclxuICAgICAgICBSZWFjdC5jcmVhdGVFbGVtZW50KEljb24sIHsgc2l6ZTogdGhlbWUuaWNvblNpemVzLm1lZGl1bSB9KSkpO1xyXG59XHJcbmZ1bmN0aW9uIGdldEJ1dHRvbkNvbG9yKHZhcmlhbnQpIHtcclxuICAgIHN3aXRjaCAodmFyaWFudCkge1xyXG4gICAgICAgIGNhc2UgJ2Rhbmdlcic6XHJcbiAgICAgICAgICAgIHJldHVybiBCdXR0b25Db2xvci5kYW5nZXI7XHJcbiAgICAgICAgZGVmYXVsdDpcclxuICAgICAgICAgICAgcmV0dXJuIEJ1dHRvbkNvbG9yLnByaW1hcnk7XHJcbiAgICB9XHJcbn1cclxuZXhwb3J0IGNvbnN0IEJhbm5lciA9IFJlYWN0LmZvcndhcmRSZWYoKHByb3BzLCByZWYpID0+
|
|
4297
|
+
}, ";}}}" + (process.env.NODE_ENV === "production" ? "" : "/*# sourceMappingURL=data:application/json;charset=utf-8;base64,{"version":3,"sources":["index.tsx"],"names":[],"mappings":"AA4BkC","file":"index.tsx","sourcesContent":["import * as React from 'react';\r\nimport isPropValid from '@emotion/is-prop-valid';\r\nimport styled from '@emotion/styled';\r\nimport { CloseIcon } from 'react-magma-icons';\r\nimport { I18nContext } from '../../i18n';\r\nimport { useIsInverse } from '../../inverse';\r\nimport { ThemeContext } from '../../theme/ThemeContext';\r\nimport { AdditionalContentWrapper, AlertVariant, buildAlertBackground, buildAlertBorder, buildAlertColor, buildLinkColor, buildLinkHoverColor, VARIANT_ICON, } from '../AlertBase';\r\nimport { Button, ButtonSize, ButtonVariant, ButtonColor } from '../Button';\r\nimport { IconButton } from '../IconButton';\r\nconst StyledBanner = styled.div `\n  align-items: stretch;\n  background: ${props => buildAlertBackground(props)};\n  color: ${props => buildAlertColor(props)};\n  display: flex;\n  font-size: ${props => props.theme.typeScale.size03.fontSize};\n  font-family: ${props => props.theme.bodyFont};\n  line-height: ${props => props.theme.typeScale.size03.lineHeight};\n  position: relative;\n  text-align: left;\n\n  @media (max-width: ${props => props.theme.breakpoints.small}px) {\n    text-align: left;\n    font-size: ${props => props.theme.typeScale.size02.fontSize};\n    letter-spacing: ${props => props.theme.typeScale.size02.letterSpacing};\n    line-height: ${props => props.theme.typeScale.size02.lineHeight};\n  }\n`;\r\nconst BannerContents = styled.div `\n  align-items: center;\n  border-bottom: 1px solid ${props => buildAlertBorder(props)};\n  display: flex;\n  flex-grow: 1;\n  justify-content: flex-start;\n  padding: ${props => props.additionalContent && props.isDismissible\r\n    ? `${props.theme.spaceScale.spacing04} 0 ${props.theme.spaceScale.spacing04} ${props.theme.spaceScale.spacing04}`\r\n    : props.theme.spaceScale.spacing04};\n\n  @media (max-width: ${props => props.theme.breakpoints.small}px) {\n    justify-content: flex-start;\n  }\n\n  a {\n    color: ${props => buildLinkColor(props)};\n    font-weight: 400;\n    font-family: ${props => props.theme.bodyFont};\n    text-decoration: underline;\n    &:not([disabled]) {\n      &:focus,\n      &:hover {\n        color: ${props => buildLinkHoverColor(props)};\n      }\n    }\n  }\n`;\r\nconst ButtonWrapper = styled.span `\n  align-items: center;\n  display: flex;\n  flex-shrink: 0;\n`;\r\nconst allowedProps = ['icon', 'isInverse', 'theme', 'variant'];\r\nconst shouldForwardProp = prop => {\r\n    return isPropValid(prop) || allowedProps.includes(prop);\r\n};\r\nfunction buildDismissButtonColor(props) {\r\n    if (props.isInverse) {\r\n        return props.theme.colors.neutral100;\r\n    }\r\n    switch (props.alertVariant) {\r\n        case 'success':\r\n            return props.theme.colors.success500;\r\n        case 'warning':\r\n            return props.theme.colors.warning500;\r\n        case 'danger':\r\n            return props.theme.colors.danger500;\r\n        default:\r\n            return props.theme.colors.info500;\r\n    }\r\n}\r\nconst DismissButton = styled(IconButton, { shouldForwardProp }) `\n  align-self: stretch;\n  border-radius: 0;\n  color: ${props => buildDismissButtonColor(props)};\n  height: auto;\n  padding: 0 ${props => props.theme.spaceScale.spacing05};\n  width: auto;\n  border-bottom: 1px solid\n    ${props => buildAlertBorder({\r\n    variant: props.alertVariant,\r\n    theme: props.theme,\r\n    isInverse: props.isInverse,\r\n})};\n\n  &:not(:disabled) {\n    &:hover {\n      background: none;\n      color: ${props => buildDismissButtonColor(props)};\n    }\n    &:focus {\n      background: none;\n      color: ${props => buildDismissButtonColor(props)};\n      outline: 2px solid\n        ${props => props.isInverse\r\n    ? props.theme.colors.focusInverse\r\n    : props.theme.colors.focus};\n      outline-offset: 0 !important;\n    }\n    &:active {\n      background: none;\n      color: ${props => buildDismissButtonColor(props)};\n    }\n  }\n`;\r\nconst IconWrapper = styled.span `\n  display: inline-flex;\n  padding-right: ${props => props.theme.spaceScale.spacing03};\n\n  @media (max-width: ${props => props.theme.breakpoints.small}px) {\n    svg {\n      width: 20px;\n    }\n  }\n`;\r\nfunction renderIcon(variant = 'info', theme) {\r\n    const Icon = VARIANT_ICON[variant];\r\n    return (React.createElement(IconWrapper, { theme: theme },\r\n        React.createElement(Icon, { size: theme.iconSizes.medium })));\r\n}\r\nfunction getButtonColor(variant) {\r\n    switch (variant) {\r\n        case 'danger':\r\n            return ButtonColor.danger;\r\n        default:\r\n            return ButtonColor.primary;\r\n    }\r\n}\r\nexport const Banner = React.forwardRef((props, ref) => {\r\n    const { actionButtonText, actionButtonOnClick, additionalContent, children, closeAriaLabel, isDismissible, onDismiss, testId, variant = AlertVariant.info, dismissibleButtonRef, ...other } = props;\r\n    const theme = React.useContext(ThemeContext);\r\n    const i18n = React.useContext(I18nContext);\r\n    const isInverse = useIsInverse(props.isInverse);\r\n    return (React.createElement(StyledBanner, Object.assign({}, other, { \"data-testid\": testId, ref: ref, theme: theme, variant: variant }),\r\n        React.createElement(BannerContents, { additionalContent: additionalContent, isDismissible: isDismissible, theme: theme, variant: variant, isInverse: isInverse },\r\n            renderIcon(variant, theme),\r\n            React.createElement(\"span\", null, children),\r\n            actionButtonText && actionButtonOnClick && (React.createElement(Button, { color: getButtonColor(variant), isInverse: isInverse, onClick: actionButtonOnClick, style: { margin: `0 0 0 ${theme.spaceScale.spacing08}` }, size: ButtonSize.small }, actionButtonText)),\r\n            additionalContent && (React.createElement(AdditionalContentWrapper, { theme: theme }, additionalContent))),\r\n        isDismissible && (React.createElement(ButtonWrapper, { color: variant },\r\n            React.createElement(DismissButton, { alertVariant: variant, \"aria-label\": closeAriaLabel ? closeAriaLabel : i18n.alert.dismissAriaLabel, icon: React.createElement(CloseIcon, { size: theme.iconSizes.small }), isInverse: isInverse, onClick: onDismiss, theme: theme, variant: ButtonVariant.link, ref: dismissibleButtonRef })))));\r\n});\r\n//# sourceMappingURL=index.js.map"]} */"));
|
|
4289
4298
|
var ButtonWrapper = /*#__PURE__*/_styled("span", {
|
|
4290
4299
|
target: "e1b9nb1m2",
|
|
4291
4300
|
label: "ButtonWrapper"
|
|
@@ -4294,7 +4303,7 @@ var ButtonWrapper = /*#__PURE__*/_styled("span", {
|
|
|
4294
4303
|
styles: "align-items:center;display:flex;flex-shrink:0"
|
|
4295
4304
|
} : {
|
|
4296
4305
|
name: "1uow4sb",
|
|
4297
|
-
styles: "align-items:center;display:flex;flex-shrink:0/*# sourceMappingURL=data:application/json;charset=utf-8;base64,eyJ2ZXJzaW9uIjozLCJzb3VyY2VzIjpbImluZGV4LnRzeCJdLCJuYW1lcyI6W10sIm1hcHBpbmdzIjoiQUF1RGtDIiwiZmlsZSI6ImluZGV4LnRzeCIsInNvdXJjZXNDb250ZW50IjpbImltcG9ydCAqIGFzIFJlYWN0IGZyb20gJ3JlYWN0JztcclxuaW1wb3J0IGlzUHJvcFZhbGlkIGZyb20gJ0BlbW90aW9uL2lzLXByb3AtdmFsaWQnO1xyXG5pbXBvcnQgc3R5bGVkIGZyb20gJ0BlbW90aW9uL3N0eWxlZCc7XHJcbmltcG9ydCB7IENsb3NlSWNvbiB9IGZyb20gJ3JlYWN0LW1hZ21hLWljb25zJztcclxuaW1wb3J0IHsgSTE4bkNvbnRleHQgfSBmcm9tICcuLi8uLi9pMThuJztcclxuaW1wb3J0IHsgdXNlSXNJbnZlcnNlIH0gZnJvbSAnLi4vLi4vaW52ZXJzZSc7XHJcbmltcG9ydCB7IFRoZW1lQ29udGV4dCB9IGZyb20gJy4uLy4uL3RoZW1lL1RoZW1lQ29udGV4dCc7XHJcbmltcG9ydCB7IEFkZGl0aW9uYWxDb250ZW50V3JhcHBlciwgQWxlcnRWYXJpYW50LCBidWlsZEFsZXJ0QmFja2dyb3VuZCwgYnVpbGRBbGVydEJvcmRlciwgYnVpbGRBbGVydENvbG9yLCBidWlsZExpbmtDb2xvciwgYnVpbGRMaW5rSG92ZXJDb2xvciwgVkFSSUFOVF9JQ09OLCB9IGZyb20gJy4uL0FsZXJ0QmFzZSc7XHJcbmltcG9ydCB7IEJ1dHRvbiwgQnV0dG9uU2l6ZSwgQnV0dG9uVmFyaWFudCwgQnV0dG9uQ29sb3IgfSBmcm9tICcuLi9CdXR0b24nO1xyXG5pbXBvcnQgeyBJY29uQnV0dG9uIH0gZnJvbSAnLi4vSWNvbkJ1dHRvbic7XHJcbmNvbnN0IFN0eWxlZEJhbm5lciA9IHN0eWxlZC5kaXYgYFxuICBhbGlnbi1pdGVtczogc3RyZXRjaDtcbiAgYmFja2dyb3VuZDogJHtwcm9wcyA9PiBidWlsZEFsZXJ0QmFja2dyb3VuZChwcm9wcyl9O1xuICBjb2xvcjogJHtwcm9wcyA9PiBidWlsZEFsZXJ0Q29sb3IocHJvcHMpfTtcbiAgZGlzcGxheTogZmxleDtcbiAgZm9udC1zaXplOiAke3Byb3BzID0+IHByb3BzLnRoZW1lLnR5cGVTY2FsZS5zaXplMDMuZm9udFNpemV9O1xuICBmb250LWZhbWlseTogJHtwcm9wcyA9PiBwcm9wcy50aGVtZS5ib2R5Rm9udH07XG4gIGxpbmUtaGVpZ2h0OiAke3Byb3BzID0+IHByb3BzLnRoZW1lLnR5cGVTY2FsZS5zaXplMDMubGluZUhlaWdodH07XG4gIHBvc2l0aW9uOiByZWxhdGl2ZTtcbiAgdGV4dC1hbGlnbjogbGVmdDtcblxuICBAbWVkaWEgKG1heC13aWR0aDogJHtwcm9wcyA9PiBwcm9wcy50aGVtZS5icmVha3BvaW50cy5zbWFsbH1weCkge1xuICAgIHRleHQtYWxpZ246IGxlZnQ7XG4gICAgZm9udC1zaXplOiAke3Byb3BzID0+IHByb3BzLnRoZW1lLnR5cGVTY2FsZS5zaXplMDIuZm9udFNpemV9O1xuICAgIGxldHRlci1zcGFjaW5nOiAke3Byb3BzID0+IHByb3BzLnRoZW1lLnR5cGVTY2FsZS5zaXplMDIubGV0dGVyU3BhY2luZ307XG4gICAgbGluZS1oZWlnaHQ6ICR7cHJvcHMgPT4gcHJvcHMudGhlbWUudHlwZVNjYWxlLnNpemUwMi5saW5lSGVpZ2h0fTtcbiAgfVxuYDtcclxuY29uc3QgQmFubmVyQ29udGVudHMgPSBzdHlsZWQuZGl2IGBcbiAgYWxpZ24taXRlbXM6IGNlbnRlcjtcbiAgYm9yZGVyLWJvdHRvbTogMXB4IHNvbGlkICR7cHJvcHMgPT4gYnVpbGRBbGVydEJvcmRlcihwcm9wcyl9O1xuICBkaXNwbGF5OiBmbGV4O1xuICBmbGV4LWdyb3c6IDE7XG4gIGp1c3RpZnktY29udGVudDogZmxleC1zdGFydDtcbiAgcGFkZGluZzogJHtwcm9wcyA9PiBwcm9wcy5hZGRpdGlvbmFsQ29udGVudCAmJiBwcm9wcy5pc0Rpc21pc3NpYmxlXHJcbiAgICA/IGAke3Byb3BzLnRoZW1lLnNwYWNlU2NhbGUuc3BhY2luZzA0fSAwICR7cHJvcHMudGhlbWUuc3BhY2VTY2FsZS5zcGFjaW5nMDR9ICR7cHJvcHMudGhlbWUuc3BhY2VTY2FsZS5zcGFjaW5nMDR9YFxyXG4gICAgOiBwcm9wcy50aGVtZS5zcGFjZVNjYWxlLnNwYWNpbmcwNH07XG5cbiAgQG1lZGlhIChtYXgtd2lkdGg6ICR7cHJvcHMgPT4gcHJvcHMudGhlbWUuYnJlYWtwb2ludHMuc21hbGx9cHgpIHtcbiAgICBqdXN0aWZ5LWNvbnRlbnQ6IGZsZXgtc3RhcnQ7XG4gIH1cblxuICBhIHtcbiAgICBjb2xvcjogJHtwcm9wcyA9PiBidWlsZExpbmtDb2xvcihwcm9wcyl9O1xuICAgIGZvbnQtd2VpZ2h0OiA0MDA7XG4gICAgZm9udC1mYW1pbHk6ICR7cHJvcHMgPT4gcHJvcHMudGhlbWUuYm9keUZvbnR9O1xuICAgIHRleHQtZGVjb3JhdGlvbjogdW5kZXJsaW5lO1xuICAgICY6bm90KFtkaXNhYmxlZF0pIHtcbiAgICAgICY6Zm9jdXMsXG4gICAgICAmOmhvdmVyIHtcbiAgICAgICAgY29sb3I6ICR7cHJvcHMgPT4gYnVpbGRMaW5rSG92ZXJDb2xvcihwcm9wcyl9O1xuICAgICAgfVxuICAgIH1cbiAgfVxuYDtcclxuY29uc3QgQnV0dG9uV3JhcHBlciA9IHN0eWxlZC5zcGFuIGBcbiAgYWxpZ24taXRlbXM6IGNlbnRlcjtcbiAgZGlzcGxheTogZmxleDtcbiAgZmxleC1zaHJpbms6IDA7XG5gO1xyXG5jb25zdCBhbGxvd2VkUHJvcHMgPSBbJ2ljb24nLCAnaXNJbnZlcnNlJywgJ3RoZW1lJywgJ3ZhcmlhbnQnXTtcclxuY29uc3Qgc2hvdWxkRm9yd2FyZFByb3AgPSBwcm9wID0+IHtcclxuICAgIHJldHVybiBpc1Byb3BWYWxpZChwcm9wKSB8fCBhbGxvd2VkUHJvcHMuaW5jbHVkZXMocHJvcCk7XHJcbn07XHJcbmZ1bmN0aW9uIGJ1aWxkRGlzbWlzc0J1dHRvbkNvbG9yKHByb3BzKSB7XHJcbiAgICBpZiAocHJvcHMuaXNJbnZlcnNlKSB7XHJcbiAgICAgICAgcmV0dXJuIHByb3BzLnRoZW1lLmNvbG9ycy5uZXV0cmFsMTAwO1xyXG4gICAgfVxyXG4gICAgc3dpdGNoIChwcm9wcy5hbGVydFZhcmlhbnQpIHtcclxuICAgICAgICBjYXNlICdzdWNjZXNzJzpcclxuICAgICAgICAgICAgcmV0dXJuIHByb3BzLnRoZW1lLmNvbG9ycy5zdWNjZXNzNTAwO1xyXG4gICAgICAgIGNhc2UgJ3dhcm5pbmcnOlxyXG4gICAgICAgICAgICByZXR1cm4gcHJvcHMudGhlbWUuY29sb3JzLndhcm5pbmc1MDA7XHJcbiAgICAgICAgY2FzZSAnZGFuZ2VyJzpcclxuICAgICAgICAgICAgcmV0dXJuIHByb3BzLnRoZW1lLmNvbG9ycy5kYW5nZXI1MDA7XHJcbiAgICAgICAgZGVmYXVsdDpcclxuICAgICAgICAgICAgcmV0dXJuIHByb3BzLnRoZW1lLmNvbG9ycy5pbmZvNTAwO1xyXG4gICAgfVxyXG59XHJcbmNvbnN0IERpc21pc3NCdXR0b24gPSBzdHlsZWQoSWNvbkJ1dHRvbiwgeyBzaG91bGRGb3J3YXJkUHJvcCB9KSBgXG4gIGFsaWduLXNlbGY6IHN0cmV0Y2g7XG4gIGJvcmRlci1yYWRpdXM6IDA7XG4gIGNvbG9yOiAke3Byb3BzID0+IGJ1aWxkRGlzbWlzc0J1dHRvbkNvbG9yKHByb3BzKX07XG4gIGhlaWdodDogYXV0bztcbiAgcGFkZGluZzogMCAke3Byb3BzID0+IHByb3BzLnRoZW1lLnNwYWNlU2NhbGUuc3BhY2luZzA1fTtcbiAgd2lkdGg6IGF1dG87XG4gIGJvcmRlci1ib3R0b206IDFweCBzb2xpZFxuICAgICR7cHJvcHMgPT4gYnVpbGRBbGVydEJvcmRlcih7XHJcbiAgICB2YXJpYW50OiBwcm9wcy5hbGVydFZhcmlhbnQsXHJcbiAgICB0aGVtZTogcHJvcHMudGhlbWUsXHJcbiAgICBpc0ludmVyc2U6IHByb3BzLmlzSW52ZXJzZSxcclxufSl9O1xuXG4gICY6bm90KDpkaXNhYmxlZCkge1xuICAgICY6aG92ZXIge1xuICAgICAgYmFja2dyb3VuZDogbm9uZTtcbiAgICAgIGNvbG9yOiAke3Byb3BzID0+IGJ1aWxkRGlzbWlzc0J1dHRvbkNvbG9yKHByb3BzKX07XG4gICAgfVxuICAgICY6Zm9jdXMge1xuICAgICAgYmFja2dyb3VuZDogbm9uZTtcbiAgICAgIGNvbG9yOiAke3Byb3BzID0+IGJ1aWxkRGlzbWlzc0J1dHRvbkNvbG9yKHByb3BzKX07XG4gICAgICBvdXRsaW5lOiAycHggc29saWRcbiAgICAgICAgJHtwcm9wcyA9PiBwcm9wcy5pc0ludmVyc2VcclxuICAgID8gcHJvcHMudGhlbWUuY29sb3JzLmZvY3VzSW52ZXJzZVxyXG4gICAgOiBwcm9wcy50aGVtZS5jb2xvcnMuZm9jdXN9O1xuICAgICAgb3V0bGluZS1vZmZzZXQ6IDAgIWltcG9ydGFudDtcbiAgICB9XG4gICAgJjphY3RpdmUge1xuICAgICAgYmFja2dyb3VuZDogbm9uZTtcbiAgICAgIGNvbG9yOiAke3Byb3BzID0+IGJ1aWxkRGlzbWlzc0J1dHRvbkNvbG9yKHByb3BzKX07XG4gICAgfVxuICB9XG5gO1xyXG5jb25zdCBJY29uV3JhcHBlciA9IHN0eWxlZC5zcGFuIGBcbiAgZGlzcGxheTogaW5saW5lLWZsZXg7XG4gIHBhZGRpbmctcmlnaHQ6ICR7cHJvcHMgPT4gcHJvcHMudGhlbWUuc3BhY2VTY2FsZS5zcGFjaW5nMDN9O1xuXG4gIEBtZWRpYSAobWF4LXdpZHRoOiAke3Byb3BzID0+IHByb3BzLnRoZW1lLmJyZWFrcG9pbnRzLnNtYWxsfXB4KSB7XG4gICAgc3ZnIHtcbiAgICAgIHdpZHRoOiAyMHB4O1xuICAgIH1cbiAgfVxuYDtcclxuZnVuY3Rpb24gcmVuZGVySWNvbih2YXJpYW50ID0gJ2luZm8nLCB0aGVtZSkge1xyXG4gICAgY29uc3QgSWNvbiA9IFZBUklBTlRfSUNPTlt2YXJpYW50XTtcclxuICAgIHJldHVybiAoUmVhY3QuY3JlYXRlRWxlbWVudChJY29uV3JhcHBlciwgeyB0aGVtZTogdGhlbWUgfSxcclxuICAgICAgICBSZWFjdC5jcmVhdGVFbGVtZW50KEljb24sIHsgc2l6ZTogdGhlbWUuaWNvblNpemVzLm1lZGl1bSB9KSkpO1xyXG59XHJcbmZ1bmN0aW9uIGdldEJ1dHRvbkNvbG9yKHZhcmlhbnQpIHtcclxuICAgIHN3aXRjaCAodmFyaWFudCkge1xyXG4gICAgICAgIGNhc2UgJ2Rhbmdlcic6XHJcbiAgICAgICAgICAgIHJldHVybiBCdXR0b25Db2xvci5kYW5nZXI7XHJcbiAgICAgICAgZGVmYXVsdDpcclxuICAgICAgICAgICAgcmV0dXJuIEJ1dHRvbkNvbG9yLnByaW1hcnk7XHJcbiAgICB9XHJcbn1cclxuZXhwb3J0IGNvbnN0IEJhbm5lciA9IFJlYWN0LmZvcndhcmRSZWYoKHByb3BzLCByZWYpID0+
|
|
4306
|
+
styles: "align-items:center;display:flex;flex-shrink:0/*# sourceMappingURL=data:application/json;charset=utf-8;base64,{"version":3,"sources":["index.tsx"],"names":[],"mappings":"AAuDkC","file":"index.tsx","sourcesContent":["import * as React from 'react';\r\nimport isPropValid from '@emotion/is-prop-valid';\r\nimport styled from '@emotion/styled';\r\nimport { CloseIcon } from 'react-magma-icons';\r\nimport { I18nContext } from '../../i18n';\r\nimport { useIsInverse } from '../../inverse';\r\nimport { ThemeContext } from '../../theme/ThemeContext';\r\nimport { AdditionalContentWrapper, AlertVariant, buildAlertBackground, buildAlertBorder, buildAlertColor, buildLinkColor, buildLinkHoverColor, VARIANT_ICON, } from '../AlertBase';\r\nimport { Button, ButtonSize, ButtonVariant, ButtonColor } from '../Button';\r\nimport { IconButton } from '../IconButton';\r\nconst StyledBanner = styled.div `\n  align-items: stretch;\n  background: ${props => buildAlertBackground(props)};\n  color: ${props => buildAlertColor(props)};\n  display: flex;\n  font-size: ${props => props.theme.typeScale.size03.fontSize};\n  font-family: ${props => props.theme.bodyFont};\n  line-height: ${props => props.theme.typeScale.size03.lineHeight};\n  position: relative;\n  text-align: left;\n\n  @media (max-width: ${props => props.theme.breakpoints.small}px) {\n    text-align: left;\n    font-size: ${props => props.theme.typeScale.size02.fontSize};\n    letter-spacing: ${props => props.theme.typeScale.size02.letterSpacing};\n    line-height: ${props => props.theme.typeScale.size02.lineHeight};\n  }\n`;\r\nconst BannerContents = styled.div `\n  align-items: center;\n  border-bottom: 1px solid ${props => buildAlertBorder(props)};\n  display: flex;\n  flex-grow: 1;\n  justify-content: flex-start;\n  padding: ${props => props.additionalContent && props.isDismissible\r\n    ? `${props.theme.spaceScale.spacing04} 0 ${props.theme.spaceScale.spacing04} ${props.theme.spaceScale.spacing04}`\r\n    : props.theme.spaceScale.spacing04};\n\n  @media (max-width: ${props => props.theme.breakpoints.small}px) {\n    justify-content: flex-start;\n  }\n\n  a {\n    color: ${props => buildLinkColor(props)};\n    font-weight: 400;\n    font-family: ${props => props.theme.bodyFont};\n    text-decoration: underline;\n    &:not([disabled]) {\n      &:focus,\n      &:hover {\n        color: ${props => buildLinkHoverColor(props)};\n      }\n    }\n  }\n`;\r\nconst ButtonWrapper = styled.span `\n  align-items: center;\n  display: flex;\n  flex-shrink: 0;\n`;\r\nconst allowedProps = ['icon', 'isInverse', 'theme', 'variant'];\r\nconst shouldForwardProp = prop => {\r\n    return isPropValid(prop) || allowedProps.includes(prop);\r\n};\r\nfunction buildDismissButtonColor(props) {\r\n    if (props.isInverse) {\r\n        return props.theme.colors.neutral100;\r\n    }\r\n    switch (props.alertVariant) {\r\n        case 'success':\r\n            return props.theme.colors.success500;\r\n        case 'warning':\r\n            return props.theme.colors.warning500;\r\n        case 'danger':\r\n            return props.theme.colors.danger500;\r\n        default:\r\n            return props.theme.colors.info500;\r\n    }\r\n}\r\nconst DismissButton = styled(IconButton, { shouldForwardProp }) `\n  align-self: stretch;\n  border-radius: 0;\n  color: ${props => buildDismissButtonColor(props)};\n  height: auto;\n  padding: 0 ${props => props.theme.spaceScale.spacing05};\n  width: auto;\n  border-bottom: 1px solid\n    ${props => buildAlertBorder({\r\n    variant: props.alertVariant,\r\n    theme: props.theme,\r\n    isInverse: props.isInverse,\r\n})};\n\n  &:not(:disabled) {\n    &:hover {\n      background: none;\n      color: ${props => buildDismissButtonColor(props)};\n    }\n    &:focus {\n      background: none;\n      color: ${props => buildDismissButtonColor(props)};\n      outline: 2px solid\n        ${props => props.isInverse\r\n    ? props.theme.colors.focusInverse\r\n    : props.theme.colors.focus};\n      outline-offset: 0 !important;\n    }\n    &:active {\n      background: none;\n      color: ${props => buildDismissButtonColor(props)};\n    }\n  }\n`;\r\nconst IconWrapper = styled.span `\n  display: inline-flex;\n  padding-right: ${props => props.theme.spaceScale.spacing03};\n\n  @media (max-width: ${props => props.theme.breakpoints.small}px) {\n    svg {\n      width: 20px;\n    }\n  }\n`;\r\nfunction renderIcon(variant = 'info', theme) {\r\n    const Icon = VARIANT_ICON[variant];\r\n    return (React.createElement(IconWrapper, { theme: theme },\r\n        React.createElement(Icon, { size: theme.iconSizes.medium })));\r\n}\r\nfunction getButtonColor(variant) {\r\n    switch (variant) {\r\n        case 'danger':\r\n            return ButtonColor.danger;\r\n        default:\r\n            return ButtonColor.primary;\r\n    }\r\n}\r\nexport const Banner = React.forwardRef((props, ref) => {\r\n    const { actionButtonText, actionButtonOnClick, additionalContent, children, closeAriaLabel, isDismissible, onDismiss, testId, variant = AlertVariant.info, dismissibleButtonRef, ...other } = props;\r\n    const theme = React.useContext(ThemeContext);\r\n    const i18n = React.useContext(I18nContext);\r\n    const isInverse = useIsInverse(props.isInverse);\r\n    return (React.createElement(StyledBanner, Object.assign({}, other, { \"data-testid\": testId, ref: ref, theme: theme, variant: variant }),\r\n        React.createElement(BannerContents, { additionalContent: additionalContent, isDismissible: isDismissible, theme: theme, variant: variant, isInverse: isInverse },\r\n            renderIcon(variant, theme),\r\n            React.createElement(\"span\", null, children),\r\n            actionButtonText && actionButtonOnClick && (React.createElement(Button, { color: getButtonColor(variant), isInverse: isInverse, onClick: actionButtonOnClick, style: { margin: `0 0 0 ${theme.spaceScale.spacing08}` }, size: ButtonSize.small }, actionButtonText)),\r\n            additionalContent && (React.createElement(AdditionalContentWrapper, { theme: theme }, additionalContent))),\r\n        isDismissible && (React.createElement(ButtonWrapper, { color: variant },\r\n            React.createElement(DismissButton, { alertVariant: variant, \"aria-label\": closeAriaLabel ? closeAriaLabel : i18n.alert.dismissAriaLabel, icon: React.createElement(CloseIcon, { size: theme.iconSizes.small }), isInverse: isInverse, onClick: onDismiss, theme: theme, variant: ButtonVariant.link, ref: dismissibleButtonRef })))));\r\n});\r\n//# sourceMappingURL=index.js.map"]} */",
|
|
4298
4307
|
toString: _EMOTION_STRINGIFIED_CSS_ERROR__$6
|
|
4299
4308
|
});
|
|
4300
4309
|
var allowedProps = ['icon', 'isInverse', 'theme', 'variant'];
|
|
@@ -4338,7 +4347,7 @@ var DismissButton$1 = /*#__PURE__*/_styled(IconButton, {
|
|
|
4338
4347
|
return props.isInverse ? props.theme.colors.focusInverse : props.theme.colors.focus;
|
|
4339
4348
|
}, ";outline-offset:0!important;}&:active{background:none;color:", function (props) {
|
|
4340
4349
|
return buildDismissButtonColor(props);
|
|
4341
|
-
}, ";}}" + (process.env.NODE_ENV === "production" ? "" : "/*# sourceMappingURL=data:application/json;charset=utf-8;base64,eyJ2ZXJzaW9uIjozLCJzb3VyY2VzIjpbImluZGV4LnRzeCJdLCJuYW1lcyI6W10sIm1hcHBpbmdzIjoiQUErRWdFIiwiZmlsZSI6ImluZGV4LnRzeCIsInNvdXJjZXNDb250ZW50IjpbImltcG9ydCAqIGFzIFJlYWN0IGZyb20gJ3JlYWN0JztcclxuaW1wb3J0IGlzUHJvcFZhbGlkIGZyb20gJ0BlbW90aW9uL2lzLXByb3AtdmFsaWQnO1xyXG5pbXBvcnQgc3R5bGVkIGZyb20gJ0BlbW90aW9uL3N0eWxlZCc7XHJcbmltcG9ydCB7IENsb3NlSWNvbiB9IGZyb20gJ3JlYWN0LW1hZ21hLWljb25zJztcclxuaW1wb3J0IHsgSTE4bkNvbnRleHQgfSBmcm9tICcuLi8uLi9pMThuJztcclxuaW1wb3J0IHsgdXNlSXNJbnZlcnNlIH0gZnJvbSAnLi4vLi4vaW52ZXJzZSc7XHJcbmltcG9ydCB7IFRoZW1lQ29udGV4dCB9IGZyb20gJy4uLy4uL3RoZW1lL1RoZW1lQ29udGV4dCc7XHJcbmltcG9ydCB7IEFkZGl0aW9uYWxDb250ZW50V3JhcHBlciwgQWxlcnRWYXJpYW50LCBidWlsZEFsZXJ0QmFja2dyb3VuZCwgYnVpbGRBbGVydEJvcmRlciwgYnVpbGRBbGVydENvbG9yLCBidWlsZExpbmtDb2xvciwgYnVpbGRMaW5rSG92ZXJDb2xvciwgVkFSSUFOVF9JQ09OLCB9IGZyb20gJy4uL0FsZXJ0QmFzZSc7XHJcbmltcG9ydCB7IEJ1dHRvbiwgQnV0dG9uU2l6ZSwgQnV0dG9uVmFyaWFudCwgQnV0dG9uQ29sb3IgfSBmcm9tICcuLi9CdXR0b24nO1xyXG5pbXBvcnQgeyBJY29uQnV0dG9uIH0gZnJvbSAnLi4vSWNvbkJ1dHRvbic7XHJcbmNvbnN0IFN0eWxlZEJhbm5lciA9IHN0eWxlZC5kaXYgYFxuICBhbGlnbi1pdGVtczogc3RyZXRjaDtcbiAgYmFja2dyb3VuZDogJHtwcm9wcyA9PiBidWlsZEFsZXJ0QmFja2dyb3VuZChwcm9wcyl9O1xuICBjb2xvcjogJHtwcm9wcyA9PiBidWlsZEFsZXJ0Q29sb3IocHJvcHMpfTtcbiAgZGlzcGxheTogZmxleDtcbiAgZm9udC1zaXplOiAke3Byb3BzID0+IHByb3BzLnRoZW1lLnR5cGVTY2FsZS5zaXplMDMuZm9udFNpemV9O1xuICBmb250LWZhbWlseTogJHtwcm9wcyA9PiBwcm9wcy50aGVtZS5ib2R5Rm9udH07XG4gIGxpbmUtaGVpZ2h0OiAke3Byb3BzID0+IHByb3BzLnRoZW1lLnR5cGVTY2FsZS5zaXplMDMubGluZUhlaWdodH07XG4gIHBvc2l0aW9uOiByZWxhdGl2ZTtcbiAgdGV4dC1hbGlnbjogbGVmdDtcblxuICBAbWVkaWEgKG1heC13aWR0aDogJHtwcm9wcyA9PiBwcm9wcy50aGVtZS5icmVha3BvaW50cy5zbWFsbH1weCkge1xuICAgIHRleHQtYWxpZ246IGxlZnQ7XG4gICAgZm9udC1zaXplOiAke3Byb3BzID0+IHByb3BzLnRoZW1lLnR5cGVTY2FsZS5zaXplMDIuZm9udFNpemV9O1xuICAgIGxldHRlci1zcGFjaW5nOiAke3Byb3BzID0+IHByb3BzLnRoZW1lLnR5cGVTY2FsZS5zaXplMDIubGV0dGVyU3BhY2luZ307XG4gICAgbGluZS1oZWlnaHQ6ICR7cHJvcHMgPT4gcHJvcHMudGhlbWUudHlwZVNjYWxlLnNpemUwMi5saW5lSGVpZ2h0fTtcbiAgfVxuYDtcclxuY29uc3QgQmFubmVyQ29udGVudHMgPSBzdHlsZWQuZGl2IGBcbiAgYWxpZ24taXRlbXM6IGNlbnRlcjtcbiAgYm9yZGVyLWJvdHRvbTogMXB4IHNvbGlkICR7cHJvcHMgPT4gYnVpbGRBbGVydEJvcmRlcihwcm9wcyl9O1xuICBkaXNwbGF5OiBmbGV4O1xuICBmbGV4LWdyb3c6IDE7XG4gIGp1c3RpZnktY29udGVudDogZmxleC1zdGFydDtcbiAgcGFkZGluZzogJHtwcm9wcyA9PiBwcm9wcy5hZGRpdGlvbmFsQ29udGVudCAmJiBwcm9wcy5pc0Rpc21pc3NpYmxlXHJcbiAgICA/IGAke3Byb3BzLnRoZW1lLnNwYWNlU2NhbGUuc3BhY2luZzA0fSAwICR7cHJvcHMudGhlbWUuc3BhY2VTY2FsZS5zcGFjaW5nMDR9ICR7cHJvcHMudGhlbWUuc3BhY2VTY2FsZS5zcGFjaW5nMDR9YFxyXG4gICAgOiBwcm9wcy50aGVtZS5zcGFjZVNjYWxlLnNwYWNpbmcwNH07XG5cbiAgQG1lZGlhIChtYXgtd2lkdGg6ICR7cHJvcHMgPT4gcHJvcHMudGhlbWUuYnJlYWtwb2ludHMuc21hbGx9cHgpIHtcbiAgICBqdXN0aWZ5LWNvbnRlbnQ6IGZsZXgtc3RhcnQ7XG4gIH1cblxuICBhIHtcbiAgICBjb2xvcjogJHtwcm9wcyA9PiBidWlsZExpbmtDb2xvcihwcm9wcyl9O1xuICAgIGZvbnQtd2VpZ2h0OiA0MDA7XG4gICAgZm9udC1mYW1pbHk6ICR7cHJvcHMgPT4gcHJvcHMudGhlbWUuYm9keUZvbnR9O1xuICAgIHRleHQtZGVjb3JhdGlvbjogdW5kZXJsaW5lO1xuICAgICY6bm90KFtkaXNhYmxlZF0pIHtcbiAgICAgICY6Zm9jdXMsXG4gICAgICAmOmhvdmVyIHtcbiAgICAgICAgY29sb3I6ICR7cHJvcHMgPT4gYnVpbGRMaW5rSG92ZXJDb2xvcihwcm9wcyl9O1xuICAgICAgfVxuICAgIH1cbiAgfVxuYDtcclxuY29uc3QgQnV0dG9uV3JhcHBlciA9IHN0eWxlZC5zcGFuIGBcbiAgYWxpZ24taXRlbXM6IGNlbnRlcjtcbiAgZGlzcGxheTogZmxleDtcbiAgZmxleC1zaHJpbms6IDA7XG5gO1xyXG5jb25zdCBhbGxvd2VkUHJvcHMgPSBbJ2ljb24nLCAnaXNJbnZlcnNlJywgJ3RoZW1lJywgJ3ZhcmlhbnQnXTtcclxuY29uc3Qgc2hvdWxkRm9yd2FyZFByb3AgPSBwcm9wID0+IHtcclxuICAgIHJldHVybiBpc1Byb3BWYWxpZChwcm9wKSB8fCBhbGxvd2VkUHJvcHMuaW5jbHVkZXMocHJvcCk7XHJcbn07XHJcbmZ1bmN0aW9uIGJ1aWxkRGlzbWlzc0J1dHRvbkNvbG9yKHByb3BzKSB7XHJcbiAgICBpZiAocHJvcHMuaXNJbnZlcnNlKSB7XHJcbiAgICAgICAgcmV0dXJuIHByb3BzLnRoZW1lLmNvbG9ycy5uZXV0cmFsMTAwO1xyXG4gICAgfVxyXG4gICAgc3dpdGNoIChwcm9wcy5hbGVydFZhcmlhbnQpIHtcclxuICAgICAgICBjYXNlICdzdWNjZXNzJzpcclxuICAgICAgICAgICAgcmV0dXJuIHByb3BzLnRoZW1lLmNvbG9ycy5zdWNjZXNzNTAwO1xyXG4gICAgICAgIGNhc2UgJ3dhcm5pbmcnOlxyXG4gICAgICAgICAgICByZXR1cm4gcHJvcHMudGhlbWUuY29sb3JzLndhcm5pbmc1MDA7XHJcbiAgICAgICAgY2FzZSAnZGFuZ2VyJzpcclxuICAgICAgICAgICAgcmV0dXJuIHByb3BzLnRoZW1lLmNvbG9ycy5kYW5nZXI1MDA7XHJcbiAgICAgICAgZGVmYXVsdDpcclxuICAgICAgICAgICAgcmV0dXJuIHByb3BzLnRoZW1lLmNvbG9ycy5pbmZvNTAwO1xyXG4gICAgfVxyXG59XHJcbmNvbnN0IERpc21pc3NCdXR0b24gPSBzdHlsZWQoSWNvbkJ1dHRvbiwgeyBzaG91bGRGb3J3YXJkUHJvcCB9KSBgXG4gIGFsaWduLXNlbGY6IHN0cmV0Y2g7XG4gIGJvcmRlci1yYWRpdXM6IDA7XG4gIGNvbG9yOiAke3Byb3BzID0+IGJ1aWxkRGlzbWlzc0J1dHRvbkNvbG9yKHByb3BzKX07XG4gIGhlaWdodDogYXV0bztcbiAgcGFkZGluZzogMCAke3Byb3BzID0+IHByb3BzLnRoZW1lLnNwYWNlU2NhbGUuc3BhY2luZzA1fTtcbiAgd2lkdGg6IGF1dG87XG4gIGJvcmRlci1ib3R0b206IDFweCBzb2xpZFxuICAgICR7cHJvcHMgPT4gYnVpbGRBbGVydEJvcmRlcih7XHJcbiAgICB2YXJpYW50OiBwcm9wcy5hbGVydFZhcmlhbnQsXHJcbiAgICB0aGVtZTogcHJvcHMudGhlbWUsXHJcbiAgICBpc0ludmVyc2U6IHByb3BzLmlzSW52ZXJzZSxcclxufSl9O1xuXG4gICY6bm90KDpkaXNhYmxlZCkge1xuICAgICY6aG92ZXIge1xuICAgICAgYmFja2dyb3VuZDogbm9uZTtcbiAgICAgIGNvbG9yOiAke3Byb3BzID0+IGJ1aWxkRGlzbWlzc0J1dHRvbkNvbG9yKHByb3BzKX07XG4gICAgfVxuICAgICY6Zm9jdXMge1xuICAgICAgYmFja2dyb3VuZDogbm9uZTtcbiAgICAgIGNvbG9yOiAke3Byb3BzID0+IGJ1aWxkRGlzbWlzc0J1dHRvbkNvbG9yKHByb3BzKX07XG4gICAgICBvdXRsaW5lOiAycHggc29saWRcbiAgICAgICAgJHtwcm9wcyA9PiBwcm9wcy5pc0ludmVyc2VcclxuICAgID8gcHJvcHMudGhlbWUuY29sb3JzLmZvY3VzSW52ZXJzZVxyXG4gICAgOiBwcm9wcy50aGVtZS5jb2xvcnMuZm9jdXN9O1xuICAgICAgb3V0bGluZS1vZmZzZXQ6IDAgIWltcG9ydGFudDtcbiAgICB9XG4gICAgJjphY3RpdmUge1xuICAgICAgYmFja2dyb3VuZDogbm9uZTtcbiAgICAgIGNvbG9yOiAke3Byb3BzID0+IGJ1aWxkRGlzbWlzc0J1dHRvbkNvbG9yKHByb3BzKX07XG4gICAgfVxuICB9XG5gO1xyXG5jb25zdCBJY29uV3JhcHBlciA9IHN0eWxlZC5zcGFuIGBcbiAgZGlzcGxheTogaW5saW5lLWZsZXg7XG4gIHBhZGRpbmctcmlnaHQ6ICR7cHJvcHMgPT4gcHJvcHMudGhlbWUuc3BhY2VTY2FsZS5zcGFjaW5nMDN9O1xuXG4gIEBtZWRpYSAobWF4LXdpZHRoOiAke3Byb3BzID0+IHByb3BzLnRoZW1lLmJyZWFrcG9pbnRzLnNtYWxsfXB4KSB7XG4gICAgc3ZnIHtcbiAgICAgIHdpZHRoOiAyMHB4O1xuICAgIH1cbiAgfVxuYDtcclxuZnVuY3Rpb24gcmVuZGVySWNvbih2YXJpYW50ID0gJ2luZm8nLCB0aGVtZSkge1xyXG4gICAgY29uc3QgSWNvbiA9IFZBUklBTlRfSUNPTlt2YXJpYW50XTtcclxuICAgIHJldHVybiAoUmVhY3QuY3JlYXRlRWxlbWVudChJY29uV3JhcHBlciwgeyB0aGVtZTogdGhlbWUgfSxcclxuICAgICAgICBSZWFjdC5jcmVhdGVFbGVtZW50KEljb24sIHsgc2l6ZTogdGhlbWUuaWNvblNpemVzLm1lZGl1bSB9KSkpO1xyXG59XHJcbmZ1bmN0aW9uIGdldEJ1dHRvbkNvbG9yKHZhcmlhbnQpIHtcclxuICAgIHN3aXRjaCAodmFyaWFudCkge1xyXG4gICAgICAgIGNhc2UgJ2Rhbmdlcic6XHJcbiAgICAgICAgICAgIHJldHVybiBCdXR0b25Db2xvci5kYW5nZXI7XHJcbiAgICAgICAgZGVmYXVsdDpcclxuICAgICAgICAgICAgcmV0dXJuIEJ1dHRvbkNvbG9yLnByaW1hcnk7XHJcbiAgICB9XHJcbn1cclxuZXhwb3J0IGNvbnN0IEJhbm5lciA9IFJlYWN0LmZvcndhcmRSZWYoKHByb3BzLCByZWYpID0+
|
|
4350
|
+
}, ";}}" + (process.env.NODE_ENV === "production" ? "" : "/*# sourceMappingURL=data:application/json;charset=utf-8;base64,{"version":3,"sources":["index.tsx"],"names":[],"mappings":"AA+EgE","file":"index.tsx","sourcesContent":["import * as React from 'react';\r\nimport isPropValid from '@emotion/is-prop-valid';\r\nimport styled from '@emotion/styled';\r\nimport { CloseIcon } from 'react-magma-icons';\r\nimport { I18nContext } from '../../i18n';\r\nimport { useIsInverse } from '../../inverse';\r\nimport { ThemeContext } from '../../theme/ThemeContext';\r\nimport { AdditionalContentWrapper, AlertVariant, buildAlertBackground, buildAlertBorder, buildAlertColor, buildLinkColor, buildLinkHoverColor, VARIANT_ICON, } from '../AlertBase';\r\nimport { Button, ButtonSize, ButtonVariant, ButtonColor } from '../Button';\r\nimport { IconButton } from '../IconButton';\r\nconst StyledBanner = styled.div `\n  align-items: stretch;\n  background: ${props => buildAlertBackground(props)};\n  color: ${props => buildAlertColor(props)};\n  display: flex;\n  font-size: ${props => props.theme.typeScale.size03.fontSize};\n  font-family: ${props => props.theme.bodyFont};\n  line-height: ${props => props.theme.typeScale.size03.lineHeight};\n  position: relative;\n  text-align: left;\n\n  @media (max-width: ${props => props.theme.breakpoints.small}px) {\n    text-align: left;\n    font-size: ${props => props.theme.typeScale.size02.fontSize};\n    letter-spacing: ${props => props.theme.typeScale.size02.letterSpacing};\n    line-height: ${props => props.theme.typeScale.size02.lineHeight};\n  }\n`;\r\nconst BannerContents = styled.div `\n  align-items: center;\n  border-bottom: 1px solid ${props => buildAlertBorder(props)};\n  display: flex;\n  flex-grow: 1;\n  justify-content: flex-start;\n  padding: ${props => props.additionalContent && props.isDismissible\r\n    ? `${props.theme.spaceScale.spacing04} 0 ${props.theme.spaceScale.spacing04} ${props.theme.spaceScale.spacing04}`\r\n    : props.theme.spaceScale.spacing04};\n\n  @media (max-width: ${props => props.theme.breakpoints.small}px) {\n    justify-content: flex-start;\n  }\n\n  a {\n    color: ${props => buildLinkColor(props)};\n    font-weight: 400;\n    font-family: ${props => props.theme.bodyFont};\n    text-decoration: underline;\n    &:not([disabled]) {\n      &:focus,\n      &:hover {\n        color: ${props => buildLinkHoverColor(props)};\n      }\n    }\n  }\n`;\r\nconst ButtonWrapper = styled.span `\n  align-items: center;\n  display: flex;\n  flex-shrink: 0;\n`;\r\nconst allowedProps = ['icon', 'isInverse', 'theme', 'variant'];\r\nconst shouldForwardProp = prop => {\r\n    return isPropValid(prop) || allowedProps.includes(prop);\r\n};\r\nfunction buildDismissButtonColor(props) {\r\n    if (props.isInverse) {\r\n        return props.theme.colors.neutral100;\r\n    }\r\n    switch (props.alertVariant) {\r\n        case 'success':\r\n            return props.theme.colors.success500;\r\n        case 'warning':\r\n            return props.theme.colors.warning500;\r\n        case 'danger':\r\n            return props.theme.colors.danger500;\r\n        default:\r\n            return props.theme.colors.info500;\r\n    }\r\n}\r\nconst DismissButton = styled(IconButton, { shouldForwardProp }) `\n  align-self: stretch;\n  border-radius: 0;\n  color: ${props => buildDismissButtonColor(props)};\n  height: auto;\n  padding: 0 ${props => props.theme.spaceScale.spacing05};\n  width: auto;\n  border-bottom: 1px solid\n    ${props => buildAlertBorder({\r\n    variant: props.alertVariant,\r\n    theme: props.theme,\r\n    isInverse: props.isInverse,\r\n})};\n\n  &:not(:disabled) {\n    &:hover {\n      background: none;\n      color: ${props => buildDismissButtonColor(props)};\n    }\n    &:focus {\n      background: none;\n      color: ${props => buildDismissButtonColor(props)};\n      outline: 2px solid\n        ${props => props.isInverse\r\n    ? props.theme.colors.focusInverse\r\n    : props.theme.colors.focus};\n      outline-offset: 0 !important;\n    }\n    &:active {\n      background: none;\n      color: ${props => buildDismissButtonColor(props)};\n    }\n  }\n`;\r\nconst IconWrapper = styled.span `\n  display: inline-flex;\n  padding-right: ${props => props.theme.spaceScale.spacing03};\n\n  @media (max-width: ${props => props.theme.breakpoints.small}px) {\n    svg {\n      width: 20px;\n    }\n  }\n`;\r\nfunction renderIcon(variant = 'info', theme) {\r\n    const Icon = VARIANT_ICON[variant];\r\n    return (React.createElement(IconWrapper, { theme: theme },\r\n        React.createElement(Icon, { size: theme.iconSizes.medium })));\r\n}\r\nfunction getButtonColor(variant) {\r\n    switch (variant) {\r\n        case 'danger':\r\n            return ButtonColor.danger;\r\n        default:\r\n            return ButtonColor.primary;\r\n    }\r\n}\r\nexport const Banner = React.forwardRef((props, ref) => {\r\n    const { actionButtonText, actionButtonOnClick, additionalContent, children, closeAriaLabel, isDismissible, onDismiss, testId, variant = AlertVariant.info, dismissibleButtonRef, ...other } = props;\r\n    const theme = React.useContext(ThemeContext);\r\n    const i18n = React.useContext(I18nContext);\r\n    const isInverse = useIsInverse(props.isInverse);\r\n    return (React.createElement(StyledBanner, Object.assign({}, other, { \"data-testid\": testId, ref: ref, theme: theme, variant: variant }),\r\n        React.createElement(BannerContents, { additionalContent: additionalContent, isDismissible: isDismissible, theme: theme, variant: variant, isInverse: isInverse },\r\n            renderIcon(variant, theme),\r\n            React.createElement(\"span\", null, children),\r\n            actionButtonText && actionButtonOnClick && (React.createElement(Button, { color: getButtonColor(variant), isInverse: isInverse, onClick: actionButtonOnClick, style: { margin: `0 0 0 ${theme.spaceScale.spacing08}` }, size: ButtonSize.small }, actionButtonText)),\r\n            additionalContent && (React.createElement(AdditionalContentWrapper, { theme: theme }, additionalContent))),\r\n        isDismissible && (React.createElement(ButtonWrapper, { color: variant },\r\n            React.createElement(DismissButton, { alertVariant: variant, \"aria-label\": closeAriaLabel ? closeAriaLabel : i18n.alert.dismissAriaLabel, icon: React.createElement(CloseIcon, { size: theme.iconSizes.small }), isInverse: isInverse, onClick: onDismiss, theme: theme, variant: ButtonVariant.link, ref: dismissibleButtonRef })))));\r\n});\r\n//# sourceMappingURL=index.js.map"]} */"));
|
|
4342
4351
|
var IconWrapper$1 = /*#__PURE__*/_styled("span", {
|
|
4343
4352
|
target: "e1b9nb1m0",
|
|
4344
4353
|
label: "IconWrapper"
|
|
@@ -4346,7 +4355,7 @@ var IconWrapper$1 = /*#__PURE__*/_styled("span", {
|
|
|
4346
4355
|
return props.theme.spaceScale.spacing03;
|
|
4347
4356
|
}, ";@media (max-width: ", function (props) {
|
|
4348
4357
|
return props.theme.breakpoints.small;
|
|
4349
|
-
}, "px){svg{width:20px;}}" + (process.env.NODE_ENV === "production" ? "" : "/*# sourceMappingURL=data:application/json;charset=utf-8;base64,eyJ2ZXJzaW9uIjozLCJzb3VyY2VzIjpbImluZGV4LnRzeCJdLCJuYW1lcyI6W10sIm1hcHBpbmdzIjoiQUFpSGdDIiwiZmlsZSI6ImluZGV4LnRzeCIsInNvdXJjZXNDb250ZW50IjpbImltcG9ydCAqIGFzIFJlYWN0IGZyb20gJ3JlYWN0JztcclxuaW1wb3J0IGlzUHJvcFZhbGlkIGZyb20gJ0BlbW90aW9uL2lzLXByb3AtdmFsaWQnO1xyXG5pbXBvcnQgc3R5bGVkIGZyb20gJ0BlbW90aW9uL3N0eWxlZCc7XHJcbmltcG9ydCB7IENsb3NlSWNvbiB9IGZyb20gJ3JlYWN0LW1hZ21hLWljb25zJztcclxuaW1wb3J0IHsgSTE4bkNvbnRleHQgfSBmcm9tICcuLi8uLi9pMThuJztcclxuaW1wb3J0IHsgdXNlSXNJbnZlcnNlIH0gZnJvbSAnLi4vLi4vaW52ZXJzZSc7XHJcbmltcG9ydCB7IFRoZW1lQ29udGV4dCB9IGZyb20gJy4uLy4uL3RoZW1lL1RoZW1lQ29udGV4dCc7XHJcbmltcG9ydCB7IEFkZGl0aW9uYWxDb250ZW50V3JhcHBlciwgQWxlcnRWYXJpYW50LCBidWlsZEFsZXJ0QmFja2dyb3VuZCwgYnVpbGRBbGVydEJvcmRlciwgYnVpbGRBbGVydENvbG9yLCBidWlsZExpbmtDb2xvciwgYnVpbGRMaW5rSG92ZXJDb2xvciwgVkFSSUFOVF9JQ09OLCB9IGZyb20gJy4uL0FsZXJ0QmFzZSc7XHJcbmltcG9ydCB7IEJ1dHRvbiwgQnV0dG9uU2l6ZSwgQnV0dG9uVmFyaWFudCwgQnV0dG9uQ29sb3IgfSBmcm9tICcuLi9CdXR0b24nO1xyXG5pbXBvcnQgeyBJY29uQnV0dG9uIH0gZnJvbSAnLi4vSWNvbkJ1dHRvbic7XHJcbmNvbnN0IFN0eWxlZEJhbm5lciA9IHN0eWxlZC5kaXYgYFxuICBhbGlnbi1pdGVtczogc3RyZXRjaDtcbiAgYmFja2dyb3VuZDogJHtwcm9wcyA9PiBidWlsZEFsZXJ0QmFja2dyb3VuZChwcm9wcyl9O1xuICBjb2xvcjogJHtwcm9wcyA9PiBidWlsZEFsZXJ0Q29sb3IocHJvcHMpfTtcbiAgZGlzcGxheTogZmxleDtcbiAgZm9udC1zaXplOiAke3Byb3BzID0+IHByb3BzLnRoZW1lLnR5cGVTY2FsZS5zaXplMDMuZm9udFNpemV9O1xuICBmb250LWZhbWlseTogJHtwcm9wcyA9PiBwcm9wcy50aGVtZS5ib2R5Rm9udH07XG4gIGxpbmUtaGVpZ2h0OiAke3Byb3BzID0+IHByb3BzLnRoZW1lLnR5cGVTY2FsZS5zaXplMDMubGluZUhlaWdodH07XG4gIHBvc2l0aW9uOiByZWxhdGl2ZTtcbiAgdGV4dC1hbGlnbjogbGVmdDtcblxuICBAbWVkaWEgKG1heC13aWR0aDogJHtwcm9wcyA9PiBwcm9wcy50aGVtZS5icmVha3BvaW50cy5zbWFsbH1weCkge1xuICAgIHRleHQtYWxpZ246IGxlZnQ7XG4gICAgZm9udC1zaXplOiAke3Byb3BzID0+IHByb3BzLnRoZW1lLnR5cGVTY2FsZS5zaXplMDIuZm9udFNpemV9O1xuICAgIGxldHRlci1zcGFjaW5nOiAke3Byb3BzID0+IHByb3BzLnRoZW1lLnR5cGVTY2FsZS5zaXplMDIubGV0dGVyU3BhY2luZ307XG4gICAgbGluZS1oZWlnaHQ6ICR7cHJvcHMgPT4gcHJvcHMudGhlbWUudHlwZVNjYWxlLnNpemUwMi5saW5lSGVpZ2h0fTtcbiAgfVxuYDtcclxuY29uc3QgQmFubmVyQ29udGVudHMgPSBzdHlsZWQuZGl2IGBcbiAgYWxpZ24taXRlbXM6IGNlbnRlcjtcbiAgYm9yZGVyLWJvdHRvbTogMXB4IHNvbGlkICR7cHJvcHMgPT4gYnVpbGRBbGVydEJvcmRlcihwcm9wcyl9O1xuICBkaXNwbGF5OiBmbGV4O1xuICBmbGV4LWdyb3c6IDE7XG4gIGp1c3RpZnktY29udGVudDogZmxleC1zdGFydDtcbiAgcGFkZGluZzogJHtwcm9wcyA9PiBwcm9wcy5hZGRpdGlvbmFsQ29udGVudCAmJiBwcm9wcy5pc0Rpc21pc3NpYmxlXHJcbiAgICA/IGAke3Byb3BzLnRoZW1lLnNwYWNlU2NhbGUuc3BhY2luZzA0fSAwICR7cHJvcHMudGhlbWUuc3BhY2VTY2FsZS5zcGFjaW5nMDR9ICR7cHJvcHMudGhlbWUuc3BhY2VTY2FsZS5zcGFjaW5nMDR9YFxyXG4gICAgOiBwcm9wcy50aGVtZS5zcGFjZVNjYWxlLnNwYWNpbmcwNH07XG5cbiAgQG1lZGlhIChtYXgtd2lkdGg6ICR7cHJvcHMgPT4gcHJvcHMudGhlbWUuYnJlYWtwb2ludHMuc21hbGx9cHgpIHtcbiAgICBqdXN0aWZ5LWNvbnRlbnQ6IGZsZXgtc3RhcnQ7XG4gIH1cblxuICBhIHtcbiAgICBjb2xvcjogJHtwcm9wcyA9PiBidWlsZExpbmtDb2xvcihwcm9wcyl9O1xuICAgIGZvbnQtd2VpZ2h0OiA0MDA7XG4gICAgZm9udC1mYW1pbHk6ICR7cHJvcHMgPT4gcHJvcHMudGhlbWUuYm9keUZvbnR9O1xuICAgIHRleHQtZGVjb3JhdGlvbjogdW5kZXJsaW5lO1xuICAgICY6bm90KFtkaXNhYmxlZF0pIHtcbiAgICAgICY6Zm9jdXMsXG4gICAgICAmOmhvdmVyIHtcbiAgICAgICAgY29sb3I6ICR7cHJvcHMgPT4gYnVpbGRMaW5rSG92ZXJDb2xvcihwcm9wcyl9O1xuICAgICAgfVxuICAgIH1cbiAgfVxuYDtcclxuY29uc3QgQnV0dG9uV3JhcHBlciA9IHN0eWxlZC5zcGFuIGBcbiAgYWxpZ24taXRlbXM6IGNlbnRlcjtcbiAgZGlzcGxheTogZmxleDtcbiAgZmxleC1zaHJpbms6IDA7XG5gO1xyXG5jb25zdCBhbGxvd2VkUHJvcHMgPSBbJ2ljb24nLCAnaXNJbnZlcnNlJywgJ3RoZW1lJywgJ3ZhcmlhbnQnXTtcclxuY29uc3Qgc2hvdWxkRm9yd2FyZFByb3AgPSBwcm9wID0+IHtcclxuICAgIHJldHVybiBpc1Byb3BWYWxpZChwcm9wKSB8fCBhbGxvd2VkUHJvcHMuaW5jbHVkZXMocHJvcCk7XHJcbn07XHJcbmZ1bmN0aW9uIGJ1aWxkRGlzbWlzc0J1dHRvbkNvbG9yKHByb3BzKSB7XHJcbiAgICBpZiAocHJvcHMuaXNJbnZlcnNlKSB7XHJcbiAgICAgICAgcmV0dXJuIHByb3BzLnRoZW1lLmNvbG9ycy5uZXV0cmFsMTAwO1xyXG4gICAgfVxyXG4gICAgc3dpdGNoIChwcm9wcy5hbGVydFZhcmlhbnQpIHtcclxuICAgICAgICBjYXNlICdzdWNjZXNzJzpcclxuICAgICAgICAgICAgcmV0dXJuIHByb3BzLnRoZW1lLmNvbG9ycy5zdWNjZXNzNTAwO1xyXG4gICAgICAgIGNhc2UgJ3dhcm5pbmcnOlxyXG4gICAgICAgICAgICByZXR1cm4gcHJvcHMudGhlbWUuY29sb3JzLndhcm5pbmc1MDA7XHJcbiAgICAgICAgY2FzZSAnZGFuZ2VyJzpcclxuICAgICAgICAgICAgcmV0dXJuIHByb3BzLnRoZW1lLmNvbG9ycy5kYW5nZXI1MDA7XHJcbiAgICAgICAgZGVmYXVsdDpcclxuICAgICAgICAgICAgcmV0dXJuIHByb3BzLnRoZW1lLmNvbG9ycy5pbmZvNTAwO1xyXG4gICAgfVxyXG59XHJcbmNvbnN0IERpc21pc3NCdXR0b24gPSBzdHlsZWQoSWNvbkJ1dHRvbiwgeyBzaG91bGRGb3J3YXJkUHJvcCB9KSBgXG4gIGFsaWduLXNlbGY6IHN0cmV0Y2g7XG4gIGJvcmRlci1yYWRpdXM6IDA7XG4gIGNvbG9yOiAke3Byb3BzID0+IGJ1aWxkRGlzbWlzc0J1dHRvbkNvbG9yKHByb3BzKX07XG4gIGhlaWdodDogYXV0bztcbiAgcGFkZGluZzogMCAke3Byb3BzID0+IHByb3BzLnRoZW1lLnNwYWNlU2NhbGUuc3BhY2luZzA1fTtcbiAgd2lkdGg6IGF1dG87XG4gIGJvcmRlci1ib3R0b206IDFweCBzb2xpZFxuICAgICR7cHJvcHMgPT4gYnVpbGRBbGVydEJvcmRlcih7XHJcbiAgICB2YXJpYW50OiBwcm9wcy5hbGVydFZhcmlhbnQsXHJcbiAgICB0aGVtZTogcHJvcHMudGhlbWUsXHJcbiAgICBpc0ludmVyc2U6IHByb3BzLmlzSW52ZXJzZSxcclxufSl9O1xuXG4gICY6bm90KDpkaXNhYmxlZCkge1xuICAgICY6aG92ZXIge1xuICAgICAgYmFja2dyb3VuZDogbm9uZTtcbiAgICAgIGNvbG9yOiAke3Byb3BzID0+IGJ1aWxkRGlzbWlzc0J1dHRvbkNvbG9yKHByb3BzKX07XG4gICAgfVxuICAgICY6Zm9jdXMge1xuICAgICAgYmFja2dyb3VuZDogbm9uZTtcbiAgICAgIGNvbG9yOiAke3Byb3BzID0+IGJ1aWxkRGlzbWlzc0J1dHRvbkNvbG9yKHByb3BzKX07XG4gICAgICBvdXRsaW5lOiAycHggc29saWRcbiAgICAgICAgJHtwcm9wcyA9PiBwcm9wcy5pc0ludmVyc2VcclxuICAgID8gcHJvcHMudGhlbWUuY29sb3JzLmZvY3VzSW52ZXJzZVxyXG4gICAgOiBwcm9wcy50aGVtZS5jb2xvcnMuZm9jdXN9O1xuICAgICAgb3V0bGluZS1vZmZzZXQ6IDAgIWltcG9ydGFudDtcbiAgICB9XG4gICAgJjphY3RpdmUge1xuICAgICAgYmFja2dyb3VuZDogbm9uZTtcbiAgICAgIGNvbG9yOiAke3Byb3BzID0+IGJ1aWxkRGlzbWlzc0J1dHRvbkNvbG9yKHByb3BzKX07XG4gICAgfVxuICB9XG5gO1xyXG5jb25zdCBJY29uV3JhcHBlciA9IHN0eWxlZC5zcGFuIGBcbiAgZGlzcGxheTogaW5saW5lLWZsZXg7XG4gIHBhZGRpbmctcmlnaHQ6ICR7cHJvcHMgPT4gcHJvcHMudGhlbWUuc3BhY2VTY2FsZS5zcGFjaW5nMDN9O1xuXG4gIEBtZWRpYSAobWF4LXdpZHRoOiAke3Byb3BzID0+IHByb3BzLnRoZW1lLmJyZWFrcG9pbnRzLnNtYWxsfXB4KSB7XG4gICAgc3ZnIHtcbiAgICAgIHdpZHRoOiAyMHB4O1xuICAgIH1cbiAgfVxuYDtcclxuZnVuY3Rpb24gcmVuZGVySWNvbih2YXJpYW50ID0gJ2luZm8nLCB0aGVtZSkge1xyXG4gICAgY29uc3QgSWNvbiA9IFZBUklBTlRfSUNPTlt2YXJpYW50XTtcclxuICAgIHJldHVybiAoUmVhY3QuY3JlYXRlRWxlbWVudChJY29uV3JhcHBlciwgeyB0aGVtZTogdGhlbWUgfSxcclxuICAgICAgICBSZWFjdC5jcmVhdGVFbGVtZW50KEljb24sIHsgc2l6ZTogdGhlbWUuaWNvblNpemVzLm1lZGl1bSB9KSkpO1xyXG59XHJcbmZ1bmN0aW9uIGdldEJ1dHRvbkNvbG9yKHZhcmlhbnQpIHtcclxuICAgIHN3aXRjaCAodmFyaWFudCkge1xyXG4gICAgICAgIGNhc2UgJ2Rhbmdlcic6XHJcbiAgICAgICAgICAgIHJldHVybiBCdXR0b25Db2xvci5kYW5nZXI7XHJcbiAgICAgICAgZGVmYXVsdDpcclxuICAgICAgICAgICAgcmV0dXJuIEJ1dHRvbkNvbG9yLnByaW1hcnk7XHJcbiAgICB9XHJcbn1cclxuZXhwb3J0IGNvbnN0IEJhbm5lciA9IFJlYWN0LmZvcndhcmRSZWYoKHByb3BzLCByZWYpID0+
|
|
4358
|
+
}, "px){svg{width:20px;}}" + (process.env.NODE_ENV === "production" ? "" : "/*# sourceMappingURL=data:application/json;charset=utf-8;base64,{"version":3,"sources":["index.tsx"],"names":[],"mappings":"AAiHgC","file":"index.tsx","sourcesContent":["import * as React from 'react';\r\nimport isPropValid from '@emotion/is-prop-valid';\r\nimport styled from '@emotion/styled';\r\nimport { CloseIcon } from 'react-magma-icons';\r\nimport { I18nContext } from '../../i18n';\r\nimport { useIsInverse } from '../../inverse';\r\nimport { ThemeContext } from '../../theme/ThemeContext';\r\nimport { AdditionalContentWrapper, AlertVariant, buildAlertBackground, buildAlertBorder, buildAlertColor, buildLinkColor, buildLinkHoverColor, VARIANT_ICON, } from '../AlertBase';\r\nimport { Button, ButtonSize, ButtonVariant, ButtonColor } from '../Button';\r\nimport { IconButton } from '../IconButton';\r\nconst StyledBanner = styled.div `\n  align-items: stretch;\n  background: ${props => buildAlertBackground(props)};\n  color: ${props => buildAlertColor(props)};\n  display: flex;\n  font-size: ${props => props.theme.typeScale.size03.fontSize};\n  font-family: ${props => props.theme.bodyFont};\n  line-height: ${props => props.theme.typeScale.size03.lineHeight};\n  position: relative;\n  text-align: left;\n\n  @media (max-width: ${props => props.theme.breakpoints.small}px) {\n    text-align: left;\n    font-size: ${props => props.theme.typeScale.size02.fontSize};\n    letter-spacing: ${props => props.theme.typeScale.size02.letterSpacing};\n    line-height: ${props => props.theme.typeScale.size02.lineHeight};\n  }\n`;\r\nconst BannerContents = styled.div `\n  align-items: center;\n  border-bottom: 1px solid ${props => buildAlertBorder(props)};\n  display: flex;\n  flex-grow: 1;\n  justify-content: flex-start;\n  padding: ${props => props.additionalContent && props.isDismissible\r\n    ? `${props.theme.spaceScale.spacing04} 0 ${props.theme.spaceScale.spacing04} ${props.theme.spaceScale.spacing04}`\r\n    : props.theme.spaceScale.spacing04};\n\n  @media (max-width: ${props => props.theme.breakpoints.small}px) {\n    justify-content: flex-start;\n  }\n\n  a {\n    color: ${props => buildLinkColor(props)};\n    font-weight: 400;\n    font-family: ${props => props.theme.bodyFont};\n    text-decoration: underline;\n    &:not([disabled]) {\n      &:focus,\n      &:hover {\n        color: ${props => buildLinkHoverColor(props)};\n      }\n    }\n  }\n`;\r\nconst ButtonWrapper = styled.span `\n  align-items: center;\n  display: flex;\n  flex-shrink: 0;\n`;\r\nconst allowedProps = ['icon', 'isInverse', 'theme', 'variant'];\r\nconst shouldForwardProp = prop => {\r\n    return isPropValid(prop) || allowedProps.includes(prop);\r\n};\r\nfunction buildDismissButtonColor(props) {\r\n    if (props.isInverse) {\r\n        return props.theme.colors.neutral100;\r\n    }\r\n    switch (props.alertVariant) {\r\n        case 'success':\r\n            return props.theme.colors.success500;\r\n        case 'warning':\r\n            return props.theme.colors.warning500;\r\n        case 'danger':\r\n            return props.theme.colors.danger500;\r\n        default:\r\n            return props.theme.colors.info500;\r\n    }\r\n}\r\nconst DismissButton = styled(IconButton, { shouldForwardProp }) `\n  align-self: stretch;\n  border-radius: 0;\n  color: ${props => buildDismissButtonColor(props)};\n  height: auto;\n  padding: 0 ${props => props.theme.spaceScale.spacing05};\n  width: auto;\n  border-bottom: 1px solid\n    ${props => buildAlertBorder({\r\n    variant: props.alertVariant,\r\n    theme: props.theme,\r\n    isInverse: props.isInverse,\r\n})};\n\n  &:not(:disabled) {\n    &:hover {\n      background: none;\n      color: ${props => buildDismissButtonColor(props)};\n    }\n    &:focus {\n      background: none;\n      color: ${props => buildDismissButtonColor(props)};\n      outline: 2px solid\n        ${props => props.isInverse\r\n    ? props.theme.colors.focusInverse\r\n    : props.theme.colors.focus};\n      outline-offset: 0 !important;\n    }\n    &:active {\n      background: none;\n      color: ${props => buildDismissButtonColor(props)};\n    }\n  }\n`;\r\nconst IconWrapper = styled.span `\n  display: inline-flex;\n  padding-right: ${props => props.theme.spaceScale.spacing03};\n\n  @media (max-width: ${props => props.theme.breakpoints.small}px) {\n    svg {\n      width: 20px;\n    }\n  }\n`;\r\nfunction renderIcon(variant = 'info', theme) {\r\n    const Icon = VARIANT_ICON[variant];\r\n    return (React.createElement(IconWrapper, { theme: theme },\r\n        React.createElement(Icon, { size: theme.iconSizes.medium })));\r\n}\r\nfunction getButtonColor(variant) {\r\n    switch (variant) {\r\n        case 'danger':\r\n            return ButtonColor.danger;\r\n        default:\r\n            return ButtonColor.primary;\r\n    }\r\n}\r\nexport const Banner = React.forwardRef((props, ref) => {\r\n    const { actionButtonText, actionButtonOnClick, additionalContent, children, closeAriaLabel, isDismissible, onDismiss, testId, variant = AlertVariant.info, dismissibleButtonRef, ...other } = props;\r\n    const theme = React.useContext(ThemeContext);\r\n    const i18n = React.useContext(I18nContext);\r\n    const isInverse = useIsInverse(props.isInverse);\r\n    return (React.createElement(StyledBanner, Object.assign({}, other, { \"data-testid\": testId, ref: ref, theme: theme, variant: variant }),\r\n        React.createElement(BannerContents, { additionalContent: additionalContent, isDismissible: isDismissible, theme: theme, variant: variant, isInverse: isInverse },\r\n            renderIcon(variant, theme),\r\n            React.createElement(\"span\", null, children),\r\n            actionButtonText && actionButtonOnClick && (React.createElement(Button, { color: getButtonColor(variant), isInverse: isInverse, onClick: actionButtonOnClick, style: { margin: `0 0 0 ${theme.spaceScale.spacing08}` }, size: ButtonSize.small }, actionButtonText)),\r\n            additionalContent && (React.createElement(AdditionalContentWrapper, { theme: theme }, additionalContent))),\r\n        isDismissible && (React.createElement(ButtonWrapper, { color: variant },\r\n            React.createElement(DismissButton, { alertVariant: variant, \"aria-label\": closeAriaLabel ? closeAriaLabel : i18n.alert.dismissAriaLabel, icon: React.createElement(CloseIcon, { size: theme.iconSizes.small }), isInverse: isInverse, onClick: onDismiss, theme: theme, variant: ButtonVariant.link, ref: dismissibleButtonRef })))));\r\n});\r\n//# sourceMappingURL=index.js.map"]} */"));
|
|
4350
4359
|
function renderIcon$1(variant, theme) {
|
|
4351
4360
|
if (variant === void 0) {
|
|
4352
4361
|
variant = 'info';
|
|
@@ -4377,6 +4386,7 @@ var Banner = /*#__PURE__*/forwardRef(function (props, ref) {
|
|
|
4377
4386
|
testId = props.testId,
|
|
4378
4387
|
_props$variant = props.variant,
|
|
4379
4388
|
variant = _props$variant === void 0 ? AlertVariant.info : _props$variant,
|
|
4389
|
+
dismissibleButtonRef = props.dismissibleButtonRef,
|
|
4380
4390
|
other = _objectWithoutPropertiesLoose(props, _excluded$c);
|
|
4381
4391
|
var theme = useContext(ThemeContext);
|
|
4382
4392
|
var i18n = useContext(I18nContext);
|
|
@@ -4413,7 +4423,8 @@ var Banner = /*#__PURE__*/forwardRef(function (props, ref) {
|
|
|
4413
4423
|
isInverse: isInverse,
|
|
4414
4424
|
onClick: onDismiss,
|
|
4415
4425
|
theme: theme,
|
|
4416
|
-
variant: ButtonVariant.link
|
|
4426
|
+
variant: ButtonVariant.link,
|
|
4427
|
+
ref: dismissibleButtonRef
|
|
4417
4428
|
}))));
|
|
4418
4429
|
});
|
|
4419
4430
|
|
|
@@ -8518,7 +8529,7 @@ var StyledContainer$2 = /*#__PURE__*/_styled("div", {
|
|
|
8518
8529
|
styles: "display:inline-block"
|
|
8519
8530
|
} : {
|
|
8520
8531
|
name: "1r5gb7q",
|
|
8521
|
-
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"]} */",
|
|
8532
|
+
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"]} */",
|
|
8522
8533
|
toString: _EMOTION_STRINGIFIED_CSS_ERROR__$b
|
|
8523
8534
|
});
|
|
8524
8535
|
var PopoverContext = /*#__PURE__*/React__default.createContext({
|
|
@@ -8534,15 +8545,6 @@ function hasActiveElementsChecker(ref) {
|
|
|
8534
8545
|
return element instanceof HTMLElement && style.display !== 'none' && style.visibility !== 'hidden' && !element.hasAttribute('disabled');
|
|
8535
8546
|
}).length > 0;
|
|
8536
8547
|
}
|
|
8537
|
-
function isElementInteractive(element) {
|
|
8538
|
-
if (!element || !(element instanceof HTMLElement)) return false;
|
|
8539
|
-
var tag = element.tagName.toLowerCase();
|
|
8540
|
-
if (['button', 'input', 'select', 'textarea', 'a'].includes(tag) || element.hasAttribute('tabindex')) {
|
|
8541
|
-
if (tag === 'a' && !element.href) return false;
|
|
8542
|
-
return !element.hasAttribute('disabled');
|
|
8543
|
-
}
|
|
8544
|
-
return false;
|
|
8545
|
-
}
|
|
8546
8548
|
var Popover = /*#__PURE__*/React__default.forwardRef(function (props, forwardedRef) {
|
|
8547
8549
|
var _refs$reference$curre;
|
|
8548
8550
|
var _React$useState = React__default.useState(false),
|
|
@@ -13892,7 +13894,7 @@ var Container$2 = /*#__PURE__*/_styled("div", {
|
|
|
13892
13894
|
styles: "display:inline-block;position:relative"
|
|
13893
13895
|
} : {
|
|
13894
13896
|
name: "11ffxfj",
|
|
13895
|
-
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"]} */",
|
|
13897
|
+
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"]} */",
|
|
13896
13898
|
toString: _EMOTION_STRINGIFIED_CSS_ERROR__$o
|
|
13897
13899
|
});
|
|
13898
13900
|
var DropdownContext = /*#__PURE__*/createContext({
|
|
@@ -13951,9 +13953,14 @@ var Dropdown = /*#__PURE__*/forwardRef(function (props, forwardedRef) {
|
|
|
13951
13953
|
onOpen && typeof onOpen === 'function' && onOpen();
|
|
13952
13954
|
}
|
|
13953
13955
|
function closeDropdown(event) {
|
|
13954
|
-
var _toggleRef$current;
|
|
13955
13956
|
setIsOpen(false);
|
|
13956
|
-
(
|
|
13957
|
+
if (event && event.type === 'blur') {
|
|
13958
|
+
var relatedTarget = event.relatedTarget;
|
|
13959
|
+
if (!isElementInteractive(relatedTarget)) {
|
|
13960
|
+
var _toggleRef$current;
|
|
13961
|
+
(_toggleRef$current = toggleRef.current) == null || _toggleRef$current.focus();
|
|
13962
|
+
}
|
|
13963
|
+
}
|
|
13957
13964
|
onClose && typeof onClose === 'function' && onClose(event);
|
|
13958
13965
|
}
|
|
13959
13966
|
function getFilteredItem() {
|