react-magma-dom 4.6.0-next.8 → 4.6.0
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/Breadcrumb/BreadcrumbItem.d.ts +1 -1
- package/dist/components/List/List.d.ts +0 -6
- package/dist/components/List/List.stories.d.ts +62 -1
- package/dist/components/List/ListItem.d.ts +8 -0
- package/dist/components/Modal/Modal.stories.d.ts +1 -0
- package/dist/components/TreeView/TreeView.stories.d.ts +9 -0
- package/dist/components/TreeView/useTreeView.d.ts +2 -2
- package/dist/esm/index.js +486 -54
- package/dist/esm/index.js.map +1 -1
- package/dist/properties.json +30 -46
- package/dist/react-magma-dom.cjs.development.js +424 -53
- package/dist/react-magma-dom.cjs.development.js.map +1 -1
- package/dist/react-magma-dom.cjs.production.min.js +1 -1
- package/dist/react-magma-dom.cjs.production.min.js.map +1 -1
- package/dist/theme/components/reducedMotionTransition.d.ts +10 -0
- package/package.json +3 -3
|
@@ -3149,24 +3149,32 @@ var Hyperlink = /*#__PURE__*/React.forwardRef(function (props, ref) {
|
|
|
3149
3149
|
var _excluded$d = ["children", "to", "testId"];
|
|
3150
3150
|
function _EMOTION_STRINGIFIED_CSS_ERROR__$6() { return "You have tried to stringify object returned from `css` function. It isn't supposed to be used directly (e.g. as value of the `className` prop), but rather handed to emotion so it can handle it (e.g. as value of `css` prop)."; }
|
|
3151
3151
|
var StyledItem = /*#__PURE__*/_styled("li", {
|
|
3152
|
-
target: "
|
|
3152
|
+
target: "e1vcflao2",
|
|
3153
3153
|
label: "StyledItem"
|
|
3154
3154
|
})( {
|
|
3155
3155
|
name: "v28fi1",
|
|
3156
3156
|
styles: "list-style:none;margin:0;padding:0;display:flex",
|
|
3157
|
-
map: "/*# sourceMappingURL=data:application/json;charset=utf-8;base64,
|
|
3157
|
+
map: "/*# sourceMappingURL=data:application/json;charset=utf-8;base64,eyJ2ZXJzaW9uIjozLCJzb3VyY2VzIjpbIkJyZWFkY3J1bWJJdGVtLnRzeCJdLCJuYW1lcyI6W10sIm1hcHBpbmdzIjoiQUFNNkIiLCJmaWxlIjoiQnJlYWRjcnVtYkl0ZW0udHN4Iiwic291cmNlc0NvbnRlbnQiOlsiaW1wb3J0IHN0eWxlZCBmcm9tICdAZW1vdGlvbi9zdHlsZWQnO1xyXG5pbXBvcnQgKiBhcyBSZWFjdCBmcm9tICdyZWFjdCc7XHJcbmltcG9ydCB7IENoZXZyb25SaWdodEljb24gfSBmcm9tICdyZWFjdC1tYWdtYS1pY29ucyc7XHJcbmltcG9ydCB7IHVzZUlzSW52ZXJzZSB9IGZyb20gJy4uLy4uL2ludmVyc2UnO1xyXG5pbXBvcnQgeyBUaGVtZUNvbnRleHQgfSBmcm9tICcuLi8uLi90aGVtZS9UaGVtZUNvbnRleHQnO1xyXG5pbXBvcnQgeyBIeXBlcmxpbmsgfSBmcm9tICcuLi9IeXBlcmxpbmsnO1xyXG5jb25zdCBTdHlsZWRJdGVtID0gc3R5bGVkLmxpIGBcbiAgbGlzdC1zdHlsZTogbm9uZTtcbiAgbWFyZ2luOiAwO1xuICBwYWRkaW5nOiAwO1xuICBkaXNwbGF5OiBmbGV4O1xuYDtcclxuY29uc3QgU3R5bGVkTGluayA9IHN0eWxlZC5hIGBcbiAgYWxpZ24taXRlbXM6IGNlbnRlcjtcbiAgZGlzcGxheTogZmxleDtcbiAgY29sb3I6ICR7cHJvcHMgPT4gcHJvcHMuaXNJbnZlcnNlXHJcbiAgICA/IHByb3BzLnRoZW1lLmNvbG9ycy5uZXV0cmFsMTAwXHJcbiAgICA6IHByb3BzLnRoZW1lLmNvbG9ycy5uZXV0cmFsNzAwfTtcbiAgdGV4dC1kZWNvcmF0aW9uOiBub25lO1xuICBjdXJzb3I6IGRlZmF1bHQ7XG4gIFxuICAmOmhvdmVyLFxuICAmOmZvY3VzIHtcbiAgICBjb2xvcjogJHtwcm9wcyA9PiBwcm9wcy5pc0ludmVyc2VcclxuICAgID8gcHJvcHMudGhlbWUuY29sb3JzLm5ldXRyYWwxMDBcclxuICAgIDogcHJvcHMudGhlbWUuY29sb3JzLm5ldXRyYWw3MDB9O1xuICB9XG4gICY6Zm9jdXMge1xuICAgIG91dGxpbmU6IDJweCBzb2xpZFxuICAgICAgJHtwcm9wcyA9PiBwcm9wcy5pc0ludmVyc2VcclxuICAgID8gcHJvcHMudGhlbWUuY29sb3JzLmZvY3VzSW52ZXJzZVxyXG4gICAgOiBwcm9wcy50aGVtZS5jb2xvcnMuZm9jdXN9O1xuICAgIG91dGxpbmUtb2Zmc2V0OiAycHg7XG4gIH1cbmA7XHJcbmNvbnN0IFN0eWxlZFNwYW4gPSBzdHlsZWQuc3BhbiBgXG4gIGFsaWduLWl0ZW1zOiBjZW50ZXI7XG4gIGRpc3BsYXk6IGZsZXg7XG5cbiAgc3ZnIHtcbiAgICBtYXJnaW46IDAgJHtwcm9wcyA9PiBwcm9wcy50aGVtZS5zcGFjZVNjYWxlLnNwYWNpbmcwMn07XG4gICAgY29sb3I6ICR7cHJvcHMgPT4gcHJvcHMuaXNJbnZlcnNlXHJcbiAgICA/IHByb3BzLnRoZW1lLmNvbG9ycy50ZXJ0aWFyeTUwMFxyXG4gICAgOiBwcm9wcy50aGVtZS5jb2xvcnMubmV1dHJhbDUwMH07XG4gIH1cbmA7XHJcbmV4cG9ydCBjb25zdCBCcmVhZGNydW1iSXRlbSA9IFJlYWN0LmZvcndhcmRSZWYoKHByb3BzLCByZWYpID0+IHtcclxuICAgIGNvbnN0IHsgY2hpbGRyZW4sIHRvLCB0ZXN0SWQsIC4uLm90aGVyIH0gPSBwcm9wcztcclxuICAgIGNvbnN0IHRoZW1lID0gUmVhY3QudXNlQ29udGV4dChUaGVtZUNvbnRleHQpO1xyXG4gICAgY29uc3QgaXNJbnZlcnNlID0gdXNlSXNJbnZlcnNlKCk7XHJcbiAgICByZXR1cm4gKFJlYWN0LmNyZWF0ZUVsZW1lbnQoU3R5bGVkSXRlbSwgT2JqZWN0LmFzc2lnbih7fSwgb3RoZXIsIHsgXCJkYXRhLXRlc3RpZFwiOiB0ZXN0SWQsIHJlZjogcmVmIH0pLCB0byA/IChSZWFjdC5jcmVhdGVFbGVtZW50KFJlYWN0LkZyYWdtZW50LCBudWxsLFxyXG4gICAgICAgIFJlYWN0LmNyZWF0ZUVsZW1lbnQoSHlwZXJsaW5rLCB7IHRvOiB0bywgaXNJbnZlcnNlOiBpc0ludmVyc2UgfSwgY2hpbGRyZW4pLFxyXG4gICAgICAgIFJlYWN0LmNyZWF0ZUVsZW1lbnQoU3R5bGVkU3BhbiwgeyBpc0ludmVyc2U6IGlzSW52ZXJzZSwgdGhlbWU6IHRoZW1lIH0sXHJcbiAgICAgICAgICAgIFJlYWN0LmNyZWF0ZUVsZW1lbnQoQ2hldnJvblJpZ2h0SWNvbiwgeyBzaXplOiB0aGVtZS5pY29uU2l6ZXMuc21hbGwgfSkpKSkgOiAoUmVhY3QuY3JlYXRlRWxlbWVudChSZWFjdC5GcmFnbWVudCwgbnVsbCxcclxuICAgICAgICBSZWFjdC5jcmVhdGVFbGVtZW50KFN0eWxlZExpbmssIHsgaHJlZjogXCJcIiwgXCJhcmlhLWN1cnJlbnRcIjogXCJwYWdlXCIsIGlzSW52ZXJzZTogaXNJbnZlcnNlLCB0aGVtZTogdGhlbWUsIG9uQ2xpY2s6IGUgPT4gZS5wcmV2ZW50RGVmYXVsdCgpIH0sIGNoaWxkcmVuKSkpKSk7XHJcbn0pO1xyXG4vLyMgc291cmNlTWFwcGluZ1VSTD1CcmVhZGNydW1iSXRlbS5qcy5tYXAiXX0= */",
|
|
3158
3158
|
toString: _EMOTION_STRINGIFIED_CSS_ERROR__$6
|
|
3159
3159
|
});
|
|
3160
|
+
var StyledLink$1 = /*#__PURE__*/_styled("a", {
|
|
3161
|
+
target: "e1vcflao1",
|
|
3162
|
+
label: "StyledLink"
|
|
3163
|
+
})("align-items:center;display:flex;color:", function (props) {
|
|
3164
|
+
return props.isInverse ? props.theme.colors.neutral100 : props.theme.colors.neutral700;
|
|
3165
|
+
}, ";text-decoration:none;cursor:default;&:hover,&:focus{color:", function (props) {
|
|
3166
|
+
return props.isInverse ? props.theme.colors.neutral100 : props.theme.colors.neutral700;
|
|
3167
|
+
}, ";}&:focus{outline:2px solid ", function (props) {
|
|
3168
|
+
return props.isInverse ? props.theme.colors.focusInverse : props.theme.colors.focus;
|
|
3169
|
+
}, ";outline-offset:2px;}" + ( "/*# sourceMappingURL=data:application/json;charset=utf-8;base64,eyJ2ZXJzaW9uIjozLCJzb3VyY2VzIjpbIkJyZWFkY3J1bWJJdGVtLnRzeCJdLCJuYW1lcyI6W10sIm1hcHBpbmdzIjoiQUFZNEIiLCJmaWxlIjoiQnJlYWRjcnVtYkl0ZW0udHN4Iiwic291cmNlc0NvbnRlbnQiOlsiaW1wb3J0IHN0eWxlZCBmcm9tICdAZW1vdGlvbi9zdHlsZWQnO1xyXG5pbXBvcnQgKiBhcyBSZWFjdCBmcm9tICdyZWFjdCc7XHJcbmltcG9ydCB7IENoZXZyb25SaWdodEljb24gfSBmcm9tICdyZWFjdC1tYWdtYS1pY29ucyc7XHJcbmltcG9ydCB7IHVzZUlzSW52ZXJzZSB9IGZyb20gJy4uLy4uL2ludmVyc2UnO1xyXG5pbXBvcnQgeyBUaGVtZUNvbnRleHQgfSBmcm9tICcuLi8uLi90aGVtZS9UaGVtZUNvbnRleHQnO1xyXG5pbXBvcnQgeyBIeXBlcmxpbmsgfSBmcm9tICcuLi9IeXBlcmxpbmsnO1xyXG5jb25zdCBTdHlsZWRJdGVtID0gc3R5bGVkLmxpIGBcbiAgbGlzdC1zdHlsZTogbm9uZTtcbiAgbWFyZ2luOiAwO1xuICBwYWRkaW5nOiAwO1xuICBkaXNwbGF5OiBmbGV4O1xuYDtcclxuY29uc3QgU3R5bGVkTGluayA9IHN0eWxlZC5hIGBcbiAgYWxpZ24taXRlbXM6IGNlbnRlcjtcbiAgZGlzcGxheTogZmxleDtcbiAgY29sb3I6ICR7cHJvcHMgPT4gcHJvcHMuaXNJbnZlcnNlXHJcbiAgICA/IHByb3BzLnRoZW1lLmNvbG9ycy5uZXV0cmFsMTAwXHJcbiAgICA6IHByb3BzLnRoZW1lLmNvbG9ycy5uZXV0cmFsNzAwfTtcbiAgdGV4dC1kZWNvcmF0aW9uOiBub25lO1xuICBjdXJzb3I6IGRlZmF1bHQ7XG4gIFxuICAmOmhvdmVyLFxuICAmOmZvY3VzIHtcbiAgICBjb2xvcjogJHtwcm9wcyA9PiBwcm9wcy5pc0ludmVyc2VcclxuICAgID8gcHJvcHMudGhlbWUuY29sb3JzLm5ldXRyYWwxMDBcclxuICAgIDogcHJvcHMudGhlbWUuY29sb3JzLm5ldXRyYWw3MDB9O1xuICB9XG4gICY6Zm9jdXMge1xuICAgIG91dGxpbmU6IDJweCBzb2xpZFxuICAgICAgJHtwcm9wcyA9PiBwcm9wcy5pc0ludmVyc2VcclxuICAgID8gcHJvcHMudGhlbWUuY29sb3JzLmZvY3VzSW52ZXJzZVxyXG4gICAgOiBwcm9wcy50aGVtZS5jb2xvcnMuZm9jdXN9O1xuICAgIG91dGxpbmUtb2Zmc2V0OiAycHg7XG4gIH1cbmA7XHJcbmNvbnN0IFN0eWxlZFNwYW4gPSBzdHlsZWQuc3BhbiBgXG4gIGFsaWduLWl0ZW1zOiBjZW50ZXI7XG4gIGRpc3BsYXk6IGZsZXg7XG5cbiAgc3ZnIHtcbiAgICBtYXJnaW46IDAgJHtwcm9wcyA9PiBwcm9wcy50aGVtZS5zcGFjZVNjYWxlLnNwYWNpbmcwMn07XG4gICAgY29sb3I6ICR7cHJvcHMgPT4gcHJvcHMuaXNJbnZlcnNlXHJcbiAgICA/IHByb3BzLnRoZW1lLmNvbG9ycy50ZXJ0aWFyeTUwMFxyXG4gICAgOiBwcm9wcy50aGVtZS5jb2xvcnMubmV1dHJhbDUwMH07XG4gIH1cbmA7XHJcbmV4cG9ydCBjb25zdCBCcmVhZGNydW1iSXRlbSA9IFJlYWN0LmZvcndhcmRSZWYoKHByb3BzLCByZWYpID0+IHtcclxuICAgIGNvbnN0IHsgY2hpbGRyZW4sIHRvLCB0ZXN0SWQsIC4uLm90aGVyIH0gPSBwcm9wcztcclxuICAgIGNvbnN0IHRoZW1lID0gUmVhY3QudXNlQ29udGV4dChUaGVtZUNvbnRleHQpO1xyXG4gICAgY29uc3QgaXNJbnZlcnNlID0gdXNlSXNJbnZlcnNlKCk7XHJcbiAgICByZXR1cm4gKFJlYWN0LmNyZWF0ZUVsZW1lbnQoU3R5bGVkSXRlbSwgT2JqZWN0LmFzc2lnbih7fSwgb3RoZXIsIHsgXCJkYXRhLXRlc3RpZFwiOiB0ZXN0SWQsIHJlZjogcmVmIH0pLCB0byA/IChSZWFjdC5jcmVhdGVFbGVtZW50KFJlYWN0LkZyYWdtZW50LCBudWxsLFxyXG4gICAgICAgIFJlYWN0LmNyZWF0ZUVsZW1lbnQoSHlwZXJsaW5rLCB7IHRvOiB0bywgaXNJbnZlcnNlOiBpc0ludmVyc2UgfSwgY2hpbGRyZW4pLFxyXG4gICAgICAgIFJlYWN0LmNyZWF0ZUVsZW1lbnQoU3R5bGVkU3BhbiwgeyBpc0ludmVyc2U6IGlzSW52ZXJzZSwgdGhlbWU6IHRoZW1lIH0sXHJcbiAgICAgICAgICAgIFJlYWN0LmNyZWF0ZUVsZW1lbnQoQ2hldnJvblJpZ2h0SWNvbiwgeyBzaXplOiB0aGVtZS5pY29uU2l6ZXMuc21hbGwgfSkpKSkgOiAoUmVhY3QuY3JlYXRlRWxlbWVudChSZWFjdC5GcmFnbWVudCwgbnVsbCxcclxuICAgICAgICBSZWFjdC5jcmVhdGVFbGVtZW50KFN0eWxlZExpbmssIHsgaHJlZjogXCJcIiwgXCJhcmlhLWN1cnJlbnRcIjogXCJwYWdlXCIsIGlzSW52ZXJzZTogaXNJbnZlcnNlLCB0aGVtZTogdGhlbWUsIG9uQ2xpY2s6IGUgPT4gZS5wcmV2ZW50RGVmYXVsdCgpIH0sIGNoaWxkcmVuKSkpKSk7XHJcbn0pO1xyXG4vLyMgc291cmNlTWFwcGluZ1VSTD1CcmVhZGNydW1iSXRlbS5qcy5tYXAiXX0= */"));
|
|
3160
3170
|
var StyledSpan$1 = /*#__PURE__*/_styled("span", {
|
|
3161
3171
|
target: "e1vcflao0",
|
|
3162
3172
|
label: "StyledSpan"
|
|
3163
|
-
})("align-items:center;display:flex;
|
|
3164
|
-
return props.isInverse ? props.theme.colors.neutral100 : props.theme.colors.neutral700;
|
|
3165
|
-
}, ";svg{margin:0 ", function (props) {
|
|
3173
|
+
})("align-items:center;display:flex;svg{margin:0 ", function (props) {
|
|
3166
3174
|
return props.theme.spaceScale.spacing02;
|
|
3167
3175
|
}, ";color:", function (props) {
|
|
3168
3176
|
return props.isInverse ? props.theme.colors.tertiary500 : props.theme.colors.neutral500;
|
|
3169
|
-
}, ";}" + ( "/*# sourceMappingURL=data:application/json;charset=utf-8;base64,
|
|
3177
|
+
}, ";}" + ( "/*# sourceMappingURL=data:application/json;charset=utf-8;base64,eyJ2ZXJzaW9uIjozLCJzb3VyY2VzIjpbIkJyZWFkY3J1bWJJdGVtLnRzeCJdLCJuYW1lcyI6W10sIm1hcHBpbmdzIjoiQUFtQytCIiwiZmlsZSI6IkJyZWFkY3J1bWJJdGVtLnRzeCIsInNvdXJjZXNDb250ZW50IjpbImltcG9ydCBzdHlsZWQgZnJvbSAnQGVtb3Rpb24vc3R5bGVkJztcclxuaW1wb3J0ICogYXMgUmVhY3QgZnJvbSAncmVhY3QnO1xyXG5pbXBvcnQgeyBDaGV2cm9uUmlnaHRJY29uIH0gZnJvbSAncmVhY3QtbWFnbWEtaWNvbnMnO1xyXG5pbXBvcnQgeyB1c2VJc0ludmVyc2UgfSBmcm9tICcuLi8uLi9pbnZlcnNlJztcclxuaW1wb3J0IHsgVGhlbWVDb250ZXh0IH0gZnJvbSAnLi4vLi4vdGhlbWUvVGhlbWVDb250ZXh0JztcclxuaW1wb3J0IHsgSHlwZXJsaW5rIH0gZnJvbSAnLi4vSHlwZXJsaW5rJztcclxuY29uc3QgU3R5bGVkSXRlbSA9IHN0eWxlZC5saSBgXG4gIGxpc3Qtc3R5bGU6IG5vbmU7XG4gIG1hcmdpbjogMDtcbiAgcGFkZGluZzogMDtcbiAgZGlzcGxheTogZmxleDtcbmA7XHJcbmNvbnN0IFN0eWxlZExpbmsgPSBzdHlsZWQuYSBgXG4gIGFsaWduLWl0ZW1zOiBjZW50ZXI7XG4gIGRpc3BsYXk6IGZsZXg7XG4gIGNvbG9yOiAke3Byb3BzID0+IHByb3BzLmlzSW52ZXJzZVxyXG4gICAgPyBwcm9wcy50aGVtZS5jb2xvcnMubmV1dHJhbDEwMFxyXG4gICAgOiBwcm9wcy50aGVtZS5jb2xvcnMubmV1dHJhbDcwMH07XG4gIHRleHQtZGVjb3JhdGlvbjogbm9uZTtcbiAgY3Vyc29yOiBkZWZhdWx0O1xuICBcbiAgJjpob3ZlcixcbiAgJjpmb2N1cyB7XG4gICAgY29sb3I6ICR7cHJvcHMgPT4gcHJvcHMuaXNJbnZlcnNlXHJcbiAgICA/IHByb3BzLnRoZW1lLmNvbG9ycy5uZXV0cmFsMTAwXHJcbiAgICA6IHByb3BzLnRoZW1lLmNvbG9ycy5uZXV0cmFsNzAwfTtcbiAgfVxuICAmOmZvY3VzIHtcbiAgICBvdXRsaW5lOiAycHggc29saWRcbiAgICAgICR7cHJvcHMgPT4gcHJvcHMuaXNJbnZlcnNlXHJcbiAgICA/IHByb3BzLnRoZW1lLmNvbG9ycy5mb2N1c0ludmVyc2VcclxuICAgIDogcHJvcHMudGhlbWUuY29sb3JzLmZvY3VzfTtcbiAgICBvdXRsaW5lLW9mZnNldDogMnB4O1xuICB9XG5gO1xyXG5jb25zdCBTdHlsZWRTcGFuID0gc3R5bGVkLnNwYW4gYFxuICBhbGlnbi1pdGVtczogY2VudGVyO1xuICBkaXNwbGF5OiBmbGV4O1xuXG4gIHN2ZyB7XG4gICAgbWFyZ2luOiAwICR7cHJvcHMgPT4gcHJvcHMudGhlbWUuc3BhY2VTY2FsZS5zcGFjaW5nMDJ9O1xuICAgIGNvbG9yOiAke3Byb3BzID0+IHByb3BzLmlzSW52ZXJzZVxyXG4gICAgPyBwcm9wcy50aGVtZS5jb2xvcnMudGVydGlhcnk1MDBcclxuICAgIDogcHJvcHMudGhlbWUuY29sb3JzLm5ldXRyYWw1MDB9O1xuICB9XG5gO1xyXG5leHBvcnQgY29uc3QgQnJlYWRjcnVtYkl0ZW0gPSBSZWFjdC5mb3J3YXJkUmVmKChwcm9wcywgcmVmKSA9PiB7XHJcbiAgICBjb25zdCB7IGNoaWxkcmVuLCB0bywgdGVzdElkLCAuLi5vdGhlciB9ID0gcHJvcHM7XHJcbiAgICBjb25zdCB0aGVtZSA9IFJlYWN0LnVzZUNvbnRleHQoVGhlbWVDb250ZXh0KTtcclxuICAgIGNvbnN0IGlzSW52ZXJzZSA9IHVzZUlzSW52ZXJzZSgpO1xyXG4gICAgcmV0dXJuIChSZWFjdC5jcmVhdGVFbGVtZW50KFN0eWxlZEl0ZW0sIE9iamVjdC5hc3NpZ24oe30sIG90aGVyLCB7IFwiZGF0YS10ZXN0aWRcIjogdGVzdElkLCByZWY6IHJlZiB9KSwgdG8gPyAoUmVhY3QuY3JlYXRlRWxlbWVudChSZWFjdC5GcmFnbWVudCwgbnVsbCxcclxuICAgICAgICBSZWFjdC5jcmVhdGVFbGVtZW50KEh5cGVybGluaywgeyB0bzogdG8sIGlzSW52ZXJzZTogaXNJbnZlcnNlIH0sIGNoaWxkcmVuKSxcclxuICAgICAgICBSZWFjdC5jcmVhdGVFbGVtZW50KFN0eWxlZFNwYW4sIHsgaXNJbnZlcnNlOiBpc0ludmVyc2UsIHRoZW1lOiB0aGVtZSB9LFxyXG4gICAgICAgICAgICBSZWFjdC5jcmVhdGVFbGVtZW50KENoZXZyb25SaWdodEljb24sIHsgc2l6ZTogdGhlbWUuaWNvblNpemVzLnNtYWxsIH0pKSkpIDogKFJlYWN0LmNyZWF0ZUVsZW1lbnQoUmVhY3QuRnJhZ21lbnQsIG51bGwsXHJcbiAgICAgICAgUmVhY3QuY3JlYXRlRWxlbWVudChTdHlsZWRMaW5rLCB7IGhyZWY6IFwiXCIsIFwiYXJpYS1jdXJyZW50XCI6IFwicGFnZVwiLCBpc0ludmVyc2U6IGlzSW52ZXJzZSwgdGhlbWU6IHRoZW1lLCBvbkNsaWNrOiBlID0+IGUucHJldmVudERlZmF1bHQoKSB9LCBjaGlsZHJlbikpKSkpO1xyXG59KTtcclxuLy8jIHNvdXJjZU1hcHBpbmdVUkw9QnJlYWRjcnVtYkl0ZW0uanMubWFwIl19 */"));
|
|
3170
3178
|
var BreadcrumbItem = /*#__PURE__*/React.forwardRef(function (props, ref) {
|
|
3171
3179
|
var children = props.children,
|
|
3172
3180
|
to = props.to,
|
|
@@ -3185,11 +3193,15 @@ var BreadcrumbItem = /*#__PURE__*/React.forwardRef(function (props, ref) {
|
|
|
3185
3193
|
theme: theme
|
|
3186
3194
|
}, React.createElement(reactMagmaIcons.ChevronRightIcon, {
|
|
3187
3195
|
size: theme.iconSizes.small
|
|
3188
|
-
}))) : React.createElement(
|
|
3196
|
+
}))) : React.createElement(React.Fragment, null, React.createElement(StyledLink$1, {
|
|
3197
|
+
href: "",
|
|
3189
3198
|
"aria-current": "page",
|
|
3190
3199
|
isInverse: isInverse,
|
|
3191
|
-
theme: theme
|
|
3192
|
-
|
|
3200
|
+
theme: theme,
|
|
3201
|
+
onClick: function onClick(e) {
|
|
3202
|
+
return e.preventDefault();
|
|
3203
|
+
}
|
|
3204
|
+
}, children)));
|
|
3193
3205
|
});
|
|
3194
3206
|
|
|
3195
3207
|
var _excluded$e = ["children", "displayType", "minWidth", "maxWidth", "testId"];
|
|
@@ -4493,9 +4505,11 @@ var IndeterminateCheckbox = /*#__PURE__*/React.forwardRef(function (props, ref)
|
|
|
4493
4505
|
var describedBy = descriptionId && groupDescriptionId ? groupDescriptionId + " " + descriptionId : descriptionId ? descriptionId : groupDescriptionId ? groupDescriptionId : null;
|
|
4494
4506
|
var hasError = context.hasError || !!errorMessage;
|
|
4495
4507
|
var isInverse = useIsInverse(props.isInverse);
|
|
4508
|
+
var ariaCheckedValue = isIndeterminate ? 'mixed' : !isUnchecked;
|
|
4496
4509
|
return React.createElement(React.Fragment, null, React.createElement(StyledContainer, {
|
|
4497
4510
|
style: containerStyle
|
|
4498
4511
|
}, React.createElement(HiddenInput, Object.assign({}, other, {
|
|
4512
|
+
"aria-checked": ariaCheckedValue,
|
|
4499
4513
|
"aria-describedby": describedBy,
|
|
4500
4514
|
checked: isChecked,
|
|
4501
4515
|
"data-testid": testId,
|
|
@@ -7971,6 +7985,9 @@ function useAccordionButton(props, forwardedRef) {
|
|
|
7971
7985
|
};
|
|
7972
7986
|
var handleKeyDown = function handleKeyDown(event) {
|
|
7973
7987
|
var arrLength = buttonRefArray.current.length;
|
|
7988
|
+
if (['ArrowDown', 'ArrowUp', 'Home', 'End'].includes(event.key)) {
|
|
7989
|
+
event.preventDefault();
|
|
7990
|
+
}
|
|
7974
7991
|
switch (event.key) {
|
|
7975
7992
|
case 'ArrowDown':
|
|
7976
7993
|
{
|
|
@@ -8018,6 +8035,349 @@ function useAccordionButton(props, forwardedRef) {
|
|
|
8018
8035
|
};
|
|
8019
8036
|
}
|
|
8020
8037
|
|
|
8038
|
+
var reducedMotionTransitions = {
|
|
8039
|
+
fade: {
|
|
8040
|
+
motion: {
|
|
8041
|
+
exit: {
|
|
8042
|
+
opacity: 0,
|
|
8043
|
+
transition: {
|
|
8044
|
+
opacity: {
|
|
8045
|
+
duration: 0,
|
|
8046
|
+
ease: 'easeOut'
|
|
8047
|
+
}
|
|
8048
|
+
}
|
|
8049
|
+
},
|
|
8050
|
+
enter: {
|
|
8051
|
+
opacity: 1,
|
|
8052
|
+
transition: {
|
|
8053
|
+
duration: 0,
|
|
8054
|
+
ease: 'easeIn'
|
|
8055
|
+
}
|
|
8056
|
+
}
|
|
8057
|
+
},
|
|
8058
|
+
baseStyle: {}
|
|
8059
|
+
},
|
|
8060
|
+
slideTop: {
|
|
8061
|
+
motion: {
|
|
8062
|
+
exit: {
|
|
8063
|
+
y: '-100%',
|
|
8064
|
+
transition: {
|
|
8065
|
+
y: {
|
|
8066
|
+
duration: 0,
|
|
8067
|
+
ease: 'easeInOut'
|
|
8068
|
+
}
|
|
8069
|
+
}
|
|
8070
|
+
},
|
|
8071
|
+
enter: {
|
|
8072
|
+
y: '0',
|
|
8073
|
+
transition: {
|
|
8074
|
+
y: {
|
|
8075
|
+
type: 'spring',
|
|
8076
|
+
damping: 25,
|
|
8077
|
+
stiffness: 180
|
|
8078
|
+
}
|
|
8079
|
+
}
|
|
8080
|
+
}
|
|
8081
|
+
},
|
|
8082
|
+
baseStyle: {
|
|
8083
|
+
position: 'fixed',
|
|
8084
|
+
top: 0,
|
|
8085
|
+
right: 0,
|
|
8086
|
+
left: 0
|
|
8087
|
+
}
|
|
8088
|
+
},
|
|
8089
|
+
slideBottom: {
|
|
8090
|
+
motion: {
|
|
8091
|
+
exit: {
|
|
8092
|
+
y: '100%',
|
|
8093
|
+
transition: {
|
|
8094
|
+
y: {
|
|
8095
|
+
duration: 0,
|
|
8096
|
+
ease: 'easeInOut'
|
|
8097
|
+
}
|
|
8098
|
+
}
|
|
8099
|
+
},
|
|
8100
|
+
enter: {
|
|
8101
|
+
y: '0',
|
|
8102
|
+
transition: {
|
|
8103
|
+
y: {
|
|
8104
|
+
type: 'spring',
|
|
8105
|
+
damping: 25,
|
|
8106
|
+
stiffness: 180
|
|
8107
|
+
}
|
|
8108
|
+
}
|
|
8109
|
+
}
|
|
8110
|
+
},
|
|
8111
|
+
baseStyle: {
|
|
8112
|
+
position: 'fixed',
|
|
8113
|
+
bottom: 0,
|
|
8114
|
+
right: 0,
|
|
8115
|
+
left: 0
|
|
8116
|
+
}
|
|
8117
|
+
},
|
|
8118
|
+
slideRight: {
|
|
8119
|
+
motion: {
|
|
8120
|
+
exit: {
|
|
8121
|
+
x: '100%',
|
|
8122
|
+
transition: {
|
|
8123
|
+
x: {
|
|
8124
|
+
duration: 0,
|
|
8125
|
+
ease: 'easeInOut'
|
|
8126
|
+
}
|
|
8127
|
+
}
|
|
8128
|
+
},
|
|
8129
|
+
enter: {
|
|
8130
|
+
x: '0',
|
|
8131
|
+
transition: {
|
|
8132
|
+
x: {
|
|
8133
|
+
type: 'spring',
|
|
8134
|
+
damping: 25,
|
|
8135
|
+
stiffness: 180
|
|
8136
|
+
}
|
|
8137
|
+
}
|
|
8138
|
+
}
|
|
8139
|
+
},
|
|
8140
|
+
baseStyle: {
|
|
8141
|
+
position: 'fixed',
|
|
8142
|
+
top: 0,
|
|
8143
|
+
right: 0,
|
|
8144
|
+
bottom: 0
|
|
8145
|
+
}
|
|
8146
|
+
},
|
|
8147
|
+
slideLeft: {
|
|
8148
|
+
motion: {
|
|
8149
|
+
exit: {
|
|
8150
|
+
x: '-100%',
|
|
8151
|
+
transition: {
|
|
8152
|
+
x: {
|
|
8153
|
+
duration: 0,
|
|
8154
|
+
ease: 'easeInOut'
|
|
8155
|
+
}
|
|
8156
|
+
}
|
|
8157
|
+
},
|
|
8158
|
+
enter: {
|
|
8159
|
+
x: '0',
|
|
8160
|
+
transition: {
|
|
8161
|
+
x: {
|
|
8162
|
+
type: 'spring',
|
|
8163
|
+
damping: 25,
|
|
8164
|
+
stiffness: 180
|
|
8165
|
+
}
|
|
8166
|
+
}
|
|
8167
|
+
}
|
|
8168
|
+
},
|
|
8169
|
+
baseStyle: {
|
|
8170
|
+
position: 'fixed',
|
|
8171
|
+
top: 0,
|
|
8172
|
+
bottom: 0,
|
|
8173
|
+
left: 0
|
|
8174
|
+
}
|
|
8175
|
+
},
|
|
8176
|
+
nudgeTop: {
|
|
8177
|
+
motion: {
|
|
8178
|
+
exit: {
|
|
8179
|
+
y: '-50px',
|
|
8180
|
+
transition: {
|
|
8181
|
+
y: {
|
|
8182
|
+
duration: 0,
|
|
8183
|
+
ease: 'easeInOut'
|
|
8184
|
+
}
|
|
8185
|
+
}
|
|
8186
|
+
},
|
|
8187
|
+
enter: {
|
|
8188
|
+
y: '0',
|
|
8189
|
+
transition: {
|
|
8190
|
+
y: {
|
|
8191
|
+
type: 'spring',
|
|
8192
|
+
damping: 25,
|
|
8193
|
+
stiffness: 180
|
|
8194
|
+
}
|
|
8195
|
+
}
|
|
8196
|
+
}
|
|
8197
|
+
},
|
|
8198
|
+
baseStyle: {}
|
|
8199
|
+
},
|
|
8200
|
+
nudgeBottom: {
|
|
8201
|
+
motion: {
|
|
8202
|
+
exit: {
|
|
8203
|
+
y: '50px',
|
|
8204
|
+
transition: {
|
|
8205
|
+
y: {
|
|
8206
|
+
duration: 0,
|
|
8207
|
+
ease: 'easeInOut'
|
|
8208
|
+
}
|
|
8209
|
+
}
|
|
8210
|
+
},
|
|
8211
|
+
enter: {
|
|
8212
|
+
y: '0',
|
|
8213
|
+
transition: {
|
|
8214
|
+
y: {
|
|
8215
|
+
type: 'spring',
|
|
8216
|
+
damping: 25,
|
|
8217
|
+
stiffness: 180
|
|
8218
|
+
}
|
|
8219
|
+
}
|
|
8220
|
+
}
|
|
8221
|
+
},
|
|
8222
|
+
baseStyle: {}
|
|
8223
|
+
},
|
|
8224
|
+
nudgeRight: {
|
|
8225
|
+
motion: {
|
|
8226
|
+
exit: {
|
|
8227
|
+
x: '50px',
|
|
8228
|
+
transition: {
|
|
8229
|
+
x: {
|
|
8230
|
+
duration: 0,
|
|
8231
|
+
ease: 'easeInOut'
|
|
8232
|
+
}
|
|
8233
|
+
}
|
|
8234
|
+
},
|
|
8235
|
+
enter: {
|
|
8236
|
+
x: '0',
|
|
8237
|
+
transition: {
|
|
8238
|
+
x: {
|
|
8239
|
+
type: 'spring',
|
|
8240
|
+
damping: 25,
|
|
8241
|
+
stiffness: 180
|
|
8242
|
+
}
|
|
8243
|
+
}
|
|
8244
|
+
}
|
|
8245
|
+
},
|
|
8246
|
+
baseStyle: {}
|
|
8247
|
+
},
|
|
8248
|
+
nudgeLeft: {
|
|
8249
|
+
motion: {
|
|
8250
|
+
exit: {
|
|
8251
|
+
x: '-50px',
|
|
8252
|
+
transition: {
|
|
8253
|
+
x: {
|
|
8254
|
+
duration: 0,
|
|
8255
|
+
ease: 'easeInOut'
|
|
8256
|
+
}
|
|
8257
|
+
}
|
|
8258
|
+
},
|
|
8259
|
+
enter: {
|
|
8260
|
+
x: '0',
|
|
8261
|
+
transition: {
|
|
8262
|
+
x: {
|
|
8263
|
+
type: 'spring',
|
|
8264
|
+
damping: 25,
|
|
8265
|
+
stiffness: 180
|
|
8266
|
+
}
|
|
8267
|
+
}
|
|
8268
|
+
}
|
|
8269
|
+
},
|
|
8270
|
+
baseStyle: {}
|
|
8271
|
+
},
|
|
8272
|
+
scale: {
|
|
8273
|
+
motion: {
|
|
8274
|
+
exit: {
|
|
8275
|
+
scale: 0.95,
|
|
8276
|
+
transition: {
|
|
8277
|
+
scale: {
|
|
8278
|
+
duration: 0,
|
|
8279
|
+
ease: 'easeOut'
|
|
8280
|
+
}
|
|
8281
|
+
}
|
|
8282
|
+
},
|
|
8283
|
+
enter: {
|
|
8284
|
+
scale: 1,
|
|
8285
|
+
transition: {
|
|
8286
|
+
scale: {
|
|
8287
|
+
duration: 0,
|
|
8288
|
+
ease: 'easeInOut'
|
|
8289
|
+
}
|
|
8290
|
+
}
|
|
8291
|
+
}
|
|
8292
|
+
},
|
|
8293
|
+
baseStyle: {}
|
|
8294
|
+
},
|
|
8295
|
+
rotate45: {
|
|
8296
|
+
motion: {
|
|
8297
|
+
exit: {
|
|
8298
|
+
rotate: 0,
|
|
8299
|
+
transition: {
|
|
8300
|
+
rotate: {
|
|
8301
|
+
type: 'tween',
|
|
8302
|
+
stiffness: 50,
|
|
8303
|
+
duration: 0
|
|
8304
|
+
}
|
|
8305
|
+
}
|
|
8306
|
+
},
|
|
8307
|
+
enter: {
|
|
8308
|
+
rotate: -45,
|
|
8309
|
+
transition: {
|
|
8310
|
+
rotate: {
|
|
8311
|
+
type: 'tween',
|
|
8312
|
+
stiffness: 50,
|
|
8313
|
+
duration: 0
|
|
8314
|
+
}
|
|
8315
|
+
}
|
|
8316
|
+
}
|
|
8317
|
+
},
|
|
8318
|
+
baseStyle: {}
|
|
8319
|
+
},
|
|
8320
|
+
rotate90: {
|
|
8321
|
+
motion: {
|
|
8322
|
+
exit: {
|
|
8323
|
+
rotate: 0,
|
|
8324
|
+
transition: {
|
|
8325
|
+
rotate: {
|
|
8326
|
+
type: 'tween',
|
|
8327
|
+
stiffness: 50,
|
|
8328
|
+
duration: 0
|
|
8329
|
+
}
|
|
8330
|
+
}
|
|
8331
|
+
},
|
|
8332
|
+
enter: {
|
|
8333
|
+
rotate: -90,
|
|
8334
|
+
transition: {
|
|
8335
|
+
rotate: {
|
|
8336
|
+
type: 'tween',
|
|
8337
|
+
stiffness: 50,
|
|
8338
|
+
duration: 0
|
|
8339
|
+
}
|
|
8340
|
+
}
|
|
8341
|
+
}
|
|
8342
|
+
},
|
|
8343
|
+
baseStyle: {}
|
|
8344
|
+
},
|
|
8345
|
+
rotate180: {
|
|
8346
|
+
motion: {
|
|
8347
|
+
exit: {
|
|
8348
|
+
rotate: 0,
|
|
8349
|
+
transition: {
|
|
8350
|
+
rotate: {
|
|
8351
|
+
type: 'tween',
|
|
8352
|
+
stiffness: 50,
|
|
8353
|
+
duration: 0
|
|
8354
|
+
}
|
|
8355
|
+
}
|
|
8356
|
+
},
|
|
8357
|
+
enter: {
|
|
8358
|
+
rotate: -180,
|
|
8359
|
+
transition: {
|
|
8360
|
+
rotate: {
|
|
8361
|
+
type: 'tween',
|
|
8362
|
+
stiffness: 50,
|
|
8363
|
+
duration: 0
|
|
8364
|
+
}
|
|
8365
|
+
}
|
|
8366
|
+
}
|
|
8367
|
+
},
|
|
8368
|
+
baseStyle: {}
|
|
8369
|
+
},
|
|
8370
|
+
collapse: {
|
|
8371
|
+
motion: {
|
|
8372
|
+
exit: {},
|
|
8373
|
+
enter: {}
|
|
8374
|
+
},
|
|
8375
|
+
baseStyle: {
|
|
8376
|
+
overflow: 'visible'
|
|
8377
|
+
}
|
|
8378
|
+
}
|
|
8379
|
+
};
|
|
8380
|
+
|
|
8021
8381
|
var _excluded$T = ["style", "unmountOnExit", "isOpen", "testId", "initial", "exit", "customTransition"];
|
|
8022
8382
|
var Transition = /*#__PURE__*/React.forwardRef(function (props, ref) {
|
|
8023
8383
|
var theme = React.useContext(ThemeContext);
|
|
@@ -8040,9 +8400,11 @@ var Transition = /*#__PURE__*/React.forwardRef(function (props, ref) {
|
|
|
8040
8400
|
} : _props$customTransiti,
|
|
8041
8401
|
rest = _objectWithoutPropertiesLoose(props, _excluded$T);
|
|
8042
8402
|
var shouldExpand = unmountOnExit ? isOpen && unmountOnExit : true;
|
|
8403
|
+
var shouldReduceMotion = framerMotion.useReducedMotion();
|
|
8404
|
+
var transitionsArr = shouldReduceMotion ? reducedMotionTransitions : theme.transitions;
|
|
8043
8405
|
var variants = Object.keys(rest).reduce(function (acc, key) {
|
|
8044
|
-
if (rest[key] &&
|
|
8045
|
-
var themeVariant =
|
|
8406
|
+
if (rest[key] && transitionsArr[key]) {
|
|
8407
|
+
var themeVariant = transitionsArr[key];
|
|
8046
8408
|
rest[key] = undefined;
|
|
8047
8409
|
return {
|
|
8048
8410
|
baseStyle: _extends({}, acc.baseStyle, themeVariant.baseStyle),
|
|
@@ -10443,13 +10805,15 @@ var ModalContainer = /*#__PURE__*/_styled(Transition, {
|
|
|
10443
10805
|
label: "ModalContainer"
|
|
10444
10806
|
})("bottom:0;left:0;overflow-y:auto;padding:", function (props) {
|
|
10445
10807
|
return props.theme.spaceScale.spacing03;
|
|
10446
|
-
}, ";right:0;top:0;z-index:998;" + ( "/*# 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 ReactDOM from 'react-dom';\r\nimport styled from '@emotion/styled';\r\nimport { Global, css } from '@emotion/react';\r\nimport { ThemeContext } from '../../theme/ThemeContext';\r\nimport { magma } from '../../theme/magma';\r\nimport { I18nContext } from '../../i18n';\r\nimport { ButtonColor, ButtonVariant } from '../Button';\r\nimport { IconButton } from '../IconButton';\r\nimport { CloseIcon } from 'react-magma-icons';\r\nimport { Heading } from '../Heading';\r\nimport { TypographyVisualStyle } from '../Typography';\r\nimport { Transition } from '../Transition';\r\nimport { omit, useGenerateId, usePrevious } from '../../utils';\r\nimport { useFocusLock } from '../../hooks/useFocusLock';\r\nimport { transparentize } from 'polished';\r\nimport { useIsInverse } from '../../inverse';\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: 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(ModalBackdrop, { \"data-testid\": \"modal-backdrop\", isExiting: isExiting, onMouseDown: isBackgroundClickDisabled\r\n                    ? event => event.preventDefault()\r\n                    : null, fade: true, isOpen: isModalOpen, unmountOnExit: true, theme: theme },\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, 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 }))))))), document.getElementsByTagName('body')[0])\r\n        : null;\r\n});\r\n//# sourceMappingURL=Modal.js.map"]} */"));
|
|
10808
|
+
}, ";right:0;top:0;z-index:", function (props) {
|
|
10809
|
+
return props.modalCount >= 2 ? '999' : '998';
|
|
10810
|
+
}, ";" + ( "/*# 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 ReactDOM from 'react-dom';\r\nimport styled from '@emotion/styled';\r\nimport { Global, css } from '@emotion/react';\r\nimport { ThemeContext } from '../../theme/ThemeContext';\r\nimport { magma } from '../../theme/magma';\r\nimport { I18nContext } from '../../i18n';\r\nimport { ButtonColor, ButtonVariant } from '../Button';\r\nimport { IconButton } from '../IconButton';\r\nimport { CloseIcon } from 'react-magma-icons';\r\nimport { Heading } from '../Heading';\r\nimport { TypographyVisualStyle } from '../Typography';\r\nimport { Transition } from '../Transition';\r\nimport { omit, useGenerateId, usePrevious } from '../../utils';\r\nimport { useFocusLock } from '../../hooks/useFocusLock';\r\nimport { transparentize } from 'polished';\r\nimport { useIsInverse } from '../../inverse';\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"]} */"));
|
|
10447
10811
|
var ModalBackdrop = /*#__PURE__*/_styled(Transition, {
|
|
10448
10812
|
target: "e1pxemtw5",
|
|
10449
10813
|
label: "ModalBackdrop"
|
|
10450
10814
|
})("backdrop-filter:blur(3px);background:", function (props) {
|
|
10451
10815
|
return polished.transparentize(0.4, props.theme.colors.neutral900);
|
|
10452
|
-
}, ";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 ReactDOM from 'react-dom';\r\nimport styled from '@emotion/styled';\r\nimport { Global, css } from '@emotion/react';\r\nimport { ThemeContext } from '../../theme/ThemeContext';\r\nimport { magma } from '../../theme/magma';\r\nimport { I18nContext } from '../../i18n';\r\nimport { ButtonColor, ButtonVariant } from '../Button';\r\nimport { IconButton } from '../IconButton';\r\nimport { CloseIcon } from 'react-magma-icons';\r\nimport { Heading } from '../Heading';\r\nimport { TypographyVisualStyle } from '../Typography';\r\nimport { Transition } from '../Transition';\r\nimport { omit, useGenerateId, usePrevious } from '../../utils';\r\nimport { useFocusLock } from '../../hooks/useFocusLock';\r\nimport { transparentize } from 'polished';\r\nimport { useIsInverse } from '../../inverse';\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: 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(ModalBackdrop, { \"data-testid\": \"modal-backdrop\", isExiting: isExiting, onMouseDown: isBackgroundClickDisabled\r\n                    ? event => event.preventDefault()\r\n                    : null, fade: true, isOpen: isModalOpen, unmountOnExit: true, theme: theme },\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, 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 }))))))), document.getElementsByTagName('body')[0])\r\n        : null;\r\n});\r\n//# sourceMappingURL=Modal.js.map"]} */"));
|
|
10816
|
+
}, ";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 ReactDOM from 'react-dom';\r\nimport styled from '@emotion/styled';\r\nimport { Global, css } from '@emotion/react';\r\nimport { ThemeContext } from '../../theme/ThemeContext';\r\nimport { magma } from '../../theme/magma';\r\nimport { I18nContext } from '../../i18n';\r\nimport { ButtonColor, ButtonVariant } from '../Button';\r\nimport { IconButton } from '../IconButton';\r\nimport { CloseIcon } from 'react-magma-icons';\r\nimport { Heading } from '../Heading';\r\nimport { TypographyVisualStyle } from '../Typography';\r\nimport { Transition } from '../Transition';\r\nimport { omit, useGenerateId, usePrevious } from '../../utils';\r\nimport { useFocusLock } from '../../hooks/useFocusLock';\r\nimport { transparentize } from 'polished';\r\nimport { useIsInverse } from '../../inverse';\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"]} */"));
|
|
10453
10817
|
var ModalContent = /*#__PURE__*/_styled("div", {
|
|
10454
10818
|
target: "e1pxemtw4",
|
|
10455
10819
|
label: "ModalContent"
|
|
@@ -10476,7 +10840,7 @@ var ModalContent = /*#__PURE__*/_styled("div", {
|
|
|
10476
10840
|
return props.theme.breakpoints.small;
|
|
10477
10841
|
}, "px){margin:", function (props) {
|
|
10478
10842
|
return props.theme.spaceScale.spacing08;
|
|
10479
|
-
}, " 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 ReactDOM from 'react-dom';\r\nimport styled from '@emotion/styled';\r\nimport { Global, css } from '@emotion/react';\r\nimport { ThemeContext } from '../../theme/ThemeContext';\r\nimport { magma } from '../../theme/magma';\r\nimport { I18nContext } from '../../i18n';\r\nimport { ButtonColor, ButtonVariant } from '../Button';\r\nimport { IconButton } from '../IconButton';\r\nimport { CloseIcon } from 'react-magma-icons';\r\nimport { Heading } from '../Heading';\r\nimport { TypographyVisualStyle } from '../Typography';\r\nimport { Transition } from '../Transition';\r\nimport { omit, useGenerateId, usePrevious } from '../../utils';\r\nimport { useFocusLock } from '../../hooks/useFocusLock';\r\nimport { transparentize } from 'polished';\r\nimport { useIsInverse } from '../../inverse';\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: 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(ModalBackdrop, { \"data-testid\": \"modal-backdrop\", isExiting: isExiting, onMouseDown: isBackgroundClickDisabled\r\n                    ? event => event.preventDefault()\r\n                    : null, fade: true, isOpen: isModalOpen, unmountOnExit: true, theme: theme },\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, 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 }))))))), document.getElementsByTagName('body')[0])\r\n        : null;\r\n});\r\n//# sourceMappingURL=Modal.js.map"]} */"));
|
|
10843
|
+
}, " 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 ReactDOM from 'react-dom';\r\nimport styled from '@emotion/styled';\r\nimport { Global, css } from '@emotion/react';\r\nimport { ThemeContext } from '../../theme/ThemeContext';\r\nimport { magma } from '../../theme/magma';\r\nimport { I18nContext } from '../../i18n';\r\nimport { ButtonColor, ButtonVariant } from '../Button';\r\nimport { IconButton } from '../IconButton';\r\nimport { CloseIcon } from 'react-magma-icons';\r\nimport { Heading } from '../Heading';\r\nimport { TypographyVisualStyle } from '../Typography';\r\nimport { Transition } from '../Transition';\r\nimport { omit, useGenerateId, usePrevious } from '../../utils';\r\nimport { useFocusLock } from '../../hooks/useFocusLock';\r\nimport { transparentize } from 'polished';\r\nimport { useIsInverse } from '../../inverse';\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"]} */"));
|
|
10480
10844
|
var ModalHeader = /*#__PURE__*/_styled("div", {
|
|
10481
10845
|
target: "e1pxemtw3",
|
|
10482
10846
|
label: "ModalHeader"
|
|
@@ -10494,7 +10858,7 @@ var ModalHeader = /*#__PURE__*/_styled("div", {
|
|
|
10494
10858
|
return props.theme.spaceScale.spacing06;
|
|
10495
10859
|
}, " 0 ", function (props) {
|
|
10496
10860
|
return props.theme.spaceScale.spacing06;
|
|
10497
|
-
}, ";}" + ( "/*# 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 ReactDOM from 'react-dom';\r\nimport styled from '@emotion/styled';\r\nimport { Global, css } from '@emotion/react';\r\nimport { ThemeContext } from '../../theme/ThemeContext';\r\nimport { magma } from '../../theme/magma';\r\nimport { I18nContext } from '../../i18n';\r\nimport { ButtonColor, ButtonVariant } from '../Button';\r\nimport { IconButton } from '../IconButton';\r\nimport { CloseIcon } from 'react-magma-icons';\r\nimport { Heading } from '../Heading';\r\nimport { TypographyVisualStyle } from '../Typography';\r\nimport { Transition } from '../Transition';\r\nimport { omit, useGenerateId, usePrevious } from '../../utils';\r\nimport { useFocusLock } from '../../hooks/useFocusLock';\r\nimport { transparentize } from 'polished';\r\nimport { useIsInverse } from '../../inverse';\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: 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(ModalBackdrop, { \"data-testid\": \"modal-backdrop\", isExiting: isExiting, onMouseDown: isBackgroundClickDisabled\r\n                    ? event => event.preventDefault()\r\n                    : null, fade: true, isOpen: isModalOpen, unmountOnExit: true, theme: theme },\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, 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 }))))))), document.getElementsByTagName('body')[0])\r\n        : null;\r\n});\r\n//# sourceMappingURL=Modal.js.map"]} */"));
|
|
10861
|
+
}, ";}" + ( "/*# 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 ReactDOM from 'react-dom';\r\nimport styled from '@emotion/styled';\r\nimport { Global, css } from '@emotion/react';\r\nimport { ThemeContext } from '../../theme/ThemeContext';\r\nimport { magma } from '../../theme/magma';\r\nimport { I18nContext } from '../../i18n';\r\nimport { ButtonColor, ButtonVariant } from '../Button';\r\nimport { IconButton } from '../IconButton';\r\nimport { CloseIcon } from 'react-magma-icons';\r\nimport { Heading } from '../Heading';\r\nimport { TypographyVisualStyle } from '../Typography';\r\nimport { Transition } from '../Transition';\r\nimport { omit, useGenerateId, usePrevious } from '../../utils';\r\nimport { useFocusLock } from '../../hooks/useFocusLock';\r\nimport { transparentize } from 'polished';\r\nimport { useIsInverse } from '../../inverse';\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"]} */"));
|
|
10498
10862
|
var ModalWrapper = /*#__PURE__*/_styled("div", {
|
|
10499
10863
|
target: "e1pxemtw2",
|
|
10500
10864
|
label: "ModalWrapper"
|
|
@@ -10504,7 +10868,7 @@ var ModalWrapper = /*#__PURE__*/_styled("div", {
|
|
|
10504
10868
|
return props.theme.breakpoints.small;
|
|
10505
10869
|
}, "px){padding:", function (props) {
|
|
10506
10870
|
return props.theme.spaceScale.spacing06;
|
|
10507
|
-
}, ";}" + ( "/*# 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 ReactDOM from 'react-dom';\r\nimport styled from '@emotion/styled';\r\nimport { Global, css } from '@emotion/react';\r\nimport { ThemeContext } from '../../theme/ThemeContext';\r\nimport { magma } from '../../theme/magma';\r\nimport { I18nContext } from '../../i18n';\r\nimport { ButtonColor, ButtonVariant } from '../Button';\r\nimport { IconButton } from '../IconButton';\r\nimport { CloseIcon } from 'react-magma-icons';\r\nimport { Heading } from '../Heading';\r\nimport { TypographyVisualStyle } from '../Typography';\r\nimport { Transition } from '../Transition';\r\nimport { omit, useGenerateId, usePrevious } from '../../utils';\r\nimport { useFocusLock } from '../../hooks/useFocusLock';\r\nimport { transparentize } from 'polished';\r\nimport { useIsInverse } from '../../inverse';\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: 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(ModalBackdrop, { \"data-testid\": \"modal-backdrop\", isExiting: isExiting, onMouseDown: isBackgroundClickDisabled\r\n                    ? event => event.preventDefault()\r\n                    : null, fade: true, isOpen: isModalOpen, unmountOnExit: true, theme: theme },\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, 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 }))))))), document.getElementsByTagName('body')[0])\r\n        : null;\r\n});\r\n//# sourceMappingURL=Modal.js.map"]} */"));
|
|
10871
|
+
}, ";}" + ( "/*# 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 ReactDOM from 'react-dom';\r\nimport styled from '@emotion/styled';\r\nimport { Global, css } from '@emotion/react';\r\nimport { ThemeContext } from '../../theme/ThemeContext';\r\nimport { magma } from '../../theme/magma';\r\nimport { I18nContext } from '../../i18n';\r\nimport { ButtonColor, ButtonVariant } from '../Button';\r\nimport { IconButton } from '../IconButton';\r\nimport { CloseIcon } from 'react-magma-icons';\r\nimport { Heading } from '../Heading';\r\nimport { TypographyVisualStyle } from '../Typography';\r\nimport { Transition } from '../Transition';\r\nimport { omit, useGenerateId, usePrevious } from '../../utils';\r\nimport { useFocusLock } from '../../hooks/useFocusLock';\r\nimport { transparentize } from 'polished';\r\nimport { useIsInverse } from '../../inverse';\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"]} */"));
|
|
10508
10872
|
var H1 = /*#__PURE__*/_styled(Heading, {
|
|
10509
10873
|
target: "e1pxemtw1",
|
|
10510
10874
|
label: "H1"
|
|
@@ -10516,13 +10880,13 @@ var H1 = /*#__PURE__*/_styled(Heading, {
|
|
|
10516
10880
|
return props.isInverse ? props.theme.colors.neutral100 : props.theme.colors.neutral700;
|
|
10517
10881
|
}, ";margin:0;padding-right:", function (props) {
|
|
10518
10882
|
return props.theme.spaceScale.spacing10;
|
|
10519
|
-
}, ";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 ReactDOM from 'react-dom';\r\nimport styled from '@emotion/styled';\r\nimport { Global, css } from '@emotion/react';\r\nimport { ThemeContext } from '../../theme/ThemeContext';\r\nimport { magma } from '../../theme/magma';\r\nimport { I18nContext } from '../../i18n';\r\nimport { ButtonColor, ButtonVariant } from '../Button';\r\nimport { IconButton } from '../IconButton';\r\nimport { CloseIcon } from 'react-magma-icons';\r\nimport { Heading } from '../Heading';\r\nimport { TypographyVisualStyle } from '../Typography';\r\nimport { Transition } from '../Transition';\r\nimport { omit, useGenerateId, usePrevious } from '../../utils';\r\nimport { useFocusLock } from '../../hooks/useFocusLock';\r\nimport { transparentize } from 'polished';\r\nimport { useIsInverse } from '../../inverse';\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: 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(ModalBackdrop, { \"data-testid\": \"modal-backdrop\", isExiting: isExiting, onMouseDown: isBackgroundClickDisabled\r\n                    ? event => event.preventDefault()\r\n                    : null, fade: true, isOpen: isModalOpen, unmountOnExit: true, theme: theme },\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, 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 }))))))), document.getElementsByTagName('body')[0])\r\n        : null;\r\n});\r\n//# sourceMappingURL=Modal.js.map"]} */"));
|
|
10883
|
+
}, ";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 ReactDOM from 'react-dom';\r\nimport styled from '@emotion/styled';\r\nimport { Global, css } from '@emotion/react';\r\nimport { ThemeContext } from '../../theme/ThemeContext';\r\nimport { magma } from '../../theme/magma';\r\nimport { I18nContext } from '../../i18n';\r\nimport { ButtonColor, ButtonVariant } from '../Button';\r\nimport { IconButton } from '../IconButton';\r\nimport { CloseIcon } from 'react-magma-icons';\r\nimport { Heading } from '../Heading';\r\nimport { TypographyVisualStyle } from '../Typography';\r\nimport { Transition } from '../Transition';\r\nimport { omit, useGenerateId, usePrevious } from '../../utils';\r\nimport { useFocusLock } from '../../hooks/useFocusLock';\r\nimport { transparentize } from 'polished';\r\nimport { useIsInverse } from '../../inverse';\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"]} */"));
|
|
10520
10884
|
var CloseBtn = /*#__PURE__*/_styled("span", {
|
|
10521
10885
|
target: "e1pxemtw0",
|
|
10522
10886
|
label: "CloseBtn"
|
|
10523
10887
|
})("position:absolute;top:0;right:0;margin:", function (props) {
|
|
10524
10888
|
return props.theme.spaceScale.spacing02;
|
|
10525
|
-
}, ";" + ( "/*# 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 ReactDOM from 'react-dom';\r\nimport styled from '@emotion/styled';\r\nimport { Global, css } from '@emotion/react';\r\nimport { ThemeContext } from '../../theme/ThemeContext';\r\nimport { magma } from '../../theme/magma';\r\nimport { I18nContext } from '../../i18n';\r\nimport { ButtonColor, ButtonVariant } from '../Button';\r\nimport { IconButton } from '../IconButton';\r\nimport { CloseIcon } from 'react-magma-icons';\r\nimport { Heading } from '../Heading';\r\nimport { TypographyVisualStyle } from '../Typography';\r\nimport { Transition } from '../Transition';\r\nimport { omit, useGenerateId, usePrevious } from '../../utils';\r\nimport { useFocusLock } from '../../hooks/useFocusLock';\r\nimport { transparentize } from 'polished';\r\nimport { useIsInverse } from '../../inverse';\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: 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(ModalBackdrop, { \"data-testid\": \"modal-backdrop\", isExiting: isExiting, onMouseDown: isBackgroundClickDisabled\r\n                    ? event => event.preventDefault()\r\n                    : null, fade: true, isOpen: isModalOpen, unmountOnExit: true, theme: theme },\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, 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 }))))))), document.getElementsByTagName('body')[0])\r\n        : null;\r\n});\r\n//# sourceMappingURL=Modal.js.map"]} */"));
|
|
10889
|
+
}, ";" + ( "/*# 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 ReactDOM from 'react-dom';\r\nimport styled from '@emotion/styled';\r\nimport { Global, css } from '@emotion/react';\r\nimport { ThemeContext } from '../../theme/ThemeContext';\r\nimport { magma } from '../../theme/magma';\r\nimport { I18nContext } from '../../i18n';\r\nimport { ButtonColor, ButtonVariant } from '../Button';\r\nimport { IconButton } from '../IconButton';\r\nimport { CloseIcon } from 'react-magma-icons';\r\nimport { Heading } from '../Heading';\r\nimport { TypographyVisualStyle } from '../Typography';\r\nimport { Transition } from '../Transition';\r\nimport { omit, useGenerateId, usePrevious } from '../../utils';\r\nimport { useFocusLock } from '../../hooks/useFocusLock';\r\nimport { transparentize } from 'polished';\r\nimport { useIsInverse } from '../../inverse';\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"]} */"));
|
|
10526
10890
|
var Modal = /*#__PURE__*/React.forwardRef(function (props, ref) {
|
|
10527
10891
|
var lastFocus = React.useRef();
|
|
10528
10892
|
var headingRef = React.useRef();
|
|
@@ -10638,23 +11002,14 @@ var Modal = /*#__PURE__*/React.forwardRef(function (props, ref) {
|
|
|
10638
11002
|
return isModalOpen ? ReactDOM.createPortal(React.createElement("div", {
|
|
10639
11003
|
ref: focusTrapElement
|
|
10640
11004
|
}, React.createElement(react.Global, {
|
|
10641
|
-
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 ReactDOM from 'react-dom';\r\nimport styled from '@emotion/styled';\r\nimport { Global, css } from '@emotion/react';\r\nimport { ThemeContext } from '../../theme/ThemeContext';\r\nimport { magma } from '../../theme/magma';\r\nimport { I18nContext } from '../../i18n';\r\nimport { ButtonColor, ButtonVariant } from '../Button';\r\nimport { IconButton } from '../IconButton';\r\nimport { CloseIcon } from 'react-magma-icons';\r\nimport { Heading } from '../Heading';\r\nimport { TypographyVisualStyle } from '../Typography';\r\nimport { Transition } from '../Transition';\r\nimport { omit, useGenerateId, usePrevious } from '../../utils';\r\nimport { useFocusLock } from '../../hooks/useFocusLock';\r\nimport { transparentize } from 'polished';\r\nimport { useIsInverse } from '../../inverse';\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: 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(ModalBackdrop, { \"data-testid\": \"modal-backdrop\", isExiting: isExiting, onMouseDown: isBackgroundClickDisabled\r\n                    ? event => event.preventDefault()\r\n                    : null, fade: true, isOpen: isModalOpen, unmountOnExit: true, theme: theme },\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, 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 }))))))), document.getElementsByTagName('body')[0])\r\n        : null;\r\n});\r\n//# sourceMappingURL=Modal.js.map"]} */"))
|
|
10642
|
-
}), React.createElement(
|
|
10643
|
-
"data-testid": "modal-backdrop",
|
|
10644
|
-
isExiting: isExiting,
|
|
10645
|
-
onMouseDown: isBackgroundClickDisabled ? function (event) {
|
|
10646
|
-
return event.preventDefault();
|
|
10647
|
-
} : null,
|
|
10648
|
-
fade: true,
|
|
10649
|
-
isOpen: isModalOpen,
|
|
10650
|
-
unmountOnExit: true,
|
|
10651
|
-
theme: theme
|
|
10652
|
-
}, React.createElement(ModalContainer, Object.assign({
|
|
11005
|
+
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 ReactDOM from 'react-dom';\r\nimport styled from '@emotion/styled';\r\nimport { Global, css } from '@emotion/react';\r\nimport { ThemeContext } from '../../theme/ThemeContext';\r\nimport { magma } from '../../theme/magma';\r\nimport { I18nContext } from '../../i18n';\r\nimport { ButtonColor, ButtonVariant } from '../Button';\r\nimport { IconButton } from '../IconButton';\r\nimport { CloseIcon } from 'react-magma-icons';\r\nimport { Heading } from '../Heading';\r\nimport { TypographyVisualStyle } from '../Typography';\r\nimport { Transition } from '../Transition';\r\nimport { omit, useGenerateId, usePrevious } from '../../utils';\r\nimport { useFocusLock } from '../../hooks/useFocusLock';\r\nimport { transparentize } from 'polished';\r\nimport { useIsInverse } from '../../inverse';\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"]} */"))
|
|
11006
|
+
}), React.createElement(ModalContainer, Object.assign({
|
|
10653
11007
|
"aria-labelledby": header ? headingId : null,
|
|
10654
11008
|
"aria-label": !header ? ariaLabel : null,
|
|
10655
11009
|
"aria-modal": true,
|
|
10656
11010
|
"data-testid": testId,
|
|
10657
11011
|
id: id,
|
|
11012
|
+
modalCount: modalCount,
|
|
10658
11013
|
onClick: isBackgroundClickDisabled ? null : handleModalClick,
|
|
10659
11014
|
onMouseDown: isBackgroundClickDisabled ? null : handleModalOnMouseDown,
|
|
10660
11015
|
role: "dialog",
|
|
@@ -10692,7 +11047,20 @@ var Modal = /*#__PURE__*/React.forwardRef(function (props, ref) {
|
|
|
10692
11047
|
onClick: handleClose,
|
|
10693
11048
|
testId: "modal-closebtn",
|
|
10694
11049
|
variant: exports.ButtonVariant.link
|
|
10695
|
-
}))))
|
|
11050
|
+
})))), React.createElement(ModalBackdrop, {
|
|
11051
|
+
"data-testid": "modal-backdrop",
|
|
11052
|
+
isExiting: isExiting,
|
|
11053
|
+
onMouseDown: isBackgroundClickDisabled ? function (event) {
|
|
11054
|
+
return event.preventDefault();
|
|
11055
|
+
} : null,
|
|
11056
|
+
fade: true,
|
|
11057
|
+
isOpen: isModalOpen,
|
|
11058
|
+
style: modalCount >= 2 && {
|
|
11059
|
+
zIndex: '998'
|
|
11060
|
+
},
|
|
11061
|
+
unmountOnExit: true,
|
|
11062
|
+
theme: theme
|
|
11063
|
+
})), document.getElementsByTagName('body')[0]) : null;
|
|
10696
11064
|
});
|
|
10697
11065
|
|
|
10698
11066
|
var _excluded$1j = ["iconAriaLabel", "isClearable", "isInverse", "isLoading", "labelText", "placeholder", "onSearch", "onClear"];
|
|
@@ -13741,7 +14109,7 @@ var GridItem = /*#__PURE__*/_styled("div", {
|
|
|
13741
14109
|
return props.gridItemAlignSelf;
|
|
13742
14110
|
}, ";" + ( "/*# sourceMappingURL=data:application/json;charset=utf-8;base64,eyJ2ZXJzaW9uIjozLCJzb3VyY2VzIjpbIkdyaWQudHN4Il0sIm5hbWVzIjpbXSwibWFwcGluZ3MiOiJBQXlFbUMiLCJmaWxlIjoiR3JpZC50c3giLCJzb3VyY2VzQ29udGVudCI6WyJpbXBvcnQgc3R5bGVkIGZyb20gJ0BlbW90aW9uL3N0eWxlZCc7XHJcbmV4cG9ydCB2YXIgR3JpZERpc3BsYXk7XHJcbihmdW5jdGlvbiAoR3JpZERpc3BsYXkpIHtcclxuICAgIEdyaWREaXNwbGF5W1wiZ3JpZFwiXSA9IFwiZ3JpZFwiO1xyXG4gICAgR3JpZERpc3BsYXlbXCJpbmxpbmVHcmlkXCJdID0gXCJpbmxpbmUtZ3JpZFwiO1xyXG59KShHcmlkRGlzcGxheSB8fCAoR3JpZERpc3BsYXkgPSB7fSkpO1xyXG5leHBvcnQgdmFyIEdyaWRKdXN0aWZ5SXRlbXM7XHJcbihmdW5jdGlvbiAoR3JpZEp1c3RpZnlJdGVtcykge1xyXG4gICAgR3JpZEp1c3RpZnlJdGVtc1tcInN0YXJ0XCJdID0gXCJzdGFydFwiO1xyXG4gICAgR3JpZEp1c3RpZnlJdGVtc1tcImVuZFwiXSA9IFwiZW5kXCI7XHJcbiAgICBHcmlkSnVzdGlmeUl0ZW1zW1wiY2VudGVyXCJdID0gXCJjZW50ZXJcIjtcclxuICAgIEdyaWRKdXN0aWZ5SXRlbXNbXCJzdHJldGNoXCJdID0gXCJzdHJldGNoXCI7XHJcbn0pKEdyaWRKdXN0aWZ5SXRlbXMgfHwgKEdyaWRKdXN0aWZ5SXRlbXMgPSB7fSkpO1xyXG5leHBvcnQgdmFyIEdyaWRKdXN0aWZ5Q29udGVudDtcclxuKGZ1bmN0aW9uIChHcmlkSnVzdGlmeUNvbnRlbnQpIHtcclxuICAgIEdyaWRKdXN0aWZ5Q29udGVudFtcInN0YXJ0XCJdID0gXCJzdGFydFwiO1xyXG4gICAgR3JpZEp1c3RpZnlDb250ZW50W1wiZW5kXCJdID0gXCJlbmRcIjtcclxuICAgIEdyaWRKdXN0aWZ5Q29udGVudFtcImNlbnRlclwiXSA9IFwiY2VudGVyXCI7XHJcbiAgICBHcmlkSnVzdGlmeUNvbnRlbnRbXCJzdHJldGNoXCJdID0gXCJzdHJldGNoXCI7XHJcbiAgICBHcmlkSnVzdGlmeUNvbnRlbnRbXCJzcGFjZUFyb3VuZFwiXSA9IFwic3BhY2UtYXJvdW5kXCI7XHJcbiAgICBHcmlkSnVzdGlmeUNvbnRlbnRbXCJzcGFjZUJldHdlZW5cIl0gPSBcInNwYWNlLWJldHdlZW5cIjtcclxuICAgIEdyaWRKdXN0aWZ5Q29udGVudFtcInNwYWNlRXZlbmx5XCJdID0gXCJzcGFjZS1ldmVubHlcIjtcclxufSkoR3JpZEp1c3RpZnlDb250ZW50IHx8IChHcmlkSnVzdGlmeUNvbnRlbnQgPSB7fSkpO1xyXG5leHBvcnQgdmFyIEdyaWRBbGlnbkl0ZW1zO1xyXG4oZnVuY3Rpb24gKEdyaWRBbGlnbkl0ZW1zKSB7XHJcbiAgICBHcmlkQWxpZ25JdGVtc1tcInN0YXJ0XCJdID0gXCJzdGFydFwiO1xyXG4gICAgR3JpZEFsaWduSXRlbXNbXCJlbmRcIl0gPSBcImVuZFwiO1xyXG4gICAgR3JpZEFsaWduSXRlbXNbXCJjZW50ZXJcIl0gPSBcImNlbnRlclwiO1xyXG4gICAgR3JpZEFsaWduSXRlbXNbXCJzdHJldGNoXCJdID0gXCJzdHJldGNoXCI7XHJcbn0pKEdyaWRBbGlnbkl0ZW1zIHx8IChHcmlkQWxpZ25JdGVtcyA9IHt9KSk7XHJcbmV4cG9ydCB2YXIgR3JpZEFsaWduQ29udGVudDtcclxuKGZ1bmN0aW9uIChHcmlkQWxpZ25Db250ZW50KSB7XHJcbiAgICBHcmlkQWxpZ25Db250ZW50W1wic3RhcnRcIl0gPSBcInN0YXJ0XCI7XHJcbiAgICBHcmlkQWxpZ25Db250ZW50W1wiZW5kXCJdID0gXCJlbmRcIjtcclxuICAgIEdyaWRBbGlnbkNvbnRlbnRbXCJjZW50ZXJcIl0gPSBcImNlbnRlclwiO1xyXG4gICAgR3JpZEFsaWduQ29udGVudFtcInN0cmV0Y2hcIl0gPSBcInN0cmV0Y2hcIjtcclxuICAgIEdyaWRBbGlnbkNvbnRlbnRbXCJzcGFjZUFyb3VuZFwiXSA9IFwic3BhY2UtYXJvdW5kXCI7XHJcbiAgICBHcmlkQWxpZ25Db250ZW50W1wic3BhY2VCZXR3ZWVuXCJdID0gXCJzcGFjZS1iZXR3ZWVuXCI7XHJcbiAgICBHcmlkQWxpZ25Db250ZW50W1wic3BhY2VFdmVubHlcIl0gPSBcInNwYWNlLWV2ZW5seVwiO1xyXG59KShHcmlkQWxpZ25Db250ZW50IHx8IChHcmlkQWxpZ25Db250ZW50ID0ge30pKTtcclxuZXhwb3J0IHZhciBHcmlkSXRlbUp1c3RpZnlTZWxmO1xyXG4oZnVuY3Rpb24gKEdyaWRJdGVtSnVzdGlmeVNlbGYpIHtcclxuICAgIEdyaWRJdGVtSnVzdGlmeVNlbGZbXCJzdGFydFwiXSA9IFwic3RhcnRcIjtcclxuICAgIEdyaWRJdGVtSnVzdGlmeVNlbGZbXCJlbmRcIl0gPSBcImVuZFwiO1xyXG4gICAgR3JpZEl0ZW1KdXN0aWZ5U2VsZltcImNlbnRlclwiXSA9IFwiY2VudGVyXCI7XHJcbiAgICBHcmlkSXRlbUp1c3RpZnlTZWxmW1wic3RyZXRjaFwiXSA9IFwic3RyZXRjaFwiO1xyXG59KShHcmlkSXRlbUp1c3RpZnlTZWxmIHx8IChHcmlkSXRlbUp1c3RpZnlTZWxmID0ge30pKTtcclxuZXhwb3J0IHZhciBHcmlkSXRlbUFsaWduU2VsZjtcclxuKGZ1bmN0aW9uIChHcmlkSXRlbUFsaWduU2VsZikge1xyXG4gICAgR3JpZEl0ZW1BbGlnblNlbGZbXCJzdGFydFwiXSA9IFwic3RhcnRcIjtcclxuICAgIEdyaWRJdGVtQWxpZ25TZWxmW1wiZW5kXCJdID0gXCJlbmRcIjtcclxuICAgIEdyaWRJdGVtQWxpZ25TZWxmW1wiY2VudGVyXCJdID0gXCJjZW50ZXJcIjtcclxuICAgIEdyaWRJdGVtQWxpZ25TZWxmW1wic3RyZXRjaFwiXSA9IFwic3RyZXRjaFwiO1xyXG59KShHcmlkSXRlbUFsaWduU2VsZiB8fCAoR3JpZEl0ZW1BbGlnblNlbGYgPSB7fSkpO1xyXG5leHBvcnQgdmFyIEdyaWRBdXRvRmxvdztcclxuKGZ1bmN0aW9uIChHcmlkQXV0b0Zsb3cpIHtcclxuICAgIEdyaWRBdXRvRmxvd1tcInJvd1wiXSA9IFwicm93XCI7XHJcbiAgICBHcmlkQXV0b0Zsb3dbXCJjb2x1bW5cIl0gPSBcImNvbHVtblwiO1xyXG4gICAgR3JpZEF1dG9GbG93W1wicm93RGVuc2VcIl0gPSBcInJvdy1kZW5zZVwiO1xyXG4gICAgR3JpZEF1dG9GbG93W1wiY29sdW1uRGVuc2VcIl0gPSBcImNvbHVtbi1kZW5zZVwiO1xyXG59KShHcmlkQXV0b0Zsb3cgfHwgKEdyaWRBdXRvRmxvdyA9IHt9KSk7XHJcbmV4cG9ydCBjb25zdCBHcmlkID0gc3R5bGVkLmRpdiBgXG4gIGRpc3BsYXk6ICR7cHJvcHMgPT4gcHJvcHMuZ3JpZERpc3BsYXkgfHwgR3JpZERpc3BsYXkuZ3JpZH07XG4gIGdyaWQtdGVtcGxhdGUtcm93czogJHtwcm9wcyA9PiBwcm9wcy5ncmlkVGVtcGxhdGVSb3dzfTtcbiAgZ3JpZC10ZW1wbGF0ZS1jb2x1bW5zOiAke3Byb3BzID0+IHByb3BzLmdyaWRUZW1wbGF0ZUNvbHVtbnN9O1xuICBncmlkLWFyZWE6ICR7cHJvcHMgPT4gcHJvcHMuZ3JpZFRlbXBsYXRlQXJlYXN9O1xuICBncmlkLWdhcDogJHtwcm9wcyA9PiBwcm9wcy5ncmlkR2FwfTtcbiAganVzdGlmeS1pdGVtczogJHtwcm9wcyA9PiBwcm9wcy5ncmlkSnVzdGlmeUl0ZW1zfTtcbiAganVzdGlmeS1jb250ZW50OiAke3Byb3BzID0+IHByb3BzLmdyaWRKdXN0aWZ5Q29udGVudH07XG4gIGFsaWduLWl0ZW1zOiAke3Byb3BzID0+IHByb3BzLmdyaWRBbGlnbkl0ZW1zfTtcbiAgYWxpZ24tY29udGVudDogJHtwcm9wcyA9PiBwcm9wcy5ncmlkQWxpZ25Db250ZW50fTtcbiAgZ3JpZC1hdXRvLWZsb3c6ICR7cHJvcHMgPT4gcHJvcHMuZ3JpZEF1dG9GbG93fTtcbmA7XHJcbmV4cG9ydCBjb25zdCBHcmlkSXRlbSA9IHN0eWxlZC5kaXYgYFxuICBncmlkLWNvbHVtbjogJHtwcm9wcyA9PiBwcm9wcy5ncmlkQ29sdW1ufTtcbiAgZ3JpZC1yb3c6ICR7cHJvcHMgPT4gcHJvcHMuZ3JpZFJvd307XG4gIGdyaWQtYXJlYTogJHtwcm9wcyA9PiBwcm9wcy5ncmlkQXJlYX07XG4gIGp1c3RpZnktc2VsZjogJHtwcm9wcyA9PiBwcm9wcy5ncmlkSXRlbUp1c3RpZnlTZWxmfTtcbiAgYWxpZ24tc2VsZjogJHtwcm9wcyA9PiBwcm9wcy5ncmlkSXRlbUFsaWduU2VsZn07XG5gO1xyXG4vLyMgc291cmNlTWFwcGluZ1VSTD1HcmlkLmpzLm1hcCJdfQ== */"));
|
|
13743
14111
|
|
|
13744
|
-
var _excluded$1y = ["children", "
|
|
14112
|
+
var _excluded$1y = ["children", "testId", "hasStart", "iconAlign", "iconSize", "isInverse", "isOrdered", "isReversed", "listType", "spacingStyle", "visualStyle"];
|
|
13745
14113
|
(function (IconSizes) {
|
|
13746
14114
|
IconSizes["small"] = "small";
|
|
13747
14115
|
IconSizes["medium"] = "medium";
|
|
@@ -13783,24 +14151,17 @@ function getListAlignment(props) {
|
|
|
13783
14151
|
return "center";
|
|
13784
14152
|
}
|
|
13785
14153
|
}
|
|
13786
|
-
function getListDisplay(props) {
|
|
13787
|
-
if (props.icon) {
|
|
13788
|
-
return 'grid';
|
|
13789
|
-
}
|
|
13790
|
-
return 'list-item';
|
|
13791
|
-
}
|
|
13792
14154
|
var ListStyles = function ListStyles(props) {
|
|
13793
|
-
return /*#__PURE__*/react.css("margin:0;padding:0;list-style-type:", props.listType, ";color:", props.isInverse ? props.theme.colors.neutral100 : props.theme.colors.neutral700, ";li{align-items:", getListAlignment(props), ";margin-bottom:", props.spacingStyle, ";grid-template-areas:'a b';grid-template-columns:auto 1fr;}span{margin:", props.iconSize === 'small' ? '0 16px 0 0' : props.iconSize === 'large' ? '0 26px 0 0' : '0 18px 0 0', ";}p{font-size:0.8em;font-weight:400;margin-bottom:8px;margin-left:0;grid-template:'b';grid-column-start:2;}svg{height:", getIconSizes(props), "px;width:", getIconSizes(props), "px;};label:ListStyles;" + ( "/*# sourceMappingURL=data:application/json;charset=utf-8;base64,
|
|
14155
|
+
return /*#__PURE__*/react.css("margin:0;padding:0;list-style-type:", props.listType, ";color:", props.isInverse ? props.theme.colors.neutral100 : props.theme.colors.neutral700, ";li{align-items:", getListAlignment(props), ";margin-bottom:", props.spacingStyle, ";grid-template-areas:'a b';grid-template-columns:auto 1fr;}span{margin:", props.iconSize === 'small' ? '0 16px 0 0' : props.iconSize === 'large' ? '0 26px 0 0' : '0 18px 0 0', ";}p{font-size:0.8em;font-weight:400;margin-bottom:8px;margin-left:0;grid-template:'b';grid-column-start:2;}svg{height:", getIconSizes(props), "px;width:", getIconSizes(props), "px;};label:ListStyles;" + ( "/*# sourceMappingURL=data:application/json;charset=utf-8;base64,eyJ2ZXJzaW9uIjozLCJzb3VyY2VzIjpbIkxpc3QudHN4Il0sIm5hbWVzIjpbXSwibWFwcGluZ3MiOiJBQW9EZ0MiLCJmaWxlIjoiTGlzdC50c3giLCJzb3VyY2VzQ29udGVudCI6WyJpbXBvcnQgKiBhcyBSZWFjdCBmcm9tICdyZWFjdCc7XHJcbmltcG9ydCB7IGNzcyB9IGZyb20gJ0BlbW90aW9uL3JlYWN0JztcclxuaW1wb3J0IHsgVGhlbWVDb250ZXh0IH0gZnJvbSAnLi4vLi4vdGhlbWUvVGhlbWVDb250ZXh0JztcclxuaW1wb3J0IHsgbWFnbWEgfSBmcm9tICcuLi8uLi90aGVtZS9tYWdtYSc7XHJcbmltcG9ydCB7IFR5cG9ncmFwaHlWaXN1YWxTdHlsZSwgVHlwb2dyYXBoeUNvbXBvbmVudCB9IGZyb20gJy4uL1R5cG9ncmFwaHknO1xyXG5pbXBvcnQgeyBJbnZlcnNlQ29udGV4dCwgdXNlSXNJbnZlcnNlIH0gZnJvbSAnLi4vLi4vaW52ZXJzZSc7XHJcbmltcG9ydCBzdHlsZWQgZnJvbSAnQGVtb3Rpb24vc3R5bGVkJztcclxuZXhwb3J0IHZhciBJY29uU2l6ZXM7XHJcbihmdW5jdGlvbiAoSWNvblNpemVzKSB7XHJcbiAgICBJY29uU2l6ZXNbXCJzbWFsbFwiXSA9IFwic21hbGxcIjtcclxuICAgIEljb25TaXplc1tcIm1lZGl1bVwiXSA9IFwibWVkaXVtXCI7XHJcbiAgICBJY29uU2l6ZXNbXCJsYXJnZVwiXSA9IFwibGFyZ2VcIjtcclxufSkoSWNvblNpemVzIHx8IChJY29uU2l6ZXMgPSB7fSkpO1xyXG5leHBvcnQgdmFyIEljb25BbGlnbm1lbnQ7XHJcbihmdW5jdGlvbiAoSWNvbkFsaWdubWVudCkge1xyXG4gICAgSWNvbkFsaWdubWVudFtcImNlbnRlclwiXSA9IFwiY2VudGVyXCI7XHJcbiAgICBJY29uQWxpZ25tZW50W1widG9wXCJdID0gXCJ0b3BcIjtcclxufSkoSWNvbkFsaWdubWVudCB8fCAoSWNvbkFsaWdubWVudCA9IHt9KSk7XHJcbmV4cG9ydCB2YXIgdWxMaXN0VHlwZTtcclxuKGZ1bmN0aW9uICh1bExpc3RUeXBlKSB7XHJcbiAgICB1bExpc3RUeXBlW1wiY2lyY2xlXCJdID0gXCJjaXJjbGVcIjtcclxuICAgIHVsTGlzdFR5cGVbXCJkaXNjXCJdID0gXCJkaXNjXCI7XHJcbiAgICB1bExpc3RUeXBlW1wic3F1YXJlXCJdID0gXCJzcXVhcmVcIjtcclxufSkodWxMaXN0VHlwZSB8fCAodWxMaXN0VHlwZSA9IHt9KSk7XHJcbmV4cG9ydCB2YXIgb2xMaXN0VHlwZTtcclxuKGZ1bmN0aW9uIChvbExpc3RUeXBlKSB7XHJcbiAgICBvbExpc3RUeXBlW1wibG93ZXJjYXNlXCJdID0gXCJhXCI7XHJcbiAgICBvbExpc3RUeXBlW1widXBwZXJjYXNlXCJdID0gXCJBXCI7XHJcbiAgICBvbExpc3RUeXBlW1wibG93ZXJjYXNlUm9tYW5cIl0gPSBcImlcIjtcclxuICAgIG9sTGlzdFR5cGVbXCJ1cHBlcmNhc2VSb21hblwiXSA9IFwiSVwiO1xyXG4gICAgb2xMaXN0VHlwZVtcIm51bWJlcnNcIl0gPSBcIjFcIjtcclxufSkob2xMaXN0VHlwZSB8fCAob2xMaXN0VHlwZSA9IHt9KSk7XHJcbmV4cG9ydCBmdW5jdGlvbiBnZXRJY29uU2l6ZXMocHJvcHMpIHtcclxuICAgIHN3aXRjaCAocHJvcHMuaWNvblNpemUpIHtcclxuICAgICAgICBjYXNlIEljb25TaXplcy5zbWFsbDpcclxuICAgICAgICAgICAgcmV0dXJuIHByb3BzLnRoZW1lLmljb25TaXplcy5zbWFsbDtcclxuICAgICAgICBjYXNlIEljb25TaXplcy5sYXJnZTpcclxuICAgICAgICAgICAgcmV0dXJuIHByb3BzLnRoZW1lLmljb25TaXplcy5sYXJnZTtcclxuICAgICAgICBkZWZhdWx0OlxyXG4gICAgICAgICAgICByZXR1cm4gcHJvcHMudGhlbWUuaWNvblNpemVzLm1lZGl1bTtcclxuICAgIH1cclxufVxyXG5leHBvcnQgZnVuY3Rpb24gZ2V0TGlzdEFsaWdubWVudChwcm9wcykge1xyXG4gICAgc3dpdGNoIChwcm9wcy5pY29uQWxpZ24pIHtcclxuICAgICAgICBjYXNlIEljb25BbGlnbm1lbnQuY2VudGVyOlxyXG4gICAgICAgICAgICByZXR1cm4gYGNlbnRlcmA7XHJcbiAgICAgICAgY2FzZSBJY29uQWxpZ25tZW50LnRvcDpcclxuICAgICAgICAgICAgcmV0dXJuIGBmbGV4LXN0YXJ0YDtcclxuICAgICAgICBkZWZhdWx0OlxyXG4gICAgICAgICAgICByZXR1cm4gYGNlbnRlcmA7XHJcbiAgICB9XHJcbn1cclxuY29uc3QgTGlzdFN0eWxlcyA9IHByb3BzID0+IGNzcyBgXG4gIG1hcmdpbjogMDtcbiAgcGFkZGluZzogMDtcbiAgbGlzdC1zdHlsZS10eXBlOiAke3Byb3BzLmxpc3RUeXBlfTtcbiAgY29sb3I6ICR7cHJvcHMuaXNJbnZlcnNlXHJcbiAgICA/IHByb3BzLnRoZW1lLmNvbG9ycy5uZXV0cmFsMTAwXHJcbiAgICA6IHByb3BzLnRoZW1lLmNvbG9ycy5uZXV0cmFsNzAwfTtcbiAgbGkge1xuICAgIGFsaWduLWl0ZW1zOiAke2dldExpc3RBbGlnbm1lbnQocHJvcHMpfTtcbiAgICBtYXJnaW4tYm90dG9tOiAke3Byb3BzLnNwYWNpbmdTdHlsZX07XG4gICAgZ3JpZC10ZW1wbGF0ZS1hcmVhczogJ2EgYic7XG4gICAgZ3JpZC10ZW1wbGF0ZS1jb2x1bW5zOiBhdXRvIDFmcjtcbiAgfVxuICBzcGFuIHtcbiAgICBtYXJnaW46ICR7cHJvcHMuaWNvblNpemUgPT09ICdzbWFsbCdcclxuICAgID8gJzAgMTZweCAwIDAnXHJcbiAgICA6IHByb3BzLmljb25TaXplID09PSAnbGFyZ2UnXHJcbiAgICAgICAgPyAnMCAyNnB4IDAgMCdcclxuICAgICAgICA6ICcwIDE4cHggMCAwJ307XG4gIH1cbiAgcCB7XG4gICAgZm9udC1zaXplOiAwLjhlbTtcbiAgICBmb250LXdlaWdodDogNDAwO1xuICAgIG1hcmdpbi1ib3R0b206IDhweDtcbiAgICBtYXJnaW4tbGVmdDogMDtcbiAgICBncmlkLXRlbXBsYXRlOiAnYic7XG4gICAgZ3JpZC1jb2x1bW4tc3RhcnQ6IDI7XG4gIH1cbiAgc3ZnIHtcbiAgICBoZWlnaHQ6ICR7Z2V0SWNvblNpemVzKHByb3BzKX1weDtcbiAgICB3aWR0aDogJHtnZXRJY29uU2l6ZXMocHJvcHMpfXB4O1xuICB9XG5gO1xyXG5jb25zdCBTdHlsZWRMaXN0ID0gc3R5bGVkKFR5cG9ncmFwaHlDb21wb25lbnQpIGBcbiAgJHtMaXN0U3R5bGVzfTtcbmA7XHJcbmV4cG9ydCBjb25zdCBMaXN0ID0gUmVhY3QuZm9yd2FyZFJlZigocHJvcHMsIHJlZikgPT4ge1xyXG4gICAgY29uc3QgeyBjaGlsZHJlbiwgdGVzdElkLCBoYXNTdGFydCwgaWNvbkFsaWduLCBpY29uU2l6ZSwgaXNJbnZlcnNlOiBpc0ludmVyc2VQcm9wLCBpc09yZGVyZWQsIGlzUmV2ZXJzZWQsIGxpc3RUeXBlLCBzcGFjaW5nU3R5bGUsIHZpc3VhbFN0eWxlLCAuLi5yZXN0IH0gPSBwcm9wcztcclxuICAgIGNvbnN0IHRoZW1lID0gUmVhY3QudXNlQ29udGV4dChUaGVtZUNvbnRleHQpO1xyXG4gICAgY29uc3QgaXNJbnZlcnNlID0gdXNlSXNJbnZlcnNlKGlzSW52ZXJzZVByb3ApO1xyXG4gICAgcmV0dXJuIChSZWFjdC5jcmVhdGVFbGVtZW50KEludmVyc2VDb250ZXh0LlByb3ZpZGVyLCB7IHZhbHVlOiB7IGlzSW52ZXJzZSB9IH0sXHJcbiAgICAgICAgUmVhY3QuY3JlYXRlRWxlbWVudChTdHlsZWRMaXN0LCBPYmplY3QuYXNzaWduKHsgYXM6IGlzT3JkZXJlZCA/ICdvbCcgOiAndWwnLCBcImRhdGEtdGVzdGlkXCI6IHRlc3RJZCwgaWNvbkFsaWduOiBpY29uQWxpZ24sIGljb25TaXplOiBpY29uU2l6ZSwgaXNJbnZlcnNlOiBpc0ludmVyc2UsIHR5cGU6IGxpc3RUeXBlID8gbGlzdFR5cGUgOiAnaW5oZXJpdCcsIHJldmVyc2VkOiBpc1JldmVyc2VkLCByZWY6IHJlZiwgc3BhY2luZ1N0eWxlOiBtYWdtYS5zcGFjZVNjYWxlW3NwYWNpbmdTdHlsZV0gfHwgc3BhY2luZ1N0eWxlLCBzdGFydDogaGFzU3RhcnQsIHRoZW1lOiB0aGVtZSwgdmlzdWFsU3R5bGU6IHZpc3VhbFN0eWxlIHx8IFR5cG9ncmFwaHlWaXN1YWxTdHlsZS5ib2R5TWVkaXVtIH0sIHJlc3QpLCBjaGlsZHJlbikpKTtcclxufSk7XHJcbi8vIyBzb3VyY2VNYXBwaW5nVVJMPUxpc3QuanMubWFwIl19 */"));
|
|
13794
14156
|
};
|
|
13795
14157
|
var StyledList$3 = /*#__PURE__*/_styled(TypographyComponent, {
|
|
13796
14158
|
target: "e14v92100",
|
|
13797
14159
|
label: "StyledList"
|
|
13798
|
-
})(ListStyles, ";" + ( "/*# sourceMappingURL=data:application/json;charset=utf-8;base64,
|
|
14160
|
+
})(ListStyles, ";" + ( "/*# sourceMappingURL=data:application/json;charset=utf-8;base64,eyJ2ZXJzaW9uIjozLCJzb3VyY2VzIjpbIkxpc3QudHN4Il0sIm5hbWVzIjpbXSwibWFwcGluZ3MiOiJBQXFGK0MiLCJmaWxlIjoiTGlzdC50c3giLCJzb3VyY2VzQ29udGVudCI6WyJpbXBvcnQgKiBhcyBSZWFjdCBmcm9tICdyZWFjdCc7XHJcbmltcG9ydCB7IGNzcyB9IGZyb20gJ0BlbW90aW9uL3JlYWN0JztcclxuaW1wb3J0IHsgVGhlbWVDb250ZXh0IH0gZnJvbSAnLi4vLi4vdGhlbWUvVGhlbWVDb250ZXh0JztcclxuaW1wb3J0IHsgbWFnbWEgfSBmcm9tICcuLi8uLi90aGVtZS9tYWdtYSc7XHJcbmltcG9ydCB7IFR5cG9ncmFwaHlWaXN1YWxTdHlsZSwgVHlwb2dyYXBoeUNvbXBvbmVudCB9IGZyb20gJy4uL1R5cG9ncmFwaHknO1xyXG5pbXBvcnQgeyBJbnZlcnNlQ29udGV4dCwgdXNlSXNJbnZlcnNlIH0gZnJvbSAnLi4vLi4vaW52ZXJzZSc7XHJcbmltcG9ydCBzdHlsZWQgZnJvbSAnQGVtb3Rpb24vc3R5bGVkJztcclxuZXhwb3J0IHZhciBJY29uU2l6ZXM7XHJcbihmdW5jdGlvbiAoSWNvblNpemVzKSB7XHJcbiAgICBJY29uU2l6ZXNbXCJzbWFsbFwiXSA9IFwic21hbGxcIjtcclxuICAgIEljb25TaXplc1tcIm1lZGl1bVwiXSA9IFwibWVkaXVtXCI7XHJcbiAgICBJY29uU2l6ZXNbXCJsYXJnZVwiXSA9IFwibGFyZ2VcIjtcclxufSkoSWNvblNpemVzIHx8IChJY29uU2l6ZXMgPSB7fSkpO1xyXG5leHBvcnQgdmFyIEljb25BbGlnbm1lbnQ7XHJcbihmdW5jdGlvbiAoSWNvbkFsaWdubWVudCkge1xyXG4gICAgSWNvbkFsaWdubWVudFtcImNlbnRlclwiXSA9IFwiY2VudGVyXCI7XHJcbiAgICBJY29uQWxpZ25tZW50W1widG9wXCJdID0gXCJ0b3BcIjtcclxufSkoSWNvbkFsaWdubWVudCB8fCAoSWNvbkFsaWdubWVudCA9IHt9KSk7XHJcbmV4cG9ydCB2YXIgdWxMaXN0VHlwZTtcclxuKGZ1bmN0aW9uICh1bExpc3RUeXBlKSB7XHJcbiAgICB1bExpc3RUeXBlW1wiY2lyY2xlXCJdID0gXCJjaXJjbGVcIjtcclxuICAgIHVsTGlzdFR5cGVbXCJkaXNjXCJdID0gXCJkaXNjXCI7XHJcbiAgICB1bExpc3RUeXBlW1wic3F1YXJlXCJdID0gXCJzcXVhcmVcIjtcclxufSkodWxMaXN0VHlwZSB8fCAodWxMaXN0VHlwZSA9IHt9KSk7XHJcbmV4cG9ydCB2YXIgb2xMaXN0VHlwZTtcclxuKGZ1bmN0aW9uIChvbExpc3RUeXBlKSB7XHJcbiAgICBvbExpc3RUeXBlW1wibG93ZXJjYXNlXCJdID0gXCJhXCI7XHJcbiAgICBvbExpc3RUeXBlW1widXBwZXJjYXNlXCJdID0gXCJBXCI7XHJcbiAgICBvbExpc3RUeXBlW1wibG93ZXJjYXNlUm9tYW5cIl0gPSBcImlcIjtcclxuICAgIG9sTGlzdFR5cGVbXCJ1cHBlcmNhc2VSb21hblwiXSA9IFwiSVwiO1xyXG4gICAgb2xMaXN0VHlwZVtcIm51bWJlcnNcIl0gPSBcIjFcIjtcclxufSkob2xMaXN0VHlwZSB8fCAob2xMaXN0VHlwZSA9IHt9KSk7XHJcbmV4cG9ydCBmdW5jdGlvbiBnZXRJY29uU2l6ZXMocHJvcHMpIHtcclxuICAgIHN3aXRjaCAocHJvcHMuaWNvblNpemUpIHtcclxuICAgICAgICBjYXNlIEljb25TaXplcy5zbWFsbDpcclxuICAgICAgICAgICAgcmV0dXJuIHByb3BzLnRoZW1lLmljb25TaXplcy5zbWFsbDtcclxuICAgICAgICBjYXNlIEljb25TaXplcy5sYXJnZTpcclxuICAgICAgICAgICAgcmV0dXJuIHByb3BzLnRoZW1lLmljb25TaXplcy5sYXJnZTtcclxuICAgICAgICBkZWZhdWx0OlxyXG4gICAgICAgICAgICByZXR1cm4gcHJvcHMudGhlbWUuaWNvblNpemVzLm1lZGl1bTtcclxuICAgIH1cclxufVxyXG5leHBvcnQgZnVuY3Rpb24gZ2V0TGlzdEFsaWdubWVudChwcm9wcykge1xyXG4gICAgc3dpdGNoIChwcm9wcy5pY29uQWxpZ24pIHtcclxuICAgICAgICBjYXNlIEljb25BbGlnbm1lbnQuY2VudGVyOlxyXG4gICAgICAgICAgICByZXR1cm4gYGNlbnRlcmA7XHJcbiAgICAgICAgY2FzZSBJY29uQWxpZ25tZW50LnRvcDpcclxuICAgICAgICAgICAgcmV0dXJuIGBmbGV4LXN0YXJ0YDtcclxuICAgICAgICBkZWZhdWx0OlxyXG4gICAgICAgICAgICByZXR1cm4gYGNlbnRlcmA7XHJcbiAgICB9XHJcbn1cclxuY29uc3QgTGlzdFN0eWxlcyA9IHByb3BzID0+IGNzcyBgXG4gIG1hcmdpbjogMDtcbiAgcGFkZGluZzogMDtcbiAgbGlzdC1zdHlsZS10eXBlOiAke3Byb3BzLmxpc3RUeXBlfTtcbiAgY29sb3I6ICR7cHJvcHMuaXNJbnZlcnNlXHJcbiAgICA/IHByb3BzLnRoZW1lLmNvbG9ycy5uZXV0cmFsMTAwXHJcbiAgICA6IHByb3BzLnRoZW1lLmNvbG9ycy5uZXV0cmFsNzAwfTtcbiAgbGkge1xuICAgIGFsaWduLWl0ZW1zOiAke2dldExpc3RBbGlnbm1lbnQocHJvcHMpfTtcbiAgICBtYXJnaW4tYm90dG9tOiAke3Byb3BzLnNwYWNpbmdTdHlsZX07XG4gICAgZ3JpZC10ZW1wbGF0ZS1hcmVhczogJ2EgYic7XG4gICAgZ3JpZC10ZW1wbGF0ZS1jb2x1bW5zOiBhdXRvIDFmcjtcbiAgfVxuICBzcGFuIHtcbiAgICBtYXJnaW46ICR7cHJvcHMuaWNvblNpemUgPT09ICdzbWFsbCdcclxuICAgID8gJzAgMTZweCAwIDAnXHJcbiAgICA6IHByb3BzLmljb25TaXplID09PSAnbGFyZ2UnXHJcbiAgICAgICAgPyAnMCAyNnB4IDAgMCdcclxuICAgICAgICA6ICcwIDE4cHggMCAwJ307XG4gIH1cbiAgcCB7XG4gICAgZm9udC1zaXplOiAwLjhlbTtcbiAgICBmb250LXdlaWdodDogNDAwO1xuICAgIG1hcmdpbi1ib3R0b206IDhweDtcbiAgICBtYXJnaW4tbGVmdDogMDtcbiAgICBncmlkLXRlbXBsYXRlOiAnYic7XG4gICAgZ3JpZC1jb2x1bW4tc3RhcnQ6IDI7XG4gIH1cbiAgc3ZnIHtcbiAgICBoZWlnaHQ6ICR7Z2V0SWNvblNpemVzKHByb3BzKX1weDtcbiAgICB3aWR0aDogJHtnZXRJY29uU2l6ZXMocHJvcHMpfXB4O1xuICB9XG5gO1xyXG5jb25zdCBTdHlsZWRMaXN0ID0gc3R5bGVkKFR5cG9ncmFwaHlDb21wb25lbnQpIGBcbiAgJHtMaXN0U3R5bGVzfTtcbmA7XHJcbmV4cG9ydCBjb25zdCBMaXN0ID0gUmVhY3QuZm9yd2FyZFJlZigocHJvcHMsIHJlZikgPT4ge1xyXG4gICAgY29uc3QgeyBjaGlsZHJlbiwgdGVzdElkLCBoYXNTdGFydCwgaWNvbkFsaWduLCBpY29uU2l6ZSwgaXNJbnZlcnNlOiBpc0ludmVyc2VQcm9wLCBpc09yZGVyZWQsIGlzUmV2ZXJzZWQsIGxpc3RUeXBlLCBzcGFjaW5nU3R5bGUsIHZpc3VhbFN0eWxlLCAuLi5yZXN0IH0gPSBwcm9wcztcclxuICAgIGNvbnN0IHRoZW1lID0gUmVhY3QudXNlQ29udGV4dChUaGVtZUNvbnRleHQpO1xyXG4gICAgY29uc3QgaXNJbnZlcnNlID0gdXNlSXNJbnZlcnNlKGlzSW52ZXJzZVByb3ApO1xyXG4gICAgcmV0dXJuIChSZWFjdC5jcmVhdGVFbGVtZW50KEludmVyc2VDb250ZXh0LlByb3ZpZGVyLCB7IHZhbHVlOiB7IGlzSW52ZXJzZSB9IH0sXHJcbiAgICAgICAgUmVhY3QuY3JlYXRlRWxlbWVudChTdHlsZWRMaXN0LCBPYmplY3QuYXNzaWduKHsgYXM6IGlzT3JkZXJlZCA/ICdvbCcgOiAndWwnLCBcImRhdGEtdGVzdGlkXCI6IHRlc3RJZCwgaWNvbkFsaWduOiBpY29uQWxpZ24sIGljb25TaXplOiBpY29uU2l6ZSwgaXNJbnZlcnNlOiBpc0ludmVyc2UsIHR5cGU6IGxpc3RUeXBlID8gbGlzdFR5cGUgOiAnaW5oZXJpdCcsIHJldmVyc2VkOiBpc1JldmVyc2VkLCByZWY6IHJlZiwgc3BhY2luZ1N0eWxlOiBtYWdtYS5zcGFjZVNjYWxlW3NwYWNpbmdTdHlsZV0gfHwgc3BhY2luZ1N0eWxlLCBzdGFydDogaGFzU3RhcnQsIHRoZW1lOiB0aGVtZSwgdmlzdWFsU3R5bGU6IHZpc3VhbFN0eWxlIHx8IFR5cG9ncmFwaHlWaXN1YWxTdHlsZS5ib2R5TWVkaXVtIH0sIHJlc3QpLCBjaGlsZHJlbikpKTtcclxufSk7XHJcbi8vIyBzb3VyY2VNYXBwaW5nVVJMPUxpc3QuanMubWFwIl19 */"));
|
|
13799
14161
|
var List$1 = /*#__PURE__*/React.forwardRef(function (props, ref) {
|
|
13800
14162
|
var children = props.children,
|
|
13801
|
-
|
|
14163
|
+
testId = props.testId,
|
|
13802
14164
|
hasStart = props.hasStart,
|
|
13803
|
-
icon = props.icon,
|
|
13804
14165
|
iconAlign = props.iconAlign,
|
|
13805
14166
|
iconSize = props.iconSize,
|
|
13806
14167
|
isInverseProp = props.isInverse,
|
|
@@ -13818,9 +14179,7 @@ var List$1 = /*#__PURE__*/React.forwardRef(function (props, ref) {
|
|
|
13818
14179
|
}
|
|
13819
14180
|
}, React.createElement(StyledList$3, Object.assign({
|
|
13820
14181
|
as: isOrdered ? 'ol' : 'ul',
|
|
13821
|
-
"data-testid":
|
|
13822
|
-
description: description,
|
|
13823
|
-
icon: icon,
|
|
14182
|
+
"data-testid": testId,
|
|
13824
14183
|
iconAlign: iconAlign,
|
|
13825
14184
|
iconSize: iconSize,
|
|
13826
14185
|
isInverse: isInverse,
|
|
@@ -13830,12 +14189,18 @@ var List$1 = /*#__PURE__*/React.forwardRef(function (props, ref) {
|
|
|
13830
14189
|
spacingStyle: magma.spaceScale[spacingStyle] || spacingStyle,
|
|
13831
14190
|
start: hasStart,
|
|
13832
14191
|
theme: theme,
|
|
13833
|
-
visualStyle: visualStyle
|
|
14192
|
+
visualStyle: visualStyle || exports.TypographyVisualStyle.bodyMedium
|
|
13834
14193
|
}, rest), children));
|
|
13835
14194
|
});
|
|
13836
14195
|
|
|
14196
|
+
function getListDisplay(props) {
|
|
14197
|
+
if (props.icon) {
|
|
14198
|
+
return 'grid';
|
|
14199
|
+
}
|
|
14200
|
+
return 'list-item';
|
|
14201
|
+
}
|
|
13837
14202
|
var IconStyles = function IconStyles(props) {
|
|
13838
|
-
return /*#__PURE__*/react.css("background:", props.iconBackground, ";color:", props.iconColor, ";border-radius:50%;display:inline-flex;padding:10px;;label:IconStyles;" + ( "/*# sourceMappingURL=data:application/json;charset=utf-8;base64,
|
|
14203
|
+
return /*#__PURE__*/react.css("background:", props.iconBackground, ";color:", props.iconColor, ";border-radius:50%;display:inline-flex;padding:10px;;label:IconStyles;" + ( "/*# sourceMappingURL=data:application/json;charset=utf-8;base64,eyJ2ZXJzaW9uIjozLCJzb3VyY2VzIjpbIkxpc3RJdGVtLnRzeCJdLCJuYW1lcyI6W10sIm1hcHBpbmdzIjoiQUFZZ0MiLCJmaWxlIjoiTGlzdEl0ZW0udHN4Iiwic291cmNlc0NvbnRlbnQiOlsiaW1wb3J0ICogYXMgUmVhY3QgZnJvbSAncmVhY3QnO1xyXG5pbXBvcnQgeyBjc3MgfSBmcm9tICdAZW1vdGlvbi9yZWFjdCc7XHJcbmltcG9ydCB7IG1hZ21hIH0gZnJvbSAnLi4vLi4vdGhlbWUvbWFnbWEnO1xyXG5pbXBvcnQgeyBUaGVtZUNvbnRleHQgfSBmcm9tICcuLi8uLi90aGVtZS9UaGVtZUNvbnRleHQnO1xyXG5pbXBvcnQgeyBJbnZlcnNlQ29udGV4dCwgdXNlSXNJbnZlcnNlIH0gZnJvbSAnLi4vLi4vaW52ZXJzZSc7XHJcbmltcG9ydCBzdHlsZWQgZnJvbSAnQGVtb3Rpb24vc3R5bGVkJztcclxuZnVuY3Rpb24gZ2V0TGlzdERpc3BsYXkocHJvcHMpIHtcclxuICAgIGlmIChwcm9wcy5pY29uKSB7XHJcbiAgICAgICAgcmV0dXJuICdncmlkJztcclxuICAgIH1cclxuICAgIHJldHVybiAnbGlzdC1pdGVtJztcclxufVxyXG5jb25zdCBJY29uU3R5bGVzID0gcHJvcHMgPT4gY3NzIGBcbiAgYmFja2dyb3VuZDogJHtwcm9wcy5pY29uQmFja2dyb3VuZH07XG4gIGNvbG9yOiAke3Byb3BzLmljb25Db2xvcn07XG4gIGJvcmRlci1yYWRpdXM6IDUwJTtcbiAgZGlzcGxheTogaW5saW5lLWZsZXg7XG4gIHBhZGRpbmc6IDEwcHg7XG5gO1xyXG5jb25zdCBTdHlsZWRMaXN0SXRlbSA9IHN0eWxlZC5saSBgXG4gIGRpc3BsYXk6ICR7cHJvcHMgPT4gZ2V0TGlzdERpc3BsYXkocHJvcHMpfTtcbiAgbWFyZ2luOiAwO1xuICBwYWRkaW5nOiAwO1xuICBtYXJnaW4tbGVmdDogJHtwcm9wcyA9PiAocHJvcHMuaWNvbiA/ICdpbmhlcml0JyA6ICcxLjFlbScpfTtcbiAgY29sb3I6ICR7cHJvcHMgPT4gcHJvcHMuZGVzY3JpcHRpb24gJiYgIXByb3BzLmlzSW52ZXJzZVxyXG4gICAgPyBwcm9wcy50aGVtZS5jb2xvcnMubmV1dHJhbFxyXG4gICAgOiAnaW5oZXJpdCd9O1xuICBsaXN0LXN0eWxlLXR5cGU6ICR7cHJvcHMgPT4gcHJvcHMuaWNvbiB8fCBwcm9wcy5kZXNjcmlwdGlvbiA/ICdub25lJyA6ICdpbmhlcml0J307XG5gO1xyXG5jb25zdCBTdHlsZWRJY29uID0gc3R5bGVkLnNwYW4gYFxuICAke0ljb25TdHlsZXN9O1xuYDtcclxuZXhwb3J0IGNvbnN0IExpc3RJdGVtID0gUmVhY3QuZm9yd2FyZFJlZigocHJvcHMsIHJlZikgPT4ge1xyXG4gICAgY29uc3QgeyBjaGlsZHJlbiwgZGVzY3JpcHRpb24sIGljb24sIGljb25BbGlnbiwgaWNvbkJhY2tncm91bmQsIGljb25Db2xvciwgdGVzdElkLCBpc0ludmVyc2U6IGlzSW52ZXJzZVByb3AsIH0gPSBwcm9wcztcclxuICAgIGNvbnN0IHRoZW1lID0gUmVhY3QudXNlQ29udGV4dChUaGVtZUNvbnRleHQpO1xyXG4gICAgY29uc3QgaXNJbnZlcnNlID0gdXNlSXNJbnZlcnNlKGlzSW52ZXJzZVByb3ApO1xyXG4gICAgcmV0dXJuIChSZWFjdC5jcmVhdGVFbGVtZW50KEludmVyc2VDb250ZXh0LlByb3ZpZGVyLCB7IHZhbHVlOiB7IGlzSW52ZXJzZSB9IH0sXHJcbiAgICAgICAgUmVhY3QuY3JlYXRlRWxlbWVudChTdHlsZWRMaXN0SXRlbSwgeyBhczogZGVzY3JpcHRpb24gPyAncCcgOiAnbGknLCBkZXNjcmlwdGlvbjogZGVzY3JpcHRpb24sIGljb246IGljb24sIGljb25BbGlnbjogaWNvbkFsaWduLCBpc0ludmVyc2U6IGlzSW52ZXJzZSwgcmVmOiByZWYsIHRoZW1lOiB0aGVtZSwgdGVzdElkOiB0ZXN0SWQgfSxcclxuICAgICAgICAgICAgaWNvbiAmJiAoUmVhY3QuY3JlYXRlRWxlbWVudChTdHlsZWRJY29uLCB7IGljb25CYWNrZ3JvdW5kOiBtYWdtYS5jb2xvcnNbaWNvbkJhY2tncm91bmRdIHx8IG1hZ21hLmNvbG9ycy5wcmltYXJ5LCBpY29uQ29sb3I6IG1hZ21hLmNvbG9yc1tpY29uQ29sb3JdIHx8IG1hZ21hLmNvbG9ycy5uZXV0cmFsMTAwLCB0aGVtZTogdGhlbWUgfSwgaWNvbikpLFxyXG4gICAgICAgICAgICBjaGlsZHJlbikpKTtcclxufSk7XHJcbi8vIyBzb3VyY2VNYXBwaW5nVVJMPUxpc3RJdGVtLmpzLm1hcCJdfQ== */"));
|
|
13839
14204
|
};
|
|
13840
14205
|
var StyledListItem$1 = /*#__PURE__*/_styled("li", {
|
|
13841
14206
|
target: "e1515b9j1",
|
|
@@ -13848,11 +14213,11 @@ var StyledListItem$1 = /*#__PURE__*/_styled("li", {
|
|
|
13848
14213
|
return props.description && !props.isInverse ? props.theme.colors.neutral : 'inherit';
|
|
13849
14214
|
}, ";list-style-type:", function (props) {
|
|
13850
14215
|
return props.icon || props.description ? 'none' : 'inherit';
|
|
13851
|
-
}, ";" + ( "/*# sourceMappingURL=data:application/json;charset=utf-8;base64,
|
|
14216
|
+
}, ";" + ( "/*# sourceMappingURL=data:application/json;charset=utf-8;base64,eyJ2ZXJzaW9uIjozLCJzb3VyY2VzIjpbIkxpc3RJdGVtLnRzeCJdLCJuYW1lcyI6W10sIm1hcHBpbmdzIjoiQUFtQmlDIiwiZmlsZSI6Ikxpc3RJdGVtLnRzeCIsInNvdXJjZXNDb250ZW50IjpbImltcG9ydCAqIGFzIFJlYWN0IGZyb20gJ3JlYWN0JztcclxuaW1wb3J0IHsgY3NzIH0gZnJvbSAnQGVtb3Rpb24vcmVhY3QnO1xyXG5pbXBvcnQgeyBtYWdtYSB9IGZyb20gJy4uLy4uL3RoZW1lL21hZ21hJztcclxuaW1wb3J0IHsgVGhlbWVDb250ZXh0IH0gZnJvbSAnLi4vLi4vdGhlbWUvVGhlbWVDb250ZXh0JztcclxuaW1wb3J0IHsgSW52ZXJzZUNvbnRleHQsIHVzZUlzSW52ZXJzZSB9IGZyb20gJy4uLy4uL2ludmVyc2UnO1xyXG5pbXBvcnQgc3R5bGVkIGZyb20gJ0BlbW90aW9uL3N0eWxlZCc7XHJcbmZ1bmN0aW9uIGdldExpc3REaXNwbGF5KHByb3BzKSB7XHJcbiAgICBpZiAocHJvcHMuaWNvbikge1xyXG4gICAgICAgIHJldHVybiAnZ3JpZCc7XHJcbiAgICB9XHJcbiAgICByZXR1cm4gJ2xpc3QtaXRlbSc7XHJcbn1cclxuY29uc3QgSWNvblN0eWxlcyA9IHByb3BzID0+IGNzcyBgXG4gIGJhY2tncm91bmQ6ICR7cHJvcHMuaWNvbkJhY2tncm91bmR9O1xuICBjb2xvcjogJHtwcm9wcy5pY29uQ29sb3J9O1xuICBib3JkZXItcmFkaXVzOiA1MCU7XG4gIGRpc3BsYXk6IGlubGluZS1mbGV4O1xuICBwYWRkaW5nOiAxMHB4O1xuYDtcclxuY29uc3QgU3R5bGVkTGlzdEl0ZW0gPSBzdHlsZWQubGkgYFxuICBkaXNwbGF5OiAke3Byb3BzID0+IGdldExpc3REaXNwbGF5KHByb3BzKX07XG4gIG1hcmdpbjogMDtcbiAgcGFkZGluZzogMDtcbiAgbWFyZ2luLWxlZnQ6ICR7cHJvcHMgPT4gKHByb3BzLmljb24gPyAnaW5oZXJpdCcgOiAnMS4xZW0nKX07XG4gIGNvbG9yOiAke3Byb3BzID0+IHByb3BzLmRlc2NyaXB0aW9uICYmICFwcm9wcy5pc0ludmVyc2VcclxuICAgID8gcHJvcHMudGhlbWUuY29sb3JzLm5ldXRyYWxcclxuICAgIDogJ2luaGVyaXQnfTtcbiAgbGlzdC1zdHlsZS10eXBlOiAke3Byb3BzID0+IHByb3BzLmljb24gfHwgcHJvcHMuZGVzY3JpcHRpb24gPyAnbm9uZScgOiAnaW5oZXJpdCd9O1xuYDtcclxuY29uc3QgU3R5bGVkSWNvbiA9IHN0eWxlZC5zcGFuIGBcbiAgJHtJY29uU3R5bGVzfTtcbmA7XHJcbmV4cG9ydCBjb25zdCBMaXN0SXRlbSA9IFJlYWN0LmZvcndhcmRSZWYoKHByb3BzLCByZWYpID0+IHtcclxuICAgIGNvbnN0IHsgY2hpbGRyZW4sIGRlc2NyaXB0aW9uLCBpY29uLCBpY29uQWxpZ24sIGljb25CYWNrZ3JvdW5kLCBpY29uQ29sb3IsIHRlc3RJZCwgaXNJbnZlcnNlOiBpc0ludmVyc2VQcm9wLCB9ID0gcHJvcHM7XHJcbiAgICBjb25zdCB0aGVtZSA9IFJlYWN0LnVzZUNvbnRleHQoVGhlbWVDb250ZXh0KTtcclxuICAgIGNvbnN0IGlzSW52ZXJzZSA9IHVzZUlzSW52ZXJzZShpc0ludmVyc2VQcm9wKTtcclxuICAgIHJldHVybiAoUmVhY3QuY3JlYXRlRWxlbWVudChJbnZlcnNlQ29udGV4dC5Qcm92aWRlciwgeyB2YWx1ZTogeyBpc0ludmVyc2UgfSB9LFxyXG4gICAgICAgIFJlYWN0LmNyZWF0ZUVsZW1lbnQoU3R5bGVkTGlzdEl0ZW0sIHsgYXM6IGRlc2NyaXB0aW9uID8gJ3AnIDogJ2xpJywgZGVzY3JpcHRpb246IGRlc2NyaXB0aW9uLCBpY29uOiBpY29uLCBpY29uQWxpZ246IGljb25BbGlnbiwgaXNJbnZlcnNlOiBpc0ludmVyc2UsIHJlZjogcmVmLCB0aGVtZTogdGhlbWUsIHRlc3RJZDogdGVzdElkIH0sXHJcbiAgICAgICAgICAgIGljb24gJiYgKFJlYWN0LmNyZWF0ZUVsZW1lbnQoU3R5bGVkSWNvbiwgeyBpY29uQmFja2dyb3VuZDogbWFnbWEuY29sb3JzW2ljb25CYWNrZ3JvdW5kXSB8fCBtYWdtYS5jb2xvcnMucHJpbWFyeSwgaWNvbkNvbG9yOiBtYWdtYS5jb2xvcnNbaWNvbkNvbG9yXSB8fCBtYWdtYS5jb2xvcnMubmV1dHJhbDEwMCwgdGhlbWU6IHRoZW1lIH0sIGljb24pKSxcclxuICAgICAgICAgICAgY2hpbGRyZW4pKSk7XHJcbn0pO1xyXG4vLyMgc291cmNlTWFwcGluZ1VSTD1MaXN0SXRlbS5qcy5tYXAiXX0= */"));
|
|
13852
14217
|
var StyledIcon$1 = /*#__PURE__*/_styled("span", {
|
|
13853
14218
|
target: "e1515b9j0",
|
|
13854
14219
|
label: "StyledIcon"
|
|
13855
|
-
})(IconStyles, ";" + ( "/*# sourceMappingURL=data:application/json;charset=utf-8;base64,
|
|
14220
|
+
})(IconStyles, ";" + ( "/*# sourceMappingURL=data:application/json;charset=utf-8;base64,eyJ2ZXJzaW9uIjozLCJzb3VyY2VzIjpbIkxpc3RJdGVtLnRzeCJdLCJuYW1lcyI6W10sIm1hcHBpbmdzIjoiQUE2QitCIiwiZmlsZSI6Ikxpc3RJdGVtLnRzeCIsInNvdXJjZXNDb250ZW50IjpbImltcG9ydCAqIGFzIFJlYWN0IGZyb20gJ3JlYWN0JztcclxuaW1wb3J0IHsgY3NzIH0gZnJvbSAnQGVtb3Rpb24vcmVhY3QnO1xyXG5pbXBvcnQgeyBtYWdtYSB9IGZyb20gJy4uLy4uL3RoZW1lL21hZ21hJztcclxuaW1wb3J0IHsgVGhlbWVDb250ZXh0IH0gZnJvbSAnLi4vLi4vdGhlbWUvVGhlbWVDb250ZXh0JztcclxuaW1wb3J0IHsgSW52ZXJzZUNvbnRleHQsIHVzZUlzSW52ZXJzZSB9IGZyb20gJy4uLy4uL2ludmVyc2UnO1xyXG5pbXBvcnQgc3R5bGVkIGZyb20gJ0BlbW90aW9uL3N0eWxlZCc7XHJcbmZ1bmN0aW9uIGdldExpc3REaXNwbGF5KHByb3BzKSB7XHJcbiAgICBpZiAocHJvcHMuaWNvbikge1xyXG4gICAgICAgIHJldHVybiAnZ3JpZCc7XHJcbiAgICB9XHJcbiAgICByZXR1cm4gJ2xpc3QtaXRlbSc7XHJcbn1cclxuY29uc3QgSWNvblN0eWxlcyA9IHByb3BzID0+IGNzcyBgXG4gIGJhY2tncm91bmQ6ICR7cHJvcHMuaWNvbkJhY2tncm91bmR9O1xuICBjb2xvcjogJHtwcm9wcy5pY29uQ29sb3J9O1xuICBib3JkZXItcmFkaXVzOiA1MCU7XG4gIGRpc3BsYXk6IGlubGluZS1mbGV4O1xuICBwYWRkaW5nOiAxMHB4O1xuYDtcclxuY29uc3QgU3R5bGVkTGlzdEl0ZW0gPSBzdHlsZWQubGkgYFxuICBkaXNwbGF5OiAke3Byb3BzID0+IGdldExpc3REaXNwbGF5KHByb3BzKX07XG4gIG1hcmdpbjogMDtcbiAgcGFkZGluZzogMDtcbiAgbWFyZ2luLWxlZnQ6ICR7cHJvcHMgPT4gKHByb3BzLmljb24gPyAnaW5oZXJpdCcgOiAnMS4xZW0nKX07XG4gIGNvbG9yOiAke3Byb3BzID0+IHByb3BzLmRlc2NyaXB0aW9uICYmICFwcm9wcy5pc0ludmVyc2VcclxuICAgID8gcHJvcHMudGhlbWUuY29sb3JzLm5ldXRyYWxcclxuICAgIDogJ2luaGVyaXQnfTtcbiAgbGlzdC1zdHlsZS10eXBlOiAke3Byb3BzID0+IHByb3BzLmljb24gfHwgcHJvcHMuZGVzY3JpcHRpb24gPyAnbm9uZScgOiAnaW5oZXJpdCd9O1xuYDtcclxuY29uc3QgU3R5bGVkSWNvbiA9IHN0eWxlZC5zcGFuIGBcbiAgJHtJY29uU3R5bGVzfTtcbmA7XHJcbmV4cG9ydCBjb25zdCBMaXN0SXRlbSA9IFJlYWN0LmZvcndhcmRSZWYoKHByb3BzLCByZWYpID0+IHtcclxuICAgIGNvbnN0IHsgY2hpbGRyZW4sIGRlc2NyaXB0aW9uLCBpY29uLCBpY29uQWxpZ24sIGljb25CYWNrZ3JvdW5kLCBpY29uQ29sb3IsIHRlc3RJZCwgaXNJbnZlcnNlOiBpc0ludmVyc2VQcm9wLCB9ID0gcHJvcHM7XHJcbiAgICBjb25zdCB0aGVtZSA9IFJlYWN0LnVzZUNvbnRleHQoVGhlbWVDb250ZXh0KTtcclxuICAgIGNvbnN0IGlzSW52ZXJzZSA9IHVzZUlzSW52ZXJzZShpc0ludmVyc2VQcm9wKTtcclxuICAgIHJldHVybiAoUmVhY3QuY3JlYXRlRWxlbWVudChJbnZlcnNlQ29udGV4dC5Qcm92aWRlciwgeyB2YWx1ZTogeyBpc0ludmVyc2UgfSB9LFxyXG4gICAgICAgIFJlYWN0LmNyZWF0ZUVsZW1lbnQoU3R5bGVkTGlzdEl0ZW0sIHsgYXM6IGRlc2NyaXB0aW9uID8gJ3AnIDogJ2xpJywgZGVzY3JpcHRpb246IGRlc2NyaXB0aW9uLCBpY29uOiBpY29uLCBpY29uQWxpZ246IGljb25BbGlnbiwgaXNJbnZlcnNlOiBpc0ludmVyc2UsIHJlZjogcmVmLCB0aGVtZTogdGhlbWUsIHRlc3RJZDogdGVzdElkIH0sXHJcbiAgICAgICAgICAgIGljb24gJiYgKFJlYWN0LmNyZWF0ZUVsZW1lbnQoU3R5bGVkSWNvbiwgeyBpY29uQmFja2dyb3VuZDogbWFnbWEuY29sb3JzW2ljb25CYWNrZ3JvdW5kXSB8fCBtYWdtYS5jb2xvcnMucHJpbWFyeSwgaWNvbkNvbG9yOiBtYWdtYS5jb2xvcnNbaWNvbkNvbG9yXSB8fCBtYWdtYS5jb2xvcnMubmV1dHJhbDEwMCwgdGhlbWU6IHRoZW1lIH0sIGljb24pKSxcclxuICAgICAgICAgICAgY2hpbGRyZW4pKSk7XHJcbn0pO1xyXG4vLyMgc291cmNlTWFwcGluZ1VSTD1MaXN0SXRlbS5qcy5tYXAiXX0= */"));
|
|
13856
14221
|
var ListItem = /*#__PURE__*/React.forwardRef(function (props, ref) {
|
|
13857
14222
|
var children = props.children,
|
|
13858
14223
|
description = props.description,
|
|
@@ -13874,6 +14239,7 @@ var ListItem = /*#__PURE__*/React.forwardRef(function (props, ref) {
|
|
|
13874
14239
|
icon: icon,
|
|
13875
14240
|
iconAlign: iconAlign,
|
|
13876
14241
|
isInverse: isInverse,
|
|
14242
|
+
ref: ref,
|
|
13877
14243
|
theme: theme,
|
|
13878
14244
|
testId: testId
|
|
13879
14245
|
}, icon && React.createElement(StyledIcon$1, {
|
|
@@ -14650,7 +15016,7 @@ function useTreeItem(props, forwardedRef) {
|
|
|
14650
15016
|
return allItems;
|
|
14651
15017
|
});
|
|
14652
15018
|
updateSelectedItemsChanged();
|
|
14653
|
-
} else if (!isDisabled && preselectedChildrenItems.length > 0) {
|
|
15019
|
+
} else if (!isDisabled && preselectedChildrenItems.length > 0 && checkParents) {
|
|
14654
15020
|
// Case for selectedItems that are inside a collapsed item
|
|
14655
15021
|
var itemIdChildren = getChildrenItemIdsInTree(treeItemChildren);
|
|
14656
15022
|
for (var _iterator = _createForOfIteratorHelperLoose(preselectedChildrenItems), _step; !(_step = _iterator()).done;) {
|
|
@@ -14915,8 +15281,14 @@ function useTreeItem(props, forwardedRef) {
|
|
|
14915
15281
|
};
|
|
14916
15282
|
var collapseFocusedNode = function collapseFocusedNode() {
|
|
14917
15283
|
if (hasOwnTreeItems) {
|
|
14918
|
-
|
|
14919
|
-
|
|
15284
|
+
if (expanded) {
|
|
15285
|
+
setExpanded(false);
|
|
15286
|
+
focusSelf();
|
|
15287
|
+
} else {
|
|
15288
|
+
focusPrev();
|
|
15289
|
+
}
|
|
15290
|
+
} else {
|
|
15291
|
+
focusPrev();
|
|
14920
15292
|
}
|
|
14921
15293
|
};
|
|
14922
15294
|
var toggleMultiSelectItems = function toggleMultiSelectItems() {
|
|
@@ -15721,7 +16093,6 @@ exports.getEnabledTreeItemChildrenLength = getEnabledTreeItemChildrenLength;
|
|
|
15721
16093
|
exports.getFirstItemInTree = getFirstItemInTree;
|
|
15722
16094
|
exports.getIconSizes = getIconSizes;
|
|
15723
16095
|
exports.getListAlignment = getListAlignment;
|
|
15724
|
-
exports.getListDisplay = getListDisplay;
|
|
15725
16096
|
exports.getMissingChildrenIds = getMissingChildrenIds;
|
|
15726
16097
|
exports.getTreeItemLabelColor = getTreeItemLabelColor;
|
|
15727
16098
|
exports.getTreeItemWrapperCursor = getTreeItemWrapperCursor;
|