react-magma-dom 4.9.0-next.13 → 4.9.0-next.15
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/Dropdown/DropdownExpandableMenuListItem.d.ts +1 -2
- package/dist/esm/index.js +31 -41
- package/dist/esm/index.js.map +1 -1
- package/dist/properties.json +58 -31
- package/dist/react-magma-dom.cjs.development.js +31 -41
- 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/package.json +1 -1
|
@@ -3679,7 +3679,7 @@ var StyledLabel = /*#__PURE__*/_styled("label", {
|
|
|
3679
3679
|
label: "StyledLabel"
|
|
3680
3680
|
})("color:", function (props) {
|
|
3681
3681
|
return props.isInverse ? props.theme.colors.neutral100 : props.theme.colors.neutral700;
|
|
3682
|
-
}, ";display:
|
|
3682
|
+
}, ";display:block;font-size:", function (props) {
|
|
3683
3683
|
return props.size === exports.InputSize.large ? props.theme.typeScale.size03.fontSize : props.theme.typeScale.size02.fontSize;
|
|
3684
3684
|
}, ";font-family:", function (props) {
|
|
3685
3685
|
return props.theme.bodyFont;
|
|
@@ -3695,7 +3695,7 @@ var StyledLabel = /*#__PURE__*/_styled("label", {
|
|
|
3695
3695
|
return props.labelPosition === exports.LabelPosition.left ? 'right' : 'left';
|
|
3696
3696
|
}, ";white-space:", function (props) {
|
|
3697
3697
|
return props.iconPosition === exports.InputIconPosition.top || props.labelPosition === exports.LabelPosition.left ? 'inherit' : 'normal';
|
|
3698
|
-
}, ";" + ( "/*# sourceMappingURL=data:application/json;charset=utf-8;base64,eyJ2ZXJzaW9uIjozLCJzb3VyY2VzIjpbImluZGV4LnRzeCJdLCJuYW1lcyI6W10sIm1hcHBpbmdzIjoiQUFVaUMiLCJmaWxlIjoiaW5kZXgudHN4Iiwic291cmNlc0NvbnRlbnQiOlsiaW1wb3J0ICogYXMgUmVhY3QgZnJvbSAncmVhY3QnO1xyXG5pbXBvcnQgc3R5bGVkIGZyb20gJ0BlbW90aW9uL3N0eWxlZCc7XHJcbmltcG9ydCB7IHVzZUlzSW52ZXJzZSB9IGZyb20gJy4uLy4uL2ludmVyc2UnO1xyXG5pbXBvcnQgeyBUaGVtZUNvbnRleHQgfSBmcm9tICcuLi8uLi90aGVtZS9UaGVtZUNvbnRleHQnO1xyXG5pbXBvcnQgeyBJbnB1dEljb25Qb3NpdGlvbiwgSW5wdXRTaXplIH0gZnJvbSAnLi4vSW5wdXRCYXNlJztcclxuZXhwb3J0IHZhciBMYWJlbFBvc2l0aW9uO1xyXG4oZnVuY3Rpb24gKExhYmVsUG9zaXRpb24pIHtcclxuICAgIExhYmVsUG9zaXRpb25bXCJsZWZ0XCJdID0gXCJsZWZ0XCI7XHJcbiAgICBMYWJlbFBvc2l0aW9uW1widG9wXCJdID0gXCJ0b3BcIjtcclxufSkoTGFiZWxQb3NpdGlvbiB8fCAoTGFiZWxQb3NpdGlvbiA9IHt9KSk7XHJcbmNvbnN0IFN0eWxlZExhYmVsID0gc3R5bGVkLmxhYmVsIGBcbiAgY29sb3I6ICR7cHJvcHMgPT4gcHJvcHMuaXNJbnZlcnNlXHJcbiAgICA/
|
|
3698
|
+
}, ";" + ( "/*# sourceMappingURL=data:application/json;charset=utf-8;base64,eyJ2ZXJzaW9uIjozLCJzb3VyY2VzIjpbImluZGV4LnRzeCJdLCJuYW1lcyI6W10sIm1hcHBpbmdzIjoiQUFVaUMiLCJmaWxlIjoiaW5kZXgudHN4Iiwic291cmNlc0NvbnRlbnQiOlsiaW1wb3J0ICogYXMgUmVhY3QgZnJvbSAncmVhY3QnO1xyXG5pbXBvcnQgc3R5bGVkIGZyb20gJ0BlbW90aW9uL3N0eWxlZCc7XHJcbmltcG9ydCB7IHVzZUlzSW52ZXJzZSB9IGZyb20gJy4uLy4uL2ludmVyc2UnO1xyXG5pbXBvcnQgeyBUaGVtZUNvbnRleHQgfSBmcm9tICcuLi8uLi90aGVtZS9UaGVtZUNvbnRleHQnO1xyXG5pbXBvcnQgeyBJbnB1dEljb25Qb3NpdGlvbiwgSW5wdXRTaXplIH0gZnJvbSAnLi4vSW5wdXRCYXNlJztcclxuZXhwb3J0IHZhciBMYWJlbFBvc2l0aW9uO1xyXG4oZnVuY3Rpb24gKExhYmVsUG9zaXRpb24pIHtcclxuICAgIExhYmVsUG9zaXRpb25bXCJsZWZ0XCJdID0gXCJsZWZ0XCI7XHJcbiAgICBMYWJlbFBvc2l0aW9uW1widG9wXCJdID0gXCJ0b3BcIjtcclxufSkoTGFiZWxQb3NpdGlvbiB8fCAoTGFiZWxQb3NpdGlvbiA9IHt9KSk7XHJcbmNvbnN0IFN0eWxlZExhYmVsID0gc3R5bGVkLmxhYmVsIGBcbiAgY29sb3I6ICR7cHJvcHMgPT4gcHJvcHMuaXNJbnZlcnNlXHJcbiAgICA/IHByb3BzLnRoZW1lLmNvbG9ycy5uZXV0cmFsMTAwXHJcbiAgICA6IHByb3BzLnRoZW1lLmNvbG9ycy5uZXV0cmFsNzAwfTtcbiAgZGlzcGxheTogYmxvY2s7XG4gIGZvbnQtc2l6ZTogJHtwcm9wcyA9PiBwcm9wcy5zaXplID09PSBJbnB1dFNpemUubGFyZ2VcclxuICAgID8gcHJvcHMudGhlbWUudHlwZVNjYWxlLnNpemUwMy5mb250U2l6ZVxyXG4gICAgOiBwcm9wcy50aGVtZS50eXBlU2NhbGUuc2l6ZTAyLmZvbnRTaXplfTtcbiAgZm9udC1mYW1pbHk6ICR7cHJvcHMgPT4gcHJvcHMudGhlbWUuYm9keUZvbnR9O1xuICBmb250LXdlaWdodDogNTAwO1xuICBsZXR0ZXItc3BhY2luZzogJHtwcm9wcyA9PiBwcm9wcy5zaXplID09PSBJbnB1dFNpemUubGFyZ2VcclxuICAgID8gJ2luaGVyaXQnXHJcbiAgICA6IHByb3BzLnRoZW1lLnR5cGVTY2FsZS5zaXplMDIubGV0dGVyU3BhY2luZ307XG4gIGxpbmUtaGVpZ2h0OiAke3Byb3BzID0+IHByb3BzLnNpemUgPT09IElucHV0U2l6ZS5sYXJnZVxyXG4gICAgPyBwcm9wcy50aGVtZS50eXBlU2NhbGUuc2l6ZTAzLmxpbmVIZWlnaHRcclxuICAgIDogcHJvcHMudGhlbWUudHlwZVNjYWxlLnNpemUwMi5saW5lSGVpZ2h0fTtcbiAgbWFyZ2luOiAke3Byb3BzID0+IHByb3BzLmxhYmVsUG9zaXRpb24gPT09IExhYmVsUG9zaXRpb24ubGVmdFxyXG4gICAgPyBgJHtwcm9wcy50aGVtZS5zcGFjZVNjYWxlLnNwYWNpbmcwNH0gJHtwcm9wcy50aGVtZS5zcGFjZVNjYWxlLnNwYWNpbmcwM30gMCAwYFxyXG4gICAgOiBgMCAwICR7cHJvcHMudGhlbWUuc3BhY2VTY2FsZS5zcGFjaW5nMDN9YH07XG4gIG1heC13aWR0aDogJHtwcm9wcyA9PiBwcm9wcy5pY29uUG9zaXRpb24gPT09IElucHV0SWNvblBvc2l0aW9uLnRvcFxyXG4gICAgPyAnY2FsYygxMDAlIC0gNTFweCknXHJcbiAgICA6ICcxMDAlJ307XG4gIHRleHQtYWxpZ246ICR7cHJvcHMgPT4gcHJvcHMubGFiZWxQb3NpdGlvbiA9PT0gTGFiZWxQb3NpdGlvbi5sZWZ0ID8gJ3JpZ2h0JyA6ICdsZWZ0J307XG4gIHdoaXRlLXNwYWNlOiAke3Byb3BzID0+IHByb3BzLmljb25Qb3NpdGlvbiA9PT0gSW5wdXRJY29uUG9zaXRpb24udG9wIHx8XHJcbiAgICBwcm9wcy5sYWJlbFBvc2l0aW9uID09PSBMYWJlbFBvc2l0aW9uLmxlZnRcclxuICAgID8gJ2luaGVyaXQnXHJcbiAgICA6ICdub3JtYWwnfTtcbmA7XHJcbmNvbnN0IFN0eWxlZFNwYW4gPSBTdHlsZWRMYWJlbC53aXRoQ29tcG9uZW50KCdzcGFuJyk7XHJcbmV4cG9ydCBjb25zdCBMYWJlbCA9IFJlYWN0LmZvcndhcmRSZWYoKHByb3BzLCByZWYpID0+IHtcclxuICAgIGNvbnN0IHsgYWN0aW9uYWJsZSA9IHRydWUsIGNoaWxkcmVuLCBpY29uUG9zaXRpb24sIGxhYmVsUG9zaXRpb24sIHNpemUsIHRlc3RJZCwgLi4ub3RoZXIgfSA9IHByb3BzO1xyXG4gICAgY29uc3QgdGhlbWUgPSBSZWFjdC51c2VDb250ZXh0KFRoZW1lQ29udGV4dCk7XHJcbiAgICBjb25zdCBpc0ludmVyc2UgPSB1c2VJc0ludmVyc2UocHJvcHMuaXNJbnZlcnNlKTtcclxuICAgIHJldHVybiBhY3Rpb25hYmxlID8gKFJlYWN0LmNyZWF0ZUVsZW1lbnQoU3R5bGVkTGFiZWwsIE9iamVjdC5hc3NpZ24oe30sIG90aGVyLCB7IFwiZGF0YS10ZXN0aWRcIjogdGVzdElkLCBpc0ludmVyc2U6IGlzSW52ZXJzZSwgaWNvblBvc2l0aW9uOiBpY29uUG9zaXRpb24sIGxhYmVsUG9zaXRpb246IGxhYmVsUG9zaXRpb24gfHwgTGFiZWxQb3NpdGlvbi50b3AsIHJlZjogcmVmLCBzaXplOiBzaXplID8gc2l6ZSA6IElucHV0U2l6ZS5tZWRpdW0sIHRoZW1lOiB0aGVtZSB9KSwgY2hpbGRyZW4pKSA6IChSZWFjdC5jcmVhdGVFbGVtZW50KFN0eWxlZFNwYW4sIE9iamVjdC5hc3NpZ24oe30sIG90aGVyLCB7IFwiZGF0YS10ZXN0aWRcIjogdGVzdElkLCBpc0ludmVyc2U6IGlzSW52ZXJzZSwgaWNvblBvc2l0aW9uOiBpY29uUG9zaXRpb24sIGxhYmVsUG9zaXRpb246IGxhYmVsUG9zaXRpb24gfHwgTGFiZWxQb3NpdGlvbi50b3AsIHJlZjogcmVmLCBzaXplOiBzaXplID8gc2l6ZSA6IElucHV0U2l6ZS5tZWRpdW0sIHRoZW1lOiB0aGVtZSB9KSwgY2hpbGRyZW4pKTtcclxufSk7XHJcbi8vIyBzb3VyY2VNYXBwaW5nVVJMPWluZGV4LmpzLm1hcCJdfQ== */"));
|
|
3699
3699
|
var StyledSpan$2 = /*#__PURE__*/StyledLabel.withComponent('span', {
|
|
3700
3700
|
target: "egrtx8x1",
|
|
3701
3701
|
label: "StyledSpan"
|
|
@@ -8988,7 +8988,7 @@ var DropdownExpandableMenuPanel = /*#__PURE__*/React.forwardRef(function (props,
|
|
|
8988
8988
|
});
|
|
8989
8989
|
DropdownExpandableMenuPanel.displayName = 'DropdownExpandableMenuPanel';
|
|
8990
8990
|
|
|
8991
|
-
var _excluded$_ = ["children", "disabled"];
|
|
8991
|
+
var _excluded$_ = ["children", "disabled", "icon"];
|
|
8992
8992
|
function menuItemPadding$1(props) {
|
|
8993
8993
|
if (props.isExpandablePanel) {
|
|
8994
8994
|
if (props.expandableMenuButtonHasIcon) {
|
|
@@ -9000,10 +9000,11 @@ function menuItemPadding$1(props) {
|
|
|
9000
9000
|
var StyledDropdownMenuItem = /*#__PURE__*/_styled(DropdownMenuItem, {
|
|
9001
9001
|
target: "e89wdun0",
|
|
9002
9002
|
label: "StyledDropdownMenuItem"
|
|
9003
|
-
})("padding:", menuItemPadding$1, ";" + ( "/*# sourceMappingURL=data:application/json;charset=utf-8;base64,
|
|
9003
|
+
})("padding:", menuItemPadding$1, ";" + ( "/*# sourceMappingURL=data:application/json;charset=utf-8;base64,eyJ2ZXJzaW9uIjozLCJzb3VyY2VzIjpbIkRyb3Bkb3duRXhwYW5kYWJsZU1lbnVMaXN0SXRlbS50c3giXSwibmFtZXMiOltdLCJtYXBwaW5ncyI6IkFBZ0J3RCIsImZpbGUiOiJEcm9wZG93bkV4cGFuZGFibGVNZW51TGlzdEl0ZW0udHN4Iiwic291cmNlc0NvbnRlbnQiOlsiaW1wb3J0ICogYXMgUmVhY3QgZnJvbSAncmVhY3QnO1xyXG5pbXBvcnQgc3R5bGVkIGZyb20gJ0BlbW90aW9uL3N0eWxlZCc7XHJcbmltcG9ydCB7IERyb3Bkb3duQ29udGV4dCB9IGZyb20gJy4vRHJvcGRvd24nO1xyXG5pbXBvcnQgeyBEcm9wZG93bkV4cGFuZGFibGVNZW51R3JvdXBDb250ZXh0IH0gZnJvbSAnLi9Ecm9wZG93bkV4cGFuZGFibGVNZW51R3JvdXAnO1xyXG5pbXBvcnQgeyBEcm9wZG93bkV4cGFuZGFibGVNZW51SXRlbUNvbnRleHQgfSBmcm9tICcuL0Ryb3Bkb3duRXhwYW5kYWJsZU1lbnVJdGVtJztcclxuaW1wb3J0IHsgRHJvcGRvd25NZW51SXRlbSB9IGZyb20gJy4vRHJvcGRvd25NZW51SXRlbSc7XHJcbmltcG9ydCB7IFRoZW1lQ29udGV4dCB9IGZyb20gJy4uLy4uL3RoZW1lL1RoZW1lQ29udGV4dCc7XHJcbmltcG9ydCB7IHVzZUZvcmtlZFJlZiB9IGZyb20gJy4uLy4uL3V0aWxzJztcclxuZnVuY3Rpb24gbWVudUl0ZW1QYWRkaW5nKHByb3BzKSB7XHJcbiAgICBpZiAocHJvcHMuaXNFeHBhbmRhYmxlUGFuZWwpIHtcclxuICAgICAgICBpZiAocHJvcHMuZXhwYW5kYWJsZU1lbnVCdXR0b25IYXNJY29uKSB7XHJcbiAgICAgICAgICAgIHJldHVybiBgJHtwcm9wcy50aGVtZS5zcGFjZVNjYWxlLnNwYWNpbmcwM30gJHtwcm9wcy50aGVtZS5zcGFjZVNjYWxlLnNwYWNpbmcwNX0gJHtwcm9wcy50aGVtZS5zcGFjZVNjYWxlLnNwYWNpbmcwM30gNzJweGA7XHJcbiAgICAgICAgfVxyXG4gICAgICAgIHJldHVybiBgJHtwcm9wcy50aGVtZS5zcGFjZVNjYWxlLnNwYWNpbmcwM30gJHtwcm9wcy50aGVtZS5zcGFjZVNjYWxlLnNwYWNpbmcwNX0gJHtwcm9wcy50aGVtZS5zcGFjZVNjYWxlLnNwYWNpbmcwM30gJHtwcm9wcy50aGVtZS5zcGFjZVNjYWxlLnNwYWNpbmcwOH1gO1xyXG4gICAgfVxyXG59XHJcbmNvbnN0IFN0eWxlZERyb3Bkb3duTWVudUl0ZW0gPSBzdHlsZWQoRHJvcGRvd25NZW51SXRlbSkgYFxuICBwYWRkaW5nOiAke21lbnVJdGVtUGFkZGluZ307XG5gO1xyXG5leHBvcnQgY29uc3QgRHJvcGRvd25FeHBhbmRhYmxlTWVudUxpc3RJdGVtID0gUmVhY3QuZm9yd2FyZFJlZigocHJvcHMsIGZvcndhcmRlZFJlZikgPT4ge1xyXG4gICAgY29uc3QgeyBjaGlsZHJlbiwgZGlzYWJsZWQsIGljb24sIC4uLm90aGVyIH0gPSBwcm9wcztcclxuICAgIGNvbnN0IG93blJlZiA9IFJlYWN0LnVzZVJlZigpO1xyXG4gICAgY29uc3QgdGhlbWUgPSBSZWFjdC51c2VDb250ZXh0KFRoZW1lQ29udGV4dCk7XHJcbiAgICBjb25zdCBjb250ZXh0ID0gUmVhY3QudXNlQ29udGV4dChEcm9wZG93bkNvbnRleHQpO1xyXG4gICAgY29uc3QgbWVudUdyb3VwQ29udGV4dCA9IFJlYWN0LnVzZUNvbnRleHQoRHJvcGRvd25FeHBhbmRhYmxlTWVudUdyb3VwQ29udGV4dCk7XHJcbiAgICBjb25zdCBleHBhbmRhYmxlTWVudUl0ZW1Db250ZXh0ID0gUmVhY3QudXNlQ29udGV4dChEcm9wZG93bkV4cGFuZGFibGVNZW51SXRlbUNvbnRleHQpO1xyXG4gICAgY29uc3QgcmVmID0gdXNlRm9ya2VkUmVmKGZvcndhcmRlZFJlZiwgb3duUmVmKTtcclxuICAgIFJlYWN0LnVzZUVmZmVjdCgoKSA9PiB7XHJcbiAgICAgICAgaWYgKCFleHBhbmRhYmxlTWVudUl0ZW1Db250ZXh0LmRpc2FibGVkKVxyXG4gICAgICAgICAgICBjb250ZXh0LnJlZ2lzdGVyRHJvcGRvd25NZW51SXRlbShjb250ZXh0Lml0ZW1SZWZBcnJheSwgb3duUmVmKTtcclxuICAgIH0sIFtdKTtcclxuICAgIHJldHVybiAoUmVhY3QuY3JlYXRlRWxlbWVudChTdHlsZWREcm9wZG93bk1lbnVJdGVtLCBPYmplY3QuYXNzaWduKHt9LCBvdGhlciwgeyBkaXNhYmxlZDogZGlzYWJsZWQsIGV4cGFuZGFibGVNZW51QnV0dG9uSGFzSWNvbjogbWVudUdyb3VwQ29udGV4dC5leHBhbmRhYmxlTWVudUJ1dHRvbkhhc0ljb24sIGljb246ICFtZW51R3JvdXBDb250ZXh0LmlzRXhwYW5kYWJsZVBhbmVsID8gaWNvbiA6IG51bGwsIGlzRXhwYW5kYWJsZVBhbmVsOiBtZW51R3JvdXBDb250ZXh0LmlzRXhwYW5kYWJsZVBhbmVsLCByZWY6IGV4cGFuZGFibGVNZW51SXRlbUNvbnRleHQuZGlzYWJsZWQgPyBudWxsIDogcmVmLCB0aGVtZTogdGhlbWUsIHJvbGU6IFwibWVudWl0ZW1cIiB9KSwgY2hpbGRyZW4pKTtcclxufSk7XHJcbkRyb3Bkb3duRXhwYW5kYWJsZU1lbnVMaXN0SXRlbS5kaXNwbGF5TmFtZSA9ICdEcm9wZG93bkV4cGFuZGFibGVNZW51TGlzdEl0ZW0nO1xyXG4vLyMgc291cmNlTWFwcGluZ1VSTD1Ecm9wZG93bkV4cGFuZGFibGVNZW51TGlzdEl0ZW0uanMubWFwIl19 */"));
|
|
9004
9004
|
var DropdownExpandableMenuListItem = /*#__PURE__*/React.forwardRef(function (props, forwardedRef) {
|
|
9005
9005
|
var children = props.children,
|
|
9006
9006
|
disabled = props.disabled,
|
|
9007
|
+
icon = props.icon,
|
|
9007
9008
|
other = _objectWithoutPropertiesLoose(props, _excluded$_);
|
|
9008
9009
|
var ownRef = React.useRef();
|
|
9009
9010
|
var theme = React.useContext(ThemeContext);
|
|
@@ -9017,6 +9018,7 @@ var DropdownExpandableMenuListItem = /*#__PURE__*/React.forwardRef(function (pro
|
|
|
9017
9018
|
return React.createElement(StyledDropdownMenuItem, Object.assign({}, other, {
|
|
9018
9019
|
disabled: disabled,
|
|
9019
9020
|
expandableMenuButtonHasIcon: menuGroupContext.expandableMenuButtonHasIcon,
|
|
9021
|
+
icon: !menuGroupContext.isExpandablePanel ? icon : null,
|
|
9020
9022
|
isExpandablePanel: menuGroupContext.isExpandablePanel,
|
|
9021
9023
|
ref: expandableMenuItemContext.disabled ? null : ref,
|
|
9022
9024
|
theme: theme,
|
|
@@ -11174,13 +11176,13 @@ var ModalContainer = /*#__PURE__*/_styled(Transition, {
|
|
|
11174
11176
|
return props.theme.spaceScale.spacing03;
|
|
11175
11177
|
}, ";right:0;top:0;z-index:", function (props) {
|
|
11176
11178
|
return props.modalCount >= 2 ? '999' : '998';
|
|
11177
|
-
}, ";" + ( "/*# sourceMappingURL=data:application/json;charset=utf-8;base64,{"version":3,"sources":["Modal.tsx"],"names":[],"mappings":"AAuB0C","file":"Modal.tsx","sourcesContent":["import * as React from 'react';\r\nimport { Global, css } from '@emotion/react';\r\nimport styled from '@emotion/styled';\r\nimport { transparentize } from 'polished';\r\nimport ReactDOM from 'react-dom';\r\nimport { CloseIcon } from 'react-magma-icons';\r\nimport { useFocusLock } from '../../hooks/useFocusLock';\r\nimport { I18nContext } from '../../i18n';\r\nimport { useIsInverse } from '../../inverse';\r\nimport { magma } from '../../theme/magma';\r\nimport { ThemeContext } from '../../theme/ThemeContext';\r\nimport { omit, useGenerateId, usePrevious } from '../../utils';\r\nimport { ButtonColor, ButtonVariant } from '../Button';\r\nimport { Heading } from '../Heading';\r\nimport { IconButton } from '../IconButton';\r\nimport { Transition } from '../Transition';\r\nimport { TypographyVisualStyle } from '../Typography';\r\nexport var ModalSize;\r\n(function (ModalSize) {\r\n    ModalSize[\"large\"] = \"large\";\r\n    ModalSize[\"medium\"] = \"medium\";\r\n    ModalSize[\"small\"] = \"small\";\r\n})(ModalSize || (ModalSize = {}));\r\nconst ModalContainer = styled(Transition) `\n  bottom: 0;\n  left: 0;\n  overflow-y: auto;\n  padding: ${props => props.theme.spaceScale.spacing03};\n  right: 0;\n  top: 0;\n  z-index: ${props => (props.modalCount >= 2 ? '999' : '998')};\n`;\r\nconst ModalBackdrop = styled(Transition) `\n  backdrop-filter: blur(3px);\n  background: ${props => transparentize(0.4, props.theme.colors.neutral900)};\n  bottom: 0;\n  left: 0;\n  right: 0;\n  top: 0;\n  z-index: 997;\n  position: fixed;\n`;\r\nconst ModalContent = styled.div `\n  background: ${props => props.isInverse\r\n    ? props.theme.colors.primary600\r\n    : props.theme.colors.neutral100};\n  border: 1px solid;\n  border-color: ${props => props.isInverse\r\n    ? transparentize(0.5, props.theme.colors.tertiary)\r\n    : props.theme.colors.neutral};\n  border-radius: ${props => props.theme.borderRadius};\n  box-shadow: ${props => `0 2px 6px ${transparentize(0.85, props.theme.colors.neutral900)}`};\n  color: ${props => props.isInverse\r\n    ? props.theme.colors.neutral100\r\n    : props.theme.colors.neutral700};\n  margin: 0 auto;\n  position: relative;\n  z-index: 1000;\n\n  max-width: ${props => {\r\n    switch (props.size) {\r\n        case 'large':\r\n            return props.theme.modal.width.large;\r\n        case 'small':\r\n            return props.theme.modal.width.small;\r\n        default:\r\n            return props.theme.modal.width.medium;\r\n    }\r\n}};\n\n  @media (min-width: ${props => props.theme.breakpoints.small}px) {\n    margin: ${props => props.theme.spaceScale.spacing08} auto;\n  }\n`;\r\nconst ModalHeader = styled.div `\n  padding: ${props => props.theme.spaceScale.spacing05}\n    ${props => props.theme.spaceScale.spacing05} 0\n    ${props => props.theme.spaceScale.spacing05};\n  @media (min-width: ${props => props.theme.breakpoints.small}px) {\n    padding: ${props => props.theme.spaceScale.spacing06}\n      ${props => props.theme.spaceScale.spacing06} 0\n      ${props => props.theme.spaceScale.spacing06};\n  }\n`;\r\nconst ModalWrapper = styled.div `\n  padding: ${props => props.theme.spaceScale.spacing05};\n  @media (min-width: ${props => props.theme.breakpoints.small}px) {\n    padding: ${props => props.theme.spaceScale.spacing06};\n  }\n`;\r\nconst H1 = styled(Heading) `\n  font-size: ${props => props.theme.typographyVisualStyles.headingSmall.desktop.fontSize};\n  line-height: ${props => props.theme.typographyVisualStyles.headingSmall.desktop.lineHeight};\n  color: ${props => props.isInverse\r\n    ? props.theme.colors.neutral100\r\n    : props.theme.colors.neutral700};\n  margin: 0;\n  padding-right: ${props => props.theme.spaceScale.spacing10};\n  font-weight: 600;\n`;\r\nconst CloseBtn = styled.span `\n  position: absolute;\n  top: 0;\n  right: 0;\n  margin: ${props => props.theme.spaceScale.spacing02};\n`;\r\nexport const Modal = React.forwardRef((props, ref) => {\r\n    const lastFocus = React.useRef();\r\n    const headingRef = React.useRef();\r\n    const bodyRef = React.useRef();\r\n    const id = useGenerateId(props.id);\r\n    const headingId = `${id}_heading`;\r\n    const contentId = `${id}_content`;\r\n    const [isModalOpen, setIsModalOpen] = React.useState(props.isOpen);\r\n    const [isExiting, setIsExiting] = React.useState(false);\r\n    const [currentTarget, setCurrentTarget] = React.useState(null);\r\n    const [modalCount, setModalCount] = React.useState(0);\r\n    const focusTrapElement = useFocusLock(isModalOpen, headingRef, bodyRef);\r\n    const prevOpen = usePrevious(props.isOpen);\r\n    React.useEffect(() => {\r\n        if (props.isModalClosingControlledManually &&\r\n            prevOpen &&\r\n            !props.isOpen &&\r\n            isModalOpen) {\r\n            setIsModalOpen(false);\r\n        }\r\n        else if (!prevOpen && props.isOpen) {\r\n            setIsModalOpen(true);\r\n            if (props.headerRef && typeof props.headerRef === 'function') {\r\n                props.headerRef(headingRef);\r\n            }\r\n        }\r\n        else if (prevOpen && !props.isOpen && isModalOpen) {\r\n            handleClose();\r\n        }\r\n    }, [props.isOpen]);\r\n    React.useEffect(() => {\r\n        if (isModalOpen) {\r\n            lastFocus.current = document.activeElement;\r\n            const count = document.querySelectorAll('[aria-modal=\"true\"]').length;\r\n            setModalCount(count);\r\n            if (!props.isEscKeyDownDisabled) {\r\n                document.body.addEventListener('keydown', handleEscapeKeyDown, false);\r\n            }\r\n        }\r\n        return () => {\r\n            document.body.removeEventListener('keydown', handleEscapeKeyDown, false);\r\n        };\r\n    }, [isModalOpen]);\r\n    function handleModalClick(event) {\r\n        if (!document.getElementById(contentId).contains(event.target) &&\r\n            event.target === currentTarget) {\r\n            handleClose(event);\r\n        }\r\n    }\r\n    function handleModalOnMouseDown(event) {\r\n        setCurrentTarget(event.target);\r\n    }\r\n    function handleEscapeKeyDown(event) {\r\n        if (event.key === 'Escape') {\r\n            event.preventDefault();\r\n            event.stopPropagation();\r\n            props.onEscKeyDown &&\r\n                typeof props.onEscKeyDown === 'function' &&\r\n                props.onEscKeyDown(event);\r\n            //Supports nested modals\r\n            const modalsInDom = document.querySelectorAll('[aria-modal=\"true\"]').length;\r\n            if (modalCount <= 1 && modalsInDom !== 1) {\r\n                if (document.getElementById(id).contains(event.target)) {\r\n                    handleClose(event);\r\n                }\r\n                else {\r\n                    headingRef.current.focus();\r\n                }\r\n            }\r\n            else {\r\n                handleClose(event);\r\n            }\r\n        }\r\n    }\r\n    function handleClose(event) {\r\n        if (event) {\r\n            event.stopPropagation();\r\n        }\r\n        setIsExiting(true);\r\n        setTimeout(() => {\r\n            setIsExiting(false);\r\n            if (!props.isModalClosingControlledManually) {\r\n                setIsModalOpen(false);\r\n            }\r\n            if (lastFocus.current) {\r\n                lastFocus.current.focus();\r\n            }\r\n            props.onClose && typeof props.onClose === 'function' && props.onClose();\r\n        }, 300);\r\n    }\r\n    const { ariaLabel, children, closeAriaLabel, closeButtonSize, containerStyle, containerTransition = { slideTop: true }, isBackgroundClickDisabled, isEscKeyDownDisabled, header, isCloseButtonHidden, isOpen, unmountOnExit = true, testId, ...rest } = props;\r\n    const isInverse = useIsInverse(props.isInverse);\r\n    const other = omit(['onEscKeyDown'], rest);\r\n    const theme = React.useContext(ThemeContext);\r\n    const i18n = React.useContext(I18nContext);\r\n    const CloseIconButton = (React.createElement(CloseIcon, { size: magma.iconSizes[closeButtonSize]\r\n            ? magma.iconSizes[closeButtonSize]\r\n            : magma.iconSizes.medium }));\r\n    return isModalOpen\r\n        ? ReactDOM.createPortal(React.createElement(\"div\", { ref: focusTrapElement },\r\n            React.createElement(Global, { styles: css `\n                html {\n                  overflow: ${isOpen ? 'hidden' : 'auto'};\n                }\n              ` }),\r\n            React.createElement(ModalContainer, Object.assign({ \"aria-labelledby\": header ? headingId : null, \"aria-label\": !header ? ariaLabel : null, \"aria-modal\": true, \"data-testid\": testId, id: id, modalCount: modalCount, onClick: isBackgroundClickDisabled ? null : handleModalClick, onMouseDown: isBackgroundClickDisabled ? null : handleModalOnMouseDown, role: \"dialog\", style: containerStyle, theme: theme, isOpen: isModalOpen }, containerTransition, { unmountOnExit: unmountOnExit }),\r\n                React.createElement(ModalContent, Object.assign({}, other, { \"data-testid\": \"modal-content\", id: contentId, isExiting: isExiting, ref: ref, theme: theme }),\r\n                    header && (React.createElement(ModalHeader, { theme: theme }, header && (React.createElement(H1, { id: headingId, isInverse: isInverse, level: 1, ref: headingRef, visualStyle: TypographyVisualStyle.headingSmall, tabIndex: -1, theme: theme }, header)))),\r\n                    React.createElement(ModalWrapper, { ref: bodyRef, theme: theme }, children),\r\n                    !isCloseButtonHidden && (React.createElement(CloseBtn, { theme: theme },\r\n                        React.createElement(IconButton, { \"aria-label\": closeAriaLabel\r\n                                ? closeAriaLabel\r\n                                : i18n.modal.closeAriaLabel, color: ButtonColor.primary, icon: CloseIconButton, isInverse: isInverse, onClick: handleClose, testId: \"modal-closebtn\", variant: ButtonVariant.link }))))),\r\n            React.createElement(ModalBackdrop, { \"data-testid\": \"modal-backdrop\", isExiting: isExiting, onMouseDown: isBackgroundClickDisabled\r\n                    ? event => event.preventDefault()\r\n                    : null, fade: true, isOpen: isModalOpen, style: modalCount >= 2 && { zIndex: '998' }, unmountOnExit: true, theme: theme })), document.getElementsByTagName('body')[0])\r\n        : null;\r\n});\r\n//# sourceMappingURL=Modal.js.map"]} */"));
|
|
11179
|
+
}, ";" + ( "/*# sourceMappingURL=data:application/json;charset=utf-8;base64,{"version":3,"sources":["Modal.tsx"],"names":[],"mappings":"AAuB0C","file":"Modal.tsx","sourcesContent":["import * as React from 'react';\r\nimport { css, Global } from '@emotion/react';\r\nimport styled from '@emotion/styled';\r\nimport { transparentize } from 'polished';\r\nimport ReactDOM from 'react-dom';\r\nimport { CloseIcon } from 'react-magma-icons';\r\nimport { useFocusLock } from '../../hooks/useFocusLock';\r\nimport { I18nContext } from '../../i18n';\r\nimport { useIsInverse } from '../../inverse';\r\nimport { magma } from '../../theme/magma';\r\nimport { ThemeContext } from '../../theme/ThemeContext';\r\nimport { omit, useGenerateId, usePrevious } from '../../utils';\r\nimport { ButtonColor, ButtonVariant } from '../Button';\r\nimport { Heading } from '../Heading';\r\nimport { IconButton } from '../IconButton';\r\nimport { Transition } from '../Transition';\r\nimport { TypographyVisualStyle } from '../Typography';\r\nexport var ModalSize;\r\n(function (ModalSize) {\r\n    ModalSize[\"large\"] = \"large\";\r\n    ModalSize[\"medium\"] = \"medium\";\r\n    ModalSize[\"small\"] = \"small\";\r\n})(ModalSize || (ModalSize = {}));\r\nconst ModalContainer = styled(Transition) `\n  bottom: 0;\n  left: 0;\n  overflow-y: auto;\n  padding: ${props => props.theme.spaceScale.spacing03};\n  right: 0;\n  top: 0;\n  z-index: ${props => (props.modalCount >= 2 ? '999' : '998')};\n`;\r\nconst ModalBackdrop = styled(Transition) `\n  backdrop-filter: blur(3px);\n  background: ${props => transparentize(0.4, props.theme.colors.neutral900)};\n  bottom: 0;\n  left: 0;\n  right: 0;\n  top: 0;\n  z-index: 997;\n  position: fixed;\n`;\r\nconst ModalContent = styled.div `\n  background: ${props => props.isInverse\r\n    ? props.theme.colors.primary600\r\n    : props.theme.colors.neutral100};\n  border: 1px solid;\n  border-color: ${props => props.isInverse\r\n    ? transparentize(0.5, props.theme.colors.tertiary)\r\n    : props.theme.colors.neutral};\n  border-radius: ${props => props.theme.borderRadius};\n  box-shadow: ${props => `0 2px 6px ${transparentize(0.85, props.theme.colors.neutral900)}`};\n  color: ${props => props.isInverse\r\n    ? props.theme.colors.neutral100\r\n    : props.theme.colors.neutral700};\n  margin: 0 auto;\n  position: relative;\n  z-index: 1000;\n\n  max-width: ${props => {\r\n    switch (props.size) {\r\n        case 'large':\r\n            return props.theme.modal.width.large;\r\n        case 'small':\r\n            return props.theme.modal.width.small;\r\n        default:\r\n            return props.theme.modal.width.medium;\r\n    }\r\n}};\n\n  @media (min-width: ${props => props.theme.breakpoints.small}px) {\n    margin: ${props => props.theme.spaceScale.spacing08} auto;\n  }\n`;\r\nconst ModalHeader = styled.div `\n  padding: ${props => props.theme.spaceScale.spacing05}\n    ${props => props.theme.spaceScale.spacing05} 0\n    ${props => props.theme.spaceScale.spacing05};\n  @media (min-width: ${props => props.theme.breakpoints.small}px) {\n    padding: ${props => props.theme.spaceScale.spacing06}\n      ${props => props.theme.spaceScale.spacing06} 0\n      ${props => props.theme.spaceScale.spacing06};\n  }\n`;\r\nconst ModalWrapper = styled.div `\n  padding: ${props => props.theme.spaceScale.spacing05};\n  @media (min-width: ${props => props.theme.breakpoints.small}px) {\n    padding: ${props => props.theme.spaceScale.spacing06};\n  }\n`;\r\nconst H1 = styled(Heading) `\n  font-size: ${props => props.theme.typographyVisualStyles.headingSmall.desktop.fontSize};\n  line-height: ${props => props.theme.typographyVisualStyles.headingSmall.desktop.lineHeight};\n  color: ${props => props.isInverse\r\n    ? props.theme.colors.neutral100\r\n    : props.theme.colors.neutral700};\n  margin: 0;\n  padding-right: ${props => props.theme.spaceScale.spacing10};\n  font-weight: 600;\n`;\r\nconst CloseBtn = styled.span `\n  position: absolute;\n  top: 0;\n  right: 0;\n  margin: ${props => props.theme.spaceScale.spacing02};\n`;\r\nexport const Modal = React.forwardRef((props, ref) => {\r\n    const lastFocus = React.useRef();\r\n    const headingRef = React.useRef();\r\n    const bodyRef = React.useRef();\r\n    const id = useGenerateId(props.id);\r\n    const headingId = `${id}_heading`;\r\n    const contentId = `${id}_content`;\r\n    const [isModalOpen, setIsModalOpen] = React.useState(props.isOpen);\r\n    const [currentTarget, setCurrentTarget] = React.useState(null);\r\n    const [modalCount, setModalCount] = React.useState(0);\r\n    const focusTrapElement = useFocusLock(isModalOpen, headingRef, bodyRef);\r\n    const prevOpen = usePrevious(props.isOpen);\r\n    React.useEffect(() => {\r\n        if (props.isModalClosingControlledManually &&\r\n            prevOpen &&\r\n            !props.isOpen &&\r\n            isModalOpen) {\r\n            setIsModalOpen(false);\r\n        }\r\n        else if (!prevOpen && props.isOpen) {\r\n            setIsModalOpen(true);\r\n            if (props.headerRef && typeof props.headerRef === 'function') {\r\n                props.headerRef(headingRef);\r\n            }\r\n        }\r\n        else if (prevOpen && !props.isOpen && isModalOpen) {\r\n            handleClose();\r\n        }\r\n    }, [props.isOpen]);\r\n    React.useEffect(() => {\r\n        if (isModalOpen) {\r\n            lastFocus.current = document.activeElement;\r\n            const count = document.querySelectorAll('[aria-modal=\"true\"]').length;\r\n            setModalCount(count);\r\n            if (!props.isEscKeyDownDisabled) {\r\n                document.body.addEventListener('keydown', handleEscapeKeyDown, false);\r\n            }\r\n        }\r\n        return () => {\r\n            document.body.removeEventListener('keydown', handleEscapeKeyDown, false);\r\n        };\r\n    }, [isModalOpen]);\r\n    function handleModalClick(event) {\r\n        if (!document.getElementById(contentId).contains(event.target) &&\r\n            event.target === currentTarget) {\r\n            handleClose(event);\r\n        }\r\n    }\r\n    function handleModalOnMouseDown(event) {\r\n        setCurrentTarget(event.target);\r\n    }\r\n    function handleEscapeKeyDown(event) {\r\n        if (event.key === 'Escape') {\r\n            event.preventDefault();\r\n            event.stopPropagation();\r\n            props.onEscKeyDown &&\r\n                typeof props.onEscKeyDown === 'function' &&\r\n                props.onEscKeyDown(event);\r\n            //Supports nested modals\r\n            const modalsInDom = document.querySelectorAll('[aria-modal=\"true\"]').length;\r\n            if (modalCount <= 1 && modalsInDom !== 1) {\r\n                if (document.getElementById(id).contains(event.target)) {\r\n                    handleClose(event);\r\n                }\r\n                else {\r\n                    headingRef.current.focus();\r\n                }\r\n            }\r\n            else {\r\n                handleClose(event);\r\n            }\r\n        }\r\n    }\r\n    function handleClose(event) {\r\n        event?.stopPropagation();\r\n        setTimeout(() => {\r\n            if (!props.isModalClosingControlledManually) {\r\n                setIsModalOpen(false);\r\n            }\r\n            lastFocus.current?.focus();\r\n            props.onClose && typeof props.onClose === 'function' && props.onClose();\r\n        }, 0);\r\n    }\r\n    const { ariaLabel, children, closeAriaLabel, closeButtonSize, containerStyle, containerTransition = { slideTop: true }, isBackgroundClickDisabled, isEscKeyDownDisabled, header, isCloseButtonHidden, isOpen, unmountOnExit = true, testId, ...rest } = props;\r\n    const isInverse = useIsInverse(props.isInverse);\r\n    const other = omit(['onEscKeyDown'], rest);\r\n    const theme = React.useContext(ThemeContext);\r\n    const i18n = React.useContext(I18nContext);\r\n    const CloseIconButton = (React.createElement(CloseIcon, { size: magma.iconSizes[closeButtonSize]\r\n            ? magma.iconSizes[closeButtonSize]\r\n            : magma.iconSizes.medium }));\r\n    return isModalOpen\r\n        ? ReactDOM.createPortal(React.createElement(\"div\", { ref: focusTrapElement },\r\n            React.createElement(Global, { styles: css `\n                html {\n                  overflow: ${isOpen ? 'hidden' : 'auto'};\n                }\n              ` }),\r\n            React.createElement(ModalContainer, Object.assign({ \"aria-labelledby\": header ? headingId : null, \"aria-label\": !header ? ariaLabel : null, \"aria-modal\": true, \"data-testid\": testId, id: id, modalCount: modalCount, onClick: isBackgroundClickDisabled ? null : handleModalClick, onMouseDown: isBackgroundClickDisabled ? null : handleModalOnMouseDown, role: \"dialog\", style: containerStyle, theme: theme, isOpen: isModalOpen }, containerTransition, { unmountOnExit: unmountOnExit }),\r\n                React.createElement(ModalContent, Object.assign({}, other, { \"data-testid\": \"modal-content\", id: contentId, ref: ref, theme: theme }),\r\n                    header && (React.createElement(ModalHeader, { theme: theme }, header && (React.createElement(H1, { id: headingId, isInverse: isInverse, level: 1, ref: headingRef, visualStyle: TypographyVisualStyle.headingSmall, tabIndex: -1, theme: theme }, header)))),\r\n                    React.createElement(ModalWrapper, { ref: bodyRef, theme: theme }, children),\r\n                    !isCloseButtonHidden && (React.createElement(CloseBtn, { theme: theme },\r\n                        React.createElement(IconButton, { \"aria-label\": closeAriaLabel\r\n                                ? closeAriaLabel\r\n                                : i18n.modal.closeAriaLabel, color: ButtonColor.primary, icon: CloseIconButton, isInverse: isInverse, onClick: handleClose, testId: \"modal-closebtn\", variant: ButtonVariant.link }))))),\r\n            React.createElement(ModalBackdrop, { \"data-testid\": \"modal-backdrop\", onMouseDown: isBackgroundClickDisabled\r\n                    ? event => event.preventDefault()\r\n                    : null, fade: true, isOpen: isModalOpen, style: modalCount >= 2 && { zIndex: '998' }, unmountOnExit: true, theme: theme })), document.getElementsByTagName('body')[0])\r\n        : null;\r\n});\r\n//# sourceMappingURL=Modal.js.map"]} */"));
|
|
11178
11180
|
var ModalBackdrop = /*#__PURE__*/_styled(Transition, {
|
|
11179
11181
|
target: "e1pxemtw5",
|
|
11180
11182
|
label: "ModalBackdrop"
|
|
11181
11183
|
})("backdrop-filter:blur(3px);background:", function (props) {
|
|
11182
11184
|
return polished.transparentize(0.4, props.theme.colors.neutral900);
|
|
11183
|
-
}, ";bottom:0;left:0;right:0;top:0;z-index:997;position:fixed;" + ( "/*# sourceMappingURL=data:application/json;charset=utf-8;base64,{"version":3,"sources":["Modal.tsx"],"names":[],"mappings":"AAgCyC","file":"Modal.tsx","sourcesContent":["import * as React from 'react';\r\nimport { Global, css } from '@emotion/react';\r\nimport styled from '@emotion/styled';\r\nimport { transparentize } from 'polished';\r\nimport ReactDOM from 'react-dom';\r\nimport { CloseIcon } from 'react-magma-icons';\r\nimport { useFocusLock } from '../../hooks/useFocusLock';\r\nimport { I18nContext } from '../../i18n';\r\nimport { useIsInverse } from '../../inverse';\r\nimport { magma } from '../../theme/magma';\r\nimport { ThemeContext } from '../../theme/ThemeContext';\r\nimport { omit, useGenerateId, usePrevious } from '../../utils';\r\nimport { ButtonColor, ButtonVariant } from '../Button';\r\nimport { Heading } from '../Heading';\r\nimport { IconButton } from '../IconButton';\r\nimport { Transition } from '../Transition';\r\nimport { TypographyVisualStyle } from '../Typography';\r\nexport var ModalSize;\r\n(function (ModalSize) {\r\n    ModalSize[\"large\"] = \"large\";\r\n    ModalSize[\"medium\"] = \"medium\";\r\n    ModalSize[\"small\"] = \"small\";\r\n})(ModalSize || (ModalSize = {}));\r\nconst ModalContainer = styled(Transition) `\n  bottom: 0;\n  left: 0;\n  overflow-y: auto;\n  padding: ${props => props.theme.spaceScale.spacing03};\n  right: 0;\n  top: 0;\n  z-index: ${props => (props.modalCount >= 2 ? '999' : '998')};\n`;\r\nconst ModalBackdrop = styled(Transition) `\n  backdrop-filter: blur(3px);\n  background: ${props => transparentize(0.4, props.theme.colors.neutral900)};\n  bottom: 0;\n  left: 0;\n  right: 0;\n  top: 0;\n  z-index: 997;\n  position: fixed;\n`;\r\nconst ModalContent = styled.div `\n  background: ${props => props.isInverse\r\n    ? props.theme.colors.primary600\r\n    : props.theme.colors.neutral100};\n  border: 1px solid;\n  border-color: ${props => props.isInverse\r\n    ? transparentize(0.5, props.theme.colors.tertiary)\r\n    : props.theme.colors.neutral};\n  border-radius: ${props => props.theme.borderRadius};\n  box-shadow: ${props => `0 2px 6px ${transparentize(0.85, props.theme.colors.neutral900)}`};\n  color: ${props => props.isInverse\r\n    ? props.theme.colors.neutral100\r\n    : props.theme.colors.neutral700};\n  margin: 0 auto;\n  position: relative;\n  z-index: 1000;\n\n  max-width: ${props => {\r\n    switch (props.size) {\r\n        case 'large':\r\n            return props.theme.modal.width.large;\r\n        case 'small':\r\n            return props.theme.modal.width.small;\r\n        default:\r\n            return props.theme.modal.width.medium;\r\n    }\r\n}};\n\n  @media (min-width: ${props => props.theme.breakpoints.small}px) {\n    margin: ${props => props.theme.spaceScale.spacing08} auto;\n  }\n`;\r\nconst ModalHeader = styled.div `\n  padding: ${props => props.theme.spaceScale.spacing05}\n    ${props => props.theme.spaceScale.spacing05} 0\n    ${props => props.theme.spaceScale.spacing05};\n  @media (min-width: ${props => props.theme.breakpoints.small}px) {\n    padding: ${props => props.theme.spaceScale.spacing06}\n      ${props => props.theme.spaceScale.spacing06} 0\n      ${props => props.theme.spaceScale.spacing06};\n  }\n`;\r\nconst ModalWrapper = styled.div `\n  padding: ${props => props.theme.spaceScale.spacing05};\n  @media (min-width: ${props => props.theme.breakpoints.small}px) {\n    padding: ${props => props.theme.spaceScale.spacing06};\n  }\n`;\r\nconst H1 = styled(Heading) `\n  font-size: ${props => props.theme.typographyVisualStyles.headingSmall.desktop.fontSize};\n  line-height: ${props => props.theme.typographyVisualStyles.headingSmall.desktop.lineHeight};\n  color: ${props => props.isInverse\r\n    ? props.theme.colors.neutral100\r\n    : props.theme.colors.neutral700};\n  margin: 0;\n  padding-right: ${props => props.theme.spaceScale.spacing10};\n  font-weight: 600;\n`;\r\nconst CloseBtn = styled.span `\n  position: absolute;\n  top: 0;\n  right: 0;\n  margin: ${props => props.theme.spaceScale.spacing02};\n`;\r\nexport const Modal = React.forwardRef((props, ref) => {\r\n    const lastFocus = React.useRef();\r\n    const headingRef = React.useRef();\r\n    const bodyRef = React.useRef();\r\n    const id = useGenerateId(props.id);\r\n    const headingId = `${id}_heading`;\r\n    const contentId = `${id}_content`;\r\n    const [isModalOpen, setIsModalOpen] = React.useState(props.isOpen);\r\n    const [isExiting, setIsExiting] = React.useState(false);\r\n    const [currentTarget, setCurrentTarget] = React.useState(null);\r\n    const [modalCount, setModalCount] = React.useState(0);\r\n    const focusTrapElement = useFocusLock(isModalOpen, headingRef, bodyRef);\r\n    const prevOpen = usePrevious(props.isOpen);\r\n    React.useEffect(() => {\r\n        if (props.isModalClosingControlledManually &&\r\n            prevOpen &&\r\n            !props.isOpen &&\r\n            isModalOpen) {\r\n            setIsModalOpen(false);\r\n        }\r\n        else if (!prevOpen && props.isOpen) {\r\n            setIsModalOpen(true);\r\n            if (props.headerRef && typeof props.headerRef === 'function') {\r\n                props.headerRef(headingRef);\r\n            }\r\n        }\r\n        else if (prevOpen && !props.isOpen && isModalOpen) {\r\n            handleClose();\r\n        }\r\n    }, [props.isOpen]);\r\n    React.useEffect(() => {\r\n        if (isModalOpen) {\r\n            lastFocus.current = document.activeElement;\r\n            const count = document.querySelectorAll('[aria-modal=\"true\"]').length;\r\n            setModalCount(count);\r\n            if (!props.isEscKeyDownDisabled) {\r\n                document.body.addEventListener('keydown', handleEscapeKeyDown, false);\r\n            }\r\n        }\r\n        return () => {\r\n            document.body.removeEventListener('keydown', handleEscapeKeyDown, false);\r\n        };\r\n    }, [isModalOpen]);\r\n    function handleModalClick(event) {\r\n        if (!document.getElementById(contentId).contains(event.target) &&\r\n            event.target === currentTarget) {\r\n            handleClose(event);\r\n        }\r\n    }\r\n    function handleModalOnMouseDown(event) {\r\n        setCurrentTarget(event.target);\r\n    }\r\n    function handleEscapeKeyDown(event) {\r\n        if (event.key === 'Escape') {\r\n            event.preventDefault();\r\n            event.stopPropagation();\r\n            props.onEscKeyDown &&\r\n                typeof props.onEscKeyDown === 'function' &&\r\n                props.onEscKeyDown(event);\r\n            //Supports nested modals\r\n            const modalsInDom = document.querySelectorAll('[aria-modal=\"true\"]').length;\r\n            if (modalCount <= 1 && modalsInDom !== 1) {\r\n                if (document.getElementById(id).contains(event.target)) {\r\n                    handleClose(event);\r\n                }\r\n                else {\r\n                    headingRef.current.focus();\r\n                }\r\n            }\r\n            else {\r\n                handleClose(event);\r\n            }\r\n        }\r\n    }\r\n    function handleClose(event) {\r\n        if (event) {\r\n            event.stopPropagation();\r\n        }\r\n        setIsExiting(true);\r\n        setTimeout(() => {\r\n            setIsExiting(false);\r\n            if (!props.isModalClosingControlledManually) {\r\n                setIsModalOpen(false);\r\n            }\r\n            if (lastFocus.current) {\r\n                lastFocus.current.focus();\r\n            }\r\n            props.onClose && typeof props.onClose === 'function' && props.onClose();\r\n        }, 300);\r\n    }\r\n    const { ariaLabel, children, closeAriaLabel, closeButtonSize, containerStyle, containerTransition = { slideTop: true }, isBackgroundClickDisabled, isEscKeyDownDisabled, header, isCloseButtonHidden, isOpen, unmountOnExit = true, testId, ...rest } = props;\r\n    const isInverse = useIsInverse(props.isInverse);\r\n    const other = omit(['onEscKeyDown'], rest);\r\n    const theme = React.useContext(ThemeContext);\r\n    const i18n = React.useContext(I18nContext);\r\n    const CloseIconButton = (React.createElement(CloseIcon, { size: magma.iconSizes[closeButtonSize]\r\n            ? magma.iconSizes[closeButtonSize]\r\n            : magma.iconSizes.medium }));\r\n    return isModalOpen\r\n        ? ReactDOM.createPortal(React.createElement(\"div\", { ref: focusTrapElement },\r\n            React.createElement(Global, { styles: css `\n                html {\n                  overflow: ${isOpen ? 'hidden' : 'auto'};\n                }\n              ` }),\r\n            React.createElement(ModalContainer, Object.assign({ \"aria-labelledby\": header ? headingId : null, \"aria-label\": !header ? ariaLabel : null, \"aria-modal\": true, \"data-testid\": testId, id: id, modalCount: modalCount, onClick: isBackgroundClickDisabled ? null : handleModalClick, onMouseDown: isBackgroundClickDisabled ? null : handleModalOnMouseDown, role: \"dialog\", style: containerStyle, theme: theme, isOpen: isModalOpen }, containerTransition, { unmountOnExit: unmountOnExit }),\r\n                React.createElement(ModalContent, Object.assign({}, other, { \"data-testid\": \"modal-content\", id: contentId, isExiting: isExiting, ref: ref, theme: theme }),\r\n                    header && (React.createElement(ModalHeader, { theme: theme }, header && (React.createElement(H1, { id: headingId, isInverse: isInverse, level: 1, ref: headingRef, visualStyle: TypographyVisualStyle.headingSmall, tabIndex: -1, theme: theme }, header)))),\r\n                    React.createElement(ModalWrapper, { ref: bodyRef, theme: theme }, children),\r\n                    !isCloseButtonHidden && (React.createElement(CloseBtn, { theme: theme },\r\n                        React.createElement(IconButton, { \"aria-label\": closeAriaLabel\r\n                                ? closeAriaLabel\r\n                                : i18n.modal.closeAriaLabel, color: ButtonColor.primary, icon: CloseIconButton, isInverse: isInverse, onClick: handleClose, testId: \"modal-closebtn\", variant: ButtonVariant.link }))))),\r\n            React.createElement(ModalBackdrop, { \"data-testid\": \"modal-backdrop\", isExiting: isExiting, onMouseDown: isBackgroundClickDisabled\r\n                    ? event => event.preventDefault()\r\n                    : null, fade: true, isOpen: isModalOpen, style: modalCount >= 2 && { zIndex: '998' }, unmountOnExit: true, theme: theme })), document.getElementsByTagName('body')[0])\r\n        : null;\r\n});\r\n//# sourceMappingURL=Modal.js.map"]} */"));
|
|
11185
|
+
}, ";bottom:0;left:0;right:0;top:0;z-index:997;position:fixed;" + ( "/*# sourceMappingURL=data:application/json;charset=utf-8;base64,{"version":3,"sources":["Modal.tsx"],"names":[],"mappings":"AAgCyC","file":"Modal.tsx","sourcesContent":["import * as React from 'react';\r\nimport { css, Global } from '@emotion/react';\r\nimport styled from '@emotion/styled';\r\nimport { transparentize } from 'polished';\r\nimport ReactDOM from 'react-dom';\r\nimport { CloseIcon } from 'react-magma-icons';\r\nimport { useFocusLock } from '../../hooks/useFocusLock';\r\nimport { I18nContext } from '../../i18n';\r\nimport { useIsInverse } from '../../inverse';\r\nimport { magma } from '../../theme/magma';\r\nimport { ThemeContext } from '../../theme/ThemeContext';\r\nimport { omit, useGenerateId, usePrevious } from '../../utils';\r\nimport { ButtonColor, ButtonVariant } from '../Button';\r\nimport { Heading } from '../Heading';\r\nimport { IconButton } from '../IconButton';\r\nimport { Transition } from '../Transition';\r\nimport { TypographyVisualStyle } from '../Typography';\r\nexport var ModalSize;\r\n(function (ModalSize) {\r\n    ModalSize[\"large\"] = \"large\";\r\n    ModalSize[\"medium\"] = \"medium\";\r\n    ModalSize[\"small\"] = \"small\";\r\n})(ModalSize || (ModalSize = {}));\r\nconst ModalContainer = styled(Transition) `\n  bottom: 0;\n  left: 0;\n  overflow-y: auto;\n  padding: ${props => props.theme.spaceScale.spacing03};\n  right: 0;\n  top: 0;\n  z-index: ${props => (props.modalCount >= 2 ? '999' : '998')};\n`;\r\nconst ModalBackdrop = styled(Transition) `\n  backdrop-filter: blur(3px);\n  background: ${props => transparentize(0.4, props.theme.colors.neutral900)};\n  bottom: 0;\n  left: 0;\n  right: 0;\n  top: 0;\n  z-index: 997;\n  position: fixed;\n`;\r\nconst ModalContent = styled.div `\n  background: ${props => props.isInverse\r\n    ? props.theme.colors.primary600\r\n    : props.theme.colors.neutral100};\n  border: 1px solid;\n  border-color: ${props => props.isInverse\r\n    ? transparentize(0.5, props.theme.colors.tertiary)\r\n    : props.theme.colors.neutral};\n  border-radius: ${props => props.theme.borderRadius};\n  box-shadow: ${props => `0 2px 6px ${transparentize(0.85, props.theme.colors.neutral900)}`};\n  color: ${props => props.isInverse\r\n    ? props.theme.colors.neutral100\r\n    : props.theme.colors.neutral700};\n  margin: 0 auto;\n  position: relative;\n  z-index: 1000;\n\n  max-width: ${props => {\r\n    switch (props.size) {\r\n        case 'large':\r\n            return props.theme.modal.width.large;\r\n        case 'small':\r\n            return props.theme.modal.width.small;\r\n        default:\r\n            return props.theme.modal.width.medium;\r\n    }\r\n}};\n\n  @media (min-width: ${props => props.theme.breakpoints.small}px) {\n    margin: ${props => props.theme.spaceScale.spacing08} auto;\n  }\n`;\r\nconst ModalHeader = styled.div `\n  padding: ${props => props.theme.spaceScale.spacing05}\n    ${props => props.theme.spaceScale.spacing05} 0\n    ${props => props.theme.spaceScale.spacing05};\n  @media (min-width: ${props => props.theme.breakpoints.small}px) {\n    padding: ${props => props.theme.spaceScale.spacing06}\n      ${props => props.theme.spaceScale.spacing06} 0\n      ${props => props.theme.spaceScale.spacing06};\n  }\n`;\r\nconst ModalWrapper = styled.div `\n  padding: ${props => props.theme.spaceScale.spacing05};\n  @media (min-width: ${props => props.theme.breakpoints.small}px) {\n    padding: ${props => props.theme.spaceScale.spacing06};\n  }\n`;\r\nconst H1 = styled(Heading) `\n  font-size: ${props => props.theme.typographyVisualStyles.headingSmall.desktop.fontSize};\n  line-height: ${props => props.theme.typographyVisualStyles.headingSmall.desktop.lineHeight};\n  color: ${props => props.isInverse\r\n    ? props.theme.colors.neutral100\r\n    : props.theme.colors.neutral700};\n  margin: 0;\n  padding-right: ${props => props.theme.spaceScale.spacing10};\n  font-weight: 600;\n`;\r\nconst CloseBtn = styled.span `\n  position: absolute;\n  top: 0;\n  right: 0;\n  margin: ${props => props.theme.spaceScale.spacing02};\n`;\r\nexport const Modal = React.forwardRef((props, ref) => {\r\n    const lastFocus = React.useRef();\r\n    const headingRef = React.useRef();\r\n    const bodyRef = React.useRef();\r\n    const id = useGenerateId(props.id);\r\n    const headingId = `${id}_heading`;\r\n    const contentId = `${id}_content`;\r\n    const [isModalOpen, setIsModalOpen] = React.useState(props.isOpen);\r\n    const [currentTarget, setCurrentTarget] = React.useState(null);\r\n    const [modalCount, setModalCount] = React.useState(0);\r\n    const focusTrapElement = useFocusLock(isModalOpen, headingRef, bodyRef);\r\n    const prevOpen = usePrevious(props.isOpen);\r\n    React.useEffect(() => {\r\n        if (props.isModalClosingControlledManually &&\r\n            prevOpen &&\r\n            !props.isOpen &&\r\n            isModalOpen) {\r\n            setIsModalOpen(false);\r\n        }\r\n        else if (!prevOpen && props.isOpen) {\r\n            setIsModalOpen(true);\r\n            if (props.headerRef && typeof props.headerRef === 'function') {\r\n                props.headerRef(headingRef);\r\n            }\r\n        }\r\n        else if (prevOpen && !props.isOpen && isModalOpen) {\r\n            handleClose();\r\n        }\r\n    }, [props.isOpen]);\r\n    React.useEffect(() => {\r\n        if (isModalOpen) {\r\n            lastFocus.current = document.activeElement;\r\n            const count = document.querySelectorAll('[aria-modal=\"true\"]').length;\r\n            setModalCount(count);\r\n            if (!props.isEscKeyDownDisabled) {\r\n                document.body.addEventListener('keydown', handleEscapeKeyDown, false);\r\n            }\r\n        }\r\n        return () => {\r\n            document.body.removeEventListener('keydown', handleEscapeKeyDown, false);\r\n        };\r\n    }, [isModalOpen]);\r\n    function handleModalClick(event) {\r\n        if (!document.getElementById(contentId).contains(event.target) &&\r\n            event.target === currentTarget) {\r\n            handleClose(event);\r\n        }\r\n    }\r\n    function handleModalOnMouseDown(event) {\r\n        setCurrentTarget(event.target);\r\n    }\r\n    function handleEscapeKeyDown(event) {\r\n        if (event.key === 'Escape') {\r\n            event.preventDefault();\r\n            event.stopPropagation();\r\n            props.onEscKeyDown &&\r\n                typeof props.onEscKeyDown === 'function' &&\r\n                props.onEscKeyDown(event);\r\n            //Supports nested modals\r\n            const modalsInDom = document.querySelectorAll('[aria-modal=\"true\"]').length;\r\n            if (modalCount <= 1 && modalsInDom !== 1) {\r\n                if (document.getElementById(id).contains(event.target)) {\r\n                    handleClose(event);\r\n                }\r\n                else {\r\n                    headingRef.current.focus();\r\n                }\r\n            }\r\n            else {\r\n                handleClose(event);\r\n            }\r\n        }\r\n    }\r\n    function handleClose(event) {\r\n        event?.stopPropagation();\r\n        setTimeout(() => {\r\n            if (!props.isModalClosingControlledManually) {\r\n                setIsModalOpen(false);\r\n            }\r\n            lastFocus.current?.focus();\r\n            props.onClose && typeof props.onClose === 'function' && props.onClose();\r\n        }, 0);\r\n    }\r\n    const { ariaLabel, children, closeAriaLabel, closeButtonSize, containerStyle, containerTransition = { slideTop: true }, isBackgroundClickDisabled, isEscKeyDownDisabled, header, isCloseButtonHidden, isOpen, unmountOnExit = true, testId, ...rest } = props;\r\n    const isInverse = useIsInverse(props.isInverse);\r\n    const other = omit(['onEscKeyDown'], rest);\r\n    const theme = React.useContext(ThemeContext);\r\n    const i18n = React.useContext(I18nContext);\r\n    const CloseIconButton = (React.createElement(CloseIcon, { size: magma.iconSizes[closeButtonSize]\r\n            ? magma.iconSizes[closeButtonSize]\r\n            : magma.iconSizes.medium }));\r\n    return isModalOpen\r\n        ? ReactDOM.createPortal(React.createElement(\"div\", { ref: focusTrapElement },\r\n            React.createElement(Global, { styles: css `\n                html {\n                  overflow: ${isOpen ? 'hidden' : 'auto'};\n                }\n              ` }),\r\n            React.createElement(ModalContainer, Object.assign({ \"aria-labelledby\": header ? headingId : null, \"aria-label\": !header ? ariaLabel : null, \"aria-modal\": true, \"data-testid\": testId, id: id, modalCount: modalCount, onClick: isBackgroundClickDisabled ? null : handleModalClick, onMouseDown: isBackgroundClickDisabled ? null : handleModalOnMouseDown, role: \"dialog\", style: containerStyle, theme: theme, isOpen: isModalOpen }, containerTransition, { unmountOnExit: unmountOnExit }),\r\n                React.createElement(ModalContent, Object.assign({}, other, { \"data-testid\": \"modal-content\", id: contentId, ref: ref, theme: theme }),\r\n                    header && (React.createElement(ModalHeader, { theme: theme }, header && (React.createElement(H1, { id: headingId, isInverse: isInverse, level: 1, ref: headingRef, visualStyle: TypographyVisualStyle.headingSmall, tabIndex: -1, theme: theme }, header)))),\r\n                    React.createElement(ModalWrapper, { ref: bodyRef, theme: theme }, children),\r\n                    !isCloseButtonHidden && (React.createElement(CloseBtn, { theme: theme },\r\n                        React.createElement(IconButton, { \"aria-label\": closeAriaLabel\r\n                                ? closeAriaLabel\r\n                                : i18n.modal.closeAriaLabel, color: ButtonColor.primary, icon: CloseIconButton, isInverse: isInverse, onClick: handleClose, testId: \"modal-closebtn\", variant: ButtonVariant.link }))))),\r\n            React.createElement(ModalBackdrop, { \"data-testid\": \"modal-backdrop\", onMouseDown: isBackgroundClickDisabled\r\n                    ? event => event.preventDefault()\r\n                    : null, fade: true, isOpen: isModalOpen, style: modalCount >= 2 && { zIndex: '998' }, unmountOnExit: true, theme: theme })), document.getElementsByTagName('body')[0])\r\n        : null;\r\n});\r\n//# sourceMappingURL=Modal.js.map"]} */"));
|
|
11184
11186
|
var ModalContent = /*#__PURE__*/_styled("div", {
|
|
11185
11187
|
target: "e1pxemtw4",
|
|
11186
11188
|
label: "ModalContent"
|
|
@@ -11207,7 +11209,7 @@ var ModalContent = /*#__PURE__*/_styled("div", {
|
|
|
11207
11209
|
return props.theme.breakpoints.small;
|
|
11208
11210
|
}, "px){margin:", function (props) {
|
|
11209
11211
|
return props.theme.spaceScale.spacing08;
|
|
11210
|
-
}, " auto;}" + ( "/*# sourceMappingURL=data:application/json;charset=utf-8;base64,{"version":3,"sources":["Modal.tsx"],"names":[],"mappings":"AA0CgC","file":"Modal.tsx","sourcesContent":["import * as React from 'react';\r\nimport { Global, css } from '@emotion/react';\r\nimport styled from '@emotion/styled';\r\nimport { transparentize } from 'polished';\r\nimport ReactDOM from 'react-dom';\r\nimport { CloseIcon } from 'react-magma-icons';\r\nimport { useFocusLock } from '../../hooks/useFocusLock';\r\nimport { I18nContext } from '../../i18n';\r\nimport { useIsInverse } from '../../inverse';\r\nimport { magma } from '../../theme/magma';\r\nimport { ThemeContext } from '../../theme/ThemeContext';\r\nimport { omit, useGenerateId, usePrevious } from '../../utils';\r\nimport { ButtonColor, ButtonVariant } from '../Button';\r\nimport { Heading } from '../Heading';\r\nimport { IconButton } from '../IconButton';\r\nimport { Transition } from '../Transition';\r\nimport { TypographyVisualStyle } from '../Typography';\r\nexport var ModalSize;\r\n(function (ModalSize) {\r\n    ModalSize[\"large\"] = \"large\";\r\n    ModalSize[\"medium\"] = \"medium\";\r\n    ModalSize[\"small\"] = \"small\";\r\n})(ModalSize || (ModalSize = {}));\r\nconst ModalContainer = styled(Transition) `\n  bottom: 0;\n  left: 0;\n  overflow-y: auto;\n  padding: ${props => props.theme.spaceScale.spacing03};\n  right: 0;\n  top: 0;\n  z-index: ${props => (props.modalCount >= 2 ? '999' : '998')};\n`;\r\nconst ModalBackdrop = styled(Transition) `\n  backdrop-filter: blur(3px);\n  background: ${props => transparentize(0.4, props.theme.colors.neutral900)};\n  bottom: 0;\n  left: 0;\n  right: 0;\n  top: 0;\n  z-index: 997;\n  position: fixed;\n`;\r\nconst ModalContent = styled.div `\n  background: ${props => props.isInverse\r\n    ? props.theme.colors.primary600\r\n    : props.theme.colors.neutral100};\n  border: 1px solid;\n  border-color: ${props => props.isInverse\r\n    ? transparentize(0.5, props.theme.colors.tertiary)\r\n    : props.theme.colors.neutral};\n  border-radius: ${props => props.theme.borderRadius};\n  box-shadow: ${props => `0 2px 6px ${transparentize(0.85, props.theme.colors.neutral900)}`};\n  color: ${props => props.isInverse\r\n    ? props.theme.colors.neutral100\r\n    : props.theme.colors.neutral700};\n  margin: 0 auto;\n  position: relative;\n  z-index: 1000;\n\n  max-width: ${props => {\r\n    switch (props.size) {\r\n        case 'large':\r\n            return props.theme.modal.width.large;\r\n        case 'small':\r\n            return props.theme.modal.width.small;\r\n        default:\r\n            return props.theme.modal.width.medium;\r\n    }\r\n}};\n\n  @media (min-width: ${props => props.theme.breakpoints.small}px) {\n    margin: ${props => props.theme.spaceScale.spacing08} auto;\n  }\n`;\r\nconst ModalHeader = styled.div `\n  padding: ${props => props.theme.spaceScale.spacing05}\n    ${props => props.theme.spaceScale.spacing05} 0\n    ${props => props.theme.spaceScale.spacing05};\n  @media (min-width: ${props => props.theme.breakpoints.small}px) {\n    padding: ${props => props.theme.spaceScale.spacing06}\n      ${props => props.theme.spaceScale.spacing06} 0\n      ${props => props.theme.spaceScale.spacing06};\n  }\n`;\r\nconst ModalWrapper = styled.div `\n  padding: ${props => props.theme.spaceScale.spacing05};\n  @media (min-width: ${props => props.theme.breakpoints.small}px) {\n    padding: ${props => props.theme.spaceScale.spacing06};\n  }\n`;\r\nconst H1 = styled(Heading) `\n  font-size: ${props => props.theme.typographyVisualStyles.headingSmall.desktop.fontSize};\n  line-height: ${props => props.theme.typographyVisualStyles.headingSmall.desktop.lineHeight};\n  color: ${props => props.isInverse\r\n    ? props.theme.colors.neutral100\r\n    : props.theme.colors.neutral700};\n  margin: 0;\n  padding-right: ${props => props.theme.spaceScale.spacing10};\n  font-weight: 600;\n`;\r\nconst CloseBtn = styled.span `\n  position: absolute;\n  top: 0;\n  right: 0;\n  margin: ${props => props.theme.spaceScale.spacing02};\n`;\r\nexport const Modal = React.forwardRef((props, ref) => {\r\n    const lastFocus = React.useRef();\r\n    const headingRef = React.useRef();\r\n    const bodyRef = React.useRef();\r\n    const id = useGenerateId(props.id);\r\n    const headingId = `${id}_heading`;\r\n    const contentId = `${id}_content`;\r\n    const [isModalOpen, setIsModalOpen] = React.useState(props.isOpen);\r\n    const [isExiting, setIsExiting] = React.useState(false);\r\n    const [currentTarget, setCurrentTarget] = React.useState(null);\r\n    const [modalCount, setModalCount] = React.useState(0);\r\n    const focusTrapElement = useFocusLock(isModalOpen, headingRef, bodyRef);\r\n    const prevOpen = usePrevious(props.isOpen);\r\n    React.useEffect(() => {\r\n        if (props.isModalClosingControlledManually &&\r\n            prevOpen &&\r\n            !props.isOpen &&\r\n            isModalOpen) {\r\n            setIsModalOpen(false);\r\n        }\r\n        else if (!prevOpen && props.isOpen) {\r\n            setIsModalOpen(true);\r\n            if (props.headerRef && typeof props.headerRef === 'function') {\r\n                props.headerRef(headingRef);\r\n            }\r\n        }\r\n        else if (prevOpen && !props.isOpen && isModalOpen) {\r\n            handleClose();\r\n        }\r\n    }, [props.isOpen]);\r\n    React.useEffect(() => {\r\n        if (isModalOpen) {\r\n            lastFocus.current = document.activeElement;\r\n            const count = document.querySelectorAll('[aria-modal=\"true\"]').length;\r\n            setModalCount(count);\r\n            if (!props.isEscKeyDownDisabled) {\r\n                document.body.addEventListener('keydown', handleEscapeKeyDown, false);\r\n            }\r\n        }\r\n        return () => {\r\n            document.body.removeEventListener('keydown', handleEscapeKeyDown, false);\r\n        };\r\n    }, [isModalOpen]);\r\n    function handleModalClick(event) {\r\n        if (!document.getElementById(contentId).contains(event.target) &&\r\n            event.target === currentTarget) {\r\n            handleClose(event);\r\n        }\r\n    }\r\n    function handleModalOnMouseDown(event) {\r\n        setCurrentTarget(event.target);\r\n    }\r\n    function handleEscapeKeyDown(event) {\r\n        if (event.key === 'Escape') {\r\n            event.preventDefault();\r\n            event.stopPropagation();\r\n            props.onEscKeyDown &&\r\n                typeof props.onEscKeyDown === 'function' &&\r\n                props.onEscKeyDown(event);\r\n            //Supports nested modals\r\n            const modalsInDom = document.querySelectorAll('[aria-modal=\"true\"]').length;\r\n            if (modalCount <= 1 && modalsInDom !== 1) {\r\n                if (document.getElementById(id).contains(event.target)) {\r\n                    handleClose(event);\r\n                }\r\n                else {\r\n                    headingRef.current.focus();\r\n                }\r\n            }\r\n            else {\r\n                handleClose(event);\r\n            }\r\n        }\r\n    }\r\n    function handleClose(event) {\r\n        if (event) {\r\n            event.stopPropagation();\r\n        }\r\n        setIsExiting(true);\r\n        setTimeout(() => {\r\n            setIsExiting(false);\r\n            if (!props.isModalClosingControlledManually) {\r\n                setIsModalOpen(false);\r\n            }\r\n            if (lastFocus.current) {\r\n                lastFocus.current.focus();\r\n            }\r\n            props.onClose && typeof props.onClose === 'function' && props.onClose();\r\n        }, 300);\r\n    }\r\n    const { ariaLabel, children, closeAriaLabel, closeButtonSize, containerStyle, containerTransition = { slideTop: true }, isBackgroundClickDisabled, isEscKeyDownDisabled, header, isCloseButtonHidden, isOpen, unmountOnExit = true, testId, ...rest } = props;\r\n    const isInverse = useIsInverse(props.isInverse);\r\n    const other = omit(['onEscKeyDown'], rest);\r\n    const theme = React.useContext(ThemeContext);\r\n    const i18n = React.useContext(I18nContext);\r\n    const CloseIconButton = (React.createElement(CloseIcon, { size: magma.iconSizes[closeButtonSize]\r\n            ? magma.iconSizes[closeButtonSize]\r\n            : magma.iconSizes.medium }));\r\n    return isModalOpen\r\n        ? ReactDOM.createPortal(React.createElement(\"div\", { ref: focusTrapElement },\r\n            React.createElement(Global, { styles: css `\n                html {\n                  overflow: ${isOpen ? 'hidden' : 'auto'};\n                }\n              ` }),\r\n            React.createElement(ModalContainer, Object.assign({ \"aria-labelledby\": header ? headingId : null, \"aria-label\": !header ? ariaLabel : null, \"aria-modal\": true, \"data-testid\": testId, id: id, modalCount: modalCount, onClick: isBackgroundClickDisabled ? null : handleModalClick, onMouseDown: isBackgroundClickDisabled ? null : handleModalOnMouseDown, role: \"dialog\", style: containerStyle, theme: theme, isOpen: isModalOpen }, containerTransition, { unmountOnExit: unmountOnExit }),\r\n                React.createElement(ModalContent, Object.assign({}, other, { \"data-testid\": \"modal-content\", id: contentId, isExiting: isExiting, ref: ref, theme: theme }),\r\n                    header && (React.createElement(ModalHeader, { theme: theme }, header && (React.createElement(H1, { id: headingId, isInverse: isInverse, level: 1, ref: headingRef, visualStyle: TypographyVisualStyle.headingSmall, tabIndex: -1, theme: theme }, header)))),\r\n                    React.createElement(ModalWrapper, { ref: bodyRef, theme: theme }, children),\r\n                    !isCloseButtonHidden && (React.createElement(CloseBtn, { theme: theme },\r\n                        React.createElement(IconButton, { \"aria-label\": closeAriaLabel\r\n                                ? closeAriaLabel\r\n                                : i18n.modal.closeAriaLabel, color: ButtonColor.primary, icon: CloseIconButton, isInverse: isInverse, onClick: handleClose, testId: \"modal-closebtn\", variant: ButtonVariant.link }))))),\r\n            React.createElement(ModalBackdrop, { \"data-testid\": \"modal-backdrop\", isExiting: isExiting, onMouseDown: isBackgroundClickDisabled\r\n                    ? event => event.preventDefault()\r\n                    : null, fade: true, isOpen: isModalOpen, style: modalCount >= 2 && { zIndex: '998' }, unmountOnExit: true, theme: theme })), document.getElementsByTagName('body')[0])\r\n        : null;\r\n});\r\n//# sourceMappingURL=Modal.js.map"]} */"));
|
|
11212
|
+
}, " auto;}" + ( "/*# sourceMappingURL=data:application/json;charset=utf-8;base64,{"version":3,"sources":["Modal.tsx"],"names":[],"mappings":"AA0CgC","file":"Modal.tsx","sourcesContent":["import * as React from 'react';\r\nimport { css, Global } from '@emotion/react';\r\nimport styled from '@emotion/styled';\r\nimport { transparentize } from 'polished';\r\nimport ReactDOM from 'react-dom';\r\nimport { CloseIcon } from 'react-magma-icons';\r\nimport { useFocusLock } from '../../hooks/useFocusLock';\r\nimport { I18nContext } from '../../i18n';\r\nimport { useIsInverse } from '../../inverse';\r\nimport { magma } from '../../theme/magma';\r\nimport { ThemeContext } from '../../theme/ThemeContext';\r\nimport { omit, useGenerateId, usePrevious } from '../../utils';\r\nimport { ButtonColor, ButtonVariant } from '../Button';\r\nimport { Heading } from '../Heading';\r\nimport { IconButton } from '../IconButton';\r\nimport { Transition } from '../Transition';\r\nimport { TypographyVisualStyle } from '../Typography';\r\nexport var ModalSize;\r\n(function (ModalSize) {\r\n    ModalSize[\"large\"] = \"large\";\r\n    ModalSize[\"medium\"] = \"medium\";\r\n    ModalSize[\"small\"] = \"small\";\r\n})(ModalSize || (ModalSize = {}));\r\nconst ModalContainer = styled(Transition) `\n  bottom: 0;\n  left: 0;\n  overflow-y: auto;\n  padding: ${props => props.theme.spaceScale.spacing03};\n  right: 0;\n  top: 0;\n  z-index: ${props => (props.modalCount >= 2 ? '999' : '998')};\n`;\r\nconst ModalBackdrop = styled(Transition) `\n  backdrop-filter: blur(3px);\n  background: ${props => transparentize(0.4, props.theme.colors.neutral900)};\n  bottom: 0;\n  left: 0;\n  right: 0;\n  top: 0;\n  z-index: 997;\n  position: fixed;\n`;\r\nconst ModalContent = styled.div `\n  background: ${props => props.isInverse\r\n    ? props.theme.colors.primary600\r\n    : props.theme.colors.neutral100};\n  border: 1px solid;\n  border-color: ${props => props.isInverse\r\n    ? transparentize(0.5, props.theme.colors.tertiary)\r\n    : props.theme.colors.neutral};\n  border-radius: ${props => props.theme.borderRadius};\n  box-shadow: ${props => `0 2px 6px ${transparentize(0.85, props.theme.colors.neutral900)}`};\n  color: ${props => props.isInverse\r\n    ? props.theme.colors.neutral100\r\n    : props.theme.colors.neutral700};\n  margin: 0 auto;\n  position: relative;\n  z-index: 1000;\n\n  max-width: ${props => {\r\n    switch (props.size) {\r\n        case 'large':\r\n            return props.theme.modal.width.large;\r\n        case 'small':\r\n            return props.theme.modal.width.small;\r\n        default:\r\n            return props.theme.modal.width.medium;\r\n    }\r\n}};\n\n  @media (min-width: ${props => props.theme.breakpoints.small}px) {\n    margin: ${props => props.theme.spaceScale.spacing08} auto;\n  }\n`;\r\nconst ModalHeader = styled.div `\n  padding: ${props => props.theme.spaceScale.spacing05}\n    ${props => props.theme.spaceScale.spacing05} 0\n    ${props => props.theme.spaceScale.spacing05};\n  @media (min-width: ${props => props.theme.breakpoints.small}px) {\n    padding: ${props => props.theme.spaceScale.spacing06}\n      ${props => props.theme.spaceScale.spacing06} 0\n      ${props => props.theme.spaceScale.spacing06};\n  }\n`;\r\nconst ModalWrapper = styled.div `\n  padding: ${props => props.theme.spaceScale.spacing05};\n  @media (min-width: ${props => props.theme.breakpoints.small}px) {\n    padding: ${props => props.theme.spaceScale.spacing06};\n  }\n`;\r\nconst H1 = styled(Heading) `\n  font-size: ${props => props.theme.typographyVisualStyles.headingSmall.desktop.fontSize};\n  line-height: ${props => props.theme.typographyVisualStyles.headingSmall.desktop.lineHeight};\n  color: ${props => props.isInverse\r\n    ? props.theme.colors.neutral100\r\n    : props.theme.colors.neutral700};\n  margin: 0;\n  padding-right: ${props => props.theme.spaceScale.spacing10};\n  font-weight: 600;\n`;\r\nconst CloseBtn = styled.span `\n  position: absolute;\n  top: 0;\n  right: 0;\n  margin: ${props => props.theme.spaceScale.spacing02};\n`;\r\nexport const Modal = React.forwardRef((props, ref) => {\r\n    const lastFocus = React.useRef();\r\n    const headingRef = React.useRef();\r\n    const bodyRef = React.useRef();\r\n    const id = useGenerateId(props.id);\r\n    const headingId = `${id}_heading`;\r\n    const contentId = `${id}_content`;\r\n    const [isModalOpen, setIsModalOpen] = React.useState(props.isOpen);\r\n    const [currentTarget, setCurrentTarget] = React.useState(null);\r\n    const [modalCount, setModalCount] = React.useState(0);\r\n    const focusTrapElement = useFocusLock(isModalOpen, headingRef, bodyRef);\r\n    const prevOpen = usePrevious(props.isOpen);\r\n    React.useEffect(() => {\r\n        if (props.isModalClosingControlledManually &&\r\n            prevOpen &&\r\n            !props.isOpen &&\r\n            isModalOpen) {\r\n            setIsModalOpen(false);\r\n        }\r\n        else if (!prevOpen && props.isOpen) {\r\n            setIsModalOpen(true);\r\n            if (props.headerRef && typeof props.headerRef === 'function') {\r\n                props.headerRef(headingRef);\r\n            }\r\n        }\r\n        else if (prevOpen && !props.isOpen && isModalOpen) {\r\n            handleClose();\r\n        }\r\n    }, [props.isOpen]);\r\n    React.useEffect(() => {\r\n        if (isModalOpen) {\r\n            lastFocus.current = document.activeElement;\r\n            const count = document.querySelectorAll('[aria-modal=\"true\"]').length;\r\n            setModalCount(count);\r\n            if (!props.isEscKeyDownDisabled) {\r\n                document.body.addEventListener('keydown', handleEscapeKeyDown, false);\r\n            }\r\n        }\r\n        return () => {\r\n            document.body.removeEventListener('keydown', handleEscapeKeyDown, false);\r\n        };\r\n    }, [isModalOpen]);\r\n    function handleModalClick(event) {\r\n        if (!document.getElementById(contentId).contains(event.target) &&\r\n            event.target === currentTarget) {\r\n            handleClose(event);\r\n        }\r\n    }\r\n    function handleModalOnMouseDown(event) {\r\n        setCurrentTarget(event.target);\r\n    }\r\n    function handleEscapeKeyDown(event) {\r\n        if (event.key === 'Escape') {\r\n            event.preventDefault();\r\n            event.stopPropagation();\r\n            props.onEscKeyDown &&\r\n                typeof props.onEscKeyDown === 'function' &&\r\n                props.onEscKeyDown(event);\r\n            //Supports nested modals\r\n            const modalsInDom = document.querySelectorAll('[aria-modal=\"true\"]').length;\r\n            if (modalCount <= 1 && modalsInDom !== 1) {\r\n                if (document.getElementById(id).contains(event.target)) {\r\n                    handleClose(event);\r\n                }\r\n                else {\r\n                    headingRef.current.focus();\r\n                }\r\n            }\r\n            else {\r\n                handleClose(event);\r\n            }\r\n        }\r\n    }\r\n    function handleClose(event) {\r\n        event?.stopPropagation();\r\n        setTimeout(() => {\r\n            if (!props.isModalClosingControlledManually) {\r\n                setIsModalOpen(false);\r\n            }\r\n            lastFocus.current?.focus();\r\n            props.onClose && typeof props.onClose === 'function' && props.onClose();\r\n        }, 0);\r\n    }\r\n    const { ariaLabel, children, closeAriaLabel, closeButtonSize, containerStyle, containerTransition = { slideTop: true }, isBackgroundClickDisabled, isEscKeyDownDisabled, header, isCloseButtonHidden, isOpen, unmountOnExit = true, testId, ...rest } = props;\r\n    const isInverse = useIsInverse(props.isInverse);\r\n    const other = omit(['onEscKeyDown'], rest);\r\n    const theme = React.useContext(ThemeContext);\r\n    const i18n = React.useContext(I18nContext);\r\n    const CloseIconButton = (React.createElement(CloseIcon, { size: magma.iconSizes[closeButtonSize]\r\n            ? magma.iconSizes[closeButtonSize]\r\n            : magma.iconSizes.medium }));\r\n    return isModalOpen\r\n        ? ReactDOM.createPortal(React.createElement(\"div\", { ref: focusTrapElement },\r\n            React.createElement(Global, { styles: css `\n                html {\n                  overflow: ${isOpen ? 'hidden' : 'auto'};\n                }\n              ` }),\r\n            React.createElement(ModalContainer, Object.assign({ \"aria-labelledby\": header ? headingId : null, \"aria-label\": !header ? ariaLabel : null, \"aria-modal\": true, \"data-testid\": testId, id: id, modalCount: modalCount, onClick: isBackgroundClickDisabled ? null : handleModalClick, onMouseDown: isBackgroundClickDisabled ? null : handleModalOnMouseDown, role: \"dialog\", style: containerStyle, theme: theme, isOpen: isModalOpen }, containerTransition, { unmountOnExit: unmountOnExit }),\r\n                React.createElement(ModalContent, Object.assign({}, other, { \"data-testid\": \"modal-content\", id: contentId, ref: ref, theme: theme }),\r\n                    header && (React.createElement(ModalHeader, { theme: theme }, header && (React.createElement(H1, { id: headingId, isInverse: isInverse, level: 1, ref: headingRef, visualStyle: TypographyVisualStyle.headingSmall, tabIndex: -1, theme: theme }, header)))),\r\n                    React.createElement(ModalWrapper, { ref: bodyRef, theme: theme }, children),\r\n                    !isCloseButtonHidden && (React.createElement(CloseBtn, { theme: theme },\r\n                        React.createElement(IconButton, { \"aria-label\": closeAriaLabel\r\n                                ? closeAriaLabel\r\n                                : i18n.modal.closeAriaLabel, color: ButtonColor.primary, icon: CloseIconButton, isInverse: isInverse, onClick: handleClose, testId: \"modal-closebtn\", variant: ButtonVariant.link }))))),\r\n            React.createElement(ModalBackdrop, { \"data-testid\": \"modal-backdrop\", onMouseDown: isBackgroundClickDisabled\r\n                    ? event => event.preventDefault()\r\n                    : null, fade: true, isOpen: isModalOpen, style: modalCount >= 2 && { zIndex: '998' }, unmountOnExit: true, theme: theme })), document.getElementsByTagName('body')[0])\r\n        : null;\r\n});\r\n//# sourceMappingURL=Modal.js.map"]} */"));
|
|
11211
11213
|
var ModalHeader = /*#__PURE__*/_styled("div", {
|
|
11212
11214
|
target: "e1pxemtw3",
|
|
11213
11215
|
label: "ModalHeader"
|
|
@@ -11225,7 +11227,7 @@ var ModalHeader = /*#__PURE__*/_styled("div", {
|
|
|
11225
11227
|
return props.theme.spaceScale.spacing06;
|
|
11226
11228
|
}, " 0 ", function (props) {
|
|
11227
11229
|
return props.theme.spaceScale.spacing06;
|
|
11228
|
-
}, ";}" + ( "/*# sourceMappingURL=data:application/json;charset=utf-8;base64,{"version":3,"sources":["Modal.tsx"],"names":[],"mappings":"AA0E+B","file":"Modal.tsx","sourcesContent":["import * as React from 'react';\r\nimport { Global, css } from '@emotion/react';\r\nimport styled from '@emotion/styled';\r\nimport { transparentize } from 'polished';\r\nimport ReactDOM from 'react-dom';\r\nimport { CloseIcon } from 'react-magma-icons';\r\nimport { useFocusLock } from '../../hooks/useFocusLock';\r\nimport { I18nContext } from '../../i18n';\r\nimport { useIsInverse } from '../../inverse';\r\nimport { magma } from '../../theme/magma';\r\nimport { ThemeContext } from '../../theme/ThemeContext';\r\nimport { omit, useGenerateId, usePrevious } from '../../utils';\r\nimport { ButtonColor, ButtonVariant } from '../Button';\r\nimport { Heading } from '../Heading';\r\nimport { IconButton } from '../IconButton';\r\nimport { Transition } from '../Transition';\r\nimport { TypographyVisualStyle } from '../Typography';\r\nexport var ModalSize;\r\n(function (ModalSize) {\r\n    ModalSize[\"large\"] = \"large\";\r\n    ModalSize[\"medium\"] = \"medium\";\r\n    ModalSize[\"small\"] = \"small\";\r\n})(ModalSize || (ModalSize = {}));\r\nconst ModalContainer = styled(Transition) `\n  bottom: 0;\n  left: 0;\n  overflow-y: auto;\n  padding: ${props => props.theme.spaceScale.spacing03};\n  right: 0;\n  top: 0;\n  z-index: ${props => (props.modalCount >= 2 ? '999' : '998')};\n`;\r\nconst ModalBackdrop = styled(Transition) `\n  backdrop-filter: blur(3px);\n  background: ${props => transparentize(0.4, props.theme.colors.neutral900)};\n  bottom: 0;\n  left: 0;\n  right: 0;\n  top: 0;\n  z-index: 997;\n  position: fixed;\n`;\r\nconst ModalContent = styled.div `\n  background: ${props => props.isInverse\r\n    ? props.theme.colors.primary600\r\n    : props.theme.colors.neutral100};\n  border: 1px solid;\n  border-color: ${props => props.isInverse\r\n    ? transparentize(0.5, props.theme.colors.tertiary)\r\n    : props.theme.colors.neutral};\n  border-radius: ${props => props.theme.borderRadius};\n  box-shadow: ${props => `0 2px 6px ${transparentize(0.85, props.theme.colors.neutral900)}`};\n  color: ${props => props.isInverse\r\n    ? props.theme.colors.neutral100\r\n    : props.theme.colors.neutral700};\n  margin: 0 auto;\n  position: relative;\n  z-index: 1000;\n\n  max-width: ${props => {\r\n    switch (props.size) {\r\n        case 'large':\r\n            return props.theme.modal.width.large;\r\n        case 'small':\r\n            return props.theme.modal.width.small;\r\n        default:\r\n            return props.theme.modal.width.medium;\r\n    }\r\n}};\n\n  @media (min-width: ${props => props.theme.breakpoints.small}px) {\n    margin: ${props => props.theme.spaceScale.spacing08} auto;\n  }\n`;\r\nconst ModalHeader = styled.div `\n  padding: ${props => props.theme.spaceScale.spacing05}\n    ${props => props.theme.spaceScale.spacing05} 0\n    ${props => props.theme.spaceScale.spacing05};\n  @media (min-width: ${props => props.theme.breakpoints.small}px) {\n    padding: ${props => props.theme.spaceScale.spacing06}\n      ${props => props.theme.spaceScale.spacing06} 0\n      ${props => props.theme.spaceScale.spacing06};\n  }\n`;\r\nconst ModalWrapper = styled.div `\n  padding: ${props => props.theme.spaceScale.spacing05};\n  @media (min-width: ${props => props.theme.breakpoints.small}px) {\n    padding: ${props => props.theme.spaceScale.spacing06};\n  }\n`;\r\nconst H1 = styled(Heading) `\n  font-size: ${props => props.theme.typographyVisualStyles.headingSmall.desktop.fontSize};\n  line-height: ${props => props.theme.typographyVisualStyles.headingSmall.desktop.lineHeight};\n  color: ${props => props.isInverse\r\n    ? props.theme.colors.neutral100\r\n    : props.theme.colors.neutral700};\n  margin: 0;\n  padding-right: ${props => props.theme.spaceScale.spacing10};\n  font-weight: 600;\n`;\r\nconst CloseBtn = styled.span `\n  position: absolute;\n  top: 0;\n  right: 0;\n  margin: ${props => props.theme.spaceScale.spacing02};\n`;\r\nexport const Modal = React.forwardRef((props, ref) => {\r\n    const lastFocus = React.useRef();\r\n    const headingRef = React.useRef();\r\n    const bodyRef = React.useRef();\r\n    const id = useGenerateId(props.id);\r\n    const headingId = `${id}_heading`;\r\n    const contentId = `${id}_content`;\r\n    const [isModalOpen, setIsModalOpen] = React.useState(props.isOpen);\r\n    const [isExiting, setIsExiting] = React.useState(false);\r\n    const [currentTarget, setCurrentTarget] = React.useState(null);\r\n    const [modalCount, setModalCount] = React.useState(0);\r\n    const focusTrapElement = useFocusLock(isModalOpen, headingRef, bodyRef);\r\n    const prevOpen = usePrevious(props.isOpen);\r\n    React.useEffect(() => {\r\n        if (props.isModalClosingControlledManually &&\r\n            prevOpen &&\r\n            !props.isOpen &&\r\n            isModalOpen) {\r\n            setIsModalOpen(false);\r\n        }\r\n        else if (!prevOpen && props.isOpen) {\r\n            setIsModalOpen(true);\r\n            if (props.headerRef && typeof props.headerRef === 'function') {\r\n                props.headerRef(headingRef);\r\n            }\r\n        }\r\n        else if (prevOpen && !props.isOpen && isModalOpen) {\r\n            handleClose();\r\n        }\r\n    }, [props.isOpen]);\r\n    React.useEffect(() => {\r\n        if (isModalOpen) {\r\n            lastFocus.current = document.activeElement;\r\n            const count = document.querySelectorAll('[aria-modal=\"true\"]').length;\r\n            setModalCount(count);\r\n            if (!props.isEscKeyDownDisabled) {\r\n                document.body.addEventListener('keydown', handleEscapeKeyDown, false);\r\n            }\r\n        }\r\n        return () => {\r\n            document.body.removeEventListener('keydown', handleEscapeKeyDown, false);\r\n        };\r\n    }, [isModalOpen]);\r\n    function handleModalClick(event) {\r\n        if (!document.getElementById(contentId).contains(event.target) &&\r\n            event.target === currentTarget) {\r\n            handleClose(event);\r\n        }\r\n    }\r\n    function handleModalOnMouseDown(event) {\r\n        setCurrentTarget(event.target);\r\n    }\r\n    function handleEscapeKeyDown(event) {\r\n        if (event.key === 'Escape') {\r\n            event.preventDefault();\r\n            event.stopPropagation();\r\n            props.onEscKeyDown &&\r\n                typeof props.onEscKeyDown === 'function' &&\r\n                props.onEscKeyDown(event);\r\n            //Supports nested modals\r\n            const modalsInDom = document.querySelectorAll('[aria-modal=\"true\"]').length;\r\n            if (modalCount <= 1 && modalsInDom !== 1) {\r\n                if (document.getElementById(id).contains(event.target)) {\r\n                    handleClose(event);\r\n                }\r\n                else {\r\n                    headingRef.current.focus();\r\n                }\r\n            }\r\n            else {\r\n                handleClose(event);\r\n            }\r\n        }\r\n    }\r\n    function handleClose(event) {\r\n        if (event) {\r\n            event.stopPropagation();\r\n        }\r\n        setIsExiting(true);\r\n        setTimeout(() => {\r\n            setIsExiting(false);\r\n            if (!props.isModalClosingControlledManually) {\r\n                setIsModalOpen(false);\r\n            }\r\n            if (lastFocus.current) {\r\n                lastFocus.current.focus();\r\n            }\r\n            props.onClose && typeof props.onClose === 'function' && props.onClose();\r\n        }, 300);\r\n    }\r\n    const { ariaLabel, children, closeAriaLabel, closeButtonSize, containerStyle, containerTransition = { slideTop: true }, isBackgroundClickDisabled, isEscKeyDownDisabled, header, isCloseButtonHidden, isOpen, unmountOnExit = true, testId, ...rest } = props;\r\n    const isInverse = useIsInverse(props.isInverse);\r\n    const other = omit(['onEscKeyDown'], rest);\r\n    const theme = React.useContext(ThemeContext);\r\n    const i18n = React.useContext(I18nContext);\r\n    const CloseIconButton = (React.createElement(CloseIcon, { size: magma.iconSizes[closeButtonSize]\r\n            ? magma.iconSizes[closeButtonSize]\r\n            : magma.iconSizes.medium }));\r\n    return isModalOpen\r\n        ? ReactDOM.createPortal(React.createElement(\"div\", { ref: focusTrapElement },\r\n            React.createElement(Global, { styles: css `\n                html {\n                  overflow: ${isOpen ? 'hidden' : 'auto'};\n                }\n              ` }),\r\n            React.createElement(ModalContainer, Object.assign({ \"aria-labelledby\": header ? headingId : null, \"aria-label\": !header ? ariaLabel : null, \"aria-modal\": true, \"data-testid\": testId, id: id, modalCount: modalCount, onClick: isBackgroundClickDisabled ? null : handleModalClick, onMouseDown: isBackgroundClickDisabled ? null : handleModalOnMouseDown, role: \"dialog\", style: containerStyle, theme: theme, isOpen: isModalOpen }, containerTransition, { unmountOnExit: unmountOnExit }),\r\n                React.createElement(ModalContent, Object.assign({}, other, { \"data-testid\": \"modal-content\", id: contentId, isExiting: isExiting, ref: ref, theme: theme }),\r\n                    header && (React.createElement(ModalHeader, { theme: theme }, header && (React.createElement(H1, { id: headingId, isInverse: isInverse, level: 1, ref: headingRef, visualStyle: TypographyVisualStyle.headingSmall, tabIndex: -1, theme: theme }, header)))),\r\n                    React.createElement(ModalWrapper, { ref: bodyRef, theme: theme }, children),\r\n                    !isCloseButtonHidden && (React.createElement(CloseBtn, { theme: theme },\r\n                        React.createElement(IconButton, { \"aria-label\": closeAriaLabel\r\n                                ? closeAriaLabel\r\n                                : i18n.modal.closeAriaLabel, color: ButtonColor.primary, icon: CloseIconButton, isInverse: isInverse, onClick: handleClose, testId: \"modal-closebtn\", variant: ButtonVariant.link }))))),\r\n            React.createElement(ModalBackdrop, { \"data-testid\": \"modal-backdrop\", isExiting: isExiting, onMouseDown: isBackgroundClickDisabled\r\n                    ? event => event.preventDefault()\r\n                    : null, fade: true, isOpen: isModalOpen, style: modalCount >= 2 && { zIndex: '998' }, unmountOnExit: true, theme: theme })), document.getElementsByTagName('body')[0])\r\n        : null;\r\n});\r\n//# sourceMappingURL=Modal.js.map"]} */"));
|
|
11230
|
+
}, ";}" + ( "/*# sourceMappingURL=data:application/json;charset=utf-8;base64,{"version":3,"sources":["Modal.tsx"],"names":[],"mappings":"AA0E+B","file":"Modal.tsx","sourcesContent":["import * as React from 'react';\r\nimport { css, Global } from '@emotion/react';\r\nimport styled from '@emotion/styled';\r\nimport { transparentize } from 'polished';\r\nimport ReactDOM from 'react-dom';\r\nimport { CloseIcon } from 'react-magma-icons';\r\nimport { useFocusLock } from '../../hooks/useFocusLock';\r\nimport { I18nContext } from '../../i18n';\r\nimport { useIsInverse } from '../../inverse';\r\nimport { magma } from '../../theme/magma';\r\nimport { ThemeContext } from '../../theme/ThemeContext';\r\nimport { omit, useGenerateId, usePrevious } from '../../utils';\r\nimport { ButtonColor, ButtonVariant } from '../Button';\r\nimport { Heading } from '../Heading';\r\nimport { IconButton } from '../IconButton';\r\nimport { Transition } from '../Transition';\r\nimport { TypographyVisualStyle } from '../Typography';\r\nexport var ModalSize;\r\n(function (ModalSize) {\r\n    ModalSize[\"large\"] = \"large\";\r\n    ModalSize[\"medium\"] = \"medium\";\r\n    ModalSize[\"small\"] = \"small\";\r\n})(ModalSize || (ModalSize = {}));\r\nconst ModalContainer = styled(Transition) `\n  bottom: 0;\n  left: 0;\n  overflow-y: auto;\n  padding: ${props => props.theme.spaceScale.spacing03};\n  right: 0;\n  top: 0;\n  z-index: ${props => (props.modalCount >= 2 ? '999' : '998')};\n`;\r\nconst ModalBackdrop = styled(Transition) `\n  backdrop-filter: blur(3px);\n  background: ${props => transparentize(0.4, props.theme.colors.neutral900)};\n  bottom: 0;\n  left: 0;\n  right: 0;\n  top: 0;\n  z-index: 997;\n  position: fixed;\n`;\r\nconst ModalContent = styled.div `\n  background: ${props => props.isInverse\r\n    ? props.theme.colors.primary600\r\n    : props.theme.colors.neutral100};\n  border: 1px solid;\n  border-color: ${props => props.isInverse\r\n    ? transparentize(0.5, props.theme.colors.tertiary)\r\n    : props.theme.colors.neutral};\n  border-radius: ${props => props.theme.borderRadius};\n  box-shadow: ${props => `0 2px 6px ${transparentize(0.85, props.theme.colors.neutral900)}`};\n  color: ${props => props.isInverse\r\n    ? props.theme.colors.neutral100\r\n    : props.theme.colors.neutral700};\n  margin: 0 auto;\n  position: relative;\n  z-index: 1000;\n\n  max-width: ${props => {\r\n    switch (props.size) {\r\n        case 'large':\r\n            return props.theme.modal.width.large;\r\n        case 'small':\r\n            return props.theme.modal.width.small;\r\n        default:\r\n            return props.theme.modal.width.medium;\r\n    }\r\n}};\n\n  @media (min-width: ${props => props.theme.breakpoints.small}px) {\n    margin: ${props => props.theme.spaceScale.spacing08} auto;\n  }\n`;\r\nconst ModalHeader = styled.div `\n  padding: ${props => props.theme.spaceScale.spacing05}\n    ${props => props.theme.spaceScale.spacing05} 0\n    ${props => props.theme.spaceScale.spacing05};\n  @media (min-width: ${props => props.theme.breakpoints.small}px) {\n    padding: ${props => props.theme.spaceScale.spacing06}\n      ${props => props.theme.spaceScale.spacing06} 0\n      ${props => props.theme.spaceScale.spacing06};\n  }\n`;\r\nconst ModalWrapper = styled.div `\n  padding: ${props => props.theme.spaceScale.spacing05};\n  @media (min-width: ${props => props.theme.breakpoints.small}px) {\n    padding: ${props => props.theme.spaceScale.spacing06};\n  }\n`;\r\nconst H1 = styled(Heading) `\n  font-size: ${props => props.theme.typographyVisualStyles.headingSmall.desktop.fontSize};\n  line-height: ${props => props.theme.typographyVisualStyles.headingSmall.desktop.lineHeight};\n  color: ${props => props.isInverse\r\n    ? props.theme.colors.neutral100\r\n    : props.theme.colors.neutral700};\n  margin: 0;\n  padding-right: ${props => props.theme.spaceScale.spacing10};\n  font-weight: 600;\n`;\r\nconst CloseBtn = styled.span `\n  position: absolute;\n  top: 0;\n  right: 0;\n  margin: ${props => props.theme.spaceScale.spacing02};\n`;\r\nexport const Modal = React.forwardRef((props, ref) => {\r\n    const lastFocus = React.useRef();\r\n    const headingRef = React.useRef();\r\n    const bodyRef = React.useRef();\r\n    const id = useGenerateId(props.id);\r\n    const headingId = `${id}_heading`;\r\n    const contentId = `${id}_content`;\r\n    const [isModalOpen, setIsModalOpen] = React.useState(props.isOpen);\r\n    const [currentTarget, setCurrentTarget] = React.useState(null);\r\n    const [modalCount, setModalCount] = React.useState(0);\r\n    const focusTrapElement = useFocusLock(isModalOpen, headingRef, bodyRef);\r\n    const prevOpen = usePrevious(props.isOpen);\r\n    React.useEffect(() => {\r\n        if (props.isModalClosingControlledManually &&\r\n            prevOpen &&\r\n            !props.isOpen &&\r\n            isModalOpen) {\r\n            setIsModalOpen(false);\r\n        }\r\n        else if (!prevOpen && props.isOpen) {\r\n            setIsModalOpen(true);\r\n            if (props.headerRef && typeof props.headerRef === 'function') {\r\n                props.headerRef(headingRef);\r\n            }\r\n        }\r\n        else if (prevOpen && !props.isOpen && isModalOpen) {\r\n            handleClose();\r\n        }\r\n    }, [props.isOpen]);\r\n    React.useEffect(() => {\r\n        if (isModalOpen) {\r\n            lastFocus.current = document.activeElement;\r\n            const count = document.querySelectorAll('[aria-modal=\"true\"]').length;\r\n            setModalCount(count);\r\n            if (!props.isEscKeyDownDisabled) {\r\n                document.body.addEventListener('keydown', handleEscapeKeyDown, false);\r\n            }\r\n        }\r\n        return () => {\r\n            document.body.removeEventListener('keydown', handleEscapeKeyDown, false);\r\n        };\r\n    }, [isModalOpen]);\r\n    function handleModalClick(event) {\r\n        if (!document.getElementById(contentId).contains(event.target) &&\r\n            event.target === currentTarget) {\r\n            handleClose(event);\r\n        }\r\n    }\r\n    function handleModalOnMouseDown(event) {\r\n        setCurrentTarget(event.target);\r\n    }\r\n    function handleEscapeKeyDown(event) {\r\n        if (event.key === 'Escape') {\r\n            event.preventDefault();\r\n            event.stopPropagation();\r\n            props.onEscKeyDown &&\r\n                typeof props.onEscKeyDown === 'function' &&\r\n                props.onEscKeyDown(event);\r\n            //Supports nested modals\r\n            const modalsInDom = document.querySelectorAll('[aria-modal=\"true\"]').length;\r\n            if (modalCount <= 1 && modalsInDom !== 1) {\r\n                if (document.getElementById(id).contains(event.target)) {\r\n                    handleClose(event);\r\n                }\r\n                else {\r\n                    headingRef.current.focus();\r\n                }\r\n            }\r\n            else {\r\n                handleClose(event);\r\n            }\r\n        }\r\n    }\r\n    function handleClose(event) {\r\n        event?.stopPropagation();\r\n        setTimeout(() => {\r\n            if (!props.isModalClosingControlledManually) {\r\n                setIsModalOpen(false);\r\n            }\r\n            lastFocus.current?.focus();\r\n            props.onClose && typeof props.onClose === 'function' && props.onClose();\r\n        }, 0);\r\n    }\r\n    const { ariaLabel, children, closeAriaLabel, closeButtonSize, containerStyle, containerTransition = { slideTop: true }, isBackgroundClickDisabled, isEscKeyDownDisabled, header, isCloseButtonHidden, isOpen, unmountOnExit = true, testId, ...rest } = props;\r\n    const isInverse = useIsInverse(props.isInverse);\r\n    const other = omit(['onEscKeyDown'], rest);\r\n    const theme = React.useContext(ThemeContext);\r\n    const i18n = React.useContext(I18nContext);\r\n    const CloseIconButton = (React.createElement(CloseIcon, { size: magma.iconSizes[closeButtonSize]\r\n            ? magma.iconSizes[closeButtonSize]\r\n            : magma.iconSizes.medium }));\r\n    return isModalOpen\r\n        ? ReactDOM.createPortal(React.createElement(\"div\", { ref: focusTrapElement },\r\n            React.createElement(Global, { styles: css `\n                html {\n                  overflow: ${isOpen ? 'hidden' : 'auto'};\n                }\n              ` }),\r\n            React.createElement(ModalContainer, Object.assign({ \"aria-labelledby\": header ? headingId : null, \"aria-label\": !header ? ariaLabel : null, \"aria-modal\": true, \"data-testid\": testId, id: id, modalCount: modalCount, onClick: isBackgroundClickDisabled ? null : handleModalClick, onMouseDown: isBackgroundClickDisabled ? null : handleModalOnMouseDown, role: \"dialog\", style: containerStyle, theme: theme, isOpen: isModalOpen }, containerTransition, { unmountOnExit: unmountOnExit }),\r\n                React.createElement(ModalContent, Object.assign({}, other, { \"data-testid\": \"modal-content\", id: contentId, ref: ref, theme: theme }),\r\n                    header && (React.createElement(ModalHeader, { theme: theme }, header && (React.createElement(H1, { id: headingId, isInverse: isInverse, level: 1, ref: headingRef, visualStyle: TypographyVisualStyle.headingSmall, tabIndex: -1, theme: theme }, header)))),\r\n                    React.createElement(ModalWrapper, { ref: bodyRef, theme: theme }, children),\r\n                    !isCloseButtonHidden && (React.createElement(CloseBtn, { theme: theme },\r\n                        React.createElement(IconButton, { \"aria-label\": closeAriaLabel\r\n                                ? closeAriaLabel\r\n                                : i18n.modal.closeAriaLabel, color: ButtonColor.primary, icon: CloseIconButton, isInverse: isInverse, onClick: handleClose, testId: \"modal-closebtn\", variant: ButtonVariant.link }))))),\r\n            React.createElement(ModalBackdrop, { \"data-testid\": \"modal-backdrop\", onMouseDown: isBackgroundClickDisabled\r\n                    ? event => event.preventDefault()\r\n                    : null, fade: true, isOpen: isModalOpen, style: modalCount >= 2 && { zIndex: '998' }, unmountOnExit: true, theme: theme })), document.getElementsByTagName('body')[0])\r\n        : null;\r\n});\r\n//# sourceMappingURL=Modal.js.map"]} */"));
|
|
11229
11231
|
var ModalWrapper = /*#__PURE__*/_styled("div", {
|
|
11230
11232
|
target: "e1pxemtw2",
|
|
11231
11233
|
label: "ModalWrapper"
|
|
@@ -11235,7 +11237,7 @@ var ModalWrapper = /*#__PURE__*/_styled("div", {
|
|
|
11235
11237
|
return props.theme.breakpoints.small;
|
|
11236
11238
|
}, "px){padding:", function (props) {
|
|
11237
11239
|
return props.theme.spaceScale.spacing06;
|
|
11238
|
-
}, ";}" + ( "/*# sourceMappingURL=data:application/json;charset=utf-8;base64,{"version":3,"sources":["Modal.tsx"],"names":[],"mappings":"AAoFgC","file":"Modal.tsx","sourcesContent":["import * as React from 'react';\r\nimport { Global, css } from '@emotion/react';\r\nimport styled from '@emotion/styled';\r\nimport { transparentize } from 'polished';\r\nimport ReactDOM from 'react-dom';\r\nimport { CloseIcon } from 'react-magma-icons';\r\nimport { useFocusLock } from '../../hooks/useFocusLock';\r\nimport { I18nContext } from '../../i18n';\r\nimport { useIsInverse } from '../../inverse';\r\nimport { magma } from '../../theme/magma';\r\nimport { ThemeContext } from '../../theme/ThemeContext';\r\nimport { omit, useGenerateId, usePrevious } from '../../utils';\r\nimport { ButtonColor, ButtonVariant } from '../Button';\r\nimport { Heading } from '../Heading';\r\nimport { IconButton } from '../IconButton';\r\nimport { Transition } from '../Transition';\r\nimport { TypographyVisualStyle } from '../Typography';\r\nexport var ModalSize;\r\n(function (ModalSize) {\r\n    ModalSize[\"large\"] = \"large\";\r\n    ModalSize[\"medium\"] = \"medium\";\r\n    ModalSize[\"small\"] = \"small\";\r\n})(ModalSize || (ModalSize = {}));\r\nconst ModalContainer = styled(Transition) `\n  bottom: 0;\n  left: 0;\n  overflow-y: auto;\n  padding: ${props => props.theme.spaceScale.spacing03};\n  right: 0;\n  top: 0;\n  z-index: ${props => (props.modalCount >= 2 ? '999' : '998')};\n`;\r\nconst ModalBackdrop = styled(Transition) `\n  backdrop-filter: blur(3px);\n  background: ${props => transparentize(0.4, props.theme.colors.neutral900)};\n  bottom: 0;\n  left: 0;\n  right: 0;\n  top: 0;\n  z-index: 997;\n  position: fixed;\n`;\r\nconst ModalContent = styled.div `\n  background: ${props => props.isInverse\r\n    ? props.theme.colors.primary600\r\n    : props.theme.colors.neutral100};\n  border: 1px solid;\n  border-color: ${props => props.isInverse\r\n    ? transparentize(0.5, props.theme.colors.tertiary)\r\n    : props.theme.colors.neutral};\n  border-radius: ${props => props.theme.borderRadius};\n  box-shadow: ${props => `0 2px 6px ${transparentize(0.85, props.theme.colors.neutral900)}`};\n  color: ${props => props.isInverse\r\n    ? props.theme.colors.neutral100\r\n    : props.theme.colors.neutral700};\n  margin: 0 auto;\n  position: relative;\n  z-index: 1000;\n\n  max-width: ${props => {\r\n    switch (props.size) {\r\n        case 'large':\r\n            return props.theme.modal.width.large;\r\n        case 'small':\r\n            return props.theme.modal.width.small;\r\n        default:\r\n            return props.theme.modal.width.medium;\r\n    }\r\n}};\n\n  @media (min-width: ${props => props.theme.breakpoints.small}px) {\n    margin: ${props => props.theme.spaceScale.spacing08} auto;\n  }\n`;\r\nconst ModalHeader = styled.div `\n  padding: ${props => props.theme.spaceScale.spacing05}\n    ${props => props.theme.spaceScale.spacing05} 0\n    ${props => props.theme.spaceScale.spacing05};\n  @media (min-width: ${props => props.theme.breakpoints.small}px) {\n    padding: ${props => props.theme.spaceScale.spacing06}\n      ${props => props.theme.spaceScale.spacing06} 0\n      ${props => props.theme.spaceScale.spacing06};\n  }\n`;\r\nconst ModalWrapper = styled.div `\n  padding: ${props => props.theme.spaceScale.spacing05};\n  @media (min-width: ${props => props.theme.breakpoints.small}px) {\n    padding: ${props => props.theme.spaceScale.spacing06};\n  }\n`;\r\nconst H1 = styled(Heading) `\n  font-size: ${props => props.theme.typographyVisualStyles.headingSmall.desktop.fontSize};\n  line-height: ${props => props.theme.typographyVisualStyles.headingSmall.desktop.lineHeight};\n  color: ${props => props.isInverse\r\n    ? props.theme.colors.neutral100\r\n    : props.theme.colors.neutral700};\n  margin: 0;\n  padding-right: ${props => props.theme.spaceScale.spacing10};\n  font-weight: 600;\n`;\r\nconst CloseBtn = styled.span `\n  position: absolute;\n  top: 0;\n  right: 0;\n  margin: ${props => props.theme.spaceScale.spacing02};\n`;\r\nexport const Modal = React.forwardRef((props, ref) => {\r\n    const lastFocus = React.useRef();\r\n    const headingRef = React.useRef();\r\n    const bodyRef = React.useRef();\r\n    const id = useGenerateId(props.id);\r\n    const headingId = `${id}_heading`;\r\n    const contentId = `${id}_content`;\r\n    const [isModalOpen, setIsModalOpen] = React.useState(props.isOpen);\r\n    const [isExiting, setIsExiting] = React.useState(false);\r\n    const [currentTarget, setCurrentTarget] = React.useState(null);\r\n    const [modalCount, setModalCount] = React.useState(0);\r\n    const focusTrapElement = useFocusLock(isModalOpen, headingRef, bodyRef);\r\n    const prevOpen = usePrevious(props.isOpen);\r\n    React.useEffect(() => {\r\n        if (props.isModalClosingControlledManually &&\r\n            prevOpen &&\r\n            !props.isOpen &&\r\n            isModalOpen) {\r\n            setIsModalOpen(false);\r\n        }\r\n        else if (!prevOpen && props.isOpen) {\r\n            setIsModalOpen(true);\r\n            if (props.headerRef && typeof props.headerRef === 'function') {\r\n                props.headerRef(headingRef);\r\n            }\r\n        }\r\n        else if (prevOpen && !props.isOpen && isModalOpen) {\r\n            handleClose();\r\n        }\r\n    }, [props.isOpen]);\r\n    React.useEffect(() => {\r\n        if (isModalOpen) {\r\n            lastFocus.current = document.activeElement;\r\n            const count = document.querySelectorAll('[aria-modal=\"true\"]').length;\r\n            setModalCount(count);\r\n            if (!props.isEscKeyDownDisabled) {\r\n                document.body.addEventListener('keydown', handleEscapeKeyDown, false);\r\n            }\r\n        }\r\n        return () => {\r\n            document.body.removeEventListener('keydown', handleEscapeKeyDown, false);\r\n        };\r\n    }, [isModalOpen]);\r\n    function handleModalClick(event) {\r\n        if (!document.getElementById(contentId).contains(event.target) &&\r\n            event.target === currentTarget) {\r\n            handleClose(event);\r\n        }\r\n    }\r\n    function handleModalOnMouseDown(event) {\r\n        setCurrentTarget(event.target);\r\n    }\r\n    function handleEscapeKeyDown(event) {\r\n        if (event.key === 'Escape') {\r\n            event.preventDefault();\r\n            event.stopPropagation();\r\n            props.onEscKeyDown &&\r\n                typeof props.onEscKeyDown === 'function' &&\r\n                props.onEscKeyDown(event);\r\n            //Supports nested modals\r\n            const modalsInDom = document.querySelectorAll('[aria-modal=\"true\"]').length;\r\n            if (modalCount <= 1 && modalsInDom !== 1) {\r\n                if (document.getElementById(id).contains(event.target)) {\r\n                    handleClose(event);\r\n                }\r\n                else {\r\n                    headingRef.current.focus();\r\n                }\r\n            }\r\n            else {\r\n                handleClose(event);\r\n            }\r\n        }\r\n    }\r\n    function handleClose(event) {\r\n        if (event) {\r\n            event.stopPropagation();\r\n        }\r\n        setIsExiting(true);\r\n        setTimeout(() => {\r\n            setIsExiting(false);\r\n            if (!props.isModalClosingControlledManually) {\r\n                setIsModalOpen(false);\r\n            }\r\n            if (lastFocus.current) {\r\n                lastFocus.current.focus();\r\n            }\r\n            props.onClose && typeof props.onClose === 'function' && props.onClose();\r\n        }, 300);\r\n    }\r\n    const { ariaLabel, children, closeAriaLabel, closeButtonSize, containerStyle, containerTransition = { slideTop: true }, isBackgroundClickDisabled, isEscKeyDownDisabled, header, isCloseButtonHidden, isOpen, unmountOnExit = true, testId, ...rest } = props;\r\n    const isInverse = useIsInverse(props.isInverse);\r\n    const other = omit(['onEscKeyDown'], rest);\r\n    const theme = React.useContext(ThemeContext);\r\n    const i18n = React.useContext(I18nContext);\r\n    const CloseIconButton = (React.createElement(CloseIcon, { size: magma.iconSizes[closeButtonSize]\r\n            ? magma.iconSizes[closeButtonSize]\r\n            : magma.iconSizes.medium }));\r\n    return isModalOpen\r\n        ? ReactDOM.createPortal(React.createElement(\"div\", { ref: focusTrapElement },\r\n            React.createElement(Global, { styles: css `\n                html {\n                  overflow: ${isOpen ? 'hidden' : 'auto'};\n                }\n              ` }),\r\n            React.createElement(ModalContainer, Object.assign({ \"aria-labelledby\": header ? headingId : null, \"aria-label\": !header ? ariaLabel : null, \"aria-modal\": true, \"data-testid\": testId, id: id, modalCount: modalCount, onClick: isBackgroundClickDisabled ? null : handleModalClick, onMouseDown: isBackgroundClickDisabled ? null : handleModalOnMouseDown, role: \"dialog\", style: containerStyle, theme: theme, isOpen: isModalOpen }, containerTransition, { unmountOnExit: unmountOnExit }),\r\n                React.createElement(ModalContent, Object.assign({}, other, { \"data-testid\": \"modal-content\", id: contentId, isExiting: isExiting, ref: ref, theme: theme }),\r\n                    header && (React.createElement(ModalHeader, { theme: theme }, header && (React.createElement(H1, { id: headingId, isInverse: isInverse, level: 1, ref: headingRef, visualStyle: TypographyVisualStyle.headingSmall, tabIndex: -1, theme: theme }, header)))),\r\n                    React.createElement(ModalWrapper, { ref: bodyRef, theme: theme }, children),\r\n                    !isCloseButtonHidden && (React.createElement(CloseBtn, { theme: theme },\r\n                        React.createElement(IconButton, { \"aria-label\": closeAriaLabel\r\n                                ? closeAriaLabel\r\n                                : i18n.modal.closeAriaLabel, color: ButtonColor.primary, icon: CloseIconButton, isInverse: isInverse, onClick: handleClose, testId: \"modal-closebtn\", variant: ButtonVariant.link }))))),\r\n            React.createElement(ModalBackdrop, { \"data-testid\": \"modal-backdrop\", isExiting: isExiting, onMouseDown: isBackgroundClickDisabled\r\n                    ? event => event.preventDefault()\r\n                    : null, fade: true, isOpen: isModalOpen, style: modalCount >= 2 && { zIndex: '998' }, unmountOnExit: true, theme: theme })), document.getElementsByTagName('body')[0])\r\n        : null;\r\n});\r\n//# sourceMappingURL=Modal.js.map"]} */"));
|
|
11240
|
+
}, ";}" + ( "/*# sourceMappingURL=data:application/json;charset=utf-8;base64,{"version":3,"sources":["Modal.tsx"],"names":[],"mappings":"AAoFgC","file":"Modal.tsx","sourcesContent":["import * as React from 'react';\r\nimport { css, Global } from '@emotion/react';\r\nimport styled from '@emotion/styled';\r\nimport { transparentize } from 'polished';\r\nimport ReactDOM from 'react-dom';\r\nimport { CloseIcon } from 'react-magma-icons';\r\nimport { useFocusLock } from '../../hooks/useFocusLock';\r\nimport { I18nContext } from '../../i18n';\r\nimport { useIsInverse } from '../../inverse';\r\nimport { magma } from '../../theme/magma';\r\nimport { ThemeContext } from '../../theme/ThemeContext';\r\nimport { omit, useGenerateId, usePrevious } from '../../utils';\r\nimport { ButtonColor, ButtonVariant } from '../Button';\r\nimport { Heading } from '../Heading';\r\nimport { IconButton } from '../IconButton';\r\nimport { Transition } from '../Transition';\r\nimport { TypographyVisualStyle } from '../Typography';\r\nexport var ModalSize;\r\n(function (ModalSize) {\r\n    ModalSize[\"large\"] = \"large\";\r\n    ModalSize[\"medium\"] = \"medium\";\r\n    ModalSize[\"small\"] = \"small\";\r\n})(ModalSize || (ModalSize = {}));\r\nconst ModalContainer = styled(Transition) `\n  bottom: 0;\n  left: 0;\n  overflow-y: auto;\n  padding: ${props => props.theme.spaceScale.spacing03};\n  right: 0;\n  top: 0;\n  z-index: ${props => (props.modalCount >= 2 ? '999' : '998')};\n`;\r\nconst ModalBackdrop = styled(Transition) `\n  backdrop-filter: blur(3px);\n  background: ${props => transparentize(0.4, props.theme.colors.neutral900)};\n  bottom: 0;\n  left: 0;\n  right: 0;\n  top: 0;\n  z-index: 997;\n  position: fixed;\n`;\r\nconst ModalContent = styled.div `\n  background: ${props => props.isInverse\r\n    ? props.theme.colors.primary600\r\n    : props.theme.colors.neutral100};\n  border: 1px solid;\n  border-color: ${props => props.isInverse\r\n    ? transparentize(0.5, props.theme.colors.tertiary)\r\n    : props.theme.colors.neutral};\n  border-radius: ${props => props.theme.borderRadius};\n  box-shadow: ${props => `0 2px 6px ${transparentize(0.85, props.theme.colors.neutral900)}`};\n  color: ${props => props.isInverse\r\n    ? props.theme.colors.neutral100\r\n    : props.theme.colors.neutral700};\n  margin: 0 auto;\n  position: relative;\n  z-index: 1000;\n\n  max-width: ${props => {\r\n    switch (props.size) {\r\n        case 'large':\r\n            return props.theme.modal.width.large;\r\n        case 'small':\r\n            return props.theme.modal.width.small;\r\n        default:\r\n            return props.theme.modal.width.medium;\r\n    }\r\n}};\n\n  @media (min-width: ${props => props.theme.breakpoints.small}px) {\n    margin: ${props => props.theme.spaceScale.spacing08} auto;\n  }\n`;\r\nconst ModalHeader = styled.div `\n  padding: ${props => props.theme.spaceScale.spacing05}\n    ${props => props.theme.spaceScale.spacing05} 0\n    ${props => props.theme.spaceScale.spacing05};\n  @media (min-width: ${props => props.theme.breakpoints.small}px) {\n    padding: ${props => props.theme.spaceScale.spacing06}\n      ${props => props.theme.spaceScale.spacing06} 0\n      ${props => props.theme.spaceScale.spacing06};\n  }\n`;\r\nconst ModalWrapper = styled.div `\n  padding: ${props => props.theme.spaceScale.spacing05};\n  @media (min-width: ${props => props.theme.breakpoints.small}px) {\n    padding: ${props => props.theme.spaceScale.spacing06};\n  }\n`;\r\nconst H1 = styled(Heading) `\n  font-size: ${props => props.theme.typographyVisualStyles.headingSmall.desktop.fontSize};\n  line-height: ${props => props.theme.typographyVisualStyles.headingSmall.desktop.lineHeight};\n  color: ${props => props.isInverse\r\n    ? props.theme.colors.neutral100\r\n    : props.theme.colors.neutral700};\n  margin: 0;\n  padding-right: ${props => props.theme.spaceScale.spacing10};\n  font-weight: 600;\n`;\r\nconst CloseBtn = styled.span `\n  position: absolute;\n  top: 0;\n  right: 0;\n  margin: ${props => props.theme.spaceScale.spacing02};\n`;\r\nexport const Modal = React.forwardRef((props, ref) => {\r\n    const lastFocus = React.useRef();\r\n    const headingRef = React.useRef();\r\n    const bodyRef = React.useRef();\r\n    const id = useGenerateId(props.id);\r\n    const headingId = `${id}_heading`;\r\n    const contentId = `${id}_content`;\r\n    const [isModalOpen, setIsModalOpen] = React.useState(props.isOpen);\r\n    const [currentTarget, setCurrentTarget] = React.useState(null);\r\n    const [modalCount, setModalCount] = React.useState(0);\r\n    const focusTrapElement = useFocusLock(isModalOpen, headingRef, bodyRef);\r\n    const prevOpen = usePrevious(props.isOpen);\r\n    React.useEffect(() => {\r\n        if (props.isModalClosingControlledManually &&\r\n            prevOpen &&\r\n            !props.isOpen &&\r\n            isModalOpen) {\r\n            setIsModalOpen(false);\r\n        }\r\n        else if (!prevOpen && props.isOpen) {\r\n            setIsModalOpen(true);\r\n            if (props.headerRef && typeof props.headerRef === 'function') {\r\n                props.headerRef(headingRef);\r\n            }\r\n        }\r\n        else if (prevOpen && !props.isOpen && isModalOpen) {\r\n            handleClose();\r\n        }\r\n    }, [props.isOpen]);\r\n    React.useEffect(() => {\r\n        if (isModalOpen) {\r\n            lastFocus.current = document.activeElement;\r\n            const count = document.querySelectorAll('[aria-modal=\"true\"]').length;\r\n            setModalCount(count);\r\n            if (!props.isEscKeyDownDisabled) {\r\n                document.body.addEventListener('keydown', handleEscapeKeyDown, false);\r\n            }\r\n        }\r\n        return () => {\r\n            document.body.removeEventListener('keydown', handleEscapeKeyDown, false);\r\n        };\r\n    }, [isModalOpen]);\r\n    function handleModalClick(event) {\r\n        if (!document.getElementById(contentId).contains(event.target) &&\r\n            event.target === currentTarget) {\r\n            handleClose(event);\r\n        }\r\n    }\r\n    function handleModalOnMouseDown(event) {\r\n        setCurrentTarget(event.target);\r\n    }\r\n    function handleEscapeKeyDown(event) {\r\n        if (event.key === 'Escape') {\r\n            event.preventDefault();\r\n            event.stopPropagation();\r\n            props.onEscKeyDown &&\r\n                typeof props.onEscKeyDown === 'function' &&\r\n                props.onEscKeyDown(event);\r\n            //Supports nested modals\r\n            const modalsInDom = document.querySelectorAll('[aria-modal=\"true\"]').length;\r\n            if (modalCount <= 1 && modalsInDom !== 1) {\r\n                if (document.getElementById(id).contains(event.target)) {\r\n                    handleClose(event);\r\n                }\r\n                else {\r\n                    headingRef.current.focus();\r\n                }\r\n            }\r\n            else {\r\n                handleClose(event);\r\n            }\r\n        }\r\n    }\r\n    function handleClose(event) {\r\n        event?.stopPropagation();\r\n        setTimeout(() => {\r\n            if (!props.isModalClosingControlledManually) {\r\n                setIsModalOpen(false);\r\n            }\r\n            lastFocus.current?.focus();\r\n            props.onClose && typeof props.onClose === 'function' && props.onClose();\r\n        }, 0);\r\n    }\r\n    const { ariaLabel, children, closeAriaLabel, closeButtonSize, containerStyle, containerTransition = { slideTop: true }, isBackgroundClickDisabled, isEscKeyDownDisabled, header, isCloseButtonHidden, isOpen, unmountOnExit = true, testId, ...rest } = props;\r\n    const isInverse = useIsInverse(props.isInverse);\r\n    const other = omit(['onEscKeyDown'], rest);\r\n    const theme = React.useContext(ThemeContext);\r\n    const i18n = React.useContext(I18nContext);\r\n    const CloseIconButton = (React.createElement(CloseIcon, { size: magma.iconSizes[closeButtonSize]\r\n            ? magma.iconSizes[closeButtonSize]\r\n            : magma.iconSizes.medium }));\r\n    return isModalOpen\r\n        ? ReactDOM.createPortal(React.createElement(\"div\", { ref: focusTrapElement },\r\n            React.createElement(Global, { styles: css `\n                html {\n                  overflow: ${isOpen ? 'hidden' : 'auto'};\n                }\n              ` }),\r\n            React.createElement(ModalContainer, Object.assign({ \"aria-labelledby\": header ? headingId : null, \"aria-label\": !header ? ariaLabel : null, \"aria-modal\": true, \"data-testid\": testId, id: id, modalCount: modalCount, onClick: isBackgroundClickDisabled ? null : handleModalClick, onMouseDown: isBackgroundClickDisabled ? null : handleModalOnMouseDown, role: \"dialog\", style: containerStyle, theme: theme, isOpen: isModalOpen }, containerTransition, { unmountOnExit: unmountOnExit }),\r\n                React.createElement(ModalContent, Object.assign({}, other, { \"data-testid\": \"modal-content\", id: contentId, ref: ref, theme: theme }),\r\n                    header && (React.createElement(ModalHeader, { theme: theme }, header && (React.createElement(H1, { id: headingId, isInverse: isInverse, level: 1, ref: headingRef, visualStyle: TypographyVisualStyle.headingSmall, tabIndex: -1, theme: theme }, header)))),\r\n                    React.createElement(ModalWrapper, { ref: bodyRef, theme: theme }, children),\r\n                    !isCloseButtonHidden && (React.createElement(CloseBtn, { theme: theme },\r\n                        React.createElement(IconButton, { \"aria-label\": closeAriaLabel\r\n                                ? closeAriaLabel\r\n                                : i18n.modal.closeAriaLabel, color: ButtonColor.primary, icon: CloseIconButton, isInverse: isInverse, onClick: handleClose, testId: \"modal-closebtn\", variant: ButtonVariant.link }))))),\r\n            React.createElement(ModalBackdrop, { \"data-testid\": \"modal-backdrop\", onMouseDown: isBackgroundClickDisabled\r\n                    ? event => event.preventDefault()\r\n                    : null, fade: true, isOpen: isModalOpen, style: modalCount >= 2 && { zIndex: '998' }, unmountOnExit: true, theme: theme })), document.getElementsByTagName('body')[0])\r\n        : null;\r\n});\r\n//# sourceMappingURL=Modal.js.map"]} */"));
|
|
11239
11241
|
var H1 = /*#__PURE__*/_styled(Heading, {
|
|
11240
11242
|
target: "e1pxemtw1",
|
|
11241
11243
|
label: "H1"
|
|
@@ -11247,13 +11249,13 @@ var H1 = /*#__PURE__*/_styled(Heading, {
|
|
|
11247
11249
|
return props.isInverse ? props.theme.colors.neutral100 : props.theme.colors.neutral700;
|
|
11248
11250
|
}, ";margin:0;padding-right:", function (props) {
|
|
11249
11251
|
return props.theme.spaceScale.spacing10;
|
|
11250
|
-
}, ";font-weight:600;" + ( "/*# sourceMappingURL=data:application/json;charset=utf-8;base64,{"version":3,"sources":["Modal.tsx"],"names":[],"mappings":"AA0F2B","file":"Modal.tsx","sourcesContent":["import * as React from 'react';\r\nimport { Global, css } from '@emotion/react';\r\nimport styled from '@emotion/styled';\r\nimport { transparentize } from 'polished';\r\nimport ReactDOM from 'react-dom';\r\nimport { CloseIcon } from 'react-magma-icons';\r\nimport { useFocusLock } from '../../hooks/useFocusLock';\r\nimport { I18nContext } from '../../i18n';\r\nimport { useIsInverse } from '../../inverse';\r\nimport { magma } from '../../theme/magma';\r\nimport { ThemeContext } from '../../theme/ThemeContext';\r\nimport { omit, useGenerateId, usePrevious } from '../../utils';\r\nimport { ButtonColor, ButtonVariant } from '../Button';\r\nimport { Heading } from '../Heading';\r\nimport { IconButton } from '../IconButton';\r\nimport { Transition } from '../Transition';\r\nimport { TypographyVisualStyle } from '../Typography';\r\nexport var ModalSize;\r\n(function (ModalSize) {\r\n    ModalSize[\"large\"] = \"large\";\r\n    ModalSize[\"medium\"] = \"medium\";\r\n    ModalSize[\"small\"] = \"small\";\r\n})(ModalSize || (ModalSize = {}));\r\nconst ModalContainer = styled(Transition) `\n  bottom: 0;\n  left: 0;\n  overflow-y: auto;\n  padding: ${props => props.theme.spaceScale.spacing03};\n  right: 0;\n  top: 0;\n  z-index: ${props => (props.modalCount >= 2 ? '999' : '998')};\n`;\r\nconst ModalBackdrop = styled(Transition) `\n  backdrop-filter: blur(3px);\n  background: ${props => transparentize(0.4, props.theme.colors.neutral900)};\n  bottom: 0;\n  left: 0;\n  right: 0;\n  top: 0;\n  z-index: 997;\n  position: fixed;\n`;\r\nconst ModalContent = styled.div `\n  background: ${props => props.isInverse\r\n    ? props.theme.colors.primary600\r\n    : props.theme.colors.neutral100};\n  border: 1px solid;\n  border-color: ${props => props.isInverse\r\n    ? transparentize(0.5, props.theme.colors.tertiary)\r\n    : props.theme.colors.neutral};\n  border-radius: ${props => props.theme.borderRadius};\n  box-shadow: ${props => `0 2px 6px ${transparentize(0.85, props.theme.colors.neutral900)}`};\n  color: ${props => props.isInverse\r\n    ? props.theme.colors.neutral100\r\n    : props.theme.colors.neutral700};\n  margin: 0 auto;\n  position: relative;\n  z-index: 1000;\n\n  max-width: ${props => {\r\n    switch (props.size) {\r\n        case 'large':\r\n            return props.theme.modal.width.large;\r\n        case 'small':\r\n            return props.theme.modal.width.small;\r\n        default:\r\n            return props.theme.modal.width.medium;\r\n    }\r\n}};\n\n  @media (min-width: ${props => props.theme.breakpoints.small}px) {\n    margin: ${props => props.theme.spaceScale.spacing08} auto;\n  }\n`;\r\nconst ModalHeader = styled.div `\n  padding: ${props => props.theme.spaceScale.spacing05}\n    ${props => props.theme.spaceScale.spacing05} 0\n    ${props => props.theme.spaceScale.spacing05};\n  @media (min-width: ${props => props.theme.breakpoints.small}px) {\n    padding: ${props => props.theme.spaceScale.spacing06}\n      ${props => props.theme.spaceScale.spacing06} 0\n      ${props => props.theme.spaceScale.spacing06};\n  }\n`;\r\nconst ModalWrapper = styled.div `\n  padding: ${props => props.theme.spaceScale.spacing05};\n  @media (min-width: ${props => props.theme.breakpoints.small}px) {\n    padding: ${props => props.theme.spaceScale.spacing06};\n  }\n`;\r\nconst H1 = styled(Heading) `\n  font-size: ${props => props.theme.typographyVisualStyles.headingSmall.desktop.fontSize};\n  line-height: ${props => props.theme.typographyVisualStyles.headingSmall.desktop.lineHeight};\n  color: ${props => props.isInverse\r\n    ? props.theme.colors.neutral100\r\n    : props.theme.colors.neutral700};\n  margin: 0;\n  padding-right: ${props => props.theme.spaceScale.spacing10};\n  font-weight: 600;\n`;\r\nconst CloseBtn = styled.span `\n  position: absolute;\n  top: 0;\n  right: 0;\n  margin: ${props => props.theme.spaceScale.spacing02};\n`;\r\nexport const Modal = React.forwardRef((props, ref) => {\r\n    const lastFocus = React.useRef();\r\n    const headingRef = React.useRef();\r\n    const bodyRef = React.useRef();\r\n    const id = useGenerateId(props.id);\r\n    const headingId = `${id}_heading`;\r\n    const contentId = `${id}_content`;\r\n    const [isModalOpen, setIsModalOpen] = React.useState(props.isOpen);\r\n    const [isExiting, setIsExiting] = React.useState(false);\r\n    const [currentTarget, setCurrentTarget] = React.useState(null);\r\n    const [modalCount, setModalCount] = React.useState(0);\r\n    const focusTrapElement = useFocusLock(isModalOpen, headingRef, bodyRef);\r\n    const prevOpen = usePrevious(props.isOpen);\r\n    React.useEffect(() => {\r\n        if (props.isModalClosingControlledManually &&\r\n            prevOpen &&\r\n            !props.isOpen &&\r\n            isModalOpen) {\r\n            setIsModalOpen(false);\r\n        }\r\n        else if (!prevOpen && props.isOpen) {\r\n            setIsModalOpen(true);\r\n            if (props.headerRef && typeof props.headerRef === 'function') {\r\n                props.headerRef(headingRef);\r\n            }\r\n        }\r\n        else if (prevOpen && !props.isOpen && isModalOpen) {\r\n            handleClose();\r\n        }\r\n    }, [props.isOpen]);\r\n    React.useEffect(() => {\r\n        if (isModalOpen) {\r\n            lastFocus.current = document.activeElement;\r\n            const count = document.querySelectorAll('[aria-modal=\"true\"]').length;\r\n            setModalCount(count);\r\n            if (!props.isEscKeyDownDisabled) {\r\n                document.body.addEventListener('keydown', handleEscapeKeyDown, false);\r\n            }\r\n        }\r\n        return () => {\r\n            document.body.removeEventListener('keydown', handleEscapeKeyDown, false);\r\n        };\r\n    }, [isModalOpen]);\r\n    function handleModalClick(event) {\r\n        if (!document.getElementById(contentId).contains(event.target) &&\r\n            event.target === currentTarget) {\r\n            handleClose(event);\r\n        }\r\n    }\r\n    function handleModalOnMouseDown(event) {\r\n        setCurrentTarget(event.target);\r\n    }\r\n    function handleEscapeKeyDown(event) {\r\n        if (event.key === 'Escape') {\r\n            event.preventDefault();\r\n            event.stopPropagation();\r\n            props.onEscKeyDown &&\r\n                typeof props.onEscKeyDown === 'function' &&\r\n                props.onEscKeyDown(event);\r\n            //Supports nested modals\r\n            const modalsInDom = document.querySelectorAll('[aria-modal=\"true\"]').length;\r\n            if (modalCount <= 1 && modalsInDom !== 1) {\r\n                if (document.getElementById(id).contains(event.target)) {\r\n                    handleClose(event);\r\n                }\r\n                else {\r\n                    headingRef.current.focus();\r\n                }\r\n            }\r\n            else {\r\n                handleClose(event);\r\n            }\r\n        }\r\n    }\r\n    function handleClose(event) {\r\n        if (event) {\r\n            event.stopPropagation();\r\n        }\r\n        setIsExiting(true);\r\n        setTimeout(() => {\r\n            setIsExiting(false);\r\n            if (!props.isModalClosingControlledManually) {\r\n                setIsModalOpen(false);\r\n            }\r\n            if (lastFocus.current) {\r\n                lastFocus.current.focus();\r\n            }\r\n            props.onClose && typeof props.onClose === 'function' && props.onClose();\r\n        }, 300);\r\n    }\r\n    const { ariaLabel, children, closeAriaLabel, closeButtonSize, containerStyle, containerTransition = { slideTop: true }, isBackgroundClickDisabled, isEscKeyDownDisabled, header, isCloseButtonHidden, isOpen, unmountOnExit = true, testId, ...rest } = props;\r\n    const isInverse = useIsInverse(props.isInverse);\r\n    const other = omit(['onEscKeyDown'], rest);\r\n    const theme = React.useContext(ThemeContext);\r\n    const i18n = React.useContext(I18nContext);\r\n    const CloseIconButton = (React.createElement(CloseIcon, { size: magma.iconSizes[closeButtonSize]\r\n            ? magma.iconSizes[closeButtonSize]\r\n            : magma.iconSizes.medium }));\r\n    return isModalOpen\r\n        ? ReactDOM.createPortal(React.createElement(\"div\", { ref: focusTrapElement },\r\n            React.createElement(Global, { styles: css `\n                html {\n                  overflow: ${isOpen ? 'hidden' : 'auto'};\n                }\n              ` }),\r\n            React.createElement(ModalContainer, Object.assign({ \"aria-labelledby\": header ? headingId : null, \"aria-label\": !header ? ariaLabel : null, \"aria-modal\": true, \"data-testid\": testId, id: id, modalCount: modalCount, onClick: isBackgroundClickDisabled ? null : handleModalClick, onMouseDown: isBackgroundClickDisabled ? null : handleModalOnMouseDown, role: \"dialog\", style: containerStyle, theme: theme, isOpen: isModalOpen }, containerTransition, { unmountOnExit: unmountOnExit }),\r\n                React.createElement(ModalContent, Object.assign({}, other, { \"data-testid\": \"modal-content\", id: contentId, isExiting: isExiting, ref: ref, theme: theme }),\r\n                    header && (React.createElement(ModalHeader, { theme: theme }, header && (React.createElement(H1, { id: headingId, isInverse: isInverse, level: 1, ref: headingRef, visualStyle: TypographyVisualStyle.headingSmall, tabIndex: -1, theme: theme }, header)))),\r\n                    React.createElement(ModalWrapper, { ref: bodyRef, theme: theme }, children),\r\n                    !isCloseButtonHidden && (React.createElement(CloseBtn, { theme: theme },\r\n                        React.createElement(IconButton, { \"aria-label\": closeAriaLabel\r\n                                ? closeAriaLabel\r\n                                : i18n.modal.closeAriaLabel, color: ButtonColor.primary, icon: CloseIconButton, isInverse: isInverse, onClick: handleClose, testId: \"modal-closebtn\", variant: ButtonVariant.link }))))),\r\n            React.createElement(ModalBackdrop, { \"data-testid\": \"modal-backdrop\", isExiting: isExiting, onMouseDown: isBackgroundClickDisabled\r\n                    ? event => event.preventDefault()\r\n                    : null, fade: true, isOpen: isModalOpen, style: modalCount >= 2 && { zIndex: '998' }, unmountOnExit: true, theme: theme })), document.getElementsByTagName('body')[0])\r\n        : null;\r\n});\r\n//# sourceMappingURL=Modal.js.map"]} */"));
|
|
11252
|
+
}, ";font-weight:600;" + ( "/*# sourceMappingURL=data:application/json;charset=utf-8;base64,{"version":3,"sources":["Modal.tsx"],"names":[],"mappings":"AA0F2B","file":"Modal.tsx","sourcesContent":["import * as React from 'react';\r\nimport { css, Global } from '@emotion/react';\r\nimport styled from '@emotion/styled';\r\nimport { transparentize } from 'polished';\r\nimport ReactDOM from 'react-dom';\r\nimport { CloseIcon } from 'react-magma-icons';\r\nimport { useFocusLock } from '../../hooks/useFocusLock';\r\nimport { I18nContext } from '../../i18n';\r\nimport { useIsInverse } from '../../inverse';\r\nimport { magma } from '../../theme/magma';\r\nimport { ThemeContext } from '../../theme/ThemeContext';\r\nimport { omit, useGenerateId, usePrevious } from '../../utils';\r\nimport { ButtonColor, ButtonVariant } from '../Button';\r\nimport { Heading } from '../Heading';\r\nimport { IconButton } from '../IconButton';\r\nimport { Transition } from '../Transition';\r\nimport { TypographyVisualStyle } from '../Typography';\r\nexport var ModalSize;\r\n(function (ModalSize) {\r\n    ModalSize[\"large\"] = \"large\";\r\n    ModalSize[\"medium\"] = \"medium\";\r\n    ModalSize[\"small\"] = \"small\";\r\n})(ModalSize || (ModalSize = {}));\r\nconst ModalContainer = styled(Transition) `\n  bottom: 0;\n  left: 0;\n  overflow-y: auto;\n  padding: ${props => props.theme.spaceScale.spacing03};\n  right: 0;\n  top: 0;\n  z-index: ${props => (props.modalCount >= 2 ? '999' : '998')};\n`;\r\nconst ModalBackdrop = styled(Transition) `\n  backdrop-filter: blur(3px);\n  background: ${props => transparentize(0.4, props.theme.colors.neutral900)};\n  bottom: 0;\n  left: 0;\n  right: 0;\n  top: 0;\n  z-index: 997;\n  position: fixed;\n`;\r\nconst ModalContent = styled.div `\n  background: ${props => props.isInverse\r\n    ? props.theme.colors.primary600\r\n    : props.theme.colors.neutral100};\n  border: 1px solid;\n  border-color: ${props => props.isInverse\r\n    ? transparentize(0.5, props.theme.colors.tertiary)\r\n    : props.theme.colors.neutral};\n  border-radius: ${props => props.theme.borderRadius};\n  box-shadow: ${props => `0 2px 6px ${transparentize(0.85, props.theme.colors.neutral900)}`};\n  color: ${props => props.isInverse\r\n    ? props.theme.colors.neutral100\r\n    : props.theme.colors.neutral700};\n  margin: 0 auto;\n  position: relative;\n  z-index: 1000;\n\n  max-width: ${props => {\r\n    switch (props.size) {\r\n        case 'large':\r\n            return props.theme.modal.width.large;\r\n        case 'small':\r\n            return props.theme.modal.width.small;\r\n        default:\r\n            return props.theme.modal.width.medium;\r\n    }\r\n}};\n\n  @media (min-width: ${props => props.theme.breakpoints.small}px) {\n    margin: ${props => props.theme.spaceScale.spacing08} auto;\n  }\n`;\r\nconst ModalHeader = styled.div `\n  padding: ${props => props.theme.spaceScale.spacing05}\n    ${props => props.theme.spaceScale.spacing05} 0\n    ${props => props.theme.spaceScale.spacing05};\n  @media (min-width: ${props => props.theme.breakpoints.small}px) {\n    padding: ${props => props.theme.spaceScale.spacing06}\n      ${props => props.theme.spaceScale.spacing06} 0\n      ${props => props.theme.spaceScale.spacing06};\n  }\n`;\r\nconst ModalWrapper = styled.div `\n  padding: ${props => props.theme.spaceScale.spacing05};\n  @media (min-width: ${props => props.theme.breakpoints.small}px) {\n    padding: ${props => props.theme.spaceScale.spacing06};\n  }\n`;\r\nconst H1 = styled(Heading) `\n  font-size: ${props => props.theme.typographyVisualStyles.headingSmall.desktop.fontSize};\n  line-height: ${props => props.theme.typographyVisualStyles.headingSmall.desktop.lineHeight};\n  color: ${props => props.isInverse\r\n    ? props.theme.colors.neutral100\r\n    : props.theme.colors.neutral700};\n  margin: 0;\n  padding-right: ${props => props.theme.spaceScale.spacing10};\n  font-weight: 600;\n`;\r\nconst CloseBtn = styled.span `\n  position: absolute;\n  top: 0;\n  right: 0;\n  margin: ${props => props.theme.spaceScale.spacing02};\n`;\r\nexport const Modal = React.forwardRef((props, ref) => {\r\n    const lastFocus = React.useRef();\r\n    const headingRef = React.useRef();\r\n    const bodyRef = React.useRef();\r\n    const id = useGenerateId(props.id);\r\n    const headingId = `${id}_heading`;\r\n    const contentId = `${id}_content`;\r\n    const [isModalOpen, setIsModalOpen] = React.useState(props.isOpen);\r\n    const [currentTarget, setCurrentTarget] = React.useState(null);\r\n    const [modalCount, setModalCount] = React.useState(0);\r\n    const focusTrapElement = useFocusLock(isModalOpen, headingRef, bodyRef);\r\n    const prevOpen = usePrevious(props.isOpen);\r\n    React.useEffect(() => {\r\n        if (props.isModalClosingControlledManually &&\r\n            prevOpen &&\r\n            !props.isOpen &&\r\n            isModalOpen) {\r\n            setIsModalOpen(false);\r\n        }\r\n        else if (!prevOpen && props.isOpen) {\r\n            setIsModalOpen(true);\r\n            if (props.headerRef && typeof props.headerRef === 'function') {\r\n                props.headerRef(headingRef);\r\n            }\r\n        }\r\n        else if (prevOpen && !props.isOpen && isModalOpen) {\r\n            handleClose();\r\n        }\r\n    }, [props.isOpen]);\r\n    React.useEffect(() => {\r\n        if (isModalOpen) {\r\n            lastFocus.current = document.activeElement;\r\n            const count = document.querySelectorAll('[aria-modal=\"true\"]').length;\r\n            setModalCount(count);\r\n            if (!props.isEscKeyDownDisabled) {\r\n                document.body.addEventListener('keydown', handleEscapeKeyDown, false);\r\n            }\r\n        }\r\n        return () => {\r\n            document.body.removeEventListener('keydown', handleEscapeKeyDown, false);\r\n        };\r\n    }, [isModalOpen]);\r\n    function handleModalClick(event) {\r\n        if (!document.getElementById(contentId).contains(event.target) &&\r\n            event.target === currentTarget) {\r\n            handleClose(event);\r\n        }\r\n    }\r\n    function handleModalOnMouseDown(event) {\r\n        setCurrentTarget(event.target);\r\n    }\r\n    function handleEscapeKeyDown(event) {\r\n        if (event.key === 'Escape') {\r\n            event.preventDefault();\r\n            event.stopPropagation();\r\n            props.onEscKeyDown &&\r\n                typeof props.onEscKeyDown === 'function' &&\r\n                props.onEscKeyDown(event);\r\n            //Supports nested modals\r\n            const modalsInDom = document.querySelectorAll('[aria-modal=\"true\"]').length;\r\n            if (modalCount <= 1 && modalsInDom !== 1) {\r\n                if (document.getElementById(id).contains(event.target)) {\r\n                    handleClose(event);\r\n                }\r\n                else {\r\n                    headingRef.current.focus();\r\n                }\r\n            }\r\n            else {\r\n                handleClose(event);\r\n            }\r\n        }\r\n    }\r\n    function handleClose(event) {\r\n        event?.stopPropagation();\r\n        setTimeout(() => {\r\n            if (!props.isModalClosingControlledManually) {\r\n                setIsModalOpen(false);\r\n            }\r\n            lastFocus.current?.focus();\r\n            props.onClose && typeof props.onClose === 'function' && props.onClose();\r\n        }, 0);\r\n    }\r\n    const { ariaLabel, children, closeAriaLabel, closeButtonSize, containerStyle, containerTransition = { slideTop: true }, isBackgroundClickDisabled, isEscKeyDownDisabled, header, isCloseButtonHidden, isOpen, unmountOnExit = true, testId, ...rest } = props;\r\n    const isInverse = useIsInverse(props.isInverse);\r\n    const other = omit(['onEscKeyDown'], rest);\r\n    const theme = React.useContext(ThemeContext);\r\n    const i18n = React.useContext(I18nContext);\r\n    const CloseIconButton = (React.createElement(CloseIcon, { size: magma.iconSizes[closeButtonSize]\r\n            ? magma.iconSizes[closeButtonSize]\r\n            : magma.iconSizes.medium }));\r\n    return isModalOpen\r\n        ? ReactDOM.createPortal(React.createElement(\"div\", { ref: focusTrapElement },\r\n            React.createElement(Global, { styles: css `\n                html {\n                  overflow: ${isOpen ? 'hidden' : 'auto'};\n                }\n              ` }),\r\n            React.createElement(ModalContainer, Object.assign({ \"aria-labelledby\": header ? headingId : null, \"aria-label\": !header ? ariaLabel : null, \"aria-modal\": true, \"data-testid\": testId, id: id, modalCount: modalCount, onClick: isBackgroundClickDisabled ? null : handleModalClick, onMouseDown: isBackgroundClickDisabled ? null : handleModalOnMouseDown, role: \"dialog\", style: containerStyle, theme: theme, isOpen: isModalOpen }, containerTransition, { unmountOnExit: unmountOnExit }),\r\n                React.createElement(ModalContent, Object.assign({}, other, { \"data-testid\": \"modal-content\", id: contentId, ref: ref, theme: theme }),\r\n                    header && (React.createElement(ModalHeader, { theme: theme }, header && (React.createElement(H1, { id: headingId, isInverse: isInverse, level: 1, ref: headingRef, visualStyle: TypographyVisualStyle.headingSmall, tabIndex: -1, theme: theme }, header)))),\r\n                    React.createElement(ModalWrapper, { ref: bodyRef, theme: theme }, children),\r\n                    !isCloseButtonHidden && (React.createElement(CloseBtn, { theme: theme },\r\n                        React.createElement(IconButton, { \"aria-label\": closeAriaLabel\r\n                                ? closeAriaLabel\r\n                                : i18n.modal.closeAriaLabel, color: ButtonColor.primary, icon: CloseIconButton, isInverse: isInverse, onClick: handleClose, testId: \"modal-closebtn\", variant: ButtonVariant.link }))))),\r\n            React.createElement(ModalBackdrop, { \"data-testid\": \"modal-backdrop\", onMouseDown: isBackgroundClickDisabled\r\n                    ? event => event.preventDefault()\r\n                    : null, fade: true, isOpen: isModalOpen, style: modalCount >= 2 && { zIndex: '998' }, unmountOnExit: true, theme: theme })), document.getElementsByTagName('body')[0])\r\n        : null;\r\n});\r\n//# sourceMappingURL=Modal.js.map"]} */"));
|
|
11251
11253
|
var CloseBtn = /*#__PURE__*/_styled("span", {
|
|
11252
11254
|
target: "e1pxemtw0",
|
|
11253
11255
|
label: "CloseBtn"
|
|
11254
11256
|
})("position:absolute;top:0;right:0;margin:", function (props) {
|
|
11255
11257
|
return props.theme.spaceScale.spacing02;
|
|
11256
|
-
}, ";" + ( "/*# sourceMappingURL=data:application/json;charset=utf-8;base64,{"version":3,"sources":["Modal.tsx"],"names":[],"mappings":"AAoG6B","file":"Modal.tsx","sourcesContent":["import * as React from 'react';\r\nimport { Global, css } from '@emotion/react';\r\nimport styled from '@emotion/styled';\r\nimport { transparentize } from 'polished';\r\nimport ReactDOM from 'react-dom';\r\nimport { CloseIcon } from 'react-magma-icons';\r\nimport { useFocusLock } from '../../hooks/useFocusLock';\r\nimport { I18nContext } from '../../i18n';\r\nimport { useIsInverse } from '../../inverse';\r\nimport { magma } from '../../theme/magma';\r\nimport { ThemeContext } from '../../theme/ThemeContext';\r\nimport { omit, useGenerateId, usePrevious } from '../../utils';\r\nimport { ButtonColor, ButtonVariant } from '../Button';\r\nimport { Heading } from '../Heading';\r\nimport { IconButton } from '../IconButton';\r\nimport { Transition } from '../Transition';\r\nimport { TypographyVisualStyle } from '../Typography';\r\nexport var ModalSize;\r\n(function (ModalSize) {\r\n    ModalSize[\"large\"] = \"large\";\r\n    ModalSize[\"medium\"] = \"medium\";\r\n    ModalSize[\"small\"] = \"small\";\r\n})(ModalSize || (ModalSize = {}));\r\nconst ModalContainer = styled(Transition) `\n  bottom: 0;\n  left: 0;\n  overflow-y: auto;\n  padding: ${props => props.theme.spaceScale.spacing03};\n  right: 0;\n  top: 0;\n  z-index: ${props => (props.modalCount >= 2 ? '999' : '998')};\n`;\r\nconst ModalBackdrop = styled(Transition) `\n  backdrop-filter: blur(3px);\n  background: ${props => transparentize(0.4, props.theme.colors.neutral900)};\n  bottom: 0;\n  left: 0;\n  right: 0;\n  top: 0;\n  z-index: 997;\n  position: fixed;\n`;\r\nconst ModalContent = styled.div `\n  background: ${props => props.isInverse\r\n    ? props.theme.colors.primary600\r\n    : props.theme.colors.neutral100};\n  border: 1px solid;\n  border-color: ${props => props.isInverse\r\n    ? transparentize(0.5, props.theme.colors.tertiary)\r\n    : props.theme.colors.neutral};\n  border-radius: ${props => props.theme.borderRadius};\n  box-shadow: ${props => `0 2px 6px ${transparentize(0.85, props.theme.colors.neutral900)}`};\n  color: ${props => props.isInverse\r\n    ? props.theme.colors.neutral100\r\n    : props.theme.colors.neutral700};\n  margin: 0 auto;\n  position: relative;\n  z-index: 1000;\n\n  max-width: ${props => {\r\n    switch (props.size) {\r\n        case 'large':\r\n            return props.theme.modal.width.large;\r\n        case 'small':\r\n            return props.theme.modal.width.small;\r\n        default:\r\n            return props.theme.modal.width.medium;\r\n    }\r\n}};\n\n  @media (min-width: ${props => props.theme.breakpoints.small}px) {\n    margin: ${props => props.theme.spaceScale.spacing08} auto;\n  }\n`;\r\nconst ModalHeader = styled.div `\n  padding: ${props => props.theme.spaceScale.spacing05}\n    ${props => props.theme.spaceScale.spacing05} 0\n    ${props => props.theme.spaceScale.spacing05};\n  @media (min-width: ${props => props.theme.breakpoints.small}px) {\n    padding: ${props => props.theme.spaceScale.spacing06}\n      ${props => props.theme.spaceScale.spacing06} 0\n      ${props => props.theme.spaceScale.spacing06};\n  }\n`;\r\nconst ModalWrapper = styled.div `\n  padding: ${props => props.theme.spaceScale.spacing05};\n  @media (min-width: ${props => props.theme.breakpoints.small}px) {\n    padding: ${props => props.theme.spaceScale.spacing06};\n  }\n`;\r\nconst H1 = styled(Heading) `\n  font-size: ${props => props.theme.typographyVisualStyles.headingSmall.desktop.fontSize};\n  line-height: ${props => props.theme.typographyVisualStyles.headingSmall.desktop.lineHeight};\n  color: ${props => props.isInverse\r\n    ? props.theme.colors.neutral100\r\n    : props.theme.colors.neutral700};\n  margin: 0;\n  padding-right: ${props => props.theme.spaceScale.spacing10};\n  font-weight: 600;\n`;\r\nconst CloseBtn = styled.span `\n  position: absolute;\n  top: 0;\n  right: 0;\n  margin: ${props => props.theme.spaceScale.spacing02};\n`;\r\nexport const Modal = React.forwardRef((props, ref) => {\r\n    const lastFocus = React.useRef();\r\n    const headingRef = React.useRef();\r\n    const bodyRef = React.useRef();\r\n    const id = useGenerateId(props.id);\r\n    const headingId = `${id}_heading`;\r\n    const contentId = `${id}_content`;\r\n    const [isModalOpen, setIsModalOpen] = React.useState(props.isOpen);\r\n    const [isExiting, setIsExiting] = React.useState(false);\r\n    const [currentTarget, setCurrentTarget] = React.useState(null);\r\n    const [modalCount, setModalCount] = React.useState(0);\r\n    const focusTrapElement = useFocusLock(isModalOpen, headingRef, bodyRef);\r\n    const prevOpen = usePrevious(props.isOpen);\r\n    React.useEffect(() => {\r\n        if (props.isModalClosingControlledManually &&\r\n            prevOpen &&\r\n            !props.isOpen &&\r\n            isModalOpen) {\r\n            setIsModalOpen(false);\r\n        }\r\n        else if (!prevOpen && props.isOpen) {\r\n            setIsModalOpen(true);\r\n            if (props.headerRef && typeof props.headerRef === 'function') {\r\n                props.headerRef(headingRef);\r\n            }\r\n        }\r\n        else if (prevOpen && !props.isOpen && isModalOpen) {\r\n            handleClose();\r\n        }\r\n    }, [props.isOpen]);\r\n    React.useEffect(() => {\r\n        if (isModalOpen) {\r\n            lastFocus.current = document.activeElement;\r\n            const count = document.querySelectorAll('[aria-modal=\"true\"]').length;\r\n            setModalCount(count);\r\n            if (!props.isEscKeyDownDisabled) {\r\n                document.body.addEventListener('keydown', handleEscapeKeyDown, false);\r\n            }\r\n        }\r\n        return () => {\r\n            document.body.removeEventListener('keydown', handleEscapeKeyDown, false);\r\n        };\r\n    }, [isModalOpen]);\r\n    function handleModalClick(event) {\r\n        if (!document.getElementById(contentId).contains(event.target) &&\r\n            event.target === currentTarget) {\r\n            handleClose(event);\r\n        }\r\n    }\r\n    function handleModalOnMouseDown(event) {\r\n        setCurrentTarget(event.target);\r\n    }\r\n    function handleEscapeKeyDown(event) {\r\n        if (event.key === 'Escape') {\r\n            event.preventDefault();\r\n            event.stopPropagation();\r\n            props.onEscKeyDown &&\r\n                typeof props.onEscKeyDown === 'function' &&\r\n                props.onEscKeyDown(event);\r\n            //Supports nested modals\r\n            const modalsInDom = document.querySelectorAll('[aria-modal=\"true\"]').length;\r\n            if (modalCount <= 1 && modalsInDom !== 1) {\r\n                if (document.getElementById(id).contains(event.target)) {\r\n                    handleClose(event);\r\n                }\r\n                else {\r\n                    headingRef.current.focus();\r\n                }\r\n            }\r\n            else {\r\n                handleClose(event);\r\n            }\r\n        }\r\n    }\r\n    function handleClose(event) {\r\n        if (event) {\r\n            event.stopPropagation();\r\n        }\r\n        setIsExiting(true);\r\n        setTimeout(() => {\r\n            setIsExiting(false);\r\n            if (!props.isModalClosingControlledManually) {\r\n                setIsModalOpen(false);\r\n            }\r\n            if (lastFocus.current) {\r\n                lastFocus.current.focus();\r\n            }\r\n            props.onClose && typeof props.onClose === 'function' && props.onClose();\r\n        }, 300);\r\n    }\r\n    const { ariaLabel, children, closeAriaLabel, closeButtonSize, containerStyle, containerTransition = { slideTop: true }, isBackgroundClickDisabled, isEscKeyDownDisabled, header, isCloseButtonHidden, isOpen, unmountOnExit = true, testId, ...rest } = props;\r\n    const isInverse = useIsInverse(props.isInverse);\r\n    const other = omit(['onEscKeyDown'], rest);\r\n    const theme = React.useContext(ThemeContext);\r\n    const i18n = React.useContext(I18nContext);\r\n    const CloseIconButton = (React.createElement(CloseIcon, { size: magma.iconSizes[closeButtonSize]\r\n            ? magma.iconSizes[closeButtonSize]\r\n            : magma.iconSizes.medium }));\r\n    return isModalOpen\r\n        ? ReactDOM.createPortal(React.createElement(\"div\", { ref: focusTrapElement },\r\n            React.createElement(Global, { styles: css `\n                html {\n                  overflow: ${isOpen ? 'hidden' : 'auto'};\n                }\n              ` }),\r\n            React.createElement(ModalContainer, Object.assign({ \"aria-labelledby\": header ? headingId : null, \"aria-label\": !header ? ariaLabel : null, \"aria-modal\": true, \"data-testid\": testId, id: id, modalCount: modalCount, onClick: isBackgroundClickDisabled ? null : handleModalClick, onMouseDown: isBackgroundClickDisabled ? null : handleModalOnMouseDown, role: \"dialog\", style: containerStyle, theme: theme, isOpen: isModalOpen }, containerTransition, { unmountOnExit: unmountOnExit }),\r\n                React.createElement(ModalContent, Object.assign({}, other, { \"data-testid\": \"modal-content\", id: contentId, isExiting: isExiting, ref: ref, theme: theme }),\r\n                    header && (React.createElement(ModalHeader, { theme: theme }, header && (React.createElement(H1, { id: headingId, isInverse: isInverse, level: 1, ref: headingRef, visualStyle: TypographyVisualStyle.headingSmall, tabIndex: -1, theme: theme }, header)))),\r\n                    React.createElement(ModalWrapper, { ref: bodyRef, theme: theme }, children),\r\n                    !isCloseButtonHidden && (React.createElement(CloseBtn, { theme: theme },\r\n                        React.createElement(IconButton, { \"aria-label\": closeAriaLabel\r\n                                ? closeAriaLabel\r\n                                : i18n.modal.closeAriaLabel, color: ButtonColor.primary, icon: CloseIconButton, isInverse: isInverse, onClick: handleClose, testId: \"modal-closebtn\", variant: ButtonVariant.link }))))),\r\n            React.createElement(ModalBackdrop, { \"data-testid\": \"modal-backdrop\", isExiting: isExiting, onMouseDown: isBackgroundClickDisabled\r\n                    ? event => event.preventDefault()\r\n                    : null, fade: true, isOpen: isModalOpen, style: modalCount >= 2 && { zIndex: '998' }, unmountOnExit: true, theme: theme })), document.getElementsByTagName('body')[0])\r\n        : null;\r\n});\r\n//# sourceMappingURL=Modal.js.map"]} */"));
|
|
11258
|
+
}, ";" + ( "/*# sourceMappingURL=data:application/json;charset=utf-8;base64,{"version":3,"sources":["Modal.tsx"],"names":[],"mappings":"AAoG6B","file":"Modal.tsx","sourcesContent":["import * as React from 'react';\r\nimport { css, Global } from '@emotion/react';\r\nimport styled from '@emotion/styled';\r\nimport { transparentize } from 'polished';\r\nimport ReactDOM from 'react-dom';\r\nimport { CloseIcon } from 'react-magma-icons';\r\nimport { useFocusLock } from '../../hooks/useFocusLock';\r\nimport { I18nContext } from '../../i18n';\r\nimport { useIsInverse } from '../../inverse';\r\nimport { magma } from '../../theme/magma';\r\nimport { ThemeContext } from '../../theme/ThemeContext';\r\nimport { omit, useGenerateId, usePrevious } from '../../utils';\r\nimport { ButtonColor, ButtonVariant } from '../Button';\r\nimport { Heading } from '../Heading';\r\nimport { IconButton } from '../IconButton';\r\nimport { Transition } from '../Transition';\r\nimport { TypographyVisualStyle } from '../Typography';\r\nexport var ModalSize;\r\n(function (ModalSize) {\r\n    ModalSize[\"large\"] = \"large\";\r\n    ModalSize[\"medium\"] = \"medium\";\r\n    ModalSize[\"small\"] = \"small\";\r\n})(ModalSize || (ModalSize = {}));\r\nconst ModalContainer = styled(Transition) `\n  bottom: 0;\n  left: 0;\n  overflow-y: auto;\n  padding: ${props => props.theme.spaceScale.spacing03};\n  right: 0;\n  top: 0;\n  z-index: ${props => (props.modalCount >= 2 ? '999' : '998')};\n`;\r\nconst ModalBackdrop = styled(Transition) `\n  backdrop-filter: blur(3px);\n  background: ${props => transparentize(0.4, props.theme.colors.neutral900)};\n  bottom: 0;\n  left: 0;\n  right: 0;\n  top: 0;\n  z-index: 997;\n  position: fixed;\n`;\r\nconst ModalContent = styled.div `\n  background: ${props => props.isInverse\r\n    ? props.theme.colors.primary600\r\n    : props.theme.colors.neutral100};\n  border: 1px solid;\n  border-color: ${props => props.isInverse\r\n    ? transparentize(0.5, props.theme.colors.tertiary)\r\n    : props.theme.colors.neutral};\n  border-radius: ${props => props.theme.borderRadius};\n  box-shadow: ${props => `0 2px 6px ${transparentize(0.85, props.theme.colors.neutral900)}`};\n  color: ${props => props.isInverse\r\n    ? props.theme.colors.neutral100\r\n    : props.theme.colors.neutral700};\n  margin: 0 auto;\n  position: relative;\n  z-index: 1000;\n\n  max-width: ${props => {\r\n    switch (props.size) {\r\n        case 'large':\r\n            return props.theme.modal.width.large;\r\n        case 'small':\r\n            return props.theme.modal.width.small;\r\n        default:\r\n            return props.theme.modal.width.medium;\r\n    }\r\n}};\n\n  @media (min-width: ${props => props.theme.breakpoints.small}px) {\n    margin: ${props => props.theme.spaceScale.spacing08} auto;\n  }\n`;\r\nconst ModalHeader = styled.div `\n  padding: ${props => props.theme.spaceScale.spacing05}\n    ${props => props.theme.spaceScale.spacing05} 0\n    ${props => props.theme.spaceScale.spacing05};\n  @media (min-width: ${props => props.theme.breakpoints.small}px) {\n    padding: ${props => props.theme.spaceScale.spacing06}\n      ${props => props.theme.spaceScale.spacing06} 0\n      ${props => props.theme.spaceScale.spacing06};\n  }\n`;\r\nconst ModalWrapper = styled.div `\n  padding: ${props => props.theme.spaceScale.spacing05};\n  @media (min-width: ${props => props.theme.breakpoints.small}px) {\n    padding: ${props => props.theme.spaceScale.spacing06};\n  }\n`;\r\nconst H1 = styled(Heading) `\n  font-size: ${props => props.theme.typographyVisualStyles.headingSmall.desktop.fontSize};\n  line-height: ${props => props.theme.typographyVisualStyles.headingSmall.desktop.lineHeight};\n  color: ${props => props.isInverse\r\n    ? props.theme.colors.neutral100\r\n    : props.theme.colors.neutral700};\n  margin: 0;\n  padding-right: ${props => props.theme.spaceScale.spacing10};\n  font-weight: 600;\n`;\r\nconst CloseBtn = styled.span `\n  position: absolute;\n  top: 0;\n  right: 0;\n  margin: ${props => props.theme.spaceScale.spacing02};\n`;\r\nexport const Modal = React.forwardRef((props, ref) => {\r\n    const lastFocus = React.useRef();\r\n    const headingRef = React.useRef();\r\n    const bodyRef = React.useRef();\r\n    const id = useGenerateId(props.id);\r\n    const headingId = `${id}_heading`;\r\n    const contentId = `${id}_content`;\r\n    const [isModalOpen, setIsModalOpen] = React.useState(props.isOpen);\r\n    const [currentTarget, setCurrentTarget] = React.useState(null);\r\n    const [modalCount, setModalCount] = React.useState(0);\r\n    const focusTrapElement = useFocusLock(isModalOpen, headingRef, bodyRef);\r\n    const prevOpen = usePrevious(props.isOpen);\r\n    React.useEffect(() => {\r\n        if (props.isModalClosingControlledManually &&\r\n            prevOpen &&\r\n            !props.isOpen &&\r\n            isModalOpen) {\r\n            setIsModalOpen(false);\r\n        }\r\n        else if (!prevOpen && props.isOpen) {\r\n            setIsModalOpen(true);\r\n            if (props.headerRef && typeof props.headerRef === 'function') {\r\n                props.headerRef(headingRef);\r\n            }\r\n        }\r\n        else if (prevOpen && !props.isOpen && isModalOpen) {\r\n            handleClose();\r\n        }\r\n    }, [props.isOpen]);\r\n    React.useEffect(() => {\r\n        if (isModalOpen) {\r\n            lastFocus.current = document.activeElement;\r\n            const count = document.querySelectorAll('[aria-modal=\"true\"]').length;\r\n            setModalCount(count);\r\n            if (!props.isEscKeyDownDisabled) {\r\n                document.body.addEventListener('keydown', handleEscapeKeyDown, false);\r\n            }\r\n        }\r\n        return () => {\r\n            document.body.removeEventListener('keydown', handleEscapeKeyDown, false);\r\n        };\r\n    }, [isModalOpen]);\r\n    function handleModalClick(event) {\r\n        if (!document.getElementById(contentId).contains(event.target) &&\r\n            event.target === currentTarget) {\r\n            handleClose(event);\r\n        }\r\n    }\r\n    function handleModalOnMouseDown(event) {\r\n        setCurrentTarget(event.target);\r\n    }\r\n    function handleEscapeKeyDown(event) {\r\n        if (event.key === 'Escape') {\r\n            event.preventDefault();\r\n            event.stopPropagation();\r\n            props.onEscKeyDown &&\r\n                typeof props.onEscKeyDown === 'function' &&\r\n                props.onEscKeyDown(event);\r\n            //Supports nested modals\r\n            const modalsInDom = document.querySelectorAll('[aria-modal=\"true\"]').length;\r\n            if (modalCount <= 1 && modalsInDom !== 1) {\r\n                if (document.getElementById(id).contains(event.target)) {\r\n                    handleClose(event);\r\n                }\r\n                else {\r\n                    headingRef.current.focus();\r\n                }\r\n            }\r\n            else {\r\n                handleClose(event);\r\n            }\r\n        }\r\n    }\r\n    function handleClose(event) {\r\n        event?.stopPropagation();\r\n        setTimeout(() => {\r\n            if (!props.isModalClosingControlledManually) {\r\n                setIsModalOpen(false);\r\n            }\r\n            lastFocus.current?.focus();\r\n            props.onClose && typeof props.onClose === 'function' && props.onClose();\r\n        }, 0);\r\n    }\r\n    const { ariaLabel, children, closeAriaLabel, closeButtonSize, containerStyle, containerTransition = { slideTop: true }, isBackgroundClickDisabled, isEscKeyDownDisabled, header, isCloseButtonHidden, isOpen, unmountOnExit = true, testId, ...rest } = props;\r\n    const isInverse = useIsInverse(props.isInverse);\r\n    const other = omit(['onEscKeyDown'], rest);\r\n    const theme = React.useContext(ThemeContext);\r\n    const i18n = React.useContext(I18nContext);\r\n    const CloseIconButton = (React.createElement(CloseIcon, { size: magma.iconSizes[closeButtonSize]\r\n            ? magma.iconSizes[closeButtonSize]\r\n            : magma.iconSizes.medium }));\r\n    return isModalOpen\r\n        ? ReactDOM.createPortal(React.createElement(\"div\", { ref: focusTrapElement },\r\n            React.createElement(Global, { styles: css `\n                html {\n                  overflow: ${isOpen ? 'hidden' : 'auto'};\n                }\n              ` }),\r\n            React.createElement(ModalContainer, Object.assign({ \"aria-labelledby\": header ? headingId : null, \"aria-label\": !header ? ariaLabel : null, \"aria-modal\": true, \"data-testid\": testId, id: id, modalCount: modalCount, onClick: isBackgroundClickDisabled ? null : handleModalClick, onMouseDown: isBackgroundClickDisabled ? null : handleModalOnMouseDown, role: \"dialog\", style: containerStyle, theme: theme, isOpen: isModalOpen }, containerTransition, { unmountOnExit: unmountOnExit }),\r\n                React.createElement(ModalContent, Object.assign({}, other, { \"data-testid\": \"modal-content\", id: contentId, ref: ref, theme: theme }),\r\n                    header && (React.createElement(ModalHeader, { theme: theme }, header && (React.createElement(H1, { id: headingId, isInverse: isInverse, level: 1, ref: headingRef, visualStyle: TypographyVisualStyle.headingSmall, tabIndex: -1, theme: theme }, header)))),\r\n                    React.createElement(ModalWrapper, { ref: bodyRef, theme: theme }, children),\r\n                    !isCloseButtonHidden && (React.createElement(CloseBtn, { theme: theme },\r\n                        React.createElement(IconButton, { \"aria-label\": closeAriaLabel\r\n                                ? closeAriaLabel\r\n                                : i18n.modal.closeAriaLabel, color: ButtonColor.primary, icon: CloseIconButton, isInverse: isInverse, onClick: handleClose, testId: \"modal-closebtn\", variant: ButtonVariant.link }))))),\r\n            React.createElement(ModalBackdrop, { \"data-testid\": \"modal-backdrop\", onMouseDown: isBackgroundClickDisabled\r\n                    ? event => event.preventDefault()\r\n                    : null, fade: true, isOpen: isModalOpen, style: modalCount >= 2 && { zIndex: '998' }, unmountOnExit: true, theme: theme })), document.getElementsByTagName('body')[0])\r\n        : null;\r\n});\r\n//# sourceMappingURL=Modal.js.map"]} */"));
|
|
11257
11259
|
var Modal = /*#__PURE__*/React.forwardRef(function (props, ref) {
|
|
11258
11260
|
var lastFocus = React.useRef();
|
|
11259
11261
|
var headingRef = React.useRef();
|
|
@@ -11264,15 +11266,12 @@ var Modal = /*#__PURE__*/React.forwardRef(function (props, ref) {
|
|
|
11264
11266
|
var _React$useState = React.useState(props.isOpen),
|
|
11265
11267
|
isModalOpen = _React$useState[0],
|
|
11266
11268
|
setIsModalOpen = _React$useState[1];
|
|
11267
|
-
var _React$useState2 = React.useState(
|
|
11268
|
-
|
|
11269
|
-
|
|
11270
|
-
var _React$useState3 = React.useState(
|
|
11271
|
-
|
|
11272
|
-
|
|
11273
|
-
var _React$useState4 = React.useState(0),
|
|
11274
|
-
modalCount = _React$useState4[0],
|
|
11275
|
-
setModalCount = _React$useState4[1];
|
|
11269
|
+
var _React$useState2 = React.useState(null),
|
|
11270
|
+
currentTarget = _React$useState2[0],
|
|
11271
|
+
setCurrentTarget = _React$useState2[1];
|
|
11272
|
+
var _React$useState3 = React.useState(0),
|
|
11273
|
+
modalCount = _React$useState3[0],
|
|
11274
|
+
setModalCount = _React$useState3[1];
|
|
11276
11275
|
var focusTrapElement = useFocusLock(isModalOpen, headingRef, bodyRef);
|
|
11277
11276
|
var prevOpen = usePrevious(props.isOpen);
|
|
11278
11277
|
React.useEffect(function () {
|
|
@@ -11327,20 +11326,15 @@ var Modal = /*#__PURE__*/React.forwardRef(function (props, ref) {
|
|
|
11327
11326
|
}
|
|
11328
11327
|
}
|
|
11329
11328
|
function handleClose(event) {
|
|
11330
|
-
|
|
11331
|
-
event.stopPropagation();
|
|
11332
|
-
}
|
|
11333
|
-
setIsExiting(true);
|
|
11329
|
+
event == null || event.stopPropagation();
|
|
11334
11330
|
setTimeout(function () {
|
|
11335
|
-
|
|
11331
|
+
var _lastFocus$current;
|
|
11336
11332
|
if (!props.isModalClosingControlledManually) {
|
|
11337
11333
|
setIsModalOpen(false);
|
|
11338
11334
|
}
|
|
11339
|
-
|
|
11340
|
-
lastFocus.current.focus();
|
|
11341
|
-
}
|
|
11335
|
+
(_lastFocus$current = lastFocus.current) == null || _lastFocus$current.focus();
|
|
11342
11336
|
props.onClose && typeof props.onClose === 'function' && props.onClose();
|
|
11343
|
-
},
|
|
11337
|
+
}, 0);
|
|
11344
11338
|
}
|
|
11345
11339
|
var ariaLabel = props.ariaLabel,
|
|
11346
11340
|
children = props.children,
|
|
@@ -11369,7 +11363,7 @@ var Modal = /*#__PURE__*/React.forwardRef(function (props, ref) {
|
|
|
11369
11363
|
return isModalOpen ? ReactDOM.createPortal(React.createElement("div", {
|
|
11370
11364
|
ref: focusTrapElement
|
|
11371
11365
|
}, React.createElement(react.Global, {
|
|
11372
|
-
styles: /*#__PURE__*/react.css("html{overflow:", isOpen ? 'hidden' : 'auto', ";};label:styles;" + ( "/*# sourceMappingURL=data:application/json;charset=utf-8;base64,{"version":3,"sources":["Modal.tsx"],"names":[],"mappings":"AA8MsD","file":"Modal.tsx","sourcesContent":["import * as React from 'react';\r\nimport { Global, css } from '@emotion/react';\r\nimport styled from '@emotion/styled';\r\nimport { transparentize } from 'polished';\r\nimport ReactDOM from 'react-dom';\r\nimport { CloseIcon } from 'react-magma-icons';\r\nimport { useFocusLock } from '../../hooks/useFocusLock';\r\nimport { I18nContext } from '../../i18n';\r\nimport { useIsInverse } from '../../inverse';\r\nimport { magma } from '../../theme/magma';\r\nimport { ThemeContext } from '../../theme/ThemeContext';\r\nimport { omit, useGenerateId, usePrevious } from '../../utils';\r\nimport { ButtonColor, ButtonVariant } from '../Button';\r\nimport { Heading } from '../Heading';\r\nimport { IconButton } from '../IconButton';\r\nimport { Transition } from '../Transition';\r\nimport { TypographyVisualStyle } from '../Typography';\r\nexport var ModalSize;\r\n(function (ModalSize) {\r\n    ModalSize[\"large\"] = \"large\";\r\n    ModalSize[\"medium\"] = \"medium\";\r\n    ModalSize[\"small\"] = \"small\";\r\n})(ModalSize || (ModalSize = {}));\r\nconst ModalContainer = styled(Transition) `\n  bottom: 0;\n  left: 0;\n  overflow-y: auto;\n  padding: ${props => props.theme.spaceScale.spacing03};\n  right: 0;\n  top: 0;\n  z-index: ${props => (props.modalCount >= 2 ? '999' : '998')};\n`;\r\nconst ModalBackdrop = styled(Transition) `\n  backdrop-filter: blur(3px);\n  background: ${props => transparentize(0.4, props.theme.colors.neutral900)};\n  bottom: 0;\n  left: 0;\n  right: 0;\n  top: 0;\n  z-index: 997;\n  position: fixed;\n`;\r\nconst ModalContent = styled.div `\n  background: ${props => props.isInverse\r\n    ? props.theme.colors.primary600\r\n    : props.theme.colors.neutral100};\n  border: 1px solid;\n  border-color: ${props => props.isInverse\r\n    ? transparentize(0.5, props.theme.colors.tertiary)\r\n    : props.theme.colors.neutral};\n  border-radius: ${props => props.theme.borderRadius};\n  box-shadow: ${props => `0 2px 6px ${transparentize(0.85, props.theme.colors.neutral900)}`};\n  color: ${props => props.isInverse\r\n    ? props.theme.colors.neutral100\r\n    : props.theme.colors.neutral700};\n  margin: 0 auto;\n  position: relative;\n  z-index: 1000;\n\n  max-width: ${props => {\r\n    switch (props.size) {\r\n        case 'large':\r\n            return props.theme.modal.width.large;\r\n        case 'small':\r\n            return props.theme.modal.width.small;\r\n        default:\r\n            return props.theme.modal.width.medium;\r\n    }\r\n}};\n\n  @media (min-width: ${props => props.theme.breakpoints.small}px) {\n    margin: ${props => props.theme.spaceScale.spacing08} auto;\n  }\n`;\r\nconst ModalHeader = styled.div `\n  padding: ${props => props.theme.spaceScale.spacing05}\n    ${props => props.theme.spaceScale.spacing05} 0\n    ${props => props.theme.spaceScale.spacing05};\n  @media (min-width: ${props => props.theme.breakpoints.small}px) {\n    padding: ${props => props.theme.spaceScale.spacing06}\n      ${props => props.theme.spaceScale.spacing06} 0\n      ${props => props.theme.spaceScale.spacing06};\n  }\n`;\r\nconst ModalWrapper = styled.div `\n  padding: ${props => props.theme.spaceScale.spacing05};\n  @media (min-width: ${props => props.theme.breakpoints.small}px) {\n    padding: ${props => props.theme.spaceScale.spacing06};\n  }\n`;\r\nconst H1 = styled(Heading) `\n  font-size: ${props => props.theme.typographyVisualStyles.headingSmall.desktop.fontSize};\n  line-height: ${props => props.theme.typographyVisualStyles.headingSmall.desktop.lineHeight};\n  color: ${props => props.isInverse\r\n    ? props.theme.colors.neutral100\r\n    : props.theme.colors.neutral700};\n  margin: 0;\n  padding-right: ${props => props.theme.spaceScale.spacing10};\n  font-weight: 600;\n`;\r\nconst CloseBtn = styled.span `\n  position: absolute;\n  top: 0;\n  right: 0;\n  margin: ${props => props.theme.spaceScale.spacing02};\n`;\r\nexport const Modal = React.forwardRef((props, ref) => {\r\n    const lastFocus = React.useRef();\r\n    const headingRef = React.useRef();\r\n    const bodyRef = React.useRef();\r\n    const id = useGenerateId(props.id);\r\n    const headingId = `${id}_heading`;\r\n    const contentId = `${id}_content`;\r\n    const [isModalOpen, setIsModalOpen] = React.useState(props.isOpen);\r\n    const [isExiting, setIsExiting] = React.useState(false);\r\n    const [currentTarget, setCurrentTarget] = React.useState(null);\r\n    const [modalCount, setModalCount] = React.useState(0);\r\n    const focusTrapElement = useFocusLock(isModalOpen, headingRef, bodyRef);\r\n    const prevOpen = usePrevious(props.isOpen);\r\n    React.useEffect(() => {\r\n        if (props.isModalClosingControlledManually &&\r\n            prevOpen &&\r\n            !props.isOpen &&\r\n            isModalOpen) {\r\n            setIsModalOpen(false);\r\n        }\r\n        else if (!prevOpen && props.isOpen) {\r\n            setIsModalOpen(true);\r\n            if (props.headerRef && typeof props.headerRef === 'function') {\r\n                props.headerRef(headingRef);\r\n            }\r\n        }\r\n        else if (prevOpen && !props.isOpen && isModalOpen) {\r\n            handleClose();\r\n        }\r\n    }, [props.isOpen]);\r\n    React.useEffect(() => {\r\n        if (isModalOpen) {\r\n            lastFocus.current = document.activeElement;\r\n            const count = document.querySelectorAll('[aria-modal=\"true\"]').length;\r\n            setModalCount(count);\r\n            if (!props.isEscKeyDownDisabled) {\r\n                document.body.addEventListener('keydown', handleEscapeKeyDown, false);\r\n            }\r\n        }\r\n        return () => {\r\n            document.body.removeEventListener('keydown', handleEscapeKeyDown, false);\r\n        };\r\n    }, [isModalOpen]);\r\n    function handleModalClick(event) {\r\n        if (!document.getElementById(contentId).contains(event.target) &&\r\n            event.target === currentTarget) {\r\n            handleClose(event);\r\n        }\r\n    }\r\n    function handleModalOnMouseDown(event) {\r\n        setCurrentTarget(event.target);\r\n    }\r\n    function handleEscapeKeyDown(event) {\r\n        if (event.key === 'Escape') {\r\n            event.preventDefault();\r\n            event.stopPropagation();\r\n            props.onEscKeyDown &&\r\n                typeof props.onEscKeyDown === 'function' &&\r\n                props.onEscKeyDown(event);\r\n            //Supports nested modals\r\n            const modalsInDom = document.querySelectorAll('[aria-modal=\"true\"]').length;\r\n            if (modalCount <= 1 && modalsInDom !== 1) {\r\n                if (document.getElementById(id).contains(event.target)) {\r\n                    handleClose(event);\r\n                }\r\n                else {\r\n                    headingRef.current.focus();\r\n                }\r\n            }\r\n            else {\r\n                handleClose(event);\r\n            }\r\n        }\r\n    }\r\n    function handleClose(event) {\r\n        if (event) {\r\n            event.stopPropagation();\r\n        }\r\n        setIsExiting(true);\r\n        setTimeout(() => {\r\n            setIsExiting(false);\r\n            if (!props.isModalClosingControlledManually) {\r\n                setIsModalOpen(false);\r\n            }\r\n            if (lastFocus.current) {\r\n                lastFocus.current.focus();\r\n            }\r\n            props.onClose && typeof props.onClose === 'function' && props.onClose();\r\n        }, 300);\r\n    }\r\n    const { ariaLabel, children, closeAriaLabel, closeButtonSize, containerStyle, containerTransition = { slideTop: true }, isBackgroundClickDisabled, isEscKeyDownDisabled, header, isCloseButtonHidden, isOpen, unmountOnExit = true, testId, ...rest } = props;\r\n    const isInverse = useIsInverse(props.isInverse);\r\n    const other = omit(['onEscKeyDown'], rest);\r\n    const theme = React.useContext(ThemeContext);\r\n    const i18n = React.useContext(I18nContext);\r\n    const CloseIconButton = (React.createElement(CloseIcon, { size: magma.iconSizes[closeButtonSize]\r\n            ? magma.iconSizes[closeButtonSize]\r\n            : magma.iconSizes.medium }));\r\n    return isModalOpen\r\n        ? ReactDOM.createPortal(React.createElement(\"div\", { ref: focusTrapElement },\r\n            React.createElement(Global, { styles: css `\n                html {\n                  overflow: ${isOpen ? 'hidden' : 'auto'};\n                }\n              ` }),\r\n            React.createElement(ModalContainer, Object.assign({ \"aria-labelledby\": header ? headingId : null, \"aria-label\": !header ? ariaLabel : null, \"aria-modal\": true, \"data-testid\": testId, id: id, modalCount: modalCount, onClick: isBackgroundClickDisabled ? null : handleModalClick, onMouseDown: isBackgroundClickDisabled ? null : handleModalOnMouseDown, role: \"dialog\", style: containerStyle, theme: theme, isOpen: isModalOpen }, containerTransition, { unmountOnExit: unmountOnExit }),\r\n                React.createElement(ModalContent, Object.assign({}, other, { \"data-testid\": \"modal-content\", id: contentId, isExiting: isExiting, ref: ref, theme: theme }),\r\n                    header && (React.createElement(ModalHeader, { theme: theme }, header && (React.createElement(H1, { id: headingId, isInverse: isInverse, level: 1, ref: headingRef, visualStyle: TypographyVisualStyle.headingSmall, tabIndex: -1, theme: theme }, header)))),\r\n                    React.createElement(ModalWrapper, { ref: bodyRef, theme: theme }, children),\r\n                    !isCloseButtonHidden && (React.createElement(CloseBtn, { theme: theme },\r\n                        React.createElement(IconButton, { \"aria-label\": closeAriaLabel\r\n                                ? closeAriaLabel\r\n                                : i18n.modal.closeAriaLabel, color: ButtonColor.primary, icon: CloseIconButton, isInverse: isInverse, onClick: handleClose, testId: \"modal-closebtn\", variant: ButtonVariant.link }))))),\r\n            React.createElement(ModalBackdrop, { \"data-testid\": \"modal-backdrop\", isExiting: isExiting, onMouseDown: isBackgroundClickDisabled\r\n                    ? event => event.preventDefault()\r\n                    : null, fade: true, isOpen: isModalOpen, style: modalCount >= 2 && { zIndex: '998' }, unmountOnExit: true, theme: theme })), document.getElementsByTagName('body')[0])\r\n        : null;\r\n});\r\n//# sourceMappingURL=Modal.js.map"]} */"))
|
|
11366
|
+
styles: /*#__PURE__*/react.css("html{overflow:", isOpen ? 'hidden' : 'auto', ";};label:styles;" + ( "/*# sourceMappingURL=data:application/json;charset=utf-8;base64,{"version":3,"sources":["Modal.tsx"],"names":[],"mappings":"AAuMsD","file":"Modal.tsx","sourcesContent":["import * as React from 'react';\r\nimport { css, Global } from '@emotion/react';\r\nimport styled from '@emotion/styled';\r\nimport { transparentize } from 'polished';\r\nimport ReactDOM from 'react-dom';\r\nimport { CloseIcon } from 'react-magma-icons';\r\nimport { useFocusLock } from '../../hooks/useFocusLock';\r\nimport { I18nContext } from '../../i18n';\r\nimport { useIsInverse } from '../../inverse';\r\nimport { magma } from '../../theme/magma';\r\nimport { ThemeContext } from '../../theme/ThemeContext';\r\nimport { omit, useGenerateId, usePrevious } from '../../utils';\r\nimport { ButtonColor, ButtonVariant } from '../Button';\r\nimport { Heading } from '../Heading';\r\nimport { IconButton } from '../IconButton';\r\nimport { Transition } from '../Transition';\r\nimport { TypographyVisualStyle } from '../Typography';\r\nexport var ModalSize;\r\n(function (ModalSize) {\r\n    ModalSize[\"large\"] = \"large\";\r\n    ModalSize[\"medium\"] = \"medium\";\r\n    ModalSize[\"small\"] = \"small\";\r\n})(ModalSize || (ModalSize = {}));\r\nconst ModalContainer = styled(Transition) `\n  bottom: 0;\n  left: 0;\n  overflow-y: auto;\n  padding: ${props => props.theme.spaceScale.spacing03};\n  right: 0;\n  top: 0;\n  z-index: ${props => (props.modalCount >= 2 ? '999' : '998')};\n`;\r\nconst ModalBackdrop = styled(Transition) `\n  backdrop-filter: blur(3px);\n  background: ${props => transparentize(0.4, props.theme.colors.neutral900)};\n  bottom: 0;\n  left: 0;\n  right: 0;\n  top: 0;\n  z-index: 997;\n  position: fixed;\n`;\r\nconst ModalContent = styled.div `\n  background: ${props => props.isInverse\r\n    ? props.theme.colors.primary600\r\n    : props.theme.colors.neutral100};\n  border: 1px solid;\n  border-color: ${props => props.isInverse\r\n    ? transparentize(0.5, props.theme.colors.tertiary)\r\n    : props.theme.colors.neutral};\n  border-radius: ${props => props.theme.borderRadius};\n  box-shadow: ${props => `0 2px 6px ${transparentize(0.85, props.theme.colors.neutral900)}`};\n  color: ${props => props.isInverse\r\n    ? props.theme.colors.neutral100\r\n    : props.theme.colors.neutral700};\n  margin: 0 auto;\n  position: relative;\n  z-index: 1000;\n\n  max-width: ${props => {\r\n    switch (props.size) {\r\n        case 'large':\r\n            return props.theme.modal.width.large;\r\n        case 'small':\r\n            return props.theme.modal.width.small;\r\n        default:\r\n            return props.theme.modal.width.medium;\r\n    }\r\n}};\n\n  @media (min-width: ${props => props.theme.breakpoints.small}px) {\n    margin: ${props => props.theme.spaceScale.spacing08} auto;\n  }\n`;\r\nconst ModalHeader = styled.div `\n  padding: ${props => props.theme.spaceScale.spacing05}\n    ${props => props.theme.spaceScale.spacing05} 0\n    ${props => props.theme.spaceScale.spacing05};\n  @media (min-width: ${props => props.theme.breakpoints.small}px) {\n    padding: ${props => props.theme.spaceScale.spacing06}\n      ${props => props.theme.spaceScale.spacing06} 0\n      ${props => props.theme.spaceScale.spacing06};\n  }\n`;\r\nconst ModalWrapper = styled.div `\n  padding: ${props => props.theme.spaceScale.spacing05};\n  @media (min-width: ${props => props.theme.breakpoints.small}px) {\n    padding: ${props => props.theme.spaceScale.spacing06};\n  }\n`;\r\nconst H1 = styled(Heading) `\n  font-size: ${props => props.theme.typographyVisualStyles.headingSmall.desktop.fontSize};\n  line-height: ${props => props.theme.typographyVisualStyles.headingSmall.desktop.lineHeight};\n  color: ${props => props.isInverse\r\n    ? props.theme.colors.neutral100\r\n    : props.theme.colors.neutral700};\n  margin: 0;\n  padding-right: ${props => props.theme.spaceScale.spacing10};\n  font-weight: 600;\n`;\r\nconst CloseBtn = styled.span `\n  position: absolute;\n  top: 0;\n  right: 0;\n  margin: ${props => props.theme.spaceScale.spacing02};\n`;\r\nexport const Modal = React.forwardRef((props, ref) => {\r\n    const lastFocus = React.useRef();\r\n    const headingRef = React.useRef();\r\n    const bodyRef = React.useRef();\r\n    const id = useGenerateId(props.id);\r\n    const headingId = `${id}_heading`;\r\n    const contentId = `${id}_content`;\r\n    const [isModalOpen, setIsModalOpen] = React.useState(props.isOpen);\r\n    const [currentTarget, setCurrentTarget] = React.useState(null);\r\n    const [modalCount, setModalCount] = React.useState(0);\r\n    const focusTrapElement = useFocusLock(isModalOpen, headingRef, bodyRef);\r\n    const prevOpen = usePrevious(props.isOpen);\r\n    React.useEffect(() => {\r\n        if (props.isModalClosingControlledManually &&\r\n            prevOpen &&\r\n            !props.isOpen &&\r\n            isModalOpen) {\r\n            setIsModalOpen(false);\r\n        }\r\n        else if (!prevOpen && props.isOpen) {\r\n            setIsModalOpen(true);\r\n            if (props.headerRef && typeof props.headerRef === 'function') {\r\n                props.headerRef(headingRef);\r\n            }\r\n        }\r\n        else if (prevOpen && !props.isOpen && isModalOpen) {\r\n            handleClose();\r\n        }\r\n    }, [props.isOpen]);\r\n    React.useEffect(() => {\r\n        if (isModalOpen) {\r\n            lastFocus.current = document.activeElement;\r\n            const count = document.querySelectorAll('[aria-modal=\"true\"]').length;\r\n            setModalCount(count);\r\n            if (!props.isEscKeyDownDisabled) {\r\n                document.body.addEventListener('keydown', handleEscapeKeyDown, false);\r\n            }\r\n        }\r\n        return () => {\r\n            document.body.removeEventListener('keydown', handleEscapeKeyDown, false);\r\n        };\r\n    }, [isModalOpen]);\r\n    function handleModalClick(event) {\r\n        if (!document.getElementById(contentId).contains(event.target) &&\r\n            event.target === currentTarget) {\r\n            handleClose(event);\r\n        }\r\n    }\r\n    function handleModalOnMouseDown(event) {\r\n        setCurrentTarget(event.target);\r\n    }\r\n    function handleEscapeKeyDown(event) {\r\n        if (event.key === 'Escape') {\r\n            event.preventDefault();\r\n            event.stopPropagation();\r\n            props.onEscKeyDown &&\r\n                typeof props.onEscKeyDown === 'function' &&\r\n                props.onEscKeyDown(event);\r\n            //Supports nested modals\r\n            const modalsInDom = document.querySelectorAll('[aria-modal=\"true\"]').length;\r\n            if (modalCount <= 1 && modalsInDom !== 1) {\r\n                if (document.getElementById(id).contains(event.target)) {\r\n                    handleClose(event);\r\n                }\r\n                else {\r\n                    headingRef.current.focus();\r\n                }\r\n            }\r\n            else {\r\n                handleClose(event);\r\n            }\r\n        }\r\n    }\r\n    function handleClose(event) {\r\n        event?.stopPropagation();\r\n        setTimeout(() => {\r\n            if (!props.isModalClosingControlledManually) {\r\n                setIsModalOpen(false);\r\n            }\r\n            lastFocus.current?.focus();\r\n            props.onClose && typeof props.onClose === 'function' && props.onClose();\r\n        }, 0);\r\n    }\r\n    const { ariaLabel, children, closeAriaLabel, closeButtonSize, containerStyle, containerTransition = { slideTop: true }, isBackgroundClickDisabled, isEscKeyDownDisabled, header, isCloseButtonHidden, isOpen, unmountOnExit = true, testId, ...rest } = props;\r\n    const isInverse = useIsInverse(props.isInverse);\r\n    const other = omit(['onEscKeyDown'], rest);\r\n    const theme = React.useContext(ThemeContext);\r\n    const i18n = React.useContext(I18nContext);\r\n    const CloseIconButton = (React.createElement(CloseIcon, { size: magma.iconSizes[closeButtonSize]\r\n            ? magma.iconSizes[closeButtonSize]\r\n            : magma.iconSizes.medium }));\r\n    return isModalOpen\r\n        ? ReactDOM.createPortal(React.createElement(\"div\", { ref: focusTrapElement },\r\n            React.createElement(Global, { styles: css `\n                html {\n                  overflow: ${isOpen ? 'hidden' : 'auto'};\n                }\n              ` }),\r\n            React.createElement(ModalContainer, Object.assign({ \"aria-labelledby\": header ? headingId : null, \"aria-label\": !header ? ariaLabel : null, \"aria-modal\": true, \"data-testid\": testId, id: id, modalCount: modalCount, onClick: isBackgroundClickDisabled ? null : handleModalClick, onMouseDown: isBackgroundClickDisabled ? null : handleModalOnMouseDown, role: \"dialog\", style: containerStyle, theme: theme, isOpen: isModalOpen }, containerTransition, { unmountOnExit: unmountOnExit }),\r\n                React.createElement(ModalContent, Object.assign({}, other, { \"data-testid\": \"modal-content\", id: contentId, ref: ref, theme: theme }),\r\n                    header && (React.createElement(ModalHeader, { theme: theme }, header && (React.createElement(H1, { id: headingId, isInverse: isInverse, level: 1, ref: headingRef, visualStyle: TypographyVisualStyle.headingSmall, tabIndex: -1, theme: theme }, header)))),\r\n                    React.createElement(ModalWrapper, { ref: bodyRef, theme: theme }, children),\r\n                    !isCloseButtonHidden && (React.createElement(CloseBtn, { theme: theme },\r\n                        React.createElement(IconButton, { \"aria-label\": closeAriaLabel\r\n                                ? closeAriaLabel\r\n                                : i18n.modal.closeAriaLabel, color: ButtonColor.primary, icon: CloseIconButton, isInverse: isInverse, onClick: handleClose, testId: \"modal-closebtn\", variant: ButtonVariant.link }))))),\r\n            React.createElement(ModalBackdrop, { \"data-testid\": \"modal-backdrop\", onMouseDown: isBackgroundClickDisabled\r\n                    ? event => event.preventDefault()\r\n                    : null, fade: true, isOpen: isModalOpen, style: modalCount >= 2 && { zIndex: '998' }, unmountOnExit: true, theme: theme })), document.getElementsByTagName('body')[0])\r\n        : null;\r\n});\r\n//# sourceMappingURL=Modal.js.map"]} */"))
|
|
11373
11367
|
}), React.createElement(ModalContainer, Object.assign({
|
|
11374
11368
|
"aria-labelledby": header ? headingId : null,
|
|
11375
11369
|
"aria-label": !header ? ariaLabel : null,
|
|
@@ -11388,7 +11382,6 @@ var Modal = /*#__PURE__*/React.forwardRef(function (props, ref) {
|
|
|
11388
11382
|
}), React.createElement(ModalContent, Object.assign({}, other, {
|
|
11389
11383
|
"data-testid": "modal-content",
|
|
11390
11384
|
id: contentId,
|
|
11391
|
-
isExiting: isExiting,
|
|
11392
11385
|
ref: ref,
|
|
11393
11386
|
theme: theme
|
|
11394
11387
|
}), header && React.createElement(ModalHeader, {
|
|
@@ -11416,7 +11409,6 @@ var Modal = /*#__PURE__*/React.forwardRef(function (props, ref) {
|
|
|
11416
11409
|
variant: exports.ButtonVariant.link
|
|
11417
11410
|
})))), React.createElement(ModalBackdrop, {
|
|
11418
11411
|
"data-testid": "modal-backdrop",
|
|
11419
|
-
isExiting: isExiting,
|
|
11420
11412
|
onMouseDown: isBackgroundClickDisabled ? function (event) {
|
|
11421
11413
|
return event.preventDefault();
|
|
11422
11414
|
} : null,
|
|
@@ -12293,7 +12285,7 @@ var ComboBoxContainer = /*#__PURE__*/_styled("div", {
|
|
|
12293
12285
|
})( {
|
|
12294
12286
|
name: "zjik7",
|
|
12295
12287
|
styles: "display:flex",
|
|
12296
|
-
map: "/*# sourceMappingURL=data:application/json;charset=utf-8;base64,eyJ2ZXJzaW9uIjozLCJzb3VyY2VzIjpbIkNvbWJvYm94SW5wdXQudHN4Il0sIm5hbWVzIjpbXSwibWFwcGluZ3MiOiJBQVFxQyIsImZpbGUiOiJDb21ib2JveElucHV0LnRzeCIsInNvdXJjZXNDb250ZW50IjpbImltcG9ydCBSZWFjdCBmcm9tICdyZWFjdCc7XHJcbmltcG9ydCB7IGNzcyB9IGZyb20gJ0BlbW90aW9uL3JlYWN0JztcclxuaW1wb3J0IHN0eWxlZCBmcm9tICdAZW1vdGlvbi9zdHlsZWQnO1xyXG5pbXBvcnQgeyB0cmFuc3BhcmVudGl6ZSB9IGZyb20gJ3BvbGlzaGVkJztcclxuaW1wb3J0IHsgVGhlbWVDb250ZXh0IH0gZnJvbSAnLi4vLi4vdGhlbWUvVGhlbWVDb250ZXh0JztcclxuaW1wb3J0IHsgaW5wdXRCYXNlU3R5bGVzIH0gZnJvbSAnLi4vSW5wdXRCYXNlJztcclxuaW1wb3J0IHsgZGVmYXVsdENvbXBvbmVudHMgfSBmcm9tICcuLi9TZWxlY3QvY29tcG9uZW50cyc7XHJcbmltcG9ydCB7IFNlbGVjdGVkSXRlbXNXcmFwcGVyIH0gZnJvbSAnLi4vU2VsZWN0L3NoYXJlZCc7XHJcbmNvbnN0IENvbWJvQm94Q29udGFpbmVyID0gc3R5bGVkLmRpdiBgXG4gIGRpc3BsYXk6IGZsZXg7XG5gO1xyXG5jb25zdCBJbnB1dENvbnRhaW5lciA9IHN0eWxlZC5kaXYgYFxuICBhbGlnbi1pdGVtczogY2VudGVyO1xuICBiYWNrZ3JvdW5kLWNvbG9yOiAke3Byb3BzID0+IHByb3BzLmlzSW52ZXJzZVxyXG4gICAgPyB0cmFuc3BhcmVudGl6ZSgwLjgsIHByb3BzLnRoZW1lLmNvbG9ycy5uZXV0cmFsOTAwKVxyXG4gICAgOiBwcm9wcy50aGVtZS5jb2xvcnMubmV1dHJhbDEwMH07XG4gIGJvcmRlcjogMXB4IHNvbGlkO1xuICBib3JkZXItY29sb3I6ICR7cHJvcHMgPT4gcHJvcHMuaXNJbnZlcnNlXHJcbiAgICA/IHRyYW5zcGFyZW50aXplKDAuNSwgcHJvcHMudGhlbWUuY29sb3JzLm5ldXRyYWwxMDApXHJcbiAgICA6IHByb3BzLnRoZW1lLmNvbG9ycy5uZXV0cmFsNTAwfTtcbiAgYm9yZGVyLXJhZGl1czogJHtwcm9wcyA9PiBwcm9wcy50aGVtZS5ib3JkZXJSYWRpdXN9O1xuICBkaXNwbGF5OiBmbGV4O1xuICBtaW4taGVpZ2h0OiAke3Byb3BzID0+IHByb3BzLnRoZW1lLnNwYWNlU2NhbGUuc3BhY2luZzA5fTtcbiAgbWluLXdpZHRoOiAke3Byb3BzID0+IHByb3BzLnRoZW1lLnNwYWNlU2NhbGUuc3BhY2luZzEzfTtcbiAgcGFkZGluZzogMCAke3Byb3BzID0+IHByb3BzLnRoZW1lLnNwYWNlU2NhbGUuc3BhY2luZzAzfSAwIDA7XG4gIHdpZHRoOiAxMDAlO1xuXG4gICR7cHJvcHMgPT4gcHJvcHMuaXNGb2N1c2VkICYmXHJcbiAgICBjc3MgYFxuICAgICAgb3V0bGluZTogMnB4IHNvbGlkXG4gICAgICAgICR7cHJvcHMuaXNJbnZlcnNlXHJcbiAgICAgICAgPyBwcm9wcy50aGVtZS5jb2xvcnMuZm9jdXNJbnZlcnNlXHJcbiAgICAgICAgOiBwcm9wcy50aGVtZS5jb2xvcnMuZm9jdXN9O1xuICAgICAgb3V0bGluZS1vZmZzZXQ6IC0xcHg7XG4gICAgYH1cblxuICAke3Byb3BzID0+IHByb3BzLmhhc0Vycm9yICYmXHJcbiAgICBjc3MgYFxuICAgICAgYm9yZGVyLWNvbG9yOiAke3Byb3BzLmlzSW52ZXJzZVxyXG4gICAgICAgID8gcHJvcHMudGhlbWUuY29sb3JzLmRhbmdlcjIwMFxyXG4gICAgICAgIDogcHJvcHMudGhlbWUuY29sb3JzLmRhbmdlcn07XG4gICAgYH1cblxuICAgICR7cHJvcHMgPT4gcHJvcHMuZGlzYWJsZWQgJiZcclxuICAgIGNzcyBgXG4gICAgICBiYWNrZ3JvdW5kOiAke3Byb3BzLmlzSW52ZXJzZVxyXG4gICAgICAgID8gdHJhbnNwYXJlbnRpemUoMC45LCBwcm9wcy50aGVtZS5jb2xvcnMubmV1dHJhbDkwMClcclxuICAgICAgICA6IHByb3BzLnRoZW1lLmNvbG9ycy5uZXV0cmFsMjAwfTtcbiAgICAgIGJvcmRlci1jb2xvcjogJHtwcm9wcy5pc0ludmVyc2VcclxuICAgICAgICA/
|
|
12288
|
+
map: "/*# sourceMappingURL=data:application/json;charset=utf-8;base64,eyJ2ZXJzaW9uIjozLCJzb3VyY2VzIjpbIkNvbWJvYm94SW5wdXQudHN4Il0sIm5hbWVzIjpbXSwibWFwcGluZ3MiOiJBQVFxQyIsImZpbGUiOiJDb21ib2JveElucHV0LnRzeCIsInNvdXJjZXNDb250ZW50IjpbImltcG9ydCBSZWFjdCBmcm9tICdyZWFjdCc7XHJcbmltcG9ydCB7IGNzcyB9IGZyb20gJ0BlbW90aW9uL3JlYWN0JztcclxuaW1wb3J0IHN0eWxlZCBmcm9tICdAZW1vdGlvbi9zdHlsZWQnO1xyXG5pbXBvcnQgeyB0cmFuc3BhcmVudGl6ZSB9IGZyb20gJ3BvbGlzaGVkJztcclxuaW1wb3J0IHsgVGhlbWVDb250ZXh0IH0gZnJvbSAnLi4vLi4vdGhlbWUvVGhlbWVDb250ZXh0JztcclxuaW1wb3J0IHsgaW5wdXRCYXNlU3R5bGVzIH0gZnJvbSAnLi4vSW5wdXRCYXNlJztcclxuaW1wb3J0IHsgZGVmYXVsdENvbXBvbmVudHMgfSBmcm9tICcuLi9TZWxlY3QvY29tcG9uZW50cyc7XHJcbmltcG9ydCB7IFNlbGVjdGVkSXRlbXNXcmFwcGVyIH0gZnJvbSAnLi4vU2VsZWN0L3NoYXJlZCc7XHJcbmNvbnN0IENvbWJvQm94Q29udGFpbmVyID0gc3R5bGVkLmRpdiBgXG4gIGRpc3BsYXk6IGZsZXg7XG5gO1xyXG5jb25zdCBJbnB1dENvbnRhaW5lciA9IHN0eWxlZC5kaXYgYFxuICBhbGlnbi1pdGVtczogY2VudGVyO1xuICBiYWNrZ3JvdW5kLWNvbG9yOiAke3Byb3BzID0+IHByb3BzLmlzSW52ZXJzZVxyXG4gICAgPyB0cmFuc3BhcmVudGl6ZSgwLjgsIHByb3BzLnRoZW1lLmNvbG9ycy5uZXV0cmFsOTAwKVxyXG4gICAgOiBwcm9wcy50aGVtZS5jb2xvcnMubmV1dHJhbDEwMH07XG4gIGJvcmRlcjogMXB4IHNvbGlkO1xuICBib3JkZXItY29sb3I6ICR7cHJvcHMgPT4gcHJvcHMuaXNJbnZlcnNlXHJcbiAgICA/IHRyYW5zcGFyZW50aXplKDAuNSwgcHJvcHMudGhlbWUuY29sb3JzLm5ldXRyYWwxMDApXHJcbiAgICA6IHByb3BzLnRoZW1lLmNvbG9ycy5uZXV0cmFsNTAwfTtcbiAgYm9yZGVyLXJhZGl1czogJHtwcm9wcyA9PiBwcm9wcy50aGVtZS5ib3JkZXJSYWRpdXN9O1xuICBkaXNwbGF5OiBmbGV4O1xuICBtaW4taGVpZ2h0OiAke3Byb3BzID0+IHByb3BzLnRoZW1lLnNwYWNlU2NhbGUuc3BhY2luZzA5fTtcbiAgbWluLXdpZHRoOiAke3Byb3BzID0+IHByb3BzLnRoZW1lLnNwYWNlU2NhbGUuc3BhY2luZzEzfTtcbiAgcGFkZGluZzogMCAke3Byb3BzID0+IHByb3BzLnRoZW1lLnNwYWNlU2NhbGUuc3BhY2luZzAzfSAwIDA7XG4gIHdpZHRoOiAxMDAlO1xuXG4gICR7cHJvcHMgPT4gcHJvcHMuaXNGb2N1c2VkICYmXHJcbiAgICBjc3MgYFxuICAgICAgb3V0bGluZTogMnB4IHNvbGlkXG4gICAgICAgICR7cHJvcHMuaXNJbnZlcnNlXHJcbiAgICAgICAgPyBwcm9wcy50aGVtZS5jb2xvcnMuZm9jdXNJbnZlcnNlXHJcbiAgICAgICAgOiBwcm9wcy50aGVtZS5jb2xvcnMuZm9jdXN9O1xuICAgICAgb3V0bGluZS1vZmZzZXQ6IC0xcHg7XG4gICAgYH1cblxuICAke3Byb3BzID0+IHByb3BzLmhhc0Vycm9yICYmXHJcbiAgICBjc3MgYFxuICAgICAgYm9yZGVyLWNvbG9yOiAke3Byb3BzLmlzSW52ZXJzZVxyXG4gICAgICAgID8gcHJvcHMudGhlbWUuY29sb3JzLmRhbmdlcjIwMFxyXG4gICAgICAgIDogcHJvcHMudGhlbWUuY29sb3JzLmRhbmdlcn07XG4gICAgYH1cblxuICAgICR7cHJvcHMgPT4gcHJvcHMuZGlzYWJsZWQgJiZcclxuICAgIGNzcyBgXG4gICAgICBiYWNrZ3JvdW5kOiAke3Byb3BzLmlzSW52ZXJzZVxyXG4gICAgICAgID8gdHJhbnNwYXJlbnRpemUoMC45LCBwcm9wcy50aGVtZS5jb2xvcnMubmV1dHJhbDkwMClcclxuICAgICAgICA6IHByb3BzLnRoZW1lLmNvbG9ycy5uZXV0cmFsMjAwfTtcbiAgICAgIGJvcmRlci1jb2xvcjogJHtwcm9wcy5pc0ludmVyc2VcclxuICAgICAgICA/IHRyYW5zcGFyZW50aXplKDAuODUsIHByb3BzLnRoZW1lLmNvbG9ycy5uZXV0cmFsMTAwKVxyXG4gICAgICAgIDogcHJvcHMudGhlbWUuY29sb3JzLm5ldXRyYWwzMDB9O1xuICAgICAgY29sb3I6ICR7dHJhbnNwYXJlbnRpemUoMC40LCBwcm9wcy50aGVtZS5jb2xvcnMubmV1dHJhbDUwMCl9O1xuICAgICAgY3Vyc29yOiBub3QtYWxsb3dlZDtcbiAgICAgIG91dGxpbmU6IDA7XG5cbiAgICAgICY6OnBsYWNlaG9sZGVyIHtcbiAgICAgICAgY29sb3I6ICR7dHJhbnNwYXJlbnRpemUoMC40LCBwcm9wcy50aGVtZS5jb2xvcnMubmV1dHJhbDUwMCl9O1xuICAgICAgfVxuICAgIGB9XG5gO1xyXG5jb25zdCBTdHlsZWRJbnB1dCA9IHN0eWxlZC5pbnB1dCBgXG4gICR7aW5wdXRCYXNlU3R5bGVzfVxuICBkaXNwbGF5OiBmbGV4O1xuICBmbGV4LWdyb3c6IDE7XG4gIG1pbi13aWR0aDogJHtwcm9wcyA9PiBwcm9wcy50aGVtZS5zcGFjZVNjYWxlLnNwYWNpbmcwN307XG4gIHBhZGRpbmctbGVmdDogJHtwcm9wcyA9PiBwcm9wcy50aGVtZS5zcGFjZVNjYWxlLnNwYWNpbmcwMn07XG4gIHdpZHRoOiAwO1xuICBoZWlnaHQ6IDM4cHg7XG5cbiAgJjpmb2N1cyB7XG4gICAgb3V0bGluZTogMDtcbiAgfVxuYDtcclxuZXhwb3J0IGZ1bmN0aW9uIENvbWJvYm94SW5wdXQocHJvcHMpIHtcclxuICAgIGNvbnN0IHsgYXJpYURlc2NyaWJlZEJ5LCBjaGlsZHJlbiwgY3VzdG9tQ29tcG9uZW50cywgZ2V0Q29tYm9ib3hQcm9wcywgZ2V0SW5wdXRQcm9wcywgZ2V0VG9nZ2xlQnV0dG9uUHJvcHMsIGhhc0Vycm9yLCBpbm5lclJlZiwgaW5wdXRTdHlsZSwgZGlzYWJsZWQsIGlzSW52ZXJzZSwgaXNMb2FkaW5nLCBpc1R5cGVhaGVhZCwgb25JbnB1dEJsdXIsIG9uSW5wdXRGb2N1cywgb25JbnB1dEtleURvd24sIG9uSW5wdXRLZXlQcmVzcywgb25JbnB1dEtleVVwLCBwbGFjZWhvbGRlciwgc2VsZWN0ZWRJdGVtcywgc2V0UmVmZXJlbmNlLCB0b2dnbGVCdXR0b25SZWYsIH0gPSBwcm9wcztcclxuICAgIGNvbnN0IHRoZW1lID0gUmVhY3QudXNlQ29udGV4dChUaGVtZUNvbnRleHQpO1xyXG4gICAgY29uc3QgW2lzRm9jdXNlZCwgc2V0SXNGb2N1c2VkXSA9IFJlYWN0LnVzZVN0YXRlKGZhbHNlKTtcclxuICAgIGNvbnN0IHsgRHJvcGRvd25JbmRpY2F0b3IsIExvYWRpbmdJbmRpY2F0b3IgfSA9IGRlZmF1bHRDb21wb25lbnRzKHtcclxuICAgICAgICAuLi5jdXN0b21Db21wb25lbnRzLFxyXG4gICAgfSk7XHJcbiAgICBmdW5jdGlvbiBoYW5kbGVCbHVyKGUpIHtcclxuICAgICAgICBzZXRJc0ZvY3VzZWQoZmFsc2UpO1xyXG4gICAgICAgIG9uSW5wdXRCbHVyICYmIHR5cGVvZiBvbklucHV0Qmx1ciA9PT0gJ2Z1bmN0aW9uJyAmJiBvbklucHV0Qmx1cihlKTtcclxuICAgIH1cclxuICAgIGZ1bmN0aW9uIGhhbmRsZUZvY3VzKGUpIHtcclxuICAgICAgICBzZXRJc0ZvY3VzZWQodHJ1ZSk7XHJcbiAgICAgICAgb25JbnB1dEZvY3VzICYmIHR5cGVvZiBvbklucHV0Rm9jdXMgPT09ICdmdW5jdGlvbicgJiYgb25JbnB1dEZvY3VzKGUpO1xyXG4gICAgfVxyXG4gICAgY29uc3QgaW5wdXRQcm9wcyA9IGdldElucHV0UHJvcHMoe1xyXG4gICAgICAgIGRpc2FibGVkOiBkaXNhYmxlZCxcclxuICAgICAgICBvbkJsdXI6IGhhbmRsZUJsdXIsXHJcbiAgICAgICAgb25Gb2N1czogaGFuZGxlRm9jdXMsXHJcbiAgICAgICAgb25LZXlEb3duOiBvbklucHV0S2V5RG93bixcclxuICAgICAgICBvbktleVByZXNzOiBvbklucHV0S2V5UHJlc3MsXHJcbiAgICAgICAgb25LZXlVcDogb25JbnB1dEtleVVwLFxyXG4gICAgICAgIC4uLihpbm5lclJlZiAmJiB7IHJlZjogaW5uZXJSZWYgfSksXHJcbiAgICB9KTtcclxuICAgIGNvbnN0IGRyb3Bkb3duSW5kaWNhdG9yQ29sb3IgPSAoKSA9PiB7XHJcbiAgICAgICAgaWYgKGRpc2FibGVkKSB7XHJcbiAgICAgICAgICAgIGlmIChpc0ludmVyc2UpIHtcclxuICAgICAgICAgICAgICAgIHJldHVybiB0cmFuc3BhcmVudGl6ZSgwLjYsIHRoZW1lLmNvbG9ycy5uZXV0cmFsMTAwKTtcclxuICAgICAgICAgICAgfVxyXG4gICAgICAgICAgICByZXR1cm4gdGhlbWUuY29sb3JzLm5ldXRyYWw1MDA7XHJcbiAgICAgICAgfVxyXG4gICAgICAgIGlmIChpc0ludmVyc2UpIHtcclxuICAgICAgICAgICAgcmV0dXJuIHRoZW1lLmNvbG9ycy5uZXV0cmFsMTAwO1xyXG4gICAgICAgIH1cclxuICAgICAgICByZXR1cm4gdGhlbWUuY29sb3JzLm5ldXRyYWw7XHJcbiAgICB9O1xyXG4gICAgcmV0dXJuIChSZWFjdC5jcmVhdGVFbGVtZW50KFwiZGl2XCIsIHsgcmVmOiBzZXRSZWZlcmVuY2UgfSxcclxuICAgICAgICBSZWFjdC5jcmVhdGVFbGVtZW50KENvbWJvQm94Q29udGFpbmVyLCBPYmplY3QuYXNzaWduKHt9LCBnZXRDb21ib2JveFByb3BzKCksIHsgaGFzRXJyb3I6IGhhc0Vycm9yLCBkaXNhYmxlZDogZGlzYWJsZWQsIGlzSW52ZXJzZTogaXNJbnZlcnNlLCB0aGVtZTogdGhlbWUgfSksXHJcbiAgICAgICAgICAgIFJlYWN0LmNyZWF0ZUVsZW1lbnQoSW5wdXRDb250YWluZXIsIE9iamVjdC5hc3NpZ24oe30sIGdldFRvZ2dsZUJ1dHRvblByb3BzKHtcclxuICAgICAgICAgICAgICAgIGRpc2FibGVkLFxyXG4gICAgICAgICAgICAgICAgLi4uKHRvZ2dsZUJ1dHRvblJlZiAmJiB7IHJlZjogdG9nZ2xlQnV0dG9uUmVmIH0pLFxyXG4gICAgICAgICAgICB9KSwgeyBoYXNFcnJvcjogaGFzRXJyb3IsIGRpc2FibGVkOiBkaXNhYmxlZCwgaXNGb2N1c2VkOiBpc0ZvY3VzZWQsIGlzSW52ZXJzZTogaXNJbnZlcnNlLCBzdHlsZTogaW5wdXRTdHlsZSwgdGhlbWU6IHRoZW1lLCByZWY6IGlubmVyUmVmIH0pLFxyXG4gICAgICAgICAgICAgICAgUmVhY3QuY3JlYXRlRWxlbWVudChTZWxlY3RlZEl0ZW1zV3JhcHBlciwgbnVsbCxcclxuICAgICAgICAgICAgICAgICAgICBzZWxlY3RlZEl0ZW1zLFxyXG4gICAgICAgICAgICAgICAgICAgIFJlYWN0LmNyZWF0ZUVsZW1lbnQoU3R5bGVkSW5wdXQsIE9iamVjdC5hc3NpZ24oe30sIGlucHV0UHJvcHMsIHsgXCJhcmlhLWRlc2NyaWJlZGJ5XCI6IGFyaWFEZXNjcmliZWRCeSwgXCJhcmlhLWludmFsaWRcIjogaGFzRXJyb3IsIGRpc2FibGVkOiBkaXNhYmxlZCwgaXNJbnZlcnNlOiBpc0ludmVyc2UsIHBsYWNlaG9sZGVyOiBwbGFjZWhvbGRlciwgdGhlbWU6IHRoZW1lIH0pKSksXHJcbiAgICAgICAgICAgICAgICBjaGlsZHJlbixcclxuICAgICAgICAgICAgICAgIGlzTG9hZGluZyAmJiAhaXNUeXBlYWhlYWQgJiYgKFJlYWN0LmNyZWF0ZUVsZW1lbnQoTG9hZGluZ0luZGljYXRvciwgeyBzdHlsZTogeyBmbGV4U2hyaW5rOiAwLCBtYXJnaW5SaWdodDogdGhlbWUuc3BhY2VTY2FsZS5zcGFjaW5nMDIgfSB9KSksXHJcbiAgICAgICAgICAgICAgICBSZWFjdC5jcmVhdGVFbGVtZW50KERyb3Bkb3duSW5kaWNhdG9yLCB7IFwiYXJpYS1sYWJlbFwiOiBcInRvZ2dsZSBtZW51XCIsIGNvbG9yOiBkcm9wZG93bkluZGljYXRvckNvbG9yKCkgfSkpKSkpO1xyXG59XHJcbi8vIyBzb3VyY2VNYXBwaW5nVVJMPUNvbWJvYm94SW5wdXQuanMubWFwIl19 */",
|
|
12297
12289
|
toString: _EMOTION_STRINGIFIED_CSS_ERROR__$x
|
|
12298
12290
|
});
|
|
12299
12291
|
var InputContainer$1 = /*#__PURE__*/_styled("div", {
|
|
@@ -12312,22 +12304,20 @@ var InputContainer$1 = /*#__PURE__*/_styled("div", {
|
|
|
12312
12304
|
}, ";padding:0 ", function (props) {
|
|
12313
12305
|
return props.theme.spaceScale.spacing03;
|
|
12314
12306
|
}, " 0 0;width:100%;", function (props) {
|
|
12315
|
-
return props.isFocused && /*#__PURE__*/react.css("outline:2px solid ", props.isInverse ? props.theme.colors.focusInverse : props.theme.colors.focus, ";outline-offset:-1px;;label:InputContainer;" + ( "/*# sourceMappingURL=data:application/json;charset=utf-8;base64,eyJ2ZXJzaW9uIjozLCJzb3VyY2VzIjpbIkNvbWJvYm94SW5wdXQudHN4Il0sIm5hbWVzIjpbXSwibWFwcGluZ3MiOiJBQTRCUSIsImZpbGUiOiJDb21ib2JveElucHV0LnRzeCIsInNvdXJjZXNDb250ZW50IjpbImltcG9ydCBSZWFjdCBmcm9tICdyZWFjdCc7XHJcbmltcG9ydCB7IGNzcyB9IGZyb20gJ0BlbW90aW9uL3JlYWN0JztcclxuaW1wb3J0IHN0eWxlZCBmcm9tICdAZW1vdGlvbi9zdHlsZWQnO1xyXG5pbXBvcnQgeyB0cmFuc3BhcmVudGl6ZSB9IGZyb20gJ3BvbGlzaGVkJztcclxuaW1wb3J0IHsgVGhlbWVDb250ZXh0IH0gZnJvbSAnLi4vLi4vdGhlbWUvVGhlbWVDb250ZXh0JztcclxuaW1wb3J0IHsgaW5wdXRCYXNlU3R5bGVzIH0gZnJvbSAnLi4vSW5wdXRCYXNlJztcclxuaW1wb3J0IHsgZGVmYXVsdENvbXBvbmVudHMgfSBmcm9tICcuLi9TZWxlY3QvY29tcG9uZW50cyc7XHJcbmltcG9ydCB7IFNlbGVjdGVkSXRlbXNXcmFwcGVyIH0gZnJvbSAnLi4vU2VsZWN0L3NoYXJlZCc7XHJcbmNvbnN0IENvbWJvQm94Q29udGFpbmVyID0gc3R5bGVkLmRpdiBgXG4gIGRpc3BsYXk6IGZsZXg7XG5gO1xyXG5jb25zdCBJbnB1dENvbnRhaW5lciA9IHN0eWxlZC5kaXYgYFxuICBhbGlnbi1pdGVtczogY2VudGVyO1xuICBiYWNrZ3JvdW5kLWNvbG9yOiAke3Byb3BzID0+IHByb3BzLmlzSW52ZXJzZVxyXG4gICAgPyB0cmFuc3BhcmVudGl6ZSgwLjgsIHByb3BzLnRoZW1lLmNvbG9ycy5uZXV0cmFsOTAwKVxyXG4gICAgOiBwcm9wcy50aGVtZS5jb2xvcnMubmV1dHJhbDEwMH07XG4gIGJvcmRlcjogMXB4IHNvbGlkO1xuICBib3JkZXItY29sb3I6ICR7cHJvcHMgPT4gcHJvcHMuaXNJbnZlcnNlXHJcbiAgICA/IHRyYW5zcGFyZW50aXplKDAuNSwgcHJvcHMudGhlbWUuY29sb3JzLm5ldXRyYWwxMDApXHJcbiAgICA6IHByb3BzLnRoZW1lLmNvbG9ycy5uZXV0cmFsNTAwfTtcbiAgYm9yZGVyLXJhZGl1czogJHtwcm9wcyA9PiBwcm9wcy50aGVtZS5ib3JkZXJSYWRpdXN9O1xuICBkaXNwbGF5OiBmbGV4O1xuICBtaW4taGVpZ2h0OiAke3Byb3BzID0+IHByb3BzLnRoZW1lLnNwYWNlU2NhbGUuc3BhY2luZzA5fTtcbiAgbWluLXdpZHRoOiAke3Byb3BzID0+IHByb3BzLnRoZW1lLnNwYWNlU2NhbGUuc3BhY2luZzEzfTtcbiAgcGFkZGluZzogMCAke3Byb3BzID0+IHByb3BzLnRoZW1lLnNwYWNlU2NhbGUuc3BhY2luZzAzfSAwIDA7XG4gIHdpZHRoOiAxMDAlO1xuXG4gICR7cHJvcHMgPT4gcHJvcHMuaXNGb2N1c2VkICYmXHJcbiAgICBjc3MgYFxuICAgICAgb3V0bGluZTogMnB4IHNvbGlkXG4gICAgICAgICR7cHJvcHMuaXNJbnZlcnNlXHJcbiAgICAgICAgPyBwcm9wcy50aGVtZS5jb2xvcnMuZm9jdXNJbnZlcnNlXHJcbiAgICAgICAgOiBwcm9wcy50aGVtZS5jb2xvcnMuZm9jdXN9O1xuICAgICAgb3V0bGluZS1vZmZzZXQ6IC0xcHg7XG4gICAgYH1cblxuICAke3Byb3BzID0+IHByb3BzLmhhc0Vycm9yICYmXHJcbiAgICBjc3MgYFxuICAgICAgYm9yZGVyLWNvbG9yOiAke3Byb3BzLmlzSW52ZXJzZVxyXG4gICAgICAgID8gcHJvcHMudGhlbWUuY29sb3JzLmRhbmdlcjIwMFxyXG4gICAgICAgIDogcHJvcHMudGhlbWUuY29sb3JzLmRhbmdlcn07XG4gICAgYH1cblxuICAgICR7cHJvcHMgPT4gcHJvcHMuZGlzYWJsZWQgJiZcclxuICAgIGNzcyBgXG4gICAgICBiYWNrZ3JvdW5kOiAke3Byb3BzLmlzSW52ZXJzZVxyXG4gICAgICAgID8gdHJhbnNwYXJlbnRpemUoMC45LCBwcm9wcy50aGVtZS5jb2xvcnMubmV1dHJhbDkwMClcclxuICAgICAgICA6IHByb3BzLnRoZW1lLmNvbG9ycy5uZXV0cmFsMjAwfTtcbiAgICAgIGJvcmRlci1jb2xvcjogJHtwcm9wcy5pc0ludmVyc2VcclxuICAgICAgICA/
|
|
12307
|
+
return props.isFocused && /*#__PURE__*/react.css("outline:2px solid ", props.isInverse ? props.theme.colors.focusInverse : props.theme.colors.focus, ";outline-offset:-1px;;label:InputContainer;" + ( "/*# sourceMappingURL=data:application/json;charset=utf-8;base64,eyJ2ZXJzaW9uIjozLCJzb3VyY2VzIjpbIkNvbWJvYm94SW5wdXQudHN4Il0sIm5hbWVzIjpbXSwibWFwcGluZ3MiOiJBQTRCUSIsImZpbGUiOiJDb21ib2JveElucHV0LnRzeCIsInNvdXJjZXNDb250ZW50IjpbImltcG9ydCBSZWFjdCBmcm9tICdyZWFjdCc7XHJcbmltcG9ydCB7IGNzcyB9IGZyb20gJ0BlbW90aW9uL3JlYWN0JztcclxuaW1wb3J0IHN0eWxlZCBmcm9tICdAZW1vdGlvbi9zdHlsZWQnO1xyXG5pbXBvcnQgeyB0cmFuc3BhcmVudGl6ZSB9IGZyb20gJ3BvbGlzaGVkJztcclxuaW1wb3J0IHsgVGhlbWVDb250ZXh0IH0gZnJvbSAnLi4vLi4vdGhlbWUvVGhlbWVDb250ZXh0JztcclxuaW1wb3J0IHsgaW5wdXRCYXNlU3R5bGVzIH0gZnJvbSAnLi4vSW5wdXRCYXNlJztcclxuaW1wb3J0IHsgZGVmYXVsdENvbXBvbmVudHMgfSBmcm9tICcuLi9TZWxlY3QvY29tcG9uZW50cyc7XHJcbmltcG9ydCB7IFNlbGVjdGVkSXRlbXNXcmFwcGVyIH0gZnJvbSAnLi4vU2VsZWN0L3NoYXJlZCc7XHJcbmNvbnN0IENvbWJvQm94Q29udGFpbmVyID0gc3R5bGVkLmRpdiBgXG4gIGRpc3BsYXk6IGZsZXg7XG5gO1xyXG5jb25zdCBJbnB1dENvbnRhaW5lciA9IHN0eWxlZC5kaXYgYFxuICBhbGlnbi1pdGVtczogY2VudGVyO1xuICBiYWNrZ3JvdW5kLWNvbG9yOiAke3Byb3BzID0+IHByb3BzLmlzSW52ZXJzZVxyXG4gICAgPyB0cmFuc3BhcmVudGl6ZSgwLjgsIHByb3BzLnRoZW1lLmNvbG9ycy5uZXV0cmFsOTAwKVxyXG4gICAgOiBwcm9wcy50aGVtZS5jb2xvcnMubmV1dHJhbDEwMH07XG4gIGJvcmRlcjogMXB4IHNvbGlkO1xuICBib3JkZXItY29sb3I6ICR7cHJvcHMgPT4gcHJvcHMuaXNJbnZlcnNlXHJcbiAgICA/IHRyYW5zcGFyZW50aXplKDAuNSwgcHJvcHMudGhlbWUuY29sb3JzLm5ldXRyYWwxMDApXHJcbiAgICA6IHByb3BzLnRoZW1lLmNvbG9ycy5uZXV0cmFsNTAwfTtcbiAgYm9yZGVyLXJhZGl1czogJHtwcm9wcyA9PiBwcm9wcy50aGVtZS5ib3JkZXJSYWRpdXN9O1xuICBkaXNwbGF5OiBmbGV4O1xuICBtaW4taGVpZ2h0OiAke3Byb3BzID0+IHByb3BzLnRoZW1lLnNwYWNlU2NhbGUuc3BhY2luZzA5fTtcbiAgbWluLXdpZHRoOiAke3Byb3BzID0+IHByb3BzLnRoZW1lLnNwYWNlU2NhbGUuc3BhY2luZzEzfTtcbiAgcGFkZGluZzogMCAke3Byb3BzID0+IHByb3BzLnRoZW1lLnNwYWNlU2NhbGUuc3BhY2luZzAzfSAwIDA7XG4gIHdpZHRoOiAxMDAlO1xuXG4gICR7cHJvcHMgPT4gcHJvcHMuaXNGb2N1c2VkICYmXHJcbiAgICBjc3MgYFxuICAgICAgb3V0bGluZTogMnB4IHNvbGlkXG4gICAgICAgICR7cHJvcHMuaXNJbnZlcnNlXHJcbiAgICAgICAgPyBwcm9wcy50aGVtZS5jb2xvcnMuZm9jdXNJbnZlcnNlXHJcbiAgICAgICAgOiBwcm9wcy50aGVtZS5jb2xvcnMuZm9jdXN9O1xuICAgICAgb3V0bGluZS1vZmZzZXQ6IC0xcHg7XG4gICAgYH1cblxuICAke3Byb3BzID0+IHByb3BzLmhhc0Vycm9yICYmXHJcbiAgICBjc3MgYFxuICAgICAgYm9yZGVyLWNvbG9yOiAke3Byb3BzLmlzSW52ZXJzZVxyXG4gICAgICAgID8gcHJvcHMudGhlbWUuY29sb3JzLmRhbmdlcjIwMFxyXG4gICAgICAgIDogcHJvcHMudGhlbWUuY29sb3JzLmRhbmdlcn07XG4gICAgYH1cblxuICAgICR7cHJvcHMgPT4gcHJvcHMuZGlzYWJsZWQgJiZcclxuICAgIGNzcyBgXG4gICAgICBiYWNrZ3JvdW5kOiAke3Byb3BzLmlzSW52ZXJzZVxyXG4gICAgICAgID8gdHJhbnNwYXJlbnRpemUoMC45LCBwcm9wcy50aGVtZS5jb2xvcnMubmV1dHJhbDkwMClcclxuICAgICAgICA6IHByb3BzLnRoZW1lLmNvbG9ycy5uZXV0cmFsMjAwfTtcbiAgICAgIGJvcmRlci1jb2xvcjogJHtwcm9wcy5pc0ludmVyc2VcclxuICAgICAgICA/IHRyYW5zcGFyZW50aXplKDAuODUsIHByb3BzLnRoZW1lLmNvbG9ycy5uZXV0cmFsMTAwKVxyXG4gICAgICAgIDogcHJvcHMudGhlbWUuY29sb3JzLm5ldXRyYWwzMDB9O1xuICAgICAgY29sb3I6ICR7dHJhbnNwYXJlbnRpemUoMC40LCBwcm9wcy50aGVtZS5jb2xvcnMubmV1dHJhbDUwMCl9O1xuICAgICAgY3Vyc29yOiBub3QtYWxsb3dlZDtcbiAgICAgIG91dGxpbmU6IDA7XG5cbiAgICAgICY6OnBsYWNlaG9sZGVyIHtcbiAgICAgICAgY29sb3I6ICR7dHJhbnNwYXJlbnRpemUoMC40LCBwcm9wcy50aGVtZS5jb2xvcnMubmV1dHJhbDUwMCl9O1xuICAgICAgfVxuICAgIGB9XG5gO1xyXG5jb25zdCBTdHlsZWRJbnB1dCA9IHN0eWxlZC5pbnB1dCBgXG4gICR7aW5wdXRCYXNlU3R5bGVzfVxuICBkaXNwbGF5OiBmbGV4O1xuICBmbGV4LWdyb3c6IDE7XG4gIG1pbi13aWR0aDogJHtwcm9wcyA9PiBwcm9wcy50aGVtZS5zcGFjZVNjYWxlLnNwYWNpbmcwN307XG4gIHBhZGRpbmctbGVmdDogJHtwcm9wcyA9PiBwcm9wcy50aGVtZS5zcGFjZVNjYWxlLnNwYWNpbmcwMn07XG4gIHdpZHRoOiAwO1xuICBoZWlnaHQ6IDM4cHg7XG5cbiAgJjpmb2N1cyB7XG4gICAgb3V0bGluZTogMDtcbiAgfVxuYDtcclxuZXhwb3J0IGZ1bmN0aW9uIENvbWJvYm94SW5wdXQocHJvcHMpIHtcclxuICAgIGNvbnN0IHsgYXJpYURlc2NyaWJlZEJ5LCBjaGlsZHJlbiwgY3VzdG9tQ29tcG9uZW50cywgZ2V0Q29tYm9ib3hQcm9wcywgZ2V0SW5wdXRQcm9wcywgZ2V0VG9nZ2xlQnV0dG9uUHJvcHMsIGhhc0Vycm9yLCBpbm5lclJlZiwgaW5wdXRTdHlsZSwgZGlzYWJsZWQsIGlzSW52ZXJzZSwgaXNMb2FkaW5nLCBpc1R5cGVhaGVhZCwgb25JbnB1dEJsdXIsIG9uSW5wdXRGb2N1cywgb25JbnB1dEtleURvd24sIG9uSW5wdXRLZXlQcmVzcywgb25JbnB1dEtleVVwLCBwbGFjZWhvbGRlciwgc2VsZWN0ZWRJdGVtcywgc2V0UmVmZXJlbmNlLCB0b2dnbGVCdXR0b25SZWYsIH0gPSBwcm9wcztcclxuICAgIGNvbnN0IHRoZW1lID0gUmVhY3QudXNlQ29udGV4dChUaGVtZUNvbnRleHQpO1xyXG4gICAgY29uc3QgW2lzRm9jdXNlZCwgc2V0SXNGb2N1c2VkXSA9IFJlYWN0LnVzZVN0YXRlKGZhbHNlKTtcclxuICAgIGNvbnN0IHsgRHJvcGRvd25JbmRpY2F0b3IsIExvYWRpbmdJbmRpY2F0b3IgfSA9IGRlZmF1bHRDb21wb25lbnRzKHtcclxuICAgICAgICAuLi5jdXN0b21Db21wb25lbnRzLFxyXG4gICAgfSk7XHJcbiAgICBmdW5jdGlvbiBoYW5kbGVCbHVyKGUpIHtcclxuICAgICAgICBzZXRJc0ZvY3VzZWQoZmFsc2UpO1xyXG4gICAgICAgIG9uSW5wdXRCbHVyICYmIHR5cGVvZiBvbklucHV0Qmx1ciA9PT0gJ2Z1bmN0aW9uJyAmJiBvbklucHV0Qmx1cihlKTtcclxuICAgIH1cclxuICAgIGZ1bmN0aW9uIGhhbmRsZUZvY3VzKGUpIHtcclxuICAgICAgICBzZXRJc0ZvY3VzZWQodHJ1ZSk7XHJcbiAgICAgICAgb25JbnB1dEZvY3VzICYmIHR5cGVvZiBvbklucHV0Rm9jdXMgPT09ICdmdW5jdGlvbicgJiYgb25JbnB1dEZvY3VzKGUpO1xyXG4gICAgfVxyXG4gICAgY29uc3QgaW5wdXRQcm9wcyA9IGdldElucHV0UHJvcHMoe1xyXG4gICAgICAgIGRpc2FibGVkOiBkaXNhYmxlZCxcclxuICAgICAgICBvbkJsdXI6IGhhbmRsZUJsdXIsXHJcbiAgICAgICAgb25Gb2N1czogaGFuZGxlRm9jdXMsXHJcbiAgICAgICAgb25LZXlEb3duOiBvbklucHV0S2V5RG93bixcclxuICAgICAgICBvbktleVByZXNzOiBvbklucHV0S2V5UHJlc3MsXHJcbiAgICAgICAgb25LZXlVcDogb25JbnB1dEtleVVwLFxyXG4gICAgICAgIC4uLihpbm5lclJlZiAmJiB7IHJlZjogaW5uZXJSZWYgfSksXHJcbiAgICB9KTtcclxuICAgIGNvbnN0IGRyb3Bkb3duSW5kaWNhdG9yQ29sb3IgPSAoKSA9PiB7XHJcbiAgICAgICAgaWYgKGRpc2FibGVkKSB7XHJcbiAgICAgICAgICAgIGlmIChpc0ludmVyc2UpIHtcclxuICAgICAgICAgICAgICAgIHJldHVybiB0cmFuc3BhcmVudGl6ZSgwLjYsIHRoZW1lLmNvbG9ycy5uZXV0cmFsMTAwKTtcclxuICAgICAgICAgICAgfVxyXG4gICAgICAgICAgICByZXR1cm4gdGhlbWUuY29sb3JzLm5ldXRyYWw1MDA7XHJcbiAgICAgICAgfVxyXG4gICAgICAgIGlmIChpc0ludmVyc2UpIHtcclxuICAgICAgICAgICAgcmV0dXJuIHRoZW1lLmNvbG9ycy5uZXV0cmFsMTAwO1xyXG4gICAgICAgIH1cclxuICAgICAgICByZXR1cm4gdGhlbWUuY29sb3JzLm5ldXRyYWw7XHJcbiAgICB9O1xyXG4gICAgcmV0dXJuIChSZWFjdC5jcmVhdGVFbGVtZW50KFwiZGl2XCIsIHsgcmVmOiBzZXRSZWZlcmVuY2UgfSxcclxuICAgICAgICBSZWFjdC5jcmVhdGVFbGVtZW50KENvbWJvQm94Q29udGFpbmVyLCBPYmplY3QuYXNzaWduKHt9LCBnZXRDb21ib2JveFByb3BzKCksIHsgaGFzRXJyb3I6IGhhc0Vycm9yLCBkaXNhYmxlZDogZGlzYWJsZWQsIGlzSW52ZXJzZTogaXNJbnZlcnNlLCB0aGVtZTogdGhlbWUgfSksXHJcbiAgICAgICAgICAgIFJlYWN0LmNyZWF0ZUVsZW1lbnQoSW5wdXRDb250YWluZXIsIE9iamVjdC5hc3NpZ24oe30sIGdldFRvZ2dsZUJ1dHRvblByb3BzKHtcclxuICAgICAgICAgICAgICAgIGRpc2FibGVkLFxyXG4gICAgICAgICAgICAgICAgLi4uKHRvZ2dsZUJ1dHRvblJlZiAmJiB7IHJlZjogdG9nZ2xlQnV0dG9uUmVmIH0pLFxyXG4gICAgICAgICAgICB9KSwgeyBoYXNFcnJvcjogaGFzRXJyb3IsIGRpc2FibGVkOiBkaXNhYmxlZCwgaXNGb2N1c2VkOiBpc0ZvY3VzZWQsIGlzSW52ZXJzZTogaXNJbnZlcnNlLCBzdHlsZTogaW5wdXRTdHlsZSwgdGhlbWU6IHRoZW1lLCByZWY6IGlubmVyUmVmIH0pLFxyXG4gICAgICAgICAgICAgICAgUmVhY3QuY3JlYXRlRWxlbWVudChTZWxlY3RlZEl0ZW1zV3JhcHBlciwgbnVsbCxcclxuICAgICAgICAgICAgICAgICAgICBzZWxlY3RlZEl0ZW1zLFxyXG4gICAgICAgICAgICAgICAgICAgIFJlYWN0LmNyZWF0ZUVsZW1lbnQoU3R5bGVkSW5wdXQsIE9iamVjdC5hc3NpZ24oe30sIGlucHV0UHJvcHMsIHsgXCJhcmlhLWRlc2NyaWJlZGJ5XCI6IGFyaWFEZXNjcmliZWRCeSwgXCJhcmlhLWludmFsaWRcIjogaGFzRXJyb3IsIGRpc2FibGVkOiBkaXNhYmxlZCwgaXNJbnZlcnNlOiBpc0ludmVyc2UsIHBsYWNlaG9sZGVyOiBwbGFjZWhvbGRlciwgdGhlbWU6IHRoZW1lIH0pKSksXHJcbiAgICAgICAgICAgICAgICBjaGlsZHJlbixcclxuICAgICAgICAgICAgICAgIGlzTG9hZGluZyAmJiAhaXNUeXBlYWhlYWQgJiYgKFJlYWN0LmNyZWF0ZUVsZW1lbnQoTG9hZGluZ0luZGljYXRvciwgeyBzdHlsZTogeyBmbGV4U2hyaW5rOiAwLCBtYXJnaW5SaWdodDogdGhlbWUuc3BhY2VTY2FsZS5zcGFjaW5nMDIgfSB9KSksXHJcbiAgICAgICAgICAgICAgICBSZWFjdC5jcmVhdGVFbGVtZW50KERyb3Bkb3duSW5kaWNhdG9yLCB7IFwiYXJpYS1sYWJlbFwiOiBcInRvZ2dsZSBtZW51XCIsIGNvbG9yOiBkcm9wZG93bkluZGljYXRvckNvbG9yKCkgfSkpKSkpO1xyXG59XHJcbi8vIyBzb3VyY2VNYXBwaW5nVVJMPUNvbWJvYm94SW5wdXQuanMubWFwIl19 */"));
|
|
12316
12308
|
}, " ", function (props) {
|
|
12317
|
-
return props.hasError && /*#__PURE__*/react.css("border-color:", props.isInverse ? props.theme.colors.danger200 : props.theme.colors.danger, ";;label:InputContainer;" + ( "/*# sourceMappingURL=data:application/json;charset=utf-8;base64,eyJ2ZXJzaW9uIjozLCJzb3VyY2VzIjpbIkNvbWJvYm94SW5wdXQudHN4Il0sIm5hbWVzIjpbXSwibWFwcGluZ3MiOiJBQXFDUSIsImZpbGUiOiJDb21ib2JveElucHV0LnRzeCIsInNvdXJjZXNDb250ZW50IjpbImltcG9ydCBSZWFjdCBmcm9tICdyZWFjdCc7XHJcbmltcG9ydCB7IGNzcyB9IGZyb20gJ0BlbW90aW9uL3JlYWN0JztcclxuaW1wb3J0IHN0eWxlZCBmcm9tICdAZW1vdGlvbi9zdHlsZWQnO1xyXG5pbXBvcnQgeyB0cmFuc3BhcmVudGl6ZSB9IGZyb20gJ3BvbGlzaGVkJztcclxuaW1wb3J0IHsgVGhlbWVDb250ZXh0IH0gZnJvbSAnLi4vLi4vdGhlbWUvVGhlbWVDb250ZXh0JztcclxuaW1wb3J0IHsgaW5wdXRCYXNlU3R5bGVzIH0gZnJvbSAnLi4vSW5wdXRCYXNlJztcclxuaW1wb3J0IHsgZGVmYXVsdENvbXBvbmVudHMgfSBmcm9tICcuLi9TZWxlY3QvY29tcG9uZW50cyc7XHJcbmltcG9ydCB7IFNlbGVjdGVkSXRlbXNXcmFwcGVyIH0gZnJvbSAnLi4vU2VsZWN0L3NoYXJlZCc7XHJcbmNvbnN0IENvbWJvQm94Q29udGFpbmVyID0gc3R5bGVkLmRpdiBgXG4gIGRpc3BsYXk6IGZsZXg7XG5gO1xyXG5jb25zdCBJbnB1dENvbnRhaW5lciA9IHN0eWxlZC5kaXYgYFxuICBhbGlnbi1pdGVtczogY2VudGVyO1xuICBiYWNrZ3JvdW5kLWNvbG9yOiAke3Byb3BzID0+IHByb3BzLmlzSW52ZXJzZVxyXG4gICAgPyB0cmFuc3BhcmVudGl6ZSgwLjgsIHByb3BzLnRoZW1lLmNvbG9ycy5uZXV0cmFsOTAwKVxyXG4gICAgOiBwcm9wcy50aGVtZS5jb2xvcnMubmV1dHJhbDEwMH07XG4gIGJvcmRlcjogMXB4IHNvbGlkO1xuICBib3JkZXItY29sb3I6ICR7cHJvcHMgPT4gcHJvcHMuaXNJbnZlcnNlXHJcbiAgICA/IHRyYW5zcGFyZW50aXplKDAuNSwgcHJvcHMudGhlbWUuY29sb3JzLm5ldXRyYWwxMDApXHJcbiAgICA6IHByb3BzLnRoZW1lLmNvbG9ycy5uZXV0cmFsNTAwfTtcbiAgYm9yZGVyLXJhZGl1czogJHtwcm9wcyA9PiBwcm9wcy50aGVtZS5ib3JkZXJSYWRpdXN9O1xuICBkaXNwbGF5OiBmbGV4O1xuICBtaW4taGVpZ2h0OiAke3Byb3BzID0+IHByb3BzLnRoZW1lLnNwYWNlU2NhbGUuc3BhY2luZzA5fTtcbiAgbWluLXdpZHRoOiAke3Byb3BzID0+IHByb3BzLnRoZW1lLnNwYWNlU2NhbGUuc3BhY2luZzEzfTtcbiAgcGFkZGluZzogMCAke3Byb3BzID0+IHByb3BzLnRoZW1lLnNwYWNlU2NhbGUuc3BhY2luZzAzfSAwIDA7XG4gIHdpZHRoOiAxMDAlO1xuXG4gICR7cHJvcHMgPT4gcHJvcHMuaXNGb2N1c2VkICYmXHJcbiAgICBjc3MgYFxuICAgICAgb3V0bGluZTogMnB4IHNvbGlkXG4gICAgICAgICR7cHJvcHMuaXNJbnZlcnNlXHJcbiAgICAgICAgPyBwcm9wcy50aGVtZS5jb2xvcnMuZm9jdXNJbnZlcnNlXHJcbiAgICAgICAgOiBwcm9wcy50aGVtZS5jb2xvcnMuZm9jdXN9O1xuICAgICAgb3V0bGluZS1vZmZzZXQ6IC0xcHg7XG4gICAgYH1cblxuICAke3Byb3BzID0+IHByb3BzLmhhc0Vycm9yICYmXHJcbiAgICBjc3MgYFxuICAgICAgYm9yZGVyLWNvbG9yOiAke3Byb3BzLmlzSW52ZXJzZVxyXG4gICAgICAgID8gcHJvcHMudGhlbWUuY29sb3JzLmRhbmdlcjIwMFxyXG4gICAgICAgIDogcHJvcHMudGhlbWUuY29sb3JzLmRhbmdlcn07XG4gICAgYH1cblxuICAgICR7cHJvcHMgPT4gcHJvcHMuZGlzYWJsZWQgJiZcclxuICAgIGNzcyBgXG4gICAgICBiYWNrZ3JvdW5kOiAke3Byb3BzLmlzSW52ZXJzZVxyXG4gICAgICAgID8gdHJhbnNwYXJlbnRpemUoMC45LCBwcm9wcy50aGVtZS5jb2xvcnMubmV1dHJhbDkwMClcclxuICAgICAgICA6IHByb3BzLnRoZW1lLmNvbG9ycy5uZXV0cmFsMjAwfTtcbiAgICAgIGJvcmRlci1jb2xvcjogJHtwcm9wcy5pc0ludmVyc2VcclxuICAgICAgICA/
|
|
12309
|
+
return props.hasError && /*#__PURE__*/react.css("border-color:", props.isInverse ? props.theme.colors.danger200 : props.theme.colors.danger, ";;label:InputContainer;" + ( "/*# sourceMappingURL=data:application/json;charset=utf-8;base64,eyJ2ZXJzaW9uIjozLCJzb3VyY2VzIjpbIkNvbWJvYm94SW5wdXQudHN4Il0sIm5hbWVzIjpbXSwibWFwcGluZ3MiOiJBQXFDUSIsImZpbGUiOiJDb21ib2JveElucHV0LnRzeCIsInNvdXJjZXNDb250ZW50IjpbImltcG9ydCBSZWFjdCBmcm9tICdyZWFjdCc7XHJcbmltcG9ydCB7IGNzcyB9IGZyb20gJ0BlbW90aW9uL3JlYWN0JztcclxuaW1wb3J0IHN0eWxlZCBmcm9tICdAZW1vdGlvbi9zdHlsZWQnO1xyXG5pbXBvcnQgeyB0cmFuc3BhcmVudGl6ZSB9IGZyb20gJ3BvbGlzaGVkJztcclxuaW1wb3J0IHsgVGhlbWVDb250ZXh0IH0gZnJvbSAnLi4vLi4vdGhlbWUvVGhlbWVDb250ZXh0JztcclxuaW1wb3J0IHsgaW5wdXRCYXNlU3R5bGVzIH0gZnJvbSAnLi4vSW5wdXRCYXNlJztcclxuaW1wb3J0IHsgZGVmYXVsdENvbXBvbmVudHMgfSBmcm9tICcuLi9TZWxlY3QvY29tcG9uZW50cyc7XHJcbmltcG9ydCB7IFNlbGVjdGVkSXRlbXNXcmFwcGVyIH0gZnJvbSAnLi4vU2VsZWN0L3NoYXJlZCc7XHJcbmNvbnN0IENvbWJvQm94Q29udGFpbmVyID0gc3R5bGVkLmRpdiBgXG4gIGRpc3BsYXk6IGZsZXg7XG5gO1xyXG5jb25zdCBJbnB1dENvbnRhaW5lciA9IHN0eWxlZC5kaXYgYFxuICBhbGlnbi1pdGVtczogY2VudGVyO1xuICBiYWNrZ3JvdW5kLWNvbG9yOiAke3Byb3BzID0+IHByb3BzLmlzSW52ZXJzZVxyXG4gICAgPyB0cmFuc3BhcmVudGl6ZSgwLjgsIHByb3BzLnRoZW1lLmNvbG9ycy5uZXV0cmFsOTAwKVxyXG4gICAgOiBwcm9wcy50aGVtZS5jb2xvcnMubmV1dHJhbDEwMH07XG4gIGJvcmRlcjogMXB4IHNvbGlkO1xuICBib3JkZXItY29sb3I6ICR7cHJvcHMgPT4gcHJvcHMuaXNJbnZlcnNlXHJcbiAgICA/IHRyYW5zcGFyZW50aXplKDAuNSwgcHJvcHMudGhlbWUuY29sb3JzLm5ldXRyYWwxMDApXHJcbiAgICA6IHByb3BzLnRoZW1lLmNvbG9ycy5uZXV0cmFsNTAwfTtcbiAgYm9yZGVyLXJhZGl1czogJHtwcm9wcyA9PiBwcm9wcy50aGVtZS5ib3JkZXJSYWRpdXN9O1xuICBkaXNwbGF5OiBmbGV4O1xuICBtaW4taGVpZ2h0OiAke3Byb3BzID0+IHByb3BzLnRoZW1lLnNwYWNlU2NhbGUuc3BhY2luZzA5fTtcbiAgbWluLXdpZHRoOiAke3Byb3BzID0+IHByb3BzLnRoZW1lLnNwYWNlU2NhbGUuc3BhY2luZzEzfTtcbiAgcGFkZGluZzogMCAke3Byb3BzID0+IHByb3BzLnRoZW1lLnNwYWNlU2NhbGUuc3BhY2luZzAzfSAwIDA7XG4gIHdpZHRoOiAxMDAlO1xuXG4gICR7cHJvcHMgPT4gcHJvcHMuaXNGb2N1c2VkICYmXHJcbiAgICBjc3MgYFxuICAgICAgb3V0bGluZTogMnB4IHNvbGlkXG4gICAgICAgICR7cHJvcHMuaXNJbnZlcnNlXHJcbiAgICAgICAgPyBwcm9wcy50aGVtZS5jb2xvcnMuZm9jdXNJbnZlcnNlXHJcbiAgICAgICAgOiBwcm9wcy50aGVtZS5jb2xvcnMuZm9jdXN9O1xuICAgICAgb3V0bGluZS1vZmZzZXQ6IC0xcHg7XG4gICAgYH1cblxuICAke3Byb3BzID0+IHByb3BzLmhhc0Vycm9yICYmXHJcbiAgICBjc3MgYFxuICAgICAgYm9yZGVyLWNvbG9yOiAke3Byb3BzLmlzSW52ZXJzZVxyXG4gICAgICAgID8gcHJvcHMudGhlbWUuY29sb3JzLmRhbmdlcjIwMFxyXG4gICAgICAgIDogcHJvcHMudGhlbWUuY29sb3JzLmRhbmdlcn07XG4gICAgYH1cblxuICAgICR7cHJvcHMgPT4gcHJvcHMuZGlzYWJsZWQgJiZcclxuICAgIGNzcyBgXG4gICAgICBiYWNrZ3JvdW5kOiAke3Byb3BzLmlzSW52ZXJzZVxyXG4gICAgICAgID8gdHJhbnNwYXJlbnRpemUoMC45LCBwcm9wcy50aGVtZS5jb2xvcnMubmV1dHJhbDkwMClcclxuICAgICAgICA6IHByb3BzLnRoZW1lLmNvbG9ycy5uZXV0cmFsMjAwfTtcbiAgICAgIGJvcmRlci1jb2xvcjogJHtwcm9wcy5pc0ludmVyc2VcclxuICAgICAgICA/IHRyYW5zcGFyZW50aXplKDAuODUsIHByb3BzLnRoZW1lLmNvbG9ycy5uZXV0cmFsMTAwKVxyXG4gICAgICAgIDogcHJvcHMudGhlbWUuY29sb3JzLm5ldXRyYWwzMDB9O1xuICAgICAgY29sb3I6ICR7dHJhbnNwYXJlbnRpemUoMC40LCBwcm9wcy50aGVtZS5jb2xvcnMubmV1dHJhbDUwMCl9O1xuICAgICAgY3Vyc29yOiBub3QtYWxsb3dlZDtcbiAgICAgIG91dGxpbmU6IDA7XG5cbiAgICAgICY6OnBsYWNlaG9sZGVyIHtcbiAgICAgICAgY29sb3I6ICR7dHJhbnNwYXJlbnRpemUoMC40LCBwcm9wcy50aGVtZS5jb2xvcnMubmV1dHJhbDUwMCl9O1xuICAgICAgfVxuICAgIGB9XG5gO1xyXG5jb25zdCBTdHlsZWRJbnB1dCA9IHN0eWxlZC5pbnB1dCBgXG4gICR7aW5wdXRCYXNlU3R5bGVzfVxuICBkaXNwbGF5OiBmbGV4O1xuICBmbGV4LWdyb3c6IDE7XG4gIG1pbi13aWR0aDogJHtwcm9wcyA9PiBwcm9wcy50aGVtZS5zcGFjZVNjYWxlLnNwYWNpbmcwN307XG4gIHBhZGRpbmctbGVmdDogJHtwcm9wcyA9PiBwcm9wcy50aGVtZS5zcGFjZVNjYWxlLnNwYWNpbmcwMn07XG4gIHdpZHRoOiAwO1xuICBoZWlnaHQ6IDM4cHg7XG5cbiAgJjpmb2N1cyB7XG4gICAgb3V0bGluZTogMDtcbiAgfVxuYDtcclxuZXhwb3J0IGZ1bmN0aW9uIENvbWJvYm94SW5wdXQocHJvcHMpIHtcclxuICAgIGNvbnN0IHsgYXJpYURlc2NyaWJlZEJ5LCBjaGlsZHJlbiwgY3VzdG9tQ29tcG9uZW50cywgZ2V0Q29tYm9ib3hQcm9wcywgZ2V0SW5wdXRQcm9wcywgZ2V0VG9nZ2xlQnV0dG9uUHJvcHMsIGhhc0Vycm9yLCBpbm5lclJlZiwgaW5wdXRTdHlsZSwgZGlzYWJsZWQsIGlzSW52ZXJzZSwgaXNMb2FkaW5nLCBpc1R5cGVhaGVhZCwgb25JbnB1dEJsdXIsIG9uSW5wdXRGb2N1cywgb25JbnB1dEtleURvd24sIG9uSW5wdXRLZXlQcmVzcywgb25JbnB1dEtleVVwLCBwbGFjZWhvbGRlciwgc2VsZWN0ZWRJdGVtcywgc2V0UmVmZXJlbmNlLCB0b2dnbGVCdXR0b25SZWYsIH0gPSBwcm9wcztcclxuICAgIGNvbnN0IHRoZW1lID0gUmVhY3QudXNlQ29udGV4dChUaGVtZUNvbnRleHQpO1xyXG4gICAgY29uc3QgW2lzRm9jdXNlZCwgc2V0SXNGb2N1c2VkXSA9IFJlYWN0LnVzZVN0YXRlKGZhbHNlKTtcclxuICAgIGNvbnN0IHsgRHJvcGRvd25JbmRpY2F0b3IsIExvYWRpbmdJbmRpY2F0b3IgfSA9IGRlZmF1bHRDb21wb25lbnRzKHtcclxuICAgICAgICAuLi5jdXN0b21Db21wb25lbnRzLFxyXG4gICAgfSk7XHJcbiAgICBmdW5jdGlvbiBoYW5kbGVCbHVyKGUpIHtcclxuICAgICAgICBzZXRJc0ZvY3VzZWQoZmFsc2UpO1xyXG4gICAgICAgIG9uSW5wdXRCbHVyICYmIHR5cGVvZiBvbklucHV0Qmx1ciA9PT0gJ2Z1bmN0aW9uJyAmJiBvbklucHV0Qmx1cihlKTtcclxuICAgIH1cclxuICAgIGZ1bmN0aW9uIGhhbmRsZUZvY3VzKGUpIHtcclxuICAgICAgICBzZXRJc0ZvY3VzZWQodHJ1ZSk7XHJcbiAgICAgICAgb25JbnB1dEZvY3VzICYmIHR5cGVvZiBvbklucHV0Rm9jdXMgPT09ICdmdW5jdGlvbicgJiYgb25JbnB1dEZvY3VzKGUpO1xyXG4gICAgfVxyXG4gICAgY29uc3QgaW5wdXRQcm9wcyA9IGdldElucHV0UHJvcHMoe1xyXG4gICAgICAgIGRpc2FibGVkOiBkaXNhYmxlZCxcclxuICAgICAgICBvbkJsdXI6IGhhbmRsZUJsdXIsXHJcbiAgICAgICAgb25Gb2N1czogaGFuZGxlRm9jdXMsXHJcbiAgICAgICAgb25LZXlEb3duOiBvbklucHV0S2V5RG93bixcclxuICAgICAgICBvbktleVByZXNzOiBvbklucHV0S2V5UHJlc3MsXHJcbiAgICAgICAgb25LZXlVcDogb25JbnB1dEtleVVwLFxyXG4gICAgICAgIC4uLihpbm5lclJlZiAmJiB7IHJlZjogaW5uZXJSZWYgfSksXHJcbiAgICB9KTtcclxuICAgIGNvbnN0IGRyb3Bkb3duSW5kaWNhdG9yQ29sb3IgPSAoKSA9PiB7XHJcbiAgICAgICAgaWYgKGRpc2FibGVkKSB7XHJcbiAgICAgICAgICAgIGlmIChpc0ludmVyc2UpIHtcclxuICAgICAgICAgICAgICAgIHJldHVybiB0cmFuc3BhcmVudGl6ZSgwLjYsIHRoZW1lLmNvbG9ycy5uZXV0cmFsMTAwKTtcclxuICAgICAgICAgICAgfVxyXG4gICAgICAgICAgICByZXR1cm4gdGhlbWUuY29sb3JzLm5ldXRyYWw1MDA7XHJcbiAgICAgICAgfVxyXG4gICAgICAgIGlmIChpc0ludmVyc2UpIHtcclxuICAgICAgICAgICAgcmV0dXJuIHRoZW1lLmNvbG9ycy5uZXV0cmFsMTAwO1xyXG4gICAgICAgIH1cclxuICAgICAgICByZXR1cm4gdGhlbWUuY29sb3JzLm5ldXRyYWw7XHJcbiAgICB9O1xyXG4gICAgcmV0dXJuIChSZWFjdC5jcmVhdGVFbGVtZW50KFwiZGl2XCIsIHsgcmVmOiBzZXRSZWZlcmVuY2UgfSxcclxuICAgICAgICBSZWFjdC5jcmVhdGVFbGVtZW50KENvbWJvQm94Q29udGFpbmVyLCBPYmplY3QuYXNzaWduKHt9LCBnZXRDb21ib2JveFByb3BzKCksIHsgaGFzRXJyb3I6IGhhc0Vycm9yLCBkaXNhYmxlZDogZGlzYWJsZWQsIGlzSW52ZXJzZTogaXNJbnZlcnNlLCB0aGVtZTogdGhlbWUgfSksXHJcbiAgICAgICAgICAgIFJlYWN0LmNyZWF0ZUVsZW1lbnQoSW5wdXRDb250YWluZXIsIE9iamVjdC5hc3NpZ24oe30sIGdldFRvZ2dsZUJ1dHRvblByb3BzKHtcclxuICAgICAgICAgICAgICAgIGRpc2FibGVkLFxyXG4gICAgICAgICAgICAgICAgLi4uKHRvZ2dsZUJ1dHRvblJlZiAmJiB7IHJlZjogdG9nZ2xlQnV0dG9uUmVmIH0pLFxyXG4gICAgICAgICAgICB9KSwgeyBoYXNFcnJvcjogaGFzRXJyb3IsIGRpc2FibGVkOiBkaXNhYmxlZCwgaXNGb2N1c2VkOiBpc0ZvY3VzZWQsIGlzSW52ZXJzZTogaXNJbnZlcnNlLCBzdHlsZTogaW5wdXRTdHlsZSwgdGhlbWU6IHRoZW1lLCByZWY6IGlubmVyUmVmIH0pLFxyXG4gICAgICAgICAgICAgICAgUmVhY3QuY3JlYXRlRWxlbWVudChTZWxlY3RlZEl0ZW1zV3JhcHBlciwgbnVsbCxcclxuICAgICAgICAgICAgICAgICAgICBzZWxlY3RlZEl0ZW1zLFxyXG4gICAgICAgICAgICAgICAgICAgIFJlYWN0LmNyZWF0ZUVsZW1lbnQoU3R5bGVkSW5wdXQsIE9iamVjdC5hc3NpZ24oe30sIGlucHV0UHJvcHMsIHsgXCJhcmlhLWRlc2NyaWJlZGJ5XCI6IGFyaWFEZXNjcmliZWRCeSwgXCJhcmlhLWludmFsaWRcIjogaGFzRXJyb3IsIGRpc2FibGVkOiBkaXNhYmxlZCwgaXNJbnZlcnNlOiBpc0ludmVyc2UsIHBsYWNlaG9sZGVyOiBwbGFjZWhvbGRlciwgdGhlbWU6IHRoZW1lIH0pKSksXHJcbiAgICAgICAgICAgICAgICBjaGlsZHJlbixcclxuICAgICAgICAgICAgICAgIGlzTG9hZGluZyAmJiAhaXNUeXBlYWhlYWQgJiYgKFJlYWN0LmNyZWF0ZUVsZW1lbnQoTG9hZGluZ0luZGljYXRvciwgeyBzdHlsZTogeyBmbGV4U2hyaW5rOiAwLCBtYXJnaW5SaWdodDogdGhlbWUuc3BhY2VTY2FsZS5zcGFjaW5nMDIgfSB9KSksXHJcbiAgICAgICAgICAgICAgICBSZWFjdC5jcmVhdGVFbGVtZW50KERyb3Bkb3duSW5kaWNhdG9yLCB7IFwiYXJpYS1sYWJlbFwiOiBcInRvZ2dsZSBtZW51XCIsIGNvbG9yOiBkcm9wZG93bkluZGljYXRvckNvbG9yKCkgfSkpKSkpO1xyXG59XHJcbi8vIyBzb3VyY2VNYXBwaW5nVVJMPUNvbWJvYm94SW5wdXQuanMubWFwIl19 */"));
|
|
12318
12310
|
}, " ", function (props) {
|
|
12319
|
-
return props.disabled && /*#__PURE__*/react.css("background:", props.isInverse ? polished.transparentize(0.9, props.theme.colors.neutral900) : props.theme.colors.neutral200, ";border-color:", props.isInverse ? polished.transparentize(0.85, props.theme.colors.neutral100) : props.theme.colors.neutral300, ";color:", polished.transparentize(0.4, props.theme.colors.neutral500), ";cursor:not-allowed;outline:0;&::placeholder{color:", polished.transparentize(0.4, props.theme.colors.neutral500), ";};label:InputContainer;" + ( "/*# sourceMappingURL=data:application/json;charset=utf-8;base64,eyJ2ZXJzaW9uIjozLCJzb3VyY2VzIjpbIkNvbWJvYm94SW5wdXQudHN4Il0sIm5hbWVzIjpbXSwibWFwcGluZ3MiOiJBQTRDUSIsImZpbGUiOiJDb21ib2JveElucHV0LnRzeCIsInNvdXJjZXNDb250ZW50IjpbImltcG9ydCBSZWFjdCBmcm9tICdyZWFjdCc7XHJcbmltcG9ydCB7IGNzcyB9IGZyb20gJ0BlbW90aW9uL3JlYWN0JztcclxuaW1wb3J0IHN0eWxlZCBmcm9tICdAZW1vdGlvbi9zdHlsZWQnO1xyXG5pbXBvcnQgeyB0cmFuc3BhcmVudGl6ZSB9IGZyb20gJ3BvbGlzaGVkJztcclxuaW1wb3J0IHsgVGhlbWVDb250ZXh0IH0gZnJvbSAnLi4vLi4vdGhlbWUvVGhlbWVDb250ZXh0JztcclxuaW1wb3J0IHsgaW5wdXRCYXNlU3R5bGVzIH0gZnJvbSAnLi4vSW5wdXRCYXNlJztcclxuaW1wb3J0IHsgZGVmYXVsdENvbXBvbmVudHMgfSBmcm9tICcuLi9TZWxlY3QvY29tcG9uZW50cyc7XHJcbmltcG9ydCB7IFNlbGVjdGVkSXRlbXNXcmFwcGVyIH0gZnJvbSAnLi4vU2VsZWN0L3NoYXJlZCc7XHJcbmNvbnN0IENvbWJvQm94Q29udGFpbmVyID0gc3R5bGVkLmRpdiBgXG4gIGRpc3BsYXk6IGZsZXg7XG5gO1xyXG5jb25zdCBJbnB1dENvbnRhaW5lciA9IHN0eWxlZC5kaXYgYFxuICBhbGlnbi1pdGVtczogY2VudGVyO1xuICBiYWNrZ3JvdW5kLWNvbG9yOiAke3Byb3BzID0+IHByb3BzLmlzSW52ZXJzZVxyXG4gICAgPyB0cmFuc3BhcmVudGl6ZSgwLjgsIHByb3BzLnRoZW1lLmNvbG9ycy5uZXV0cmFsOTAwKVxyXG4gICAgOiBwcm9wcy50aGVtZS5jb2xvcnMubmV1dHJhbDEwMH07XG4gIGJvcmRlcjogMXB4IHNvbGlkO1xuICBib3JkZXItY29sb3I6ICR7cHJvcHMgPT4gcHJvcHMuaXNJbnZlcnNlXHJcbiAgICA/IHRyYW5zcGFyZW50aXplKDAuNSwgcHJvcHMudGhlbWUuY29sb3JzLm5ldXRyYWwxMDApXHJcbiAgICA6IHByb3BzLnRoZW1lLmNvbG9ycy5uZXV0cmFsNTAwfTtcbiAgYm9yZGVyLXJhZGl1czogJHtwcm9wcyA9PiBwcm9wcy50aGVtZS5ib3JkZXJSYWRpdXN9O1xuICBkaXNwbGF5OiBmbGV4O1xuICBtaW4taGVpZ2h0OiAke3Byb3BzID0+IHByb3BzLnRoZW1lLnNwYWNlU2NhbGUuc3BhY2luZzA5fTtcbiAgbWluLXdpZHRoOiAke3Byb3BzID0+IHByb3BzLnRoZW1lLnNwYWNlU2NhbGUuc3BhY2luZzEzfTtcbiAgcGFkZGluZzogMCAke3Byb3BzID0+IHByb3BzLnRoZW1lLnNwYWNlU2NhbGUuc3BhY2luZzAzfSAwIDA7XG4gIHdpZHRoOiAxMDAlO1xuXG4gICR7cHJvcHMgPT4gcHJvcHMuaXNGb2N1c2VkICYmXHJcbiAgICBjc3MgYFxuICAgICAgb3V0bGluZTogMnB4IHNvbGlkXG4gICAgICAgICR7cHJvcHMuaXNJbnZlcnNlXHJcbiAgICAgICAgPyBwcm9wcy50aGVtZS5jb2xvcnMuZm9jdXNJbnZlcnNlXHJcbiAgICAgICAgOiBwcm9wcy50aGVtZS5jb2xvcnMuZm9jdXN9O1xuICAgICAgb3V0bGluZS1vZmZzZXQ6IC0xcHg7XG4gICAgYH1cblxuICAke3Byb3BzID0+IHByb3BzLmhhc0Vycm9yICYmXHJcbiAgICBjc3MgYFxuICAgICAgYm9yZGVyLWNvbG9yOiAke3Byb3BzLmlzSW52ZXJzZVxyXG4gICAgICAgID8gcHJvcHMudGhlbWUuY29sb3JzLmRhbmdlcjIwMFxyXG4gICAgICAgIDogcHJvcHMudGhlbWUuY29sb3JzLmRhbmdlcn07XG4gICAgYH1cblxuICAgICR7cHJvcHMgPT4gcHJvcHMuZGlzYWJsZWQgJiZcclxuICAgIGNzcyBgXG4gICAgICBiYWNrZ3JvdW5kOiAke3Byb3BzLmlzSW52ZXJzZVxyXG4gICAgICAgID8gdHJhbnNwYXJlbnRpemUoMC45LCBwcm9wcy50aGVtZS5jb2xvcnMubmV1dHJhbDkwMClcclxuICAgICAgICA6IHByb3BzLnRoZW1lLmNvbG9ycy5uZXV0cmFsMjAwfTtcbiAgICAgIGJvcmRlci1jb2xvcjogJHtwcm9wcy5pc0ludmVyc2VcclxuICAgICAgICA/
|
|
12320
|
-
}, ";" + ( "/*# sourceMappingURL=data:application/json;charset=utf-8;base64,eyJ2ZXJzaW9uIjozLCJzb3VyY2VzIjpbIkNvbWJvYm94SW5wdXQudHN4Il0sIm5hbWVzIjpbXSwibWFwcGluZ3MiOiJBQVdrQyIsImZpbGUiOiJDb21ib2JveElucHV0LnRzeCIsInNvdXJjZXNDb250ZW50IjpbImltcG9ydCBSZWFjdCBmcm9tICdyZWFjdCc7XHJcbmltcG9ydCB7IGNzcyB9IGZyb20gJ0BlbW90aW9uL3JlYWN0JztcclxuaW1wb3J0IHN0eWxlZCBmcm9tICdAZW1vdGlvbi9zdHlsZWQnO1xyXG5pbXBvcnQgeyB0cmFuc3BhcmVudGl6ZSB9IGZyb20gJ3BvbGlzaGVkJztcclxuaW1wb3J0IHsgVGhlbWVDb250ZXh0IH0gZnJvbSAnLi4vLi4vdGhlbWUvVGhlbWVDb250ZXh0JztcclxuaW1wb3J0IHsgaW5wdXRCYXNlU3R5bGVzIH0gZnJvbSAnLi4vSW5wdXRCYXNlJztcclxuaW1wb3J0IHsgZGVmYXVsdENvbXBvbmVudHMgfSBmcm9tICcuLi9TZWxlY3QvY29tcG9uZW50cyc7XHJcbmltcG9ydCB7IFNlbGVjdGVkSXRlbXNXcmFwcGVyIH0gZnJvbSAnLi4vU2VsZWN0L3NoYXJlZCc7XHJcbmNvbnN0IENvbWJvQm94Q29udGFpbmVyID0gc3R5bGVkLmRpdiBgXG4gIGRpc3BsYXk6IGZsZXg7XG5gO1xyXG5jb25zdCBJbnB1dENvbnRhaW5lciA9IHN0eWxlZC5kaXYgYFxuICBhbGlnbi1pdGVtczogY2VudGVyO1xuICBiYWNrZ3JvdW5kLWNvbG9yOiAke3Byb3BzID0+IHByb3BzLmlzSW52ZXJzZVxyXG4gICAgPyB0cmFuc3BhcmVudGl6ZSgwLjgsIHByb3BzLnRoZW1lLmNvbG9ycy5uZXV0cmFsOTAwKVxyXG4gICAgOiBwcm9wcy50aGVtZS5jb2xvcnMubmV1dHJhbDEwMH07XG4gIGJvcmRlcjogMXB4IHNvbGlkO1xuICBib3JkZXItY29sb3I6ICR7cHJvcHMgPT4gcHJvcHMuaXNJbnZlcnNlXHJcbiAgICA/IHRyYW5zcGFyZW50aXplKDAuNSwgcHJvcHMudGhlbWUuY29sb3JzLm5ldXRyYWwxMDApXHJcbiAgICA6IHByb3BzLnRoZW1lLmNvbG9ycy5uZXV0cmFsNTAwfTtcbiAgYm9yZGVyLXJhZGl1czogJHtwcm9wcyA9PiBwcm9wcy50aGVtZS5ib3JkZXJSYWRpdXN9O1xuICBkaXNwbGF5OiBmbGV4O1xuICBtaW4taGVpZ2h0OiAke3Byb3BzID0+IHByb3BzLnRoZW1lLnNwYWNlU2NhbGUuc3BhY2luZzA5fTtcbiAgbWluLXdpZHRoOiAke3Byb3BzID0+IHByb3BzLnRoZW1lLnNwYWNlU2NhbGUuc3BhY2luZzEzfTtcbiAgcGFkZGluZzogMCAke3Byb3BzID0+IHByb3BzLnRoZW1lLnNwYWNlU2NhbGUuc3BhY2luZzAzfSAwIDA7XG4gIHdpZHRoOiAxMDAlO1xuXG4gICR7cHJvcHMgPT4gcHJvcHMuaXNGb2N1c2VkICYmXHJcbiAgICBjc3MgYFxuICAgICAgb3V0bGluZTogMnB4IHNvbGlkXG4gICAgICAgICR7cHJvcHMuaXNJbnZlcnNlXHJcbiAgICAgICAgPyBwcm9wcy50aGVtZS5jb2xvcnMuZm9jdXNJbnZlcnNlXHJcbiAgICAgICAgOiBwcm9wcy50aGVtZS5jb2xvcnMuZm9jdXN9O1xuICAgICAgb3V0bGluZS1vZmZzZXQ6IC0xcHg7XG4gICAgYH1cblxuICAke3Byb3BzID0+IHByb3BzLmhhc0Vycm9yICYmXHJcbiAgICBjc3MgYFxuICAgICAgYm9yZGVyLWNvbG9yOiAke3Byb3BzLmlzSW52ZXJzZVxyXG4gICAgICAgID8gcHJvcHMudGhlbWUuY29sb3JzLmRhbmdlcjIwMFxyXG4gICAgICAgIDogcHJvcHMudGhlbWUuY29sb3JzLmRhbmdlcn07XG4gICAgYH1cblxuICAgICR7cHJvcHMgPT4gcHJvcHMuZGlzYWJsZWQgJiZcclxuICAgIGNzcyBgXG4gICAgICBiYWNrZ3JvdW5kOiAke3Byb3BzLmlzSW52ZXJzZVxyXG4gICAgICAgID8gdHJhbnNwYXJlbnRpemUoMC45LCBwcm9wcy50aGVtZS5jb2xvcnMubmV1dHJhbDkwMClcclxuICAgICAgICA6IHByb3BzLnRoZW1lLmNvbG9ycy5uZXV0cmFsMjAwfTtcbiAgICAgIGJvcmRlci1jb2xvcjogJHtwcm9wcy5pc0ludmVyc2VcclxuICAgICAgICA/
|
|
12311
|
+
return props.disabled && /*#__PURE__*/react.css("background:", props.isInverse ? polished.transparentize(0.9, props.theme.colors.neutral900) : props.theme.colors.neutral200, ";border-color:", props.isInverse ? polished.transparentize(0.85, props.theme.colors.neutral100) : props.theme.colors.neutral300, ";color:", polished.transparentize(0.4, props.theme.colors.neutral500), ";cursor:not-allowed;outline:0;&::placeholder{color:", polished.transparentize(0.4, props.theme.colors.neutral500), ";};label:InputContainer;" + ( "/*# sourceMappingURL=data:application/json;charset=utf-8;base64,eyJ2ZXJzaW9uIjozLCJzb3VyY2VzIjpbIkNvbWJvYm94SW5wdXQudHN4Il0sIm5hbWVzIjpbXSwibWFwcGluZ3MiOiJBQTRDUSIsImZpbGUiOiJDb21ib2JveElucHV0LnRzeCIsInNvdXJjZXNDb250ZW50IjpbImltcG9ydCBSZWFjdCBmcm9tICdyZWFjdCc7XHJcbmltcG9ydCB7IGNzcyB9IGZyb20gJ0BlbW90aW9uL3JlYWN0JztcclxuaW1wb3J0IHN0eWxlZCBmcm9tICdAZW1vdGlvbi9zdHlsZWQnO1xyXG5pbXBvcnQgeyB0cmFuc3BhcmVudGl6ZSB9IGZyb20gJ3BvbGlzaGVkJztcclxuaW1wb3J0IHsgVGhlbWVDb250ZXh0IH0gZnJvbSAnLi4vLi4vdGhlbWUvVGhlbWVDb250ZXh0JztcclxuaW1wb3J0IHsgaW5wdXRCYXNlU3R5bGVzIH0gZnJvbSAnLi4vSW5wdXRCYXNlJztcclxuaW1wb3J0IHsgZGVmYXVsdENvbXBvbmVudHMgfSBmcm9tICcuLi9TZWxlY3QvY29tcG9uZW50cyc7XHJcbmltcG9ydCB7IFNlbGVjdGVkSXRlbXNXcmFwcGVyIH0gZnJvbSAnLi4vU2VsZWN0L3NoYXJlZCc7XHJcbmNvbnN0IENvbWJvQm94Q29udGFpbmVyID0gc3R5bGVkLmRpdiBgXG4gIGRpc3BsYXk6IGZsZXg7XG5gO1xyXG5jb25zdCBJbnB1dENvbnRhaW5lciA9IHN0eWxlZC5kaXYgYFxuICBhbGlnbi1pdGVtczogY2VudGVyO1xuICBiYWNrZ3JvdW5kLWNvbG9yOiAke3Byb3BzID0+IHByb3BzLmlzSW52ZXJzZVxyXG4gICAgPyB0cmFuc3BhcmVudGl6ZSgwLjgsIHByb3BzLnRoZW1lLmNvbG9ycy5uZXV0cmFsOTAwKVxyXG4gICAgOiBwcm9wcy50aGVtZS5jb2xvcnMubmV1dHJhbDEwMH07XG4gIGJvcmRlcjogMXB4IHNvbGlkO1xuICBib3JkZXItY29sb3I6ICR7cHJvcHMgPT4gcHJvcHMuaXNJbnZlcnNlXHJcbiAgICA/IHRyYW5zcGFyZW50aXplKDAuNSwgcHJvcHMudGhlbWUuY29sb3JzLm5ldXRyYWwxMDApXHJcbiAgICA6IHByb3BzLnRoZW1lLmNvbG9ycy5uZXV0cmFsNTAwfTtcbiAgYm9yZGVyLXJhZGl1czogJHtwcm9wcyA9PiBwcm9wcy50aGVtZS5ib3JkZXJSYWRpdXN9O1xuICBkaXNwbGF5OiBmbGV4O1xuICBtaW4taGVpZ2h0OiAke3Byb3BzID0+IHByb3BzLnRoZW1lLnNwYWNlU2NhbGUuc3BhY2luZzA5fTtcbiAgbWluLXdpZHRoOiAke3Byb3BzID0+IHByb3BzLnRoZW1lLnNwYWNlU2NhbGUuc3BhY2luZzEzfTtcbiAgcGFkZGluZzogMCAke3Byb3BzID0+IHByb3BzLnRoZW1lLnNwYWNlU2NhbGUuc3BhY2luZzAzfSAwIDA7XG4gIHdpZHRoOiAxMDAlO1xuXG4gICR7cHJvcHMgPT4gcHJvcHMuaXNGb2N1c2VkICYmXHJcbiAgICBjc3MgYFxuICAgICAgb3V0bGluZTogMnB4IHNvbGlkXG4gICAgICAgICR7cHJvcHMuaXNJbnZlcnNlXHJcbiAgICAgICAgPyBwcm9wcy50aGVtZS5jb2xvcnMuZm9jdXNJbnZlcnNlXHJcbiAgICAgICAgOiBwcm9wcy50aGVtZS5jb2xvcnMuZm9jdXN9O1xuICAgICAgb3V0bGluZS1vZmZzZXQ6IC0xcHg7XG4gICAgYH1cblxuICAke3Byb3BzID0+IHByb3BzLmhhc0Vycm9yICYmXHJcbiAgICBjc3MgYFxuICAgICAgYm9yZGVyLWNvbG9yOiAke3Byb3BzLmlzSW52ZXJzZVxyXG4gICAgICAgID8gcHJvcHMudGhlbWUuY29sb3JzLmRhbmdlcjIwMFxyXG4gICAgICAgIDogcHJvcHMudGhlbWUuY29sb3JzLmRhbmdlcn07XG4gICAgYH1cblxuICAgICR7cHJvcHMgPT4gcHJvcHMuZGlzYWJsZWQgJiZcclxuICAgIGNzcyBgXG4gICAgICBiYWNrZ3JvdW5kOiAke3Byb3BzLmlzSW52ZXJzZVxyXG4gICAgICAgID8gdHJhbnNwYXJlbnRpemUoMC45LCBwcm9wcy50aGVtZS5jb2xvcnMubmV1dHJhbDkwMClcclxuICAgICAgICA6IHByb3BzLnRoZW1lLmNvbG9ycy5uZXV0cmFsMjAwfTtcbiAgICAgIGJvcmRlci1jb2xvcjogJHtwcm9wcy5pc0ludmVyc2VcclxuICAgICAgICA/IHRyYW5zcGFyZW50aXplKDAuODUsIHByb3BzLnRoZW1lLmNvbG9ycy5uZXV0cmFsMTAwKVxyXG4gICAgICAgIDogcHJvcHMudGhlbWUuY29sb3JzLm5ldXRyYWwzMDB9O1xuICAgICAgY29sb3I6ICR7dHJhbnNwYXJlbnRpemUoMC40LCBwcm9wcy50aGVtZS5jb2xvcnMubmV1dHJhbDUwMCl9O1xuICAgICAgY3Vyc29yOiBub3QtYWxsb3dlZDtcbiAgICAgIG91dGxpbmU6IDA7XG5cbiAgICAgICY6OnBsYWNlaG9sZGVyIHtcbiAgICAgICAgY29sb3I6ICR7dHJhbnNwYXJlbnRpemUoMC40LCBwcm9wcy50aGVtZS5jb2xvcnMubmV1dHJhbDUwMCl9O1xuICAgICAgfVxuICAgIGB9XG5gO1xyXG5jb25zdCBTdHlsZWRJbnB1dCA9IHN0eWxlZC5pbnB1dCBgXG4gICR7aW5wdXRCYXNlU3R5bGVzfVxuICBkaXNwbGF5OiBmbGV4O1xuICBmbGV4LWdyb3c6IDE7XG4gIG1pbi13aWR0aDogJHtwcm9wcyA9PiBwcm9wcy50aGVtZS5zcGFjZVNjYWxlLnNwYWNpbmcwN307XG4gIHBhZGRpbmctbGVmdDogJHtwcm9wcyA9PiBwcm9wcy50aGVtZS5zcGFjZVNjYWxlLnNwYWNpbmcwMn07XG4gIHdpZHRoOiAwO1xuICBoZWlnaHQ6IDM4cHg7XG5cbiAgJjpmb2N1cyB7XG4gICAgb3V0bGluZTogMDtcbiAgfVxuYDtcclxuZXhwb3J0IGZ1bmN0aW9uIENvbWJvYm94SW5wdXQocHJvcHMpIHtcclxuICAgIGNvbnN0IHsgYXJpYURlc2NyaWJlZEJ5LCBjaGlsZHJlbiwgY3VzdG9tQ29tcG9uZW50cywgZ2V0Q29tYm9ib3hQcm9wcywgZ2V0SW5wdXRQcm9wcywgZ2V0VG9nZ2xlQnV0dG9uUHJvcHMsIGhhc0Vycm9yLCBpbm5lclJlZiwgaW5wdXRTdHlsZSwgZGlzYWJsZWQsIGlzSW52ZXJzZSwgaXNMb2FkaW5nLCBpc1R5cGVhaGVhZCwgb25JbnB1dEJsdXIsIG9uSW5wdXRGb2N1cywgb25JbnB1dEtleURvd24sIG9uSW5wdXRLZXlQcmVzcywgb25JbnB1dEtleVVwLCBwbGFjZWhvbGRlciwgc2VsZWN0ZWRJdGVtcywgc2V0UmVmZXJlbmNlLCB0b2dnbGVCdXR0b25SZWYsIH0gPSBwcm9wcztcclxuICAgIGNvbnN0IHRoZW1lID0gUmVhY3QudXNlQ29udGV4dChUaGVtZUNvbnRleHQpO1xyXG4gICAgY29uc3QgW2lzRm9jdXNlZCwgc2V0SXNGb2N1c2VkXSA9IFJlYWN0LnVzZVN0YXRlKGZhbHNlKTtcclxuICAgIGNvbnN0IHsgRHJvcGRvd25JbmRpY2F0b3IsIExvYWRpbmdJbmRpY2F0b3IgfSA9IGRlZmF1bHRDb21wb25lbnRzKHtcclxuICAgICAgICAuLi5jdXN0b21Db21wb25lbnRzLFxyXG4gICAgfSk7XHJcbiAgICBmdW5jdGlvbiBoYW5kbGVCbHVyKGUpIHtcclxuICAgICAgICBzZXRJc0ZvY3VzZWQoZmFsc2UpO1xyXG4gICAgICAgIG9uSW5wdXRCbHVyICYmIHR5cGVvZiBvbklucHV0Qmx1ciA9PT0gJ2Z1bmN0aW9uJyAmJiBvbklucHV0Qmx1cihlKTtcclxuICAgIH1cclxuICAgIGZ1bmN0aW9uIGhhbmRsZUZvY3VzKGUpIHtcclxuICAgICAgICBzZXRJc0ZvY3VzZWQodHJ1ZSk7XHJcbiAgICAgICAgb25JbnB1dEZvY3VzICYmIHR5cGVvZiBvbklucHV0Rm9jdXMgPT09ICdmdW5jdGlvbicgJiYgb25JbnB1dEZvY3VzKGUpO1xyXG4gICAgfVxyXG4gICAgY29uc3QgaW5wdXRQcm9wcyA9IGdldElucHV0UHJvcHMoe1xyXG4gICAgICAgIGRpc2FibGVkOiBkaXNhYmxlZCxcclxuICAgICAgICBvbkJsdXI6IGhhbmRsZUJsdXIsXHJcbiAgICAgICAgb25Gb2N1czogaGFuZGxlRm9jdXMsXHJcbiAgICAgICAgb25LZXlEb3duOiBvbklucHV0S2V5RG93bixcclxuICAgICAgICBvbktleVByZXNzOiBvbklucHV0S2V5UHJlc3MsXHJcbiAgICAgICAgb25LZXlVcDogb25JbnB1dEtleVVwLFxyXG4gICAgICAgIC4uLihpbm5lclJlZiAmJiB7IHJlZjogaW5uZXJSZWYgfSksXHJcbiAgICB9KTtcclxuICAgIGNvbnN0IGRyb3Bkb3duSW5kaWNhdG9yQ29sb3IgPSAoKSA9PiB7XHJcbiAgICAgICAgaWYgKGRpc2FibGVkKSB7XHJcbiAgICAgICAgICAgIGlmIChpc0ludmVyc2UpIHtcclxuICAgICAgICAgICAgICAgIHJldHVybiB0cmFuc3BhcmVudGl6ZSgwLjYsIHRoZW1lLmNvbG9ycy5uZXV0cmFsMTAwKTtcclxuICAgICAgICAgICAgfVxyXG4gICAgICAgICAgICByZXR1cm4gdGhlbWUuY29sb3JzLm5ldXRyYWw1MDA7XHJcbiAgICAgICAgfVxyXG4gICAgICAgIGlmIChpc0ludmVyc2UpIHtcclxuICAgICAgICAgICAgcmV0dXJuIHRoZW1lLmNvbG9ycy5uZXV0cmFsMTAwO1xyXG4gICAgICAgIH1cclxuICAgICAgICByZXR1cm4gdGhlbWUuY29sb3JzLm5ldXRyYWw7XHJcbiAgICB9O1xyXG4gICAgcmV0dXJuIChSZWFjdC5jcmVhdGVFbGVtZW50KFwiZGl2XCIsIHsgcmVmOiBzZXRSZWZlcmVuY2UgfSxcclxuICAgICAgICBSZWFjdC5jcmVhdGVFbGVtZW50KENvbWJvQm94Q29udGFpbmVyLCBPYmplY3QuYXNzaWduKHt9LCBnZXRDb21ib2JveFByb3BzKCksIHsgaGFzRXJyb3I6IGhhc0Vycm9yLCBkaXNhYmxlZDogZGlzYWJsZWQsIGlzSW52ZXJzZTogaXNJbnZlcnNlLCB0aGVtZTogdGhlbWUgfSksXHJcbiAgICAgICAgICAgIFJlYWN0LmNyZWF0ZUVsZW1lbnQoSW5wdXRDb250YWluZXIsIE9iamVjdC5hc3NpZ24oe30sIGdldFRvZ2dsZUJ1dHRvblByb3BzKHtcclxuICAgICAgICAgICAgICAgIGRpc2FibGVkLFxyXG4gICAgICAgICAgICAgICAgLi4uKHRvZ2dsZUJ1dHRvblJlZiAmJiB7IHJlZjogdG9nZ2xlQnV0dG9uUmVmIH0pLFxyXG4gICAgICAgICAgICB9KSwgeyBoYXNFcnJvcjogaGFzRXJyb3IsIGRpc2FibGVkOiBkaXNhYmxlZCwgaXNGb2N1c2VkOiBpc0ZvY3VzZWQsIGlzSW52ZXJzZTogaXNJbnZlcnNlLCBzdHlsZTogaW5wdXRTdHlsZSwgdGhlbWU6IHRoZW1lLCByZWY6IGlubmVyUmVmIH0pLFxyXG4gICAgICAgICAgICAgICAgUmVhY3QuY3JlYXRlRWxlbWVudChTZWxlY3RlZEl0ZW1zV3JhcHBlciwgbnVsbCxcclxuICAgICAgICAgICAgICAgICAgICBzZWxlY3RlZEl0ZW1zLFxyXG4gICAgICAgICAgICAgICAgICAgIFJlYWN0LmNyZWF0ZUVsZW1lbnQoU3R5bGVkSW5wdXQsIE9iamVjdC5hc3NpZ24oe30sIGlucHV0UHJvcHMsIHsgXCJhcmlhLWRlc2NyaWJlZGJ5XCI6IGFyaWFEZXNjcmliZWRCeSwgXCJhcmlhLWludmFsaWRcIjogaGFzRXJyb3IsIGRpc2FibGVkOiBkaXNhYmxlZCwgaXNJbnZlcnNlOiBpc0ludmVyc2UsIHBsYWNlaG9sZGVyOiBwbGFjZWhvbGRlciwgdGhlbWU6IHRoZW1lIH0pKSksXHJcbiAgICAgICAgICAgICAgICBjaGlsZHJlbixcclxuICAgICAgICAgICAgICAgIGlzTG9hZGluZyAmJiAhaXNUeXBlYWhlYWQgJiYgKFJlYWN0LmNyZWF0ZUVsZW1lbnQoTG9hZGluZ0luZGljYXRvciwgeyBzdHlsZTogeyBmbGV4U2hyaW5rOiAwLCBtYXJnaW5SaWdodDogdGhlbWUuc3BhY2VTY2FsZS5zcGFjaW5nMDIgfSB9KSksXHJcbiAgICAgICAgICAgICAgICBSZWFjdC5jcmVhdGVFbGVtZW50KERyb3Bkb3duSW5kaWNhdG9yLCB7IFwiYXJpYS1sYWJlbFwiOiBcInRvZ2dsZSBtZW51XCIsIGNvbG9yOiBkcm9wZG93bkluZGljYXRvckNvbG9yKCkgfSkpKSkpO1xyXG59XHJcbi8vIyBzb3VyY2VNYXBwaW5nVVJMPUNvbWJvYm94SW5wdXQuanMubWFwIl19 */"));
|
|
12312
|
+
}, ";" + ( "/*# sourceMappingURL=data:application/json;charset=utf-8;base64,eyJ2ZXJzaW9uIjozLCJzb3VyY2VzIjpbIkNvbWJvYm94SW5wdXQudHN4Il0sIm5hbWVzIjpbXSwibWFwcGluZ3MiOiJBQVdrQyIsImZpbGUiOiJDb21ib2JveElucHV0LnRzeCIsInNvdXJjZXNDb250ZW50IjpbImltcG9ydCBSZWFjdCBmcm9tICdyZWFjdCc7XHJcbmltcG9ydCB7IGNzcyB9IGZyb20gJ0BlbW90aW9uL3JlYWN0JztcclxuaW1wb3J0IHN0eWxlZCBmcm9tICdAZW1vdGlvbi9zdHlsZWQnO1xyXG5pbXBvcnQgeyB0cmFuc3BhcmVudGl6ZSB9IGZyb20gJ3BvbGlzaGVkJztcclxuaW1wb3J0IHsgVGhlbWVDb250ZXh0IH0gZnJvbSAnLi4vLi4vdGhlbWUvVGhlbWVDb250ZXh0JztcclxuaW1wb3J0IHsgaW5wdXRCYXNlU3R5bGVzIH0gZnJvbSAnLi4vSW5wdXRCYXNlJztcclxuaW1wb3J0IHsgZGVmYXVsdENvbXBvbmVudHMgfSBmcm9tICcuLi9TZWxlY3QvY29tcG9uZW50cyc7XHJcbmltcG9ydCB7IFNlbGVjdGVkSXRlbXNXcmFwcGVyIH0gZnJvbSAnLi4vU2VsZWN0L3NoYXJlZCc7XHJcbmNvbnN0IENvbWJvQm94Q29udGFpbmVyID0gc3R5bGVkLmRpdiBgXG4gIGRpc3BsYXk6IGZsZXg7XG5gO1xyXG5jb25zdCBJbnB1dENvbnRhaW5lciA9IHN0eWxlZC5kaXYgYFxuICBhbGlnbi1pdGVtczogY2VudGVyO1xuICBiYWNrZ3JvdW5kLWNvbG9yOiAke3Byb3BzID0+IHByb3BzLmlzSW52ZXJzZVxyXG4gICAgPyB0cmFuc3BhcmVudGl6ZSgwLjgsIHByb3BzLnRoZW1lLmNvbG9ycy5uZXV0cmFsOTAwKVxyXG4gICAgOiBwcm9wcy50aGVtZS5jb2xvcnMubmV1dHJhbDEwMH07XG4gIGJvcmRlcjogMXB4IHNvbGlkO1xuICBib3JkZXItY29sb3I6ICR7cHJvcHMgPT4gcHJvcHMuaXNJbnZlcnNlXHJcbiAgICA/IHRyYW5zcGFyZW50aXplKDAuNSwgcHJvcHMudGhlbWUuY29sb3JzLm5ldXRyYWwxMDApXHJcbiAgICA6IHByb3BzLnRoZW1lLmNvbG9ycy5uZXV0cmFsNTAwfTtcbiAgYm9yZGVyLXJhZGl1czogJHtwcm9wcyA9PiBwcm9wcy50aGVtZS5ib3JkZXJSYWRpdXN9O1xuICBkaXNwbGF5OiBmbGV4O1xuICBtaW4taGVpZ2h0OiAke3Byb3BzID0+IHByb3BzLnRoZW1lLnNwYWNlU2NhbGUuc3BhY2luZzA5fTtcbiAgbWluLXdpZHRoOiAke3Byb3BzID0+IHByb3BzLnRoZW1lLnNwYWNlU2NhbGUuc3BhY2luZzEzfTtcbiAgcGFkZGluZzogMCAke3Byb3BzID0+IHByb3BzLnRoZW1lLnNwYWNlU2NhbGUuc3BhY2luZzAzfSAwIDA7XG4gIHdpZHRoOiAxMDAlO1xuXG4gICR7cHJvcHMgPT4gcHJvcHMuaXNGb2N1c2VkICYmXHJcbiAgICBjc3MgYFxuICAgICAgb3V0bGluZTogMnB4IHNvbGlkXG4gICAgICAgICR7cHJvcHMuaXNJbnZlcnNlXHJcbiAgICAgICAgPyBwcm9wcy50aGVtZS5jb2xvcnMuZm9jdXNJbnZlcnNlXHJcbiAgICAgICAgOiBwcm9wcy50aGVtZS5jb2xvcnMuZm9jdXN9O1xuICAgICAgb3V0bGluZS1vZmZzZXQ6IC0xcHg7XG4gICAgYH1cblxuICAke3Byb3BzID0+IHByb3BzLmhhc0Vycm9yICYmXHJcbiAgICBjc3MgYFxuICAgICAgYm9yZGVyLWNvbG9yOiAke3Byb3BzLmlzSW52ZXJzZVxyXG4gICAgICAgID8gcHJvcHMudGhlbWUuY29sb3JzLmRhbmdlcjIwMFxyXG4gICAgICAgIDogcHJvcHMudGhlbWUuY29sb3JzLmRhbmdlcn07XG4gICAgYH1cblxuICAgICR7cHJvcHMgPT4gcHJvcHMuZGlzYWJsZWQgJiZcclxuICAgIGNzcyBgXG4gICAgICBiYWNrZ3JvdW5kOiAke3Byb3BzLmlzSW52ZXJzZVxyXG4gICAgICAgID8gdHJhbnNwYXJlbnRpemUoMC45LCBwcm9wcy50aGVtZS5jb2xvcnMubmV1dHJhbDkwMClcclxuICAgICAgICA6IHByb3BzLnRoZW1lLmNvbG9ycy5uZXV0cmFsMjAwfTtcbiAgICAgIGJvcmRlci1jb2xvcjogJHtwcm9wcy5pc0ludmVyc2VcclxuICAgICAgICA/IHRyYW5zcGFyZW50aXplKDAuODUsIHByb3BzLnRoZW1lLmNvbG9ycy5uZXV0cmFsMTAwKVxyXG4gICAgICAgIDogcHJvcHMudGhlbWUuY29sb3JzLm5ldXRyYWwzMDB9O1xuICAgICAgY29sb3I6ICR7dHJhbnNwYXJlbnRpemUoMC40LCBwcm9wcy50aGVtZS5jb2xvcnMubmV1dHJhbDUwMCl9O1xuICAgICAgY3Vyc29yOiBub3QtYWxsb3dlZDtcbiAgICAgIG91dGxpbmU6IDA7XG5cbiAgICAgICY6OnBsYWNlaG9sZGVyIHtcbiAgICAgICAgY29sb3I6ICR7dHJhbnNwYXJlbnRpemUoMC40LCBwcm9wcy50aGVtZS5jb2xvcnMubmV1dHJhbDUwMCl9O1xuICAgICAgfVxuICAgIGB9XG5gO1xyXG5jb25zdCBTdHlsZWRJbnB1dCA9IHN0eWxlZC5pbnB1dCBgXG4gICR7aW5wdXRCYXNlU3R5bGVzfVxuICBkaXNwbGF5OiBmbGV4O1xuICBmbGV4LWdyb3c6IDE7XG4gIG1pbi13aWR0aDogJHtwcm9wcyA9PiBwcm9wcy50aGVtZS5zcGFjZVNjYWxlLnNwYWNpbmcwN307XG4gIHBhZGRpbmctbGVmdDogJHtwcm9wcyA9PiBwcm9wcy50aGVtZS5zcGFjZVNjYWxlLnNwYWNpbmcwMn07XG4gIHdpZHRoOiAwO1xuICBoZWlnaHQ6IDM4cHg7XG5cbiAgJjpmb2N1cyB7XG4gICAgb3V0bGluZTogMDtcbiAgfVxuYDtcclxuZXhwb3J0IGZ1bmN0aW9uIENvbWJvYm94SW5wdXQocHJvcHMpIHtcclxuICAgIGNvbnN0IHsgYXJpYURlc2NyaWJlZEJ5LCBjaGlsZHJlbiwgY3VzdG9tQ29tcG9uZW50cywgZ2V0Q29tYm9ib3hQcm9wcywgZ2V0SW5wdXRQcm9wcywgZ2V0VG9nZ2xlQnV0dG9uUHJvcHMsIGhhc0Vycm9yLCBpbm5lclJlZiwgaW5wdXRTdHlsZSwgZGlzYWJsZWQsIGlzSW52ZXJzZSwgaXNMb2FkaW5nLCBpc1R5cGVhaGVhZCwgb25JbnB1dEJsdXIsIG9uSW5wdXRGb2N1cywgb25JbnB1dEtleURvd24sIG9uSW5wdXRLZXlQcmVzcywgb25JbnB1dEtleVVwLCBwbGFjZWhvbGRlciwgc2VsZWN0ZWRJdGVtcywgc2V0UmVmZXJlbmNlLCB0b2dnbGVCdXR0b25SZWYsIH0gPSBwcm9wcztcclxuICAgIGNvbnN0IHRoZW1lID0gUmVhY3QudXNlQ29udGV4dChUaGVtZUNvbnRleHQpO1xyXG4gICAgY29uc3QgW2lzRm9jdXNlZCwgc2V0SXNGb2N1c2VkXSA9IFJlYWN0LnVzZVN0YXRlKGZhbHNlKTtcclxuICAgIGNvbnN0IHsgRHJvcGRvd25JbmRpY2F0b3IsIExvYWRpbmdJbmRpY2F0b3IgfSA9IGRlZmF1bHRDb21wb25lbnRzKHtcclxuICAgICAgICAuLi5jdXN0b21Db21wb25lbnRzLFxyXG4gICAgfSk7XHJcbiAgICBmdW5jdGlvbiBoYW5kbGVCbHVyKGUpIHtcclxuICAgICAgICBzZXRJc0ZvY3VzZWQoZmFsc2UpO1xyXG4gICAgICAgIG9uSW5wdXRCbHVyICYmIHR5cGVvZiBvbklucHV0Qmx1ciA9PT0gJ2Z1bmN0aW9uJyAmJiBvbklucHV0Qmx1cihlKTtcclxuICAgIH1cclxuICAgIGZ1bmN0aW9uIGhhbmRsZUZvY3VzKGUpIHtcclxuICAgICAgICBzZXRJc0ZvY3VzZWQodHJ1ZSk7XHJcbiAgICAgICAgb25JbnB1dEZvY3VzICYmIHR5cGVvZiBvbklucHV0Rm9jdXMgPT09ICdmdW5jdGlvbicgJiYgb25JbnB1dEZvY3VzKGUpO1xyXG4gICAgfVxyXG4gICAgY29uc3QgaW5wdXRQcm9wcyA9IGdldElucHV0UHJvcHMoe1xyXG4gICAgICAgIGRpc2FibGVkOiBkaXNhYmxlZCxcclxuICAgICAgICBvbkJsdXI6IGhhbmRsZUJsdXIsXHJcbiAgICAgICAgb25Gb2N1czogaGFuZGxlRm9jdXMsXHJcbiAgICAgICAgb25LZXlEb3duOiBvbklucHV0S2V5RG93bixcclxuICAgICAgICBvbktleVByZXNzOiBvbklucHV0S2V5UHJlc3MsXHJcbiAgICAgICAgb25LZXlVcDogb25JbnB1dEtleVVwLFxyXG4gICAgICAgIC4uLihpbm5lclJlZiAmJiB7IHJlZjogaW5uZXJSZWYgfSksXHJcbiAgICB9KTtcclxuICAgIGNvbnN0IGRyb3Bkb3duSW5kaWNhdG9yQ29sb3IgPSAoKSA9PiB7XHJcbiAgICAgICAgaWYgKGRpc2FibGVkKSB7XHJcbiAgICAgICAgICAgIGlmIChpc0ludmVyc2UpIHtcclxuICAgICAgICAgICAgICAgIHJldHVybiB0cmFuc3BhcmVudGl6ZSgwLjYsIHRoZW1lLmNvbG9ycy5uZXV0cmFsMTAwKTtcclxuICAgICAgICAgICAgfVxyXG4gICAgICAgICAgICByZXR1cm4gdGhlbWUuY29sb3JzLm5ldXRyYWw1MDA7XHJcbiAgICAgICAgfVxyXG4gICAgICAgIGlmIChpc0ludmVyc2UpIHtcclxuICAgICAgICAgICAgcmV0dXJuIHRoZW1lLmNvbG9ycy5uZXV0cmFsMTAwO1xyXG4gICAgICAgIH1cclxuICAgICAgICByZXR1cm4gdGhlbWUuY29sb3JzLm5ldXRyYWw7XHJcbiAgICB9O1xyXG4gICAgcmV0dXJuIChSZWFjdC5jcmVhdGVFbGVtZW50KFwiZGl2XCIsIHsgcmVmOiBzZXRSZWZlcmVuY2UgfSxcclxuICAgICAgICBSZWFjdC5jcmVhdGVFbGVtZW50KENvbWJvQm94Q29udGFpbmVyLCBPYmplY3QuYXNzaWduKHt9LCBnZXRDb21ib2JveFByb3BzKCksIHsgaGFzRXJyb3I6IGhhc0Vycm9yLCBkaXNhYmxlZDogZGlzYWJsZWQsIGlzSW52ZXJzZTogaXNJbnZlcnNlLCB0aGVtZTogdGhlbWUgfSksXHJcbiAgICAgICAgICAgIFJlYWN0LmNyZWF0ZUVsZW1lbnQoSW5wdXRDb250YWluZXIsIE9iamVjdC5hc3NpZ24oe30sIGdldFRvZ2dsZUJ1dHRvblByb3BzKHtcclxuICAgICAgICAgICAgICAgIGRpc2FibGVkLFxyXG4gICAgICAgICAgICAgICAgLi4uKHRvZ2dsZUJ1dHRvblJlZiAmJiB7IHJlZjogdG9nZ2xlQnV0dG9uUmVmIH0pLFxyXG4gICAgICAgICAgICB9KSwgeyBoYXNFcnJvcjogaGFzRXJyb3IsIGRpc2FibGVkOiBkaXNhYmxlZCwgaXNGb2N1c2VkOiBpc0ZvY3VzZWQsIGlzSW52ZXJzZTogaXNJbnZlcnNlLCBzdHlsZTogaW5wdXRTdHlsZSwgdGhlbWU6IHRoZW1lLCByZWY6IGlubmVyUmVmIH0pLFxyXG4gICAgICAgICAgICAgICAgUmVhY3QuY3JlYXRlRWxlbWVudChTZWxlY3RlZEl0ZW1zV3JhcHBlciwgbnVsbCxcclxuICAgICAgICAgICAgICAgICAgICBzZWxlY3RlZEl0ZW1zLFxyXG4gICAgICAgICAgICAgICAgICAgIFJlYWN0LmNyZWF0ZUVsZW1lbnQoU3R5bGVkSW5wdXQsIE9iamVjdC5hc3NpZ24oe30sIGlucHV0UHJvcHMsIHsgXCJhcmlhLWRlc2NyaWJlZGJ5XCI6IGFyaWFEZXNjcmliZWRCeSwgXCJhcmlhLWludmFsaWRcIjogaGFzRXJyb3IsIGRpc2FibGVkOiBkaXNhYmxlZCwgaXNJbnZlcnNlOiBpc0ludmVyc2UsIHBsYWNlaG9sZGVyOiBwbGFjZWhvbGRlciwgdGhlbWU6IHRoZW1lIH0pKSksXHJcbiAgICAgICAgICAgICAgICBjaGlsZHJlbixcclxuICAgICAgICAgICAgICAgIGlzTG9hZGluZyAmJiAhaXNUeXBlYWhlYWQgJiYgKFJlYWN0LmNyZWF0ZUVsZW1lbnQoTG9hZGluZ0luZGljYXRvciwgeyBzdHlsZTogeyBmbGV4U2hyaW5rOiAwLCBtYXJnaW5SaWdodDogdGhlbWUuc3BhY2VTY2FsZS5zcGFjaW5nMDIgfSB9KSksXHJcbiAgICAgICAgICAgICAgICBSZWFjdC5jcmVhdGVFbGVtZW50KERyb3Bkb3duSW5kaWNhdG9yLCB7IFwiYXJpYS1sYWJlbFwiOiBcInRvZ2dsZSBtZW51XCIsIGNvbG9yOiBkcm9wZG93bkluZGljYXRvckNvbG9yKCkgfSkpKSkpO1xyXG59XHJcbi8vIyBzb3VyY2VNYXBwaW5nVVJMPUNvbWJvYm94SW5wdXQuanMubWFwIl19 */"));
|
|
12321
12313
|
var StyledInput$1 = /*#__PURE__*/_styled("input", {
|
|
12322
12314
|
target: "ecunvrq0",
|
|
12323
12315
|
label: "StyledInput"
|
|
12324
|
-
})(inputBaseStyles, "
|
|
12325
|
-
return props.theme.spaceScale.spacing09;
|
|
12326
|
-
}, ";min-width:", function (props) {
|
|
12316
|
+
})(inputBaseStyles, " display:flex;flex-grow:1;min-width:", function (props) {
|
|
12327
12317
|
return props.theme.spaceScale.spacing07;
|
|
12328
12318
|
}, ";padding-left:", function (props) {
|
|
12329
12319
|
return props.theme.spaceScale.spacing02;
|
|
12330
|
-
}, ";width:0;&:focus{outline:0;}" + ( "/*# sourceMappingURL=data:application/json;charset=utf-8;base64,eyJ2ZXJzaW9uIjozLCJzb3VyY2VzIjpbIkNvbWJvYm94SW5wdXQudHN4Il0sIm5hbWVzIjpbXSwibWFwcGluZ3MiOiJBQTREaUMiLCJmaWxlIjoiQ29tYm9ib3hJbnB1dC50c3giLCJzb3VyY2VzQ29udGVudCI6WyJpbXBvcnQgUmVhY3QgZnJvbSAncmVhY3QnO1xyXG5pbXBvcnQgeyBjc3MgfSBmcm9tICdAZW1vdGlvbi9yZWFjdCc7XHJcbmltcG9ydCBzdHlsZWQgZnJvbSAnQGVtb3Rpb24vc3R5bGVkJztcclxuaW1wb3J0IHsgdHJhbnNwYXJlbnRpemUgfSBmcm9tICdwb2xpc2hlZCc7XHJcbmltcG9ydCB7IFRoZW1lQ29udGV4dCB9IGZyb20gJy4uLy4uL3RoZW1lL1RoZW1lQ29udGV4dCc7XHJcbmltcG9ydCB7IGlucHV0QmFzZVN0eWxlcyB9IGZyb20gJy4uL0lucHV0QmFzZSc7XHJcbmltcG9ydCB7IGRlZmF1bHRDb21wb25lbnRzIH0gZnJvbSAnLi4vU2VsZWN0L2NvbXBvbmVudHMnO1xyXG5pbXBvcnQgeyBTZWxlY3RlZEl0ZW1zV3JhcHBlciB9IGZyb20gJy4uL1NlbGVjdC9zaGFyZWQnO1xyXG5jb25zdCBDb21ib0JveENvbnRhaW5lciA9IHN0eWxlZC5kaXYgYFxuICBkaXNwbGF5OiBmbGV4O1xuYDtcclxuY29uc3QgSW5wdXRDb250YWluZXIgPSBzdHlsZWQuZGl2IGBcbiAgYWxpZ24taXRlbXM6IGNlbnRlcjtcbiAgYmFja2dyb3VuZC1jb2xvcjogJHtwcm9wcyA9PiBwcm9wcy5pc0ludmVyc2VcclxuICAgID8gdHJhbnNwYXJlbnRpemUoMC44LCBwcm9wcy50aGVtZS5jb2xvcnMubmV1dHJhbDkwMClcclxuICAgIDogcHJvcHMudGhlbWUuY29sb3JzLm5ldXRyYWwxMDB9O1xuICBib3JkZXI6IDFweCBzb2xpZDtcbiAgYm9yZGVyLWNvbG9yOiAke3Byb3BzID0+IHByb3BzLmlzSW52ZXJzZVxyXG4gICAgPyB0cmFuc3BhcmVudGl6ZSgwLjUsIHByb3BzLnRoZW1lLmNvbG9ycy5uZXV0cmFsMTAwKVxyXG4gICAgOiBwcm9wcy50aGVtZS5jb2xvcnMubmV1dHJhbDUwMH07XG4gIGJvcmRlci1yYWRpdXM6ICR7cHJvcHMgPT4gcHJvcHMudGhlbWUuYm9yZGVyUmFkaXVzfTtcbiAgZGlzcGxheTogZmxleDtcbiAgbWluLWhlaWdodDogJHtwcm9wcyA9PiBwcm9wcy50aGVtZS5zcGFjZVNjYWxlLnNwYWNpbmcwOX07XG4gIG1pbi13aWR0aDogJHtwcm9wcyA9PiBwcm9wcy50aGVtZS5zcGFjZVNjYWxlLnNwYWNpbmcxM307XG4gIHBhZGRpbmc6IDAgJHtwcm9wcyA9PiBwcm9wcy50aGVtZS5zcGFjZVNjYWxlLnNwYWNpbmcwM30gMCAwO1xuICB3aWR0aDogMTAwJTtcblxuICAke3Byb3BzID0+IHByb3BzLmlzRm9jdXNlZCAmJlxyXG4gICAgY3NzIGBcbiAgICAgIG91dGxpbmU6IDJweCBzb2xpZFxuICAgICAgICAke3Byb3BzLmlzSW52ZXJzZVxyXG4gICAgICAgID8gcHJvcHMudGhlbWUuY29sb3JzLmZvY3VzSW52ZXJzZVxyXG4gICAgICAgIDogcHJvcHMudGhlbWUuY29sb3JzLmZvY3VzfTtcbiAgICAgIG91dGxpbmUtb2Zmc2V0OiAtMXB4O1xuICAgIGB9XG5cbiAgJHtwcm9wcyA9PiBwcm9wcy5oYXNFcnJvciAmJlxyXG4gICAgY3NzIGBcbiAgICAgIGJvcmRlci1jb2xvcjogJHtwcm9wcy5pc0ludmVyc2VcclxuICAgICAgICA/IHByb3BzLnRoZW1lLmNvbG9ycy5kYW5nZXIyMDBcclxuICAgICAgICA6IHByb3BzLnRoZW1lLmNvbG9ycy5kYW5nZXJ9O1xuICAgIGB9XG5cbiAgICAke3Byb3BzID0+IHByb3BzLmRpc2FibGVkICYmXHJcbiAgICBjc3MgYFxuICAgICAgYmFja2dyb3VuZDogJHtwcm9wcy5pc0ludmVyc2VcclxuICAgICAgICA/
|
|
12320
|
+
}, ";width:0;height:38px;&:focus{outline:0;}" + ( "/*# sourceMappingURL=data:application/json;charset=utf-8;base64,eyJ2ZXJzaW9uIjozLCJzb3VyY2VzIjpbIkNvbWJvYm94SW5wdXQudHN4Il0sIm5hbWVzIjpbXSwibWFwcGluZ3MiOiJBQTREaUMiLCJmaWxlIjoiQ29tYm9ib3hJbnB1dC50c3giLCJzb3VyY2VzQ29udGVudCI6WyJpbXBvcnQgUmVhY3QgZnJvbSAncmVhY3QnO1xyXG5pbXBvcnQgeyBjc3MgfSBmcm9tICdAZW1vdGlvbi9yZWFjdCc7XHJcbmltcG9ydCBzdHlsZWQgZnJvbSAnQGVtb3Rpb24vc3R5bGVkJztcclxuaW1wb3J0IHsgdHJhbnNwYXJlbnRpemUgfSBmcm9tICdwb2xpc2hlZCc7XHJcbmltcG9ydCB7IFRoZW1lQ29udGV4dCB9IGZyb20gJy4uLy4uL3RoZW1lL1RoZW1lQ29udGV4dCc7XHJcbmltcG9ydCB7IGlucHV0QmFzZVN0eWxlcyB9IGZyb20gJy4uL0lucHV0QmFzZSc7XHJcbmltcG9ydCB7IGRlZmF1bHRDb21wb25lbnRzIH0gZnJvbSAnLi4vU2VsZWN0L2NvbXBvbmVudHMnO1xyXG5pbXBvcnQgeyBTZWxlY3RlZEl0ZW1zV3JhcHBlciB9IGZyb20gJy4uL1NlbGVjdC9zaGFyZWQnO1xyXG5jb25zdCBDb21ib0JveENvbnRhaW5lciA9IHN0eWxlZC5kaXYgYFxuICBkaXNwbGF5OiBmbGV4O1xuYDtcclxuY29uc3QgSW5wdXRDb250YWluZXIgPSBzdHlsZWQuZGl2IGBcbiAgYWxpZ24taXRlbXM6IGNlbnRlcjtcbiAgYmFja2dyb3VuZC1jb2xvcjogJHtwcm9wcyA9PiBwcm9wcy5pc0ludmVyc2VcclxuICAgID8gdHJhbnNwYXJlbnRpemUoMC44LCBwcm9wcy50aGVtZS5jb2xvcnMubmV1dHJhbDkwMClcclxuICAgIDogcHJvcHMudGhlbWUuY29sb3JzLm5ldXRyYWwxMDB9O1xuICBib3JkZXI6IDFweCBzb2xpZDtcbiAgYm9yZGVyLWNvbG9yOiAke3Byb3BzID0+IHByb3BzLmlzSW52ZXJzZVxyXG4gICAgPyB0cmFuc3BhcmVudGl6ZSgwLjUsIHByb3BzLnRoZW1lLmNvbG9ycy5uZXV0cmFsMTAwKVxyXG4gICAgOiBwcm9wcy50aGVtZS5jb2xvcnMubmV1dHJhbDUwMH07XG4gIGJvcmRlci1yYWRpdXM6ICR7cHJvcHMgPT4gcHJvcHMudGhlbWUuYm9yZGVyUmFkaXVzfTtcbiAgZGlzcGxheTogZmxleDtcbiAgbWluLWhlaWdodDogJHtwcm9wcyA9PiBwcm9wcy50aGVtZS5zcGFjZVNjYWxlLnNwYWNpbmcwOX07XG4gIG1pbi13aWR0aDogJHtwcm9wcyA9PiBwcm9wcy50aGVtZS5zcGFjZVNjYWxlLnNwYWNpbmcxM307XG4gIHBhZGRpbmc6IDAgJHtwcm9wcyA9PiBwcm9wcy50aGVtZS5zcGFjZVNjYWxlLnNwYWNpbmcwM30gMCAwO1xuICB3aWR0aDogMTAwJTtcblxuICAke3Byb3BzID0+IHByb3BzLmlzRm9jdXNlZCAmJlxyXG4gICAgY3NzIGBcbiAgICAgIG91dGxpbmU6IDJweCBzb2xpZFxuICAgICAgICAke3Byb3BzLmlzSW52ZXJzZVxyXG4gICAgICAgID8gcHJvcHMudGhlbWUuY29sb3JzLmZvY3VzSW52ZXJzZVxyXG4gICAgICAgIDogcHJvcHMudGhlbWUuY29sb3JzLmZvY3VzfTtcbiAgICAgIG91dGxpbmUtb2Zmc2V0OiAtMXB4O1xuICAgIGB9XG5cbiAgJHtwcm9wcyA9PiBwcm9wcy5oYXNFcnJvciAmJlxyXG4gICAgY3NzIGBcbiAgICAgIGJvcmRlci1jb2xvcjogJHtwcm9wcy5pc0ludmVyc2VcclxuICAgICAgICA/IHByb3BzLnRoZW1lLmNvbG9ycy5kYW5nZXIyMDBcclxuICAgICAgICA6IHByb3BzLnRoZW1lLmNvbG9ycy5kYW5nZXJ9O1xuICAgIGB9XG5cbiAgICAke3Byb3BzID0+IHByb3BzLmRpc2FibGVkICYmXHJcbiAgICBjc3MgYFxuICAgICAgYmFja2dyb3VuZDogJHtwcm9wcy5pc0ludmVyc2VcclxuICAgICAgICA/IHRyYW5zcGFyZW50aXplKDAuOSwgcHJvcHMudGhlbWUuY29sb3JzLm5ldXRyYWw5MDApXHJcbiAgICAgICAgOiBwcm9wcy50aGVtZS5jb2xvcnMubmV1dHJhbDIwMH07XG4gICAgICBib3JkZXItY29sb3I6ICR7cHJvcHMuaXNJbnZlcnNlXHJcbiAgICAgICAgPyB0cmFuc3BhcmVudGl6ZSgwLjg1LCBwcm9wcy50aGVtZS5jb2xvcnMubmV1dHJhbDEwMClcclxuICAgICAgICA6IHByb3BzLnRoZW1lLmNvbG9ycy5uZXV0cmFsMzAwfTtcbiAgICAgIGNvbG9yOiAke3RyYW5zcGFyZW50aXplKDAuNCwgcHJvcHMudGhlbWUuY29sb3JzLm5ldXRyYWw1MDApfTtcbiAgICAgIGN1cnNvcjogbm90LWFsbG93ZWQ7XG4gICAgICBvdXRsaW5lOiAwO1xuXG4gICAgICAmOjpwbGFjZWhvbGRlciB7XG4gICAgICAgIGNvbG9yOiAke3RyYW5zcGFyZW50aXplKDAuNCwgcHJvcHMudGhlbWUuY29sb3JzLm5ldXRyYWw1MDApfTtcbiAgICAgIH1cbiAgICBgfVxuYDtcclxuY29uc3QgU3R5bGVkSW5wdXQgPSBzdHlsZWQuaW5wdXQgYFxuICAke2lucHV0QmFzZVN0eWxlc31cbiAgZGlzcGxheTogZmxleDtcbiAgZmxleC1ncm93OiAxO1xuICBtaW4td2lkdGg6ICR7cHJvcHMgPT4gcHJvcHMudGhlbWUuc3BhY2VTY2FsZS5zcGFjaW5nMDd9O1xuICBwYWRkaW5nLWxlZnQ6ICR7cHJvcHMgPT4gcHJvcHMudGhlbWUuc3BhY2VTY2FsZS5zcGFjaW5nMDJ9O1xuICB3aWR0aDogMDtcbiAgaGVpZ2h0OiAzOHB4O1xuXG4gICY6Zm9jdXMge1xuICAgIG91dGxpbmU6IDA7XG4gIH1cbmA7XHJcbmV4cG9ydCBmdW5jdGlvbiBDb21ib2JveElucHV0KHByb3BzKSB7XHJcbiAgICBjb25zdCB7IGFyaWFEZXNjcmliZWRCeSwgY2hpbGRyZW4sIGN1c3RvbUNvbXBvbmVudHMsIGdldENvbWJvYm94UHJvcHMsIGdldElucHV0UHJvcHMsIGdldFRvZ2dsZUJ1dHRvblByb3BzLCBoYXNFcnJvciwgaW5uZXJSZWYsIGlucHV0U3R5bGUsIGRpc2FibGVkLCBpc0ludmVyc2UsIGlzTG9hZGluZywgaXNUeXBlYWhlYWQsIG9uSW5wdXRCbHVyLCBvbklucHV0Rm9jdXMsIG9uSW5wdXRLZXlEb3duLCBvbklucHV0S2V5UHJlc3MsIG9uSW5wdXRLZXlVcCwgcGxhY2Vob2xkZXIsIHNlbGVjdGVkSXRlbXMsIHNldFJlZmVyZW5jZSwgdG9nZ2xlQnV0dG9uUmVmLCB9ID0gcHJvcHM7XHJcbiAgICBjb25zdCB0aGVtZSA9IFJlYWN0LnVzZUNvbnRleHQoVGhlbWVDb250ZXh0KTtcclxuICAgIGNvbnN0IFtpc0ZvY3VzZWQsIHNldElzRm9jdXNlZF0gPSBSZWFjdC51c2VTdGF0ZShmYWxzZSk7XHJcbiAgICBjb25zdCB7IERyb3Bkb3duSW5kaWNhdG9yLCBMb2FkaW5nSW5kaWNhdG9yIH0gPSBkZWZhdWx0Q29tcG9uZW50cyh7XHJcbiAgICAgICAgLi4uY3VzdG9tQ29tcG9uZW50cyxcclxuICAgIH0pO1xyXG4gICAgZnVuY3Rpb24gaGFuZGxlQmx1cihlKSB7XHJcbiAgICAgICAgc2V0SXNGb2N1c2VkKGZhbHNlKTtcclxuICAgICAgICBvbklucHV0Qmx1ciAmJiB0eXBlb2Ygb25JbnB1dEJsdXIgPT09ICdmdW5jdGlvbicgJiYgb25JbnB1dEJsdXIoZSk7XHJcbiAgICB9XHJcbiAgICBmdW5jdGlvbiBoYW5kbGVGb2N1cyhlKSB7XHJcbiAgICAgICAgc2V0SXNGb2N1c2VkKHRydWUpO1xyXG4gICAgICAgIG9uSW5wdXRGb2N1cyAmJiB0eXBlb2Ygb25JbnB1dEZvY3VzID09PSAnZnVuY3Rpb24nICYmIG9uSW5wdXRGb2N1cyhlKTtcclxuICAgIH1cclxuICAgIGNvbnN0IGlucHV0UHJvcHMgPSBnZXRJbnB1dFByb3BzKHtcclxuICAgICAgICBkaXNhYmxlZDogZGlzYWJsZWQsXHJcbiAgICAgICAgb25CbHVyOiBoYW5kbGVCbHVyLFxyXG4gICAgICAgIG9uRm9jdXM6IGhhbmRsZUZvY3VzLFxyXG4gICAgICAgIG9uS2V5RG93bjogb25JbnB1dEtleURvd24sXHJcbiAgICAgICAgb25LZXlQcmVzczogb25JbnB1dEtleVByZXNzLFxyXG4gICAgICAgIG9uS2V5VXA6IG9uSW5wdXRLZXlVcCxcclxuICAgICAgICAuLi4oaW5uZXJSZWYgJiYgeyByZWY6IGlubmVyUmVmIH0pLFxyXG4gICAgfSk7XHJcbiAgICBjb25zdCBkcm9wZG93bkluZGljYXRvckNvbG9yID0gKCkgPT4ge1xyXG4gICAgICAgIGlmIChkaXNhYmxlZCkge1xyXG4gICAgICAgICAgICBpZiAoaXNJbnZlcnNlKSB7XHJcbiAgICAgICAgICAgICAgICByZXR1cm4gdHJhbnNwYXJlbnRpemUoMC42LCB0aGVtZS5jb2xvcnMubmV1dHJhbDEwMCk7XHJcbiAgICAgICAgICAgIH1cclxuICAgICAgICAgICAgcmV0dXJuIHRoZW1lLmNvbG9ycy5uZXV0cmFsNTAwO1xyXG4gICAgICAgIH1cclxuICAgICAgICBpZiAoaXNJbnZlcnNlKSB7XHJcbiAgICAgICAgICAgIHJldHVybiB0aGVtZS5jb2xvcnMubmV1dHJhbDEwMDtcclxuICAgICAgICB9XHJcbiAgICAgICAgcmV0dXJuIHRoZW1lLmNvbG9ycy5uZXV0cmFsO1xyXG4gICAgfTtcclxuICAgIHJldHVybiAoUmVhY3QuY3JlYXRlRWxlbWVudChcImRpdlwiLCB7IHJlZjogc2V0UmVmZXJlbmNlIH0sXHJcbiAgICAgICAgUmVhY3QuY3JlYXRlRWxlbWVudChDb21ib0JveENvbnRhaW5lciwgT2JqZWN0LmFzc2lnbih7fSwgZ2V0Q29tYm9ib3hQcm9wcygpLCB7IGhhc0Vycm9yOiBoYXNFcnJvciwgZGlzYWJsZWQ6IGRpc2FibGVkLCBpc0ludmVyc2U6IGlzSW52ZXJzZSwgdGhlbWU6IHRoZW1lIH0pLFxyXG4gICAgICAgICAgICBSZWFjdC5jcmVhdGVFbGVtZW50KElucHV0Q29udGFpbmVyLCBPYmplY3QuYXNzaWduKHt9LCBnZXRUb2dnbGVCdXR0b25Qcm9wcyh7XHJcbiAgICAgICAgICAgICAgICBkaXNhYmxlZCxcclxuICAgICAgICAgICAgICAgIC4uLih0b2dnbGVCdXR0b25SZWYgJiYgeyByZWY6IHRvZ2dsZUJ1dHRvblJlZiB9KSxcclxuICAgICAgICAgICAgfSksIHsgaGFzRXJyb3I6IGhhc0Vycm9yLCBkaXNhYmxlZDogZGlzYWJsZWQsIGlzRm9jdXNlZDogaXNGb2N1c2VkLCBpc0ludmVyc2U6IGlzSW52ZXJzZSwgc3R5bGU6IGlucHV0U3R5bGUsIHRoZW1lOiB0aGVtZSwgcmVmOiBpbm5lclJlZiB9KSxcclxuICAgICAgICAgICAgICAgIFJlYWN0LmNyZWF0ZUVsZW1lbnQoU2VsZWN0ZWRJdGVtc1dyYXBwZXIsIG51bGwsXHJcbiAgICAgICAgICAgICAgICAgICAgc2VsZWN0ZWRJdGVtcyxcclxuICAgICAgICAgICAgICAgICAgICBSZWFjdC5jcmVhdGVFbGVtZW50KFN0eWxlZElucHV0LCBPYmplY3QuYXNzaWduKHt9LCBpbnB1dFByb3BzLCB7IFwiYXJpYS1kZXNjcmliZWRieVwiOiBhcmlhRGVzY3JpYmVkQnksIFwiYXJpYS1pbnZhbGlkXCI6IGhhc0Vycm9yLCBkaXNhYmxlZDogZGlzYWJsZWQsIGlzSW52ZXJzZTogaXNJbnZlcnNlLCBwbGFjZWhvbGRlcjogcGxhY2Vob2xkZXIsIHRoZW1lOiB0aGVtZSB9KSkpLFxyXG4gICAgICAgICAgICAgICAgY2hpbGRyZW4sXHJcbiAgICAgICAgICAgICAgICBpc0xvYWRpbmcgJiYgIWlzVHlwZWFoZWFkICYmIChSZWFjdC5jcmVhdGVFbGVtZW50KExvYWRpbmdJbmRpY2F0b3IsIHsgc3R5bGU6IHsgZmxleFNocmluazogMCwgbWFyZ2luUmlnaHQ6IHRoZW1lLnNwYWNlU2NhbGUuc3BhY2luZzAyIH0gfSkpLFxyXG4gICAgICAgICAgICAgICAgUmVhY3QuY3JlYXRlRWxlbWVudChEcm9wZG93bkluZGljYXRvciwgeyBcImFyaWEtbGFiZWxcIjogXCJ0b2dnbGUgbWVudVwiLCBjb2xvcjogZHJvcGRvd25JbmRpY2F0b3JDb2xvcigpIH0pKSkpKTtcclxufVxyXG4vLyMgc291cmNlTWFwcGluZ1VSTD1Db21ib2JveElucHV0LmpzLm1hcCJdfQ== */"));
|
|
12331
12321
|
function ComboboxInput(props) {
|
|
12332
12322
|
var ariaDescribedBy = props.ariaDescribedBy,
|
|
12333
12323
|
children = props.children,
|